0xV3NOMx
Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64



Your IP : 18.216.207.209


Current Path : /var/www/html/nitte/src21042016/
Upload File :
Current File : //var/www/html/nitte/src21042016/systemsetup.php

<?php
function getModuleType($aobj_context)
{
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
	$sql_query="select internal_code,value as type from s_ref_type  	
				where type='module_type' and active=1 order by 2";	
	
	$lobj_rs = $aobj_context->mobj_db->GetAll($sql_query);   
	$arr[0]=$lobj_rs;
	$sql_query_menu="select internal_code,value as type from s_ref_type  	
				where type='sub_menu' and active=1  order by 2";	
	$lobj_rs_menu = $aobj_context->mobj_db->GetAll($sql_query_menu);  
	$arr[1]=$lobj_rs_menu;
	 
	 include_once("getmoduledetails.php");
	 $arr['links_data']= getLinks($aobj_context,"General Master Setup");
	   
     if(count($lobj_rs) != 0)
      print_r($aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success")); 
     else
      print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,-1,"Failure"));
    return;
}
function getAutoIncrementSourceFields($aobj_context)
{
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
	$schema_code=$aobj_context->mobj_data["schema_code"];
	$sql_query="select su.internal_code,su.name as value
		from s_user_schema_elements su 
		inner join s_ref_type st on st.internal_code=data_type
		inner join s_ref_type st1 on st1.internal_code=data_type
		where su.ref_s_user_schema_code={$schema_code} and st1.value='Date'";	
	
	$lobj_rs = $aobj_context->mobj_db->GetAll($sql_query);   
	
     if(count($lobj_rs) != 0)
      print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success")); 
     else
      print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,-1,"Failure"));
    return;
}

function pupulateSystemMenu($aobj_context)
{
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
	 
	  
	
	
	
	//######################Form Menu HTML######################
	
 

	   
		 $get_all_menus="select * from system_menu where active=1 order by sequence";  
		  $lobj_get_all_menus = $aobj_context->mobj_db->GetAll($get_all_menus);
		  	$html="";
			session_start();
			$user_id=$_SESSION['user_id'];
			$user_name=$_SESSION['usr'] ;
			 $college_code=$_SESSION['collcode'];
			 	 $get_user_right="select ss.internal_code as user_id,user_type,value  from  s_sysdb ss 
			inner join  s_ref_type sr on sr.internal_code=user_type 
			where ss.internal_code=".$_SESSION['user_id'];
		   $lobj_get_user_right = $aobj_context->mobj_db->GetRow($get_user_right);
		  foreach( $lobj_get_all_menus as $menu_key=>$menu_val)
		  {
			$type=$menu_val['id'];
			$id=$menu_val['id'];
						if(strtolower($user_name)=='lsys')
						{
						$sql_query="select internal_code,menu_name,menu_function,id  from system_menu  	
						where active=1  and system_menu='T' order by ifnull(sequence,1),menu_name";		 
	 
	
								$lstr_qry = "select s.internal_code,ifnull(display_module_name,module_name) as module_name,
								ifnull(display_module_name,module_name)  as  display_module_name,t.value,
								is_menu_only,if(is_menu_only=1,menu_function,'') as menu_function 
								,IFNULL(main_menu,'0') as main_menu_id,
								REPLACE(module_name,' ','~') as r_module_name,
								IFNULL(mm.value,concat('z',display_module_name)) as main_menu_val from s_user_schema s inner join s_ref_type t
								on t.internal_code=module_type
								left join s_ref_type mm on mm.internal_code=main_menu
								where display_module_name is not null and t.value='{$type}'
								and s.active=1 
								group by s.internal_code order by 
								 ifnull(s.sequence,0),main_menu_val,ifnull(display_module_name,module_name)";
						}
						else if(($lobj_get_user_right[value]=='Admin' || $lobj_get_user_right[value]=='SuperUser') && strtolower($user_name)!='lsys')
						{
						
						$sql_query="select internal_code,menu_name,menu_function,id  from system_menu  	
						where active=1  and system_menu='F' order by ifnull(sequence,1),menu_name";		 
	 
	
								$lstr_qry = "select s.internal_code,ifnull(display_module_name,module_name) as module_name,
								ifnull(display_module_name,module_name)  as  display_module_name,t.value,
								is_menu_only,if(is_menu_only=1,menu_function,'') as menu_function 
								,IFNULL(main_menu,'0') as main_menu_id,
								REPLACE(module_name,' ','~') as r_module_name,
								IFNULL(mm.value,concat('z',display_module_name)) as main_menu_val from s_user_schema s inner join s_ref_type t
								on t.internal_code=module_type
								left join s_ref_type mm on mm.internal_code=main_menu
								where display_module_name is not null and t.value='{$type}'
								and s.active=1 
								group by s.internal_code order by 
								 ifnull(s.sequence,0),main_menu_val,ifnull(display_module_name,module_name)";
						}else if($lobj_get_user_right[value]=='University' && strtolower($user_name)!='lsys')
						{
						
						$sql_query="select internal_code,menu_name,menu_function,id  from system_menu  	
						where active=1  and system_menu='U' order by ifnull(sequence,1),menu_name";		 
	 
	
								$lstr_qry = "select s.internal_code,ifnull(display_module_name,module_name) as module_name,
								ifnull(display_module_name,module_name)  as  display_module_name,t.value,
								is_menu_only,if(is_menu_only=1,menu_function,'') as menu_function 
								,IFNULL(main_menu,'0') as main_menu_id,
								REPLACE(module_name,' ','~') as r_module_name,
								IFNULL(mm.value,concat('z',display_module_name)) as main_menu_val from s_user_schema s inner join s_ref_type t
								on t.internal_code=module_type
								left join s_ref_type mm on mm.internal_code=main_menu
								where display_module_name is not null and t.value='{$type}'
								and s.active=1 
								group by s.internal_code order by 
								 ifnull(s.sequence,0),main_menu_val,ifnull(display_module_name,module_name)";
						}
						else if($lobj_get_user_right[value]=='User')
						{
						
							$sql_query="select s.internal_code,s.menu_name,s.menu_function,s.id  
								from system_menu s  inner join 	s_ref_type st on st.value=s.id 
								and st.type='module_type' inner join
								s_user_schema us on us.module_type=st.internal_code
								inner join 	user_rights ur on ur.module_id=us.internal_code
								where s.active=1  and ur.is_view=1  and system_menu='F'
								and ref_s_sysdb_code={$user_id}  and college_code='{$college_code}'
								group by s.internal_code
								order by ifnull(s.sequence,1),s.menu_name";	
							$lstr_qry = "select s.internal_code,ifnull(display_module_name,module_name) as module_name,  
								ifnull(display_module_name,module_name)  as  display_module_name,
								t.value,is_menu_only,if(is_menu_only=1,menu_function,'') as menu_function 
								,IFNULL(main_menu,'0') as main_menu_id,
								REPLACE(module_name,' ','~') as r_module_name,
								IFNULL(mm.value,concat('z',display_module_name)) as main_menu_val 
									from s_user_schema s inner join s_ref_type t
									on t.internal_code=module_type
									left join s_ref_type mm on mm.internal_code=main_menu
								inner join user_rights ur on ur.module_id=s.internal_code
									where module_name is not null and t.value='{$type}'
									and (is_view=1 or is_add=1 or is_edit=1 or is_del=1)
								and ref_s_sysdb_code={$user_id} and college_code='{$college_code}' and s.active=1
								group by s.internal_code
								order by  ifnull(s.sequence,0),main_menu_val,ifnull(display_module_name,module_name)";
						}
						   
						$lobj_rs = $aobj_context->mobj_db->GetAll($lstr_qry);
					   $lobj_rs_data = $aobj_context->mobj_db->GetAll($sql_query); 
						$html.="\n\n\n\n\n\n\n\n\n\n\n<div id='tarka_main_menu_{$id}' class='hidden'>  \n";
						$html.="<ul>  \n";
						$main_menu_id= $lobj_rs[0][main_menu_id];
						$main_menu_val= $lobj_rs[0][main_menu_val];
						$i=0;
						 
					
					for($m=0;$m<count($lobj_rs);$m++)
					{
					$r_module_name=$lobj_rs[$m][r_module_name];
					$dis_module_name=$lobj_rs[$m][display_module_name];
					$int_code=$lobj_rs[$m][internal_code];
					$call_mod="";
					$call_mod=($lobj_rs[$m]['is_menu_only']=='0')?" getModulesDetails('{$r_module_name}',{$int_code},'Add','{$dis_module_name}') ":$lobj_rs[$m]['menu_function'];
					 
						if($i==0)
						{
							if($main_menu_id>0)
								{
									$html.="<li><a href='#' >{$lobj_rs[$m][main_menu_val]}</a>  \n";
									$html.="<ul> \n";
									$html.="<li><a href='#' onclick=\"{$call_mod};\" >{$lobj_rs[$m][module_name]} </a> </li>\n";
								}
								else
								{
									$html.="<li><a href='#' onclick=\"{$call_mod};\" >{$lobj_rs[$m][module_name]} </a> </li> \n";
								}
								$main_menu_id =   $lobj_rs[$m][main_menu_id];
								$main_menu_val =  $lobj_rs[$m][main_menu_val];
								$i++;
								continue;
								
						}
						else 
						{
							if($main_menu_id==$lobj_rs[$m][main_menu_id] && $lobj_rs[$m][main_menu_id]>0)
							{
								$html.="<li><a href='#' onclick=\"{$call_mod};\" >{$lobj_rs[$m][module_name]} </a> </li>\n";
								$main_menu_id =   $lobj_rs[$m][main_menu_id];
								$main_menu_val =  $lobj_rs[$m][main_menu_val];
							}
							else if($main_menu_id<>$lobj_rs[$m][main_menu_id] && $lobj_rs[$m][main_menu_id]>0)
							{
									if($lobj_rs[$m-1][main_menu_id]>0) {
									$html.="</ul> \n";
									$html.="</li> \n"; }
									$html.="\t <li><a href='#'>{$lobj_rs[$m][main_menu_val]}</a>   \n";
									$html.="<ul> \n";
									$html.="<li><a href='#' onclick=\"{$call_mod};\" >{$lobj_rs[$m][module_name]}</a> </li>\n";
							}
							else 
							{
								if($lobj_rs[$m-1][main_menu_id]>0) {
									$html.="</ul> \n";
									$html.="</li> \n"; 
									}
								$html.=" \t <li><a href='#' onclick=\"{$call_mod};\" >{$lobj_rs[$m][module_name]}</a> </li>\n";	
							}
							$main_menu_id =   $lobj_rs[$m][main_menu_id];
							$main_menu_val =  $lobj_rs[$m][main_menu_val];
							
						}
					}
						if($lobj_rs[$m-1][main_menu_id]>0) {
									$html.="</ul> \n";
									$html.="</li> \n"; 
									 }
							$html.="</ul>  \n";	
							$html.="</div>  \n";	
			
		}
  	 	  
	$arr['login_cnt'] = $_SESSION['login_cnt'];
	$arr['details'] = $lobj_rs_data;
	$arr['html'] = $html;
	 
     if(count($lobj_rs_data) != 0)
      print_r($aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success")); 
     else
      print_r($aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure"));
    return;
}

function GetUserSchemaParentGroup($aobj_context)
 { 
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);  	 
	$schema_name =($aobj_context->mobj_data["schema_name"]);
    $get_details="select  internal_code,name as user_schema from s_user_schema_group 
	              where ref_s_user_schema_code={$schema_name} order by name";
             //echo $get_details; die();
			$lobj_details = $aobj_context->mobj_db->getAll($get_details); 
			$arr['parent_group']=$lobj_details;						
		 if( $lobj_details)
		 echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success");
		 else
		  echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
  }

function insertUserSchemaMaster($aobj_context)
{
 
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);  
	$internal_code=$aobj_context->mobj_data["internal_code"];
	$active=$aobj_context->mobj_data["active"];
	$create_table=$aobj_context->mobj_data["create_table"];
	$module_name=addslashes(trim($aobj_context->mobj_data["module_name"]));
	$user_schema_js_path=addslashes(trim($aobj_context->mobj_data["user_schema_js_path"]));
	$user_schema_grid_default_rows=addslashes(trim($aobj_context->mobj_data["user_schema_grid_default_rows"]));
	$user_schema_display_module_name=addslashes(trim($aobj_context->mobj_data["user_schema_display_module_name"]));
	$grid_custom_links=addslashes(trim($aobj_context->mobj_data["grid_custom_links"]));
	$is_menu_only=addslashes(trim($aobj_context->mobj_data["is_menu_only"]));
	$module_function_name=addslashes(trim($aobj_context->mobj_data["module_function_name"]));
	$module_type=$aobj_context->mobj_data["module_type"];
	$main_menu=$aobj_context->mobj_data["main_menu"];
	$module_grid_type=$aobj_context->mobj_data["module_grid_type"];
	$grid_user_schema_coloum_names=$aobj_context->mobj_data["grid_user_schema_coloum_names"];
	$grid_user_schema_grid_query=$aobj_context->mobj_data["grid_user_schema_grid_query"];
	$grid_user_schema_coloum_models=$aobj_context->mobj_data["grid_user_schema_coloum_models"];
	$is_save=addslashes(trim($aobj_context->mobj_data["is_save"]));
	$is_clear=addslashes(trim($aobj_context->mobj_data["is_clear"]));
	$is_download=addslashes(trim($aobj_context->mobj_data["is_download"]));
	$is_view=addslashes(trim($aobj_context->mobj_data["is_view"]));
	$is_generate=addslashes(trim($aobj_context->mobj_data["is_generate"]));	
	$custom_links=(trim($aobj_context->mobj_data["custom_links"]));	
	$display_type=$aobj_context->mobj_data["display_type"];
	$get_module_type="select value from s_ref_type where internal_code=$module_type";
	$lobj_module_type = $aobj_context->mobj_db->GetRow($get_module_type);
	$mod_type=$lobj_module_type[value];
	
	if($internal_code==0)
	{	
		$get_data="select count(*) as module_count from s_user_schema where module_name='".$module_name."'
		and  module_type='".$module_type."'";
		$lobj_rs = $aobj_context->mobj_db->GetRow($get_data);
		
		if($lobj_rs['module_count']==0)
		{
		    $lstr_qry = "insert into s_user_schema( 
		        module_name,
				display_module_name,
		        module_type,
				is_menu_only,
				menu_function,
				active,main_menu,display_type,
				include_save,include_clear,
				include_download,include_view,
				include_generate,grid_type,custom_links,s_col_names,s_col_model,s_grid_query,s_grid_custom_links,grid_default_rows,js_path)
		         values ( '{$module_name}','{$user_schema_display_module_name}','{$module_type}',
							'{$is_menu_only}',
							'{$module_function_name}',
							'{$active}',
							'{$main_menu}',
							'{$display_type}',
							'{$is_save}',
							'{$is_clear}',
							'{$is_download}',
							'{$is_view}',
							'{$is_generate}',
							'{$module_grid_type}',
							\"{$custom_links}\",
							\"{$grid_user_schema_coloum_names}\",
							\"{$grid_user_schema_coloum_models}\",
							\"{$grid_user_schema_grid_query}\",
							\"{$grid_custom_links}\",
							\"{$user_schema_grid_default_rows}\",
							'{$user_schema_js_path}')";  
	             //  echo  $lstr_qry ; 	
				   
				   
					$lobj_rs = $aobj_context->mobj_db->Execute($lstr_qry);  
					
			//	 echo mysql_error();	
					
 			
					$last_inserted_id  = $aobj_context->mobj_db->Insert_ID();
					//if new module is inserted by default will give permission to Admin
					$get_admin_id="select * from s_sysdb where sysusr='admin'";
					$lobj_get_admin_id = $aobj_context->mobj_db->getRow($get_admin_id); 
					$insert_new_user="insert into user_rights(
						ref_s_sysdb_code,
						module_type,
						module_id,
						is_view,
						is_add,
						is_edit,
						is_del) values
				 		(
						'{$lobj_get_admin_id[internal_code]}',
						'{$module_type}',
						'{$last_inserted_id}',
						'1',
						'1',
						'1',
						'1'	)";
						$lobj_insert_user = $aobj_context->mobj_db->Execute($insert_new_user);
						
						if($mod_type=='Reports')
						{
						$main_src_obj=(explode("/",$_SERVER["REQUEST_URI"]));
						$main_src=$main_src_obj[1];
						 $report_storage_path=$_SERVER["DOCUMENT_ROOT"]."/".$main_src."/Report_details/report_result_".$last_inserted_id.".php";
						 $report_format_path=$_SERVER["DOCUMENT_ROOT"]."/".$main_src."/src/general_report_format.php";
						file_put_contents($report_storage_path,file_get_contents($report_format_path));  
						}																				
						
						
					if($create_table==1 && $mod_type!='Reports' && $is_menu_only=='0')
					{
					$create_table="CREATE TABLE module_".$last_inserted_id.
								"(
								  internal_code bigint(20) unsigned NOT NULL auto_increment,
								  ref_s_user_schema_code bigint(20),
								    created_by  int(11) default NULL,
								   created_date  datetime default NULL,
								   modified_by  int(11) default NULL,
								   modified_date  datetime default NULL,
								   PRIMARY KEY  (internal_code)
								) engine INNODB ";		
											
					$lobj_rs = $aobj_context->mobj_db->Execute($create_table);   
					$create_details_table="CREATE TABLE module_".$last_inserted_id."_details".
								"(
								  internal_code bigint(20) unsigned NOT NULL auto_increment,
								  ref_s_user_schema_code bigint(20) ,
								   ref_s_module_code int(11) default NULL,
								  ref_s_user_schema_group_code int(11) default NULL,
								  ref_s_user_schema_elements_code int(11) default NULL,
								  value text collate latin1_general_ci,
								  ref_ref_s_user_schema_code int(11) default NULL,
								   created_by  int(11) default NULL,
								   created_date  datetime default NULL,
								   modified_by  int(11) default NULL,
								   modified_date  datetime default NULL,
								  PRIMARY KEY  (internal_code),
								  KEY NewIndex1 (ref_s_user_schema_code),
								  KEY NewIndex2 (ref_s_module_code),
								  KEY NewIndex3 (ref_s_user_schema_group_code),
								  KEY NewIndex4 (ref_s_user_schema_elements_code)
								   
								) engine INNODB";		
											
					$lobj_rs = $aobj_context->mobj_db->Execute($create_details_table); 
					}
				    if($lobj_rs)
				    {
				        $rdata = "Module Inserted Successfully.";
				        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
				        return $rdata;
				     }
				    else
				    {
				        $rdata = "insertion Failed.";
				        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure"));  
						return $rdata;			
				    }    
		}
		else 	
		{
		     $rdata = "Module Name Already Exstis!";
	        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
	        return $rdata;
	    }
	}
	else  
		{
			$lstr_qry = "update s_user_schema
			set module_name='".$module_name."',
			module_type='".$module_type."',display_module_name='".$user_schema_display_module_name."', main_menu= '{$main_menu}', display_type= '".$display_type."',
			active= {$active} ,is_menu_only='{$is_menu_only}',
			menu_function= '{$module_function_name}',
			include_save= '".$is_save."',include_clear= '".$is_clear."',
			include_download= '".$is_download."',include_view= '".$is_view."',
			include_generate = '".$is_generate."',
			custom_links= \"{$custom_links}\",
			grid_type= '{$module_grid_type}',
			s_col_names= \"{$grid_user_schema_coloum_names}\",
			s_col_model= \"{$grid_user_schema_coloum_models}\",
			s_grid_query= \"{$grid_user_schema_grid_query}\" ,
			s_grid_custom_links= \"{$grid_custom_links}\", 
			grid_default_rows = \"{$user_schema_grid_default_rows}\",
			js_path= '{$user_schema_js_path}'
			where internal_code ={$internal_code}";
		   //echo $lstr_qry;	
			$lobj_rs = $aobj_context->mobj_db->Execute($lstr_qry);
			if($lobj_rs)
		    {
		        $rdata = "Updated  Successfully.";
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
		        return;
		     }
		    else
		    {
		        $rdata = "Udatation Failed.";
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure"));      
		     } 
		}            
}
function GetSchemaDetailsForUpdate($aobj_context)
{
		$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
		$internal_code = $aobj_context->mobj_data["internal_code"]; 
		$get_data="select internal_code, module_name, display_module_name, module_type,is_menu_only,ifnull(menu_function,'') as menu_function,main_menu
		,display_type, active,include_save,include_clear,include_download,include_view,
		s_col_names,s_col_model,s_grid_query,grid_type,
		include_generate,include_close,custom_links,s_grid_custom_links,js_path,grid_default_rows from s_user_schema where internal_code='".$internal_code."'";	
		//echo $get_data; die();
		$lobj_rs = $aobj_context->mobj_db->GetRow($get_data); 
		if(count($lobj_rs) > 0)
			echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success"); 
		else
			echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,-1,"Failure");
		return;
}

function getModuleNameForGroups($aobj_context)
{
		$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);    
		$get_module_name="select internal_code,module_name as user_schema from s_user_schema where 
		is_menu_only=0 and active =1 order by module_name";	
		$lobj_rs = $aobj_context->mobj_db->GetAll($get_module_name);        
    
	if(count($lobj_rs) != 0)
      print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success")); 
    else
      print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,-1,"Failure"));
    return;
}

function forInsertuserschemagroup($aobj_context)
{
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);  
	$internal_code=$aobj_context->mobj_data["internal_code"];
	$group_order_by=$aobj_context->mobj_data["user_schema_group_order_by"];
	$grid_default_rows=$aobj_context->mobj_data["user_schema_group_grid_default_rows"];
	$grid_default_rows= (empty($grid_default_rows))?0:$grid_default_rows;
	
	if($internal_code==0)
	{	
		$get_data="select count(*) as group_schema_count from s_user_schema_group 
		where name='". $aobj_context->mobj_data["user_schema_group_name"] ."'"." 
		and ref_s_user_schema_code=".$aobj_context->mobj_data["group_user_schema"];
		$lobj_rs = $aobj_context->mobj_db->GetRow($get_data);
	
		if($lobj_rs['group_schema_count']==0)
		{
		    $lstr_qry = "insert into s_user_schema_group(  
		        ref_s_user_schema_code,
		        name,parent_group_code,sequence,multiple,is_grid_edit,inline_div,col_name,col_model,grid_edit_query,custom_links,on_click_event,group_order_by,group_default_rows) 
		         values ( '".   addslashes($aobj_context->mobj_data["group_user_schema"]) ."','"
		                    .   addslashes($aobj_context->mobj_data["user_schema_group_name"])."','"
		                    .   addslashes($aobj_context->mobj_data["user_schema_parent_group"])."','"
							 .   addslashes($aobj_context->mobj_data["sequence"])."','"
							 .   addslashes($aobj_context->mobj_data["is_multiple_user_schema_group"])."','"
							 .   addslashes($aobj_context->mobj_data["is_grid_edit_user_schema_group"])."','"
							 .   addslashes($aobj_context->mobj_data["is_inline_div_user_schema_group"])."',\""
							 .   addslashes($aobj_context->mobj_data["user_schema_coloum_names"])."\",\""
							 .   addslashes($aobj_context->mobj_data["user_schema_coloum_models"])."\",\""
							 .   addslashes($aobj_context->mobj_data["user_schema_grid_query"])."\",\""
							 .   addslashes($aobj_context->mobj_data["user_schema_group_custom_links"])."\",\""
							 .   addslashes($aobj_context->mobj_data["user_schema_group_onclick"])."\",
							  '{$group_order_by}',{$grid_default_rows})";
							
					$lobj_rs = $aobj_context->mobj_db->Execute($lstr_qry);      
		    	    $last_inserted_id  = $aobj_context->mobj_db->Insert_ID();
					//if group is set to multile it will create new table with user_schema_[internal_code]_group_[internal_code] with fields internal_code,ref_s_user_schema_code,ref_s_user_schema_group_code
					// we will alter this table when new elemnt has been added to coresponding schema and group
					if($aobj_context->mobj_data["is_multiple_user_schema_group"]==1)
					{ 
					$qry="select CONCAT('user_schema_',ms.INTERNAL_CODE,'_group_',msg.internal_code) as  group_table_name,
							CONCAT('user_schema_',ms.INTERNAL_CODE,'_entry_',msg.internal_code) as  entry_table_name 
						from s_user_schema_group msg inner join s_user_schema ms on ms.internal_code=msg.ref_s_user_schema_code
						where msg.internal_code=$last_inserted_id";
						$lobj_rs = $aobj_context->mobj_db->GetRow($qry);
						 
							$create_table="CREATE TABLE ". $lobj_rs['group_table_name'].
									"(
									  internal_code bigint(20) unsigned NOT NULL auto_increment,
									  ref_s_user_schema_code bigint(20),
									  ref_s_user_schema_group_code bigint(20),
									  ref_s_ref_data_code bigint(20),
									  created_by  int(11) default NULL,
										created_date  datetime default NULL,
										modified_by  int(11) default NULL,
										modified_date  datetime default NULL,
									  PRIMARY KEY  (internal_code),
									    KEY `ref_s_ref_data_code` (`ref_s_ref_data_code`) 
									)  engine INNODB";
									$lobj_create_table = $aobj_context->mobj_db->Execute($create_table); 
									
							$create_entry_table="CREATE TABLE {$lobj_rs['entry_table_name']}
									 (
									  internal_code bigint(20) unsigned NOT NULL auto_increment,
									  login_cnt int(11), 
									  group_int_code int(11) default 0, 
									  ref_s_user_schema_code bigint(20),
									  ref_s_user_schema_group_code bigint(20),
									  ref_s_ref_data_code bigint(20),
									  created_by  int(11) default NULL,
										created_date  datetime default NULL,
										modified_by  int(11) default NULL,
										modified_date  datetime default NULL,
										PRIMARY KEY  (internal_code),
									   KEY `login_cnt` (`login_cnt`),
									   KEY `group_int_code` (`group_int_code`),
									   KEY `ref_s_ref_data_code` (`ref_s_ref_data_code`) 
									)  engine INNODB";
									 
									
									 $lobj_create_entry_table = $aobj_context->mobj_db->Execute($create_entry_table);
								 		
					}
				// to give default add permisssion to user_rights table Start on 14-nov-2008
				
				$get_module_type="select module_type from s_user_schema where internal_code=".$aobj_context->mobj_data["group_user_schema"];
				$lobj_get_module_type = $aobj_context->mobj_db->getRow($get_module_type); 
				// to give default add permisssion to user_rights table End on 14-nov-2008
				$module_type=$lobj_get_module_type["module_type"];
				$module_id=$aobj_context->mobj_data["group_user_schema"]."_".$last_inserted_id;
				$insert_rights="insert into user_rights(
				ref_s_sysdb_code,
				module_type,
				module_id,
				is_view,
				is_add,
				is_edit,
				is_del) values
				(1,{$module_type},'{$module_id}',1,1,1,1)";
				 $lobj_insert_rights = $aobj_context->mobj_db->Execute($insert_rights);    	
		    if($lobj_rs)
		    {
		        $rdata = "Group Name inserted successfully.";
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
		        return $rdata;
		     }
		    else
		    {
		        $rdata = "insertion Failed.";
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure"));  
				return $rdata;			
		    }    			
		}
		else 	
		{
		     $rdata = "Group Name Already Exstis!";
	        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
	        return $rdata;
	    }
	}
	else
	{
		$group_table="select internal_code,ref_s_user_schema_code,multiple, 
				concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code)
				as table_name from s_user_schema_group where internal_code=".$internal_code;
				$lobj_rs_row = $aobj_context->mobj_db->GetRow($group_table);
				//if grou has been changed from multiple to non mutiple delete that group
		if($aobj_context->mobj_data["is_multiple_user_schema_group"]==0)
		{
		$drop_non_multiple="drop table if EXISTS user_schema_".$aobj_context->mobj_data["group_user_schema"]."_group_".$aobj_context->mobj_data["internal_code"];
		$drop_obj=$aobj_context->mobj_db->Execute($drop_non_multiple);
		//echo $drop_non_multiple;
		}
		// if existing group has non multiple and trieng to make it as multiple
		else if($lobj_rs_row["multiple"]==0 && $aobj_context->mobj_data["is_multiple_user_schema_group"]==1)
		{	$create_table="CREATE TABLE user_schema_".$aobj_context->mobj_data["group_user_schema"]."_group_".$internal_code.
								"(
								  internal_code bigint(20) unsigned NOT NULL auto_increment,
								    ref_s_user_schema_code bigint(20),
									  ref_s_user_schema_group_code bigint(20),
									  ref_s_ref_data_code bigint(20),
									  created_by  int(11) default NULL,
								   created_date  datetime default NULL,
								   modified_by  int(11) default NULL,
								   modified_date  datetime default NULL,
									  PRIMARY KEY  (internal_code)
								)  ";
								$lobj_create_table = $aobj_context->mobj_db->Execute($create_table); 
		$create_entry_table="CREATE TABLE ". $lobj_rs['entry_table_name'].
									"(
									  internal_code bigint(20) unsigned NOT NULL auto_increment,
									  login_cnt int(11), 
									   group_int_code int(11) default 0,
									  ref_s_user_schema_code bigint(20),
									  ref_s_user_schema_group_code bigint(20),
									  ref_s_ref_data_code bigint(20),
									  created_by  int(11) default NULL,
										created_date  datetime default NULL,
										modified_by  int(11) default NULL,
										modified_date  datetime default NULL,
										PRIMARY KEY  (internal_code),
									   KEY `login_cnt` (`login_cnt`),
									   KEY `group_int_code` (`group_int_code`)
									)  ";
									$lobj_create_entry_table = $aobj_context->mobj_db->Execute($create_entry_table); 	
		}
			$lstr_qry = "update s_user_schema_group
			set ref_s_user_schema_code='".trim($aobj_context->mobj_data["group_user_schema"]) ."',".
			"name='".$aobj_context->mobj_data["user_schema_group_name"] ."',".
			"parent_group_code='".$aobj_context->mobj_data["user_schema_parent_group"] ."',".
			"multiple='".$aobj_context->mobj_data["is_multiple_user_schema_group"] ."',
			sequence=".trim($aobj_context->mobj_data["sequence"]) .",
			is_grid_edit=".trim($aobj_context->mobj_data["is_grid_edit_user_schema_group"]) .",
			inline_div=".trim($aobj_context->mobj_data["is_inline_div_user_schema_group"]) .",
			col_name=\"".trim($aobj_context->mobj_data["user_schema_coloum_names"]) ."\",
			col_model=\"".trim($aobj_context->mobj_data["user_schema_coloum_models"]) ."\",
			grid_edit_query=\"".trim($aobj_context->mobj_data["user_schema_grid_query"]) ."\",
			custom_links=\"".trim($aobj_context->mobj_data["user_schema_group_custom_links"]) ."\",
			on_click_event=\"".trim($aobj_context->mobj_data["user_schema_group_onclick"]) ."\",
			group_order_by='{$group_order_by}',
			group_default_rows={$grid_default_rows}
			where internal_code =".$aobj_context->mobj_data["internal_code"];
			
			  $lobj_rs = $aobj_context->mobj_db->Execute($lstr_qry);
			  if($lobj_rs)
		    {
		        $rdata = "Updated  Successfully.";
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
		        return;
		     }
		    else
		    {
		        $rdata = "Udatation Failed.";
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure"));      
		     } 
	}		 
}

function GetUserSchemaGroupDetailsForUpdate($aobj_context)
{
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);  
	$internal_code = $aobj_context->mobj_data["internal_code"]; 
	
	$qry="select * from s_user_schema_group where internal_code=$internal_code";
    $lobj_rs = $aobj_context->mobj_db->GetRow($qry); 
                     
    if(count($lobj_rs) != 0)
      echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success"); 
    else
      echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,-1,"Failure");
    return;
}

function getUserSchemaElementType($aobj_context)
{
  	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
	 
	$sql_query="select internal_code, type,value  from s_ref_type  	
	 where type in('data_type','element_type') order by type,value";
	 
	$lobj_rs = $aobj_context->mobj_db->GetAll($sql_query);        
     if(count($lobj_rs) != 0)
      print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success")); 
     else
      print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,-1,"Failure"));
    return;
}

function getUserSchemaElementReferenceData($aobj_context)
{
	    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
		$module_name=$aobj_context->mobj_data["module_name"];
		$qry=" select 
		internal_code,module_name  
			from s_user_schema where 
		is_menu_only=0 and active =1 order by module_name"; 
		$lobj_rs = $aobj_context->mobj_db->GetAll($qry);
		//echo $qry;
		print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success"));
			        return $lobj_rs;
}

function getUserSchemaGroup($aobj_context)
{
		$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
		$sql_query="select internal_code,name as user_schema_group  from s_user_schema_group where 
				ref_s_user_schema_code=".$aobj_context->mobj_data["elemenmt_user_schema"]." order by name";	
		$lobj_rs = $aobj_context->mobj_db->GetAll($sql_query);        
    $select_max_seq="select round(ifnull(max(sequence),0)+1) as sequence from s_user_schema_elements 					
					where ref_s_user_schema_code=".$aobj_context->mobj_data["elemenmt_user_schema"];
					$lobj_select_max_seq = $aobj_context->mobj_db->GetRow($select_max_seq); 
	$sequence=	$lobj_select_max_seq['sequence'];
	$arr[0]=$lobj_rs;
	$arr[1]=$sequence;
     if(count($lobj_rs) != 0)
      print_r($aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success")); 
     else
      print_r($aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure"));
    return;
}

function GetUserSchemaElementDetailsForUpdate($aobj_context)
{
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);  
	$internal_code = $aobj_context->mobj_data["internal_code"]; 	
	
	$qry="select * from s_user_schema_elements where internal_code=$internal_code";	
    $lobj_rs = $aobj_context->mobj_db->GetRow($qry); 	 
         
    if(count($lobj_rs) != 0)
      echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success"); 
    else
      echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,-1,"Failure");
    return;
}
function getLinkedModules($aobj_context)
{
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);  
	$schema_code = $aobj_context->mobj_data["schema_code"]; 	
	
	$qry="select internal_code,name as value from s_user_schema_elements where ref_module_code>0 
		and ref_s_user_schema_code=$schema_code";
		 
    $lobj_rs = $aobj_context->mobj_db->GetAll($qry); 
         
    if(count($lobj_rs) != 0)
      echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success"); 
    else
      echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,-1,"Failure");
    return;
}
function getSourceFields($aobj_context)
{
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);  
	$element_code = $aobj_context->mobj_data["element_code"]; 	
	
	$qry="select internal_code,name as value from s_user_schema_elements where 
	ref_s_user_schema_code=(select ref_module_code from s_user_schema_elements where internal_code=$element_code )";
		 
    $lobj_rs = $aobj_context->mobj_db->GetAll($qry); 
         
    if(count($lobj_rs) != 0)
      echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success"); 
    else
      echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,-1,"Failure");
    return;
}
function insertUserSchemaElements($aobj_context)
{
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
	$internal_code=$aobj_context->mobj_data["internal_code"];
	$name =$aobj_context->mobj_data["user_schema_element_name"];		
	$group_id =$aobj_context->mobj_data["elemenmt_user_schema_group"];		
	$system_name =$aobj_context->mobj_data["user_schema_system_name"];		
	$schema_id =$aobj_context->mobj_data["elemenmt_user_schema"];		
	$include_in_pop_up =$aobj_context->mobj_data["include_in_pop_up"];	
	$on_enter =stripslashes($aobj_context->mobj_data["on_enter"]);
	$on_exit =stripslashes($aobj_context->mobj_data["on_exit"]);
	$ref_module_code_ref_field_const = ($aobj_context->mobj_data["ref_module_code_ref_field_const"]);
	$ref_module_code_ref_field_on = ($aobj_context->mobj_data["ref_module_code_ref_field_on"]);
	$ref_module_code_ref_field = ($aobj_context->mobj_data["ref_module_code_ref_field"]);
	$include_in_grid = ($aobj_context->mobj_data["include_in_grid"]);
	$is_key_field = ($aobj_context->mobj_data["is_key_field"]);
	$is_lov = ($aobj_context->mobj_data["is_lov"]);
	$is_populate_lov = ($aobj_context->mobj_data["is_populate_lov"]);
	$text_area_rows = ($aobj_context->mobj_data["user_schema_element_text_area_rows"]);
	$text_area_rows=empty($text_area_rows)?2:$text_area_rows;
	$grid_width = ($aobj_context->mobj_data["user_schema_element_grid_width"]);
	if(empty($grid_width))
	  $grid_width = 0;
      	
	// to get the ids from the values
	 
	// to get the ids from the values
	 
	 
	$is_unique =$aobj_context->mobj_data["is_unique"];	
	$select_max_seq="select round(ifnull(max(sequence),0)+1)  as sequence from s_user_schema_elements 					
					where ref_s_user_schema_code=".$aobj_context->mobj_data["elemenmt_user_schema"]."
					and ref_s_user_schema_group_code=".$aobj_context->mobj_data["elemenmt_user_schema_group"];
					$lobj_select_max_seq = $aobj_context->mobj_db->GetRow($select_max_seq); 
					$max_seq=$lobj_select_max_seq["sequence"];	
				
	$get_multiple_group="select multiple from s_user_schema_group where internal_code=".$aobj_context->mobj_data["elemenmt_user_schema_group"]; 
	$lobj_multiple_group = $aobj_context->mobj_db->GetRow($get_multiple_group);
	if(!empty($lobj_multiple_group))
	$is_multiple_group=$lobj_multiple_group[multiple];
	else
	$is_multiple_group=0;
			
	// to check whether group is non -multiple and incoming value is meta
	$get_group_multiple="select count(*) as count from s_user_schema_group 
		where internal_code=".$aobj_context->mobj_data["elemenmt_user_schema_group"]." 
		and (multiple=1 or parent_group_code<>0) ";
		$lobj_get_group_multiple = $aobj_context->mobj_db->GetRow($get_group_multiple);
		  
	if($internal_code==0)
	{
		$get_data="select count(*) as element_count from s_user_schema_elements 
		where ref_s_user_schema_code={$schema_id}  and system_name='{$system_name}'";
		 
		$lobj_rs = $aobj_context->mobj_db->GetRow($get_data);
		
		if($lobj_rs['element_count']==0)
		{
		$select_id="select value from s_ref_type 
		where internal_code=".addslashes($aobj_context->mobj_data["meta_type"]);
		$lobj_select_id = $aobj_context->mobj_db->GetRow($select_id);
			
			//to insert the linked fields table id
			$insert_linked_table="select ref_module_code from s_user_schema_elements 
			where internal_code={$schema_id}";
			$lobj_inked_table = $aobj_context->mobj_db->GetRow($insert_linked_table);
			if(!empty($lobj_inked_table))
			$lobj_inked_table_id=$lobj_inked_table[ref_module_code];
			else
			$lobj_inked_table_id='0';
			 
			
		    $lstr_qry = "insert into s_user_schema_elements(  
		        ref_s_user_schema_code,
		        name,
				system_name,
				data_type,
				sequence,
				field_position,
				ref_s_user_schema_group_code,
				description,
				default_value,
				optional,
				decimals,
				list_of_values,
				ref_module_code,
				 ref_module_code_ref_field,
				 ref_module_code_ref_field_on,
				 ref_module_code_ref_field_const,
				s_ref_type_meta,
				is_multiple_group,
				linked_field,
				linked_field_table,
				source_field,
				suffix,
				width,
				padding,
				is_visible,
				is_ref_module_code_lov,
				populate_lov,
				conditional_display,
				is_read_only,
				is_unique,
				include_in_popup,
				include_in_grid,
				is_key_field,
				on_enter,
				on_exit,
				grid_width,
				text_area_rows				
				) 
		         values ( '".   addslashes($aobj_context->mobj_data["elemenmt_user_schema"]) ."','"
		                    .   addslashes($aobj_context->mobj_data["user_schema_element_name"])."','"
		                    .   addslashes($aobj_context->mobj_data["user_schema_system_name"])."','"
		                    .   addslashes($aobj_context->mobj_data["user_schema_element_type"])."','"
		                    .   addslashes($aobj_context->mobj_data["user_schema_element_sequence"])."','"
		                    .   addslashes($aobj_context->mobj_data["user_schema_element_field_position"])."','"
		                    .   addslashes($aobj_context->mobj_data["elemenmt_user_schema_group"])."','"
		                    .   addslashes($aobj_context->mobj_data["user_schema_element_description"])."','"
		                    .   addslashes($aobj_context->mobj_data["user_schema_element_default_value"])."',"
							.   addslashes($aobj_context->mobj_data["is_user_schema_element_optional"]).","
							.   addslashes($aobj_context->mobj_data["decimal"]).",'"
							.   addslashes($aobj_context->mobj_data["lov"])."',"
							.   addslashes($aobj_context->mobj_data["ref_module_code"]).",
								'{$ref_module_code_ref_field}',{$ref_module_code_ref_field_on},'{$ref_module_code_ref_field_const}',"
							.   addslashes($aobj_context->mobj_data["meta_type"]).","
							. 	$is_multiple_group.",'"
							. 	addslashes($aobj_context->mobj_data["linked_field"])."','"
							. 	$lobj_inked_table_id."','"
							. 	addslashes($aobj_context->mobj_data["source_fields"])."','"
							. 	addslashes($aobj_context->mobj_data["suffix"])."','"
							. 	addslashes($aobj_context->mobj_data["width"])."','"
							. 	addslashes($aobj_context->mobj_data["padding"])."','"
							. 	addslashes($aobj_context->mobj_data["is_visible"])."','"
							. 	addslashes($aobj_context->mobj_data["is_lov"])."','"
							. 	addslashes($aobj_context->mobj_data["is_populate_lov"])."','"
							. 	addslashes($aobj_context->mobj_data["user_schema_element_conditional_display"])."','"
							. 	addslashes($aobj_context->mobj_data["is_read_only"])
							."',{$is_unique},'{$include_in_pop_up}','{$include_in_grid}',
							'{$is_key_field}','{$on_enter}','{$on_exit}','{$grid_width}',{$text_area_rows})";
					$lobj_rs = $aobj_context->mobj_db->Execute($lstr_qry); 
					 
					UpdateDbField($aobj_context,$schema_id);					
					$select_max_seq="select round(ifnull(max(sequence),0)+1)  as sequence from s_user_schema_elements 					
					where ref_s_user_schema_code=".$aobj_context->mobj_data["elemenmt_user_schema"]."
					and ref_s_user_schema_group_code=".$aobj_context->mobj_data["elemenmt_user_schema_group"];
					$lobj_select_max_seq = $aobj_context->mobj_db->GetRow($select_max_seq); 
					$max_seq=$lobj_select_max_seq["sequence"];	
			   	     $last_inserted_id  = $aobj_context->mobj_db->Insert_ID();
			
					 //to check whether elements belongs to multiple group
					 $decml = $aobj_context->mobj_data["decimal"]+12;
					 $is_visible=$aobj_context->mobj_data["is_visible"];
				
					 $is_group="select 
						if(multiple=1,CONCAT('user_schema_',sus.INTERNAL_CODE,'_group_',susg.internal_code),
						CONCAT('user_schema_',sus.INTERNAL_CODE,'_group_',susg.parent_group_code)) 
							as table_name,
							case when s.value='Text' then 'varchar(500)'
							when s.value='List Of Values' then 'varchar(50)'
							when s.value='Reference Data' then 'int(11)'
							when s.value ='Number' and {$decml}>12 then 'decimal(".$decml.",".$aobj_context->mobj_data["decimal"].")'
							when s.value ='Number' and {$decml}=12 then 'int(11)'
							when s.value ='Date' then 'date'
							when s.value='Month' then 'int(6)'
							when s.value='Image' then 'varchar(250)'
							else 'text' end as   data_type
							from 
							s_user_schema_elements suse 
							inner join s_user_schema_group susg 
							on susg.internal_code=suse.ref_s_user_schema_group_code  
							inner join s_user_schema sus on sus.internal_code=susg.ref_s_user_schema_code
							inner join s_ref_type s1 on s1.internal_code=suse.s_ref_type_meta
							and s1.value='Meta'
							left join s_ref_type s on s.internal_code=suse.data_type
							where suse.internal_code=". $last_inserted_id ." 
							and ((multiple=1) or (multiple=0 and parent_group_code<>0) )";
						 
							$lobj_rs_group = $aobj_context->mobj_db->GetRow($is_group);
							
						 
							// if count of Group is greater than one the alter the table 
							if(count($lobj_rs_group['table_name'])>0)
							{
							$table_count="show tables like '".$lobj_rs_group['table_name']."'";
							$lobj_rs_table_count = $aobj_context->mobj_db->GetRow($table_count);
							 
								if(count($lobj_rs_table_count)>0)
								{	
								$ref_s_user_schema_group_code=$aobj_context->mobj_data["elemenmt_user_schema_group"];
								// it will insert into corresponding filds
								$getafterId="select max(suse.internal_code) as max_id
								from s_user_schema_elements suse
								inner join s_user_schema_group sg on sg.internal_code=suse.ref_s_user_schema_group_code
								inner join s_ref_type t on t.internal_code=suse.s_ref_type_meta
								where suse.ref_s_user_schema_code={$aobj_context->mobj_data["elemenmt_user_schema"]}
								and suse.internal_code<{$last_inserted_id}  and sg.internal_code={$group_id}
								and t.value='meta'
								and (sg.internal_code={$ref_s_user_schema_group_code}
								or sg.parent_group_code={$ref_s_user_schema_group_code})";
								$lobj_getafterId = $aobj_context->mobj_db->GetRow($getafterId);
								 
								$after=(!is_null($lobj_getafterId['max_id']))?"u_".$aobj_context->mobj_data["elemenmt_user_schema"]."_g_".$aobj_context->mobj_data["elemenmt_user_schema_group"]."_ele_".$lobj_getafterId["max_id"]:" ref_s_ref_data_code";
									foreach ($lobj_rs_table_count as $key=>$value)
									{
									$select_db_field="select db_field from s_user_schema_elements 
									where internal_code={$last_inserted_id}
									";
									$lobj_select_db_field = $aobj_context->mobj_db->GetRow($select_db_field);
									 
									$field_id=$lobj_select_db_field['db_field'];
									$alter_qr="alter table ". $value ."  add  {$field_id} ".$lobj_rs_group['data_type']." after " .$after ;
									$lobj_rs = $aobj_context->mobj_db->Execute($alter_qr); 
							 
									 
									// for Inserting Entry Group Table STARTS
									$group_entry_table=str_ireplace("group","entry",$value);
									$alter_e_qr="alter table ". $group_entry_table ."  add  {$field_id} ".$lobj_rs_group['data_type']." after " .$after ;
									$lobj_alter_e_qr = $aobj_context->mobj_db->Execute($alter_e_qr); 
										// for Inserting Entry Group Table ENDS
										if($is_unique=='1')
										{
										$create_idx="CREATE UNIQUE INDEX indx_{$field_id}  ON {$value}(ref_s_ref_data_code,{$field_id}) ";
										//echo $create_idx;
										$lobj_create_idx = $aobj_context->mobj_db->Execute($create_idx); 
										}
									}
								}
							}
							//to check element belong to meta
							if($lobj_select_id['value']=='Meta' && $lobj_get_group_multiple['count']==0)
							{						
							 $is_group="select CONCAT('module_',sus.INTERNAL_CODE) 
							as table_name,
							case when s.value='Text' then 'varchar(500)'
							when s.value='List Of Values' then 'varchar(50)'
							when s.value='Reference Data' then 'int(11)'
							when s.value ='Number' and {$decml}>12 then 'decimal(".$decml.",".$aobj_context->mobj_data["decimal"].")'
							when s.value ='Number' and {$decml}=12 then 'int(11)'
							when s.value ='Date' then 'date'
							when s.value='Month' then 'int(6)'
							when s.value='Image' then 'varchar(250)'
							else 'text' end as data_type
							from 
							s_user_schema_elements suse 
							inner join s_user_schema sus on sus.internal_code=suse.ref_s_user_schema_code
							left join s_ref_type s on s.internal_code=suse.data_type
							inner join s_ref_type s1 on s1.internal_code=suse.s_ref_type_meta
							where suse.internal_code=". $last_inserted_id ." and s1.value='Meta'";
							
							$lobj_rs_group = $aobj_context->mobj_db->GetRow($is_group);
							 
							//echo 'count'.count($lobj_rs_group['table_name']);
							// if count of Group is greater than one the alter the table 
								if(count($lobj_rs_group['table_name'])>0)
								{
								// it will insert into corresponding filds
								$getafterId="select max(s.internal_code) as max_id
								from s_user_schema_elements s inner join s_ref_type t on t.internal_code=s_ref_type_meta where ref_s_user_schema_code={$aobj_context->mobj_data["elemenmt_user_schema"]}
								and s.internal_code<{$last_inserted_id}  and is_multiple_group=0 and t.value='meta'";
								$lobj_getafterId = $aobj_context->mobj_db->GetRow($getafterId);
								$after=(!is_null($lobj_getafterId['max_id']))?"m_".$aobj_context->mobj_data["elemenmt_user_schema"]."_ele_".$lobj_getafterId["max_id"]:" ref_s_user_schema_code";
								$table_count="show tables like '".$lobj_rs_group['table_name']."'";
								$lobj_rs_table_count = $aobj_context->mobj_db->GetRow($table_count);
								
									if(count($lobj_rs_table_count)>0)
									{	
									foreach ($lobj_rs_table_count as $key=>$value)
									{
									$meta_field_id="m_".$aobj_context->mobj_data["elemenmt_user_schema"]."_ele_".$last_inserted_id;
									$alter_qr="alter table ". $value ."  add  {$meta_field_id} ".$lobj_rs_group['data_type'] ." after ".$after;
									$lobj_rs = $aobj_context->mobj_db->Execute($alter_qr); 
									
									if($is_unique=='1')
										{
										$create_idx="CREATE UNIQUE INDEX indx_{$meta_field_id}  ON {$value}({$meta_field_id}) ";
										$lobj_create_idx = $aobj_context->mobj_db->Execute($create_idx); 
										}
									}
									}
								}
							}
			 
							//to create the file for each group
				//include(dirname(__FILE__)."\create_file.php");
					$aobj_context->mobj_data["schema_id"]=$schema_id;
				include(dirname(__FILE__)."/create_all_grid_files.php");
				populateAllGridFiles($aobj_context);
				include(dirname(__FILE__)."/create_module_meta_columns.php");
				createModuleMetaColumns($aobj_context);
				//include(dirname(__FILE__)."\create_group_file.php");
				include_once(dirname(__FILE__)."/create_all_grid_group_files.php");
				populateAllGridGroupFiles($aobj_context); 
				include(dirname(__FILE__)."/create_html_files.php");
				CreateModuleHtmlFiles($aobj_context);
				include(dirname(__FILE__)."/create_all_popup_files.php");
				populateAllPopupGridFiles($aobj_context);
				include(dirname(__FILE__)."/create_all_views.php");
				CreateView($aobj_context);
				include(dirname(__FILE__)."/update_defined_flag.php");
				UpdateDefinedFlag($aobj_context);
			fclose($handle); 
			    if($lobj_rs)
			    {
			        $rdata[0] = "Element Name inserted successfully.";
			        $rdata[1] = $max_seq;
			        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
			        return $rdata;
			     }
			    else
			    {
			        $rdata[0] = "insertion Failed.";
					 $rdata[1] = $max_seq;
			        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure"));  
					return $rdata;			
			    } 
			  
			
		}
			else 	
			{
			     $rdata[0] = "System Name Already Exstis!";
				  $rdata[1] = $max_seq;
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
		        return $rdata;
		    }
			
	}
	else
	{ //to updATE THE s_group_table
			$decml = $aobj_context->mobj_data["decimal"]+12;
			$update_field="select CONCAT('user_schema_',sus.INTERNAL_CODE,'_group_',susg.internal_code) 
				as table_name,concat('u_',sus.internal_code,'_g_',susg.internal_code,'_ele_',suse.internal_code) as field_name,
				case when s.value='Text' then 'varchar(500)'
				when s.value='List Of Values' then 'varchar(50)'
				when s.value='Reference Data' then 'int(11)'
				when s.value ='Number' and {$decml}>12 then 'decimal(".$decml.",".$aobj_context->mobj_data["decimal"].")'
				when s.value ='Number' and {$decml}=12 then 'int(11)'
				when s.value ='Date' then 'date'
				when s.value='Month' then 'int(6)'
				when s.value='Image' then 'varchar(250)'
				else 'text' end as data_type,s.internal_code as data_type_code,susg.internal_code as group_code
				from 
				s_user_schema_elements suse 
				inner join s_user_schema_group susg 
				on susg.internal_code=suse.ref_s_user_schema_group_code  
				inner join s_user_schema sus on sus.internal_code=susg.ref_s_user_schema_code
				left join s_ref_type s on s.internal_code=suse.data_type
				where suse.internal_code=".$aobj_context->mobj_data["internal_code"]." and multiple=1";
			
				$lobj_rs_alter_field = $aobj_context->mobj_db->GetRow($update_field);
				// to make is unique to set for group elemens if unique=1
							if($is_unique=='1')
							{
							$alt_drop_indx="ALTER   TABLE ". $lobj_rs_alter_field["table_name"]." drop INDEX  indx_".$lobj_rs_alter_field["field_name"];
							$lobj_alt_drop_indx = $aobj_context->mobj_db->Execute($alt_drop_indx);
				
							$alt_add_indx="ALTER   TABLE ". $lobj_rs_alter_field["table_name"]." add   UNIQUE INDEX  indx_".$lobj_rs_alter_field["field_name"] ."(ref_s_ref_data_code,".$lobj_rs_alter_field["field_name"].")";
							$lobj_alt_add_indx = $aobj_context->mobj_db->Execute($alt_add_indx);
							}
				// to check updated group name is same as db group name and data type has been changed
				if($lobj_rs_alter_field["group_code"]==$aobj_context->mobj_data["elemenmt_user_schema_group"] && $lobj_rs_alter_field["data_type_code"]!=$aobj_context->mobj_data["user_schema_element_type"] )
				{
					$table_count="show tables like '".$lobj_rs_alter_field['table_name']."'";
					$lobj_rs_table_count = $aobj_context->mobj_db->GetRow($table_count);
					if(count($lobj_rs_table_count)>0)
					{
						$desc_qry="desc ". $lobj_rs_alter_field['table_name'];
						//echo $desc_qry;
						$obj_desc=$aobj_context->mobj_db->GetAll($desc_qry);
						foreach ($obj_desc as $key=>$value)
						//to check whether table has secific fied name
						if($value['Field']==$lobj_rs_alter_field["field_name"])
						{
						$get_data_type="select case when s.value='Text' then 'varchar(500)'
							when s.value='List Of Values' then 'varchar(50)'
							when s.value='Reference Data' then 'int(11)'
							when s.value ='Number' and {$decml}>12 then 'decimal(".$decml.",".$aobj_context->mobj_data["decimal"].")'
							when s.value ='Number' and {$decml}=12 then 'int(11)'
							when s.value ='Date' then 'date'
							when s.value='Month' then 'int(6)'
							when s.value='Image' then 'varchar(250)'
							else 'text' end as data_type from s_ref_type s  where internal_code=".$aobj_context->mobj_data["user_schema_element_type"];
						//echo $get_data_type;
						$get_data_type_for_update=$aobj_context->mobj_db->GetRow($get_data_type);
						$update_field_row="alter table ".$lobj_rs_alter_field["table_name"]." change ".$lobj_rs_alter_field["field_name"]."  ". $lobj_rs_alter_field["field_name"]." ".$get_data_type_for_update["data_type"];
						 $lobj_rs = $aobj_context->mobj_db->Execute($update_field_row);
						 // for Inserting Entry Group Table STARTS
						$entry_group_table=str_ireplace("group","entry",$lobj_rs_alter_field["table_name"]);
						$update_entry_field_row="alter table {$entry_group_table} change ".$lobj_rs_alter_field["field_name"]."  ". $lobj_rs_alter_field["field_name"]." ".$get_data_type_for_update["data_type"];
						$lobj_update_entry_field_row = $aobj_context->mobj_db->Execute($update_entry_field_row);
						// for Inserting Entry Group Table ENDS
						$alt_drop_indx="ALTER   TABLE ". $lobj_rs_alter_field["table_name"]." drop INDEX  indx_".$lobj_rs_alter_field["field_name"];
						$lobj_alt_drop_indx = $aobj_context->mobj_db->Execute($alt_drop_indx);
							if($is_unique=='1')
							{
							$alt_add_indx="ALTER   TABLE ". $lobj_rs_alter_field["table_name"]." add   UNIQUE INDEX  indx_".$lobj_rs_alter_field["field_name"] ."(ref_s_ref_data_code,".$lobj_rs_alter_field["field_name"].")";
							$lobj_alt_add_indx = $aobj_context->mobj_db->Execute($alt_add_indx);
							}
						 }
					}
				}
				// If users changes the Exsting Multi Group to None
				else if($aobj_context->mobj_data["elemenmt_user_schema_group"]==0 && $lobj_rs_alter_field["group_code"]>0)
				{
					if(count($lobj_rs_alter_field['table_name'])>0)
							{
							$table_count="show tables like '".$lobj_rs_alter_field['table_name']."'";
							$lobj_rs_table_count = $aobj_context->mobj_db->GetRow($table_count);
								if(count($lobj_rs_table_count)>0)
								{	
								foreach ($lobj_rs_table_count as $key=>$value)
								{
								$alter_qr="alter table ". $value ." drop ".$lobj_rs_alter_field['field_name']   ;
								$lobj_rs_drop = $aobj_context->mobj_db->Execute($alter_qr); 
								
								$alt_drop_indx="ALTER   TABLE ". $value." drop INDEX  indx_".$lobj_rs_alter_field["field_name"];
								$lobj_alt_drop_indx = $aobj_context->mobj_db->Execute($alt_drop_indx);
							if($is_unique=='1')
							{
							$alt_add_indx="ALTER   TABLE ". $value." add   UNIQUE INDEX  indx_".$lobj_rs_alter_field["field_name"] ."(ref_s_ref_data_code,".$lobj_rs_alter_field["field_name"].")"; 
							$lobj_alt_add_indx = $aobj_context->mobj_db->Execute($alt_add_indx);
							}
								}
								}
							}
				}//if user changs one group name to other grup name need to delete the exsting group field and insert new field in selected group
				else if($aobj_context->mobj_data["elemenmt_user_schema_group"]!= $lobj_rs_alter_field["group_code"]  && $aobj_context->mobj_data["elemenmt_user_schema_group"]!=0)
				{
					if(count($lobj_rs_alter_field['table_name'])>0)
							{
							$table_count="show tables like '".$lobj_rs_alter_field['table_name']."'";
							$lobj_rs_table_count = $aobj_context->mobj_db->GetRow($table_count);
								if(count($lobj_rs_table_count)>0)
								{	
								foreach ($lobj_rs_table_count as $key=>$value)
								$alter_qr="alter table ". $value ." drop ".$lobj_rs_alter_field['field_name']   ;
							$lobj_rs_drop = $aobj_context->mobj_db->Execute($alter_qr); 
									$alt_drop_indx="ALTER   TABLE ". $value." drop INDEX  indx_".$lobj_rs_alter_field["field_name"];
									$lobj_alt_drop_indx = $aobj_context->mobj_db->Execute($alt_drop_indx);
									if($is_unique=='1')
									{
									$alt_add_indx="ALTER   TABLE ". $value." add   UNIQUE INDEX  indx_".$lobj_rs_alter_field["field_name"]."(ref_s_ref_data_code,".$lobj_rs_alter_field["field_name"].")"; 
									$lobj_alt_add_indx = $aobj_context->mobj_db->Execute($alt_add_indx);
									}
								}
							}
							//to get new grup name
						$new_group_qry="select concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as table_name
							from  s_user_schema_group where multiple=1 and internal_code=".$aobj_context->mobj_data["elemenmt_user_schema_group"];
							$get_new_group_qry=$aobj_context->mobj_db->GetRow($new_group_qry);
							//to get new data type for that element
							$get_data_type="select case when s.value='Text' then 'varchar(500)'
							when s.value='List Of Values' then 'varchar(50)'
							when s.value='Reference Data' then 'int(11)'
							when s.value ='Number' and {$decml}>12 then 'decimal(".$decml.",".$aobj_context->mobj_data["decimal"].")'
							when s.value ='Number' and {$decml}=12 then 'int(11)'
							when s.value ='Date' then 'date'
							when s.value='Month' then 'int(6)'
							when s.value='Image' then 'varchar(250)'
							else 'text' end as data_type from s_ref_type s  where internal_code=".$aobj_context->mobj_data["user_schema_element_type"];
						//echo $get_data_type;
						$get_data_type_for_update=$aobj_context->mobj_db->GetRow($get_data_type);
						
						$getafterId="select max(internal_code) as max_id
								from s_user_schema_elements where ref_s_user_schema_code={$aobj_context->mobj_data["elemenmt_user_schema"]}
								and internal_code<".$aobj_context->mobj_data["internal_code"]." and is_multiple_group=1 and ref_s_user_schema_group_code=".$aobj_context->mobj_data["elemenmt_user_schema_group"];
								$lobj_getafterId = $aobj_context->mobj_db->GetRow($getafterId);
								$after=(!is_null($lobj_getafterId['max_id']))?"u_".$aobj_context->mobj_data["elemenmt_user_schema"]."_g_".$aobj_context->mobj_data["elemenmt_user_schema_group"]."_ele_".$lobj_getafterId["max_id"]:" ref_s_ref_data_code";
								
						//to alter the new field name
						$update_field_row="alter table ".$get_new_group_qry["table_name"]." add u_".$aobj_context->mobj_data["elemenmt_user_schema"]."_g_".$aobj_context->mobj_data["elemenmt_user_schema_group"]."_ele_".$aobj_context->mobj_data["internal_code"]." ".$get_data_type_for_update['data_type'] ." after " .$after;
						// echo $update_field_row;
						 $alter_lobj_rs = $aobj_context->mobj_db->Execute($update_field_row);
						 
						$alt_drop_indx="ALTER   TABLE ".$get_new_group_qry["table_name"]." drop INDEX  indx_u_".$aobj_context->mobj_data["elemenmt_user_schema"]."_g_".$aobj_context->mobj_data["elemenmt_user_schema_group"]."_ele_".$aobj_context->mobj_data["internal_code"];
								$lobj_alt_drop_indx = $aobj_context->mobj_db->Execute($alt_drop_indx);
							if($is_unique=='1')
							{
							$f_id=$aobj_context->mobj_data["elemenmt_user_schema"]."_g_".$aobj_context->mobj_data["elemenmt_user_schema_group"]."_ele_".$aobj_context->mobj_data["internal_code"];
							$alt_add_indx="ALTER   TABLE ". $get_new_group_qry["table_name"]." add   UNIQUE INDEX  indx_{$f_id} (ref_s_ref_data_code,{$f_id}) ";
							$lobj_alt_add_indx = $aobj_context->mobj_db->Execute($alt_add_indx);
							}
				}
				
				$select_id="select value from s_ref_type where internal_code=".addslashes($aobj_context->mobj_data["meta_type"]);
				$lobj_select_id = $aobj_context->mobj_db->GetRow($select_id);
				//if users updates Type from Meta to Users then drop the Exsting Meta Field from Corresponing Table
				if($lobj_select_id['value']=='User')
							{
							$is_group="select CONCAT('module_',sus.INTERNAL_CODE) 
							as table_name,CONCAT('m_',sus.INTERNAL_CODE,'_ele_',".$aobj_context->mobj_data["internal_code"].") as field_name,
							case when s.value='Text' then 'varchar(500)'
								when s.value='List Of Values' then 'varchar(50)'
								when s.value='Reference Data' then 'int(11)'
								when s.value ='Number' and {$decml}>12 then 'decimal(".$decml.",".$aobj_context->mobj_data["decimal"].")'
								when s.value ='Number' and {$decml}=12 then 'int(11)'
								when s.value ='Date' then 'date'
								when s.value='Month' then 'int(6)'
								when s.value='Image' then 'varchar(250)'
								else 'text'   end as data_type
							from 
							s_user_schema_elements suse 
							inner join s_user_schema sus on sus.internal_code=suse.ref_s_user_schema_code
							left join s_ref_type s on s.internal_code=suse.data_type
							inner join s_ref_type s1 on s1.internal_code=suse.s_ref_type_meta
							where suse.internal_code=". $aobj_context->mobj_data["internal_code"] ." and s1.value='Meta'";
							//echo $is_group;
							$lobj_rs_group = $aobj_context->mobj_db->GetRow($is_group);
							//echo $is_group;
							//echo 'count'.count($lobj_rs_group['table_name']);
							// if count of Group is greater than one the alter the table 
								if(!empty($lobj_rs_group['table_name']))
								{
								$table_count="show tables like '".$lobj_rs_group['table_name']."'";
								$lobj_rs_table_count = $aobj_context->mobj_db->GetRow($table_count);
									if(!empty($lobj_rs_table_count))
									{	
									foreach ($lobj_rs_table_count as $key=>$value)
								$alter_qr="alter table ". $value ." drop ".$lobj_rs_group['field_name']   ;
								$lobj_rs_drop = $aobj_context->mobj_db->Execute($alter_qr); 
								
								$alt_drop_indx="ALTER   TABLE ". $value." drop INDEX  indx_".$lobj_rs_group["field_name"];
									$lobj_alt_drop_indx = $aobj_context->mobj_db->Execute($alt_drop_indx);
									if($is_unique=='1')
									{
									$alt_add_indx="ALTER   TABLE ". $value." add   UNIQUE INDEX  indx_".$lobj_rs_group["field_name"]."(".$lobj_rs_group["field_name"].")";
									$lobj_alt_add_indx = $aobj_context->mobj_db->Execute($alt_add_indx);
									}
									}
								}
							} 
							//if users updates Type from Users to Meta need to insert new column in field
							if($lobj_select_id['value']=='Meta' && $lobj_get_group_multiple['count']==0)
							{
							$is_group="select CONCAT('module_',sus.INTERNAL_CODE) 
							as table_name,CONCAT('m_',sus.INTERNAL_CODE,'_ele_',".$aobj_context->mobj_data["internal_code"].") as field_name,
							case when s.value='Text' then 'varchar(500)'
								when s.value='List Of Values' then 'varchar(50)'
								when s.value='Reference Data' then 'int(11)'
								when s.value ='Number' and {$decml}>12 then 'decimal(".$decml.",".$aobj_context->mobj_data["decimal"].")'
							when s.value ='Number' and {$decml}=12 then 'int(11)'
								when s.value ='Date' then 'date'
								when s.value='Month' then 'int(6)'
								when s.value='Image' then 'varchar(250)'
								else 'text' end as data_type
							from 
							s_user_schema_elements suse 
							inner join s_user_schema sus on sus.internal_code=suse.ref_s_user_schema_code
							left join s_ref_type s on s.internal_code=suse.data_type
							inner join s_ref_type s1 on s1.internal_code=suse.s_ref_type_meta
							where suse.internal_code=". $aobj_context->mobj_data["internal_code"] ." and s1.value='User'";
							//echo $is_group;
							$lobj_rs_group = $aobj_context->mobj_db->GetRow($is_group);
							
						
								if(!empty($lobj_rs_group['table_name']))
								{
								$table_count="show tables like '".$lobj_rs_group['table_name']."'";
								$lobj_rs_table_count = $aobj_context->mobj_db->GetRow($table_count);
									if(!empty($lobj_rs_table_count))
									{
							$getafterId="select max(s.internal_code) as max_id
								from s_user_schema_elements s inner join s_ref_type t on t.internal_code=s_ref_type_meta where ref_s_user_schema_code={$aobj_context->mobj_data["elemenmt_user_schema"]}
								and s.internal_code<". $aobj_context->mobj_data["internal_code"]."  and is_multiple_group=0 and t.value='meta'";
								$lobj_getafterId = $aobj_context->mobj_db->GetRow($getafterId);
								$after=(!is_null($lobj_getafterId['max_id']))?"m_".$aobj_context->mobj_data["elemenmt_user_schema"]."_ele_".$lobj_getafterId["max_id"]:" ref_s_user_schema_code";
																	
									foreach ($lobj_rs_table_count as $key=>$value)
								$alter_qr="alter table ". $value ." add ".$lobj_rs_group['field_name']." ".$lobj_rs_group['data_type'] ." after ".$after ;
								$lobj_rs_drop = $aobj_context->mobj_db->Execute($alter_qr); 
								
									}
								}
							}
								 $decml = $aobj_context->mobj_data["decimal"]+12;
							//if element type is META and user changes data type from int->date  etc....need to alter the table by droping the exsting field and insert new field
							$check_data_type="select is_unique,data_type,s.value,concat('module_',ref_s_user_schema_code) as table_name,
											concat('m_',ref_s_user_schema_code,'_ele_',suse.internal_code) as field_name,data_type
											from s_user_schema_elements suse
											inner join s_ref_type s on s.internal_code=s_ref_type_meta
											where suse.internal_code=".$aobj_context->mobj_data["internal_code"];
						
							$lobj_check_data_type = $aobj_context->mobj_db->GetRow($check_data_type);
							if(($lobj_check_data_type[value]=='Meta' && $lobj_check_data_type[data_type] != $aobj_context->mobj_data["user_schema_element_type"]) || ($lobj_check_data_type[is_unique] != $aobj_context->mobj_data["is_unique"]) )
							{
							$table_count="show tables like '".$lobj_check_data_type['table_name']."'";
							$lobj_rs_table_count = $aobj_context->mobj_db->GetRow($table_count);
								if(count($lobj_rs_table_count)>0)
								{
									$desc_qry="desc ". $lobj_check_data_type['table_name'];
									//echo $desc_qry;
									$obj_desc=$aobj_context->mobj_db->GetAll($desc_qry);
									foreach ($obj_desc as $key=>$value)
									{
									//to check whether table has secific fied name
									if($value['Field']==$lobj_check_data_type["field_name"])
									{
									$get_data_type="select case when s.value='Text' then 'varchar(500)'
										when s.value='List Of Values' then 'varchar(50)'
										when s.value='Reference Data' then 'int(11)'
										when s.value ='Number' and {$decml}>12 then 'decimal(".$decml.",".$aobj_context->mobj_data["decimal"].")'
										when s.value ='Number' and {$decml}=12 then 'int(11)'
										when s.value ='Date' then 'date'
										when s.value='Month' then 'int(6)'
										when s.value='Image' then 'varchar(250)'
										else 'text' end as data_type from s_ref_type s  where internal_code=".$aobj_context->mobj_data["user_schema_element_type"];
									//echo $get_data_type;
									$get_data_type_for_update=$aobj_context->mobj_db->GetRow($get_data_type);
									$update_field_row="alter table ".$lobj_check_data_type["table_name"]." change ".$lobj_check_data_type["field_name"]."  ". $lobj_check_data_type["field_name"]." ".$get_data_type_for_update["data_type"];
									
									 $lobj_rs = $aobj_context->mobj_db->Execute($update_field_row);
									 $alt_drop_indx="ALTER   TABLE ".$lobj_check_data_type["table_name"]." drop INDEX  indx_".$lobj_check_data_type["field_name"];
									$lobj_alt_drop_indx = $aobj_context->mobj_db->Execute($alt_drop_indx);
								 
									if($is_unique=='1')
									{
									$alt_add_indx="ALTER   TABLE ". $lobj_check_data_type["table_name"]." add   UNIQUE INDEX  indx_".$lobj_check_data_type["field_name"] ."(".$lobj_check_data_type["field_name"].")";
									$lobj_alt_add_indx = $aobj_context->mobj_db->Execute($alt_add_indx);
									 
									}
									 }
									
									 }
								}
							}
								//to insert the linked fields table id
			$insert_linked_table="select ref_module_code from s_user_schema_elements where internal_code=".$aobj_context->mobj_data["linked_field"];
			$lobj_inked_table = $aobj_context->mobj_db->GetRow($insert_linked_table);	
	if(!empty($lobj_inked_table))
				$lobj_inked_table_id=$insert_linked_table[ref_module_code];
				else
				$lobj_inked_table_id=0;			
				$lstr_qry = "update s_user_schema_elements
			set ref_s_user_schema_code='".   trim($aobj_context->mobj_data["elemenmt_user_schema"]) ."',".
			"name='".stripcslashes($aobj_context->mobj_data["user_schema_element_name"]) ."',".
			"system_name='".stripcslashes($aobj_context->mobj_data["user_schema_system_name"]) ."',".
			"data_type='".addslashes($aobj_context->mobj_data["user_schema_element_type"]) ."',".
			"sequence='".addslashes($aobj_context->mobj_data["user_schema_element_sequence"]) ."',".
			"field_position='".addslashes($aobj_context->mobj_data["user_schema_element_field_position"]) ."',".
			"ref_s_user_schema_group_code='".addslashes($aobj_context->mobj_data["elemenmt_user_schema_group"]) ."',".
			"description='".addslashes($aobj_context->mobj_data["user_schema_element_description"]) ."',".
			"default_value='".addslashes($aobj_context->mobj_data["user_schema_element_default_value"]) ."',".
			"optional='".$aobj_context->mobj_data["is_user_schema_element_optional"] ."',
			list_of_values='".addslashes($aobj_context->mobj_data["lov"])."',
			linked_field='".addslashes($aobj_context->mobj_data["linked_field"])."',
			source_field='".addslashes($aobj_context->mobj_data["source_fields"])."',
			suffix='".addslashes($aobj_context->mobj_data["suffix"])."',
			width='".addslashes($aobj_context->mobj_data["width"])."',
			padding='".addslashes($aobj_context->mobj_data["padding"])."',
			is_read_only='".addslashes($aobj_context->mobj_data["is_read_only"])."',
			is_unique={$is_unique},include_in_popup={$include_in_pop_up},
			linked_field_table='".$lobj_inked_table_id."',
			is_visible='".$aobj_context->mobj_data["is_visible"]."',
			is_ref_module_code_lov='".$aobj_context->mobj_data["is_lov"]."',
			populate_lov='".$aobj_context->mobj_data["is_populate_lov"]."',
			conditional_display='".$aobj_context->mobj_data["user_schema_element_conditional_display"]."',
			on_enter='{$on_enter}',on_exit='{$on_exit}',is_key_field={$is_key_field},include_in_grid={$include_in_grid},
			ref_module_code_ref_field='{$ref_module_code_ref_field}',
			ref_module_code_ref_field_on='{$ref_module_code_ref_field_on}',
			ref_module_code_ref_field_const='{$ref_module_code_ref_field_const}',
			decimals =". addslashes($aobj_context->mobj_data["decimal"]).",ref_module_code=". addslashes($aobj_context->mobj_data["ref_module_code"]).", 
			s_ref_type_meta=".addslashes($aobj_context->mobj_data["meta_type"]).",
			is_multiple_group={$is_multiple_group}".",
			grid_width={$grid_width},text_area_rows={$text_area_rows}  where internal_code =".$aobj_context->mobj_data["internal_code"];
			  $lobj_rs = $aobj_context->mobj_db->Execute($lstr_qry);
			  
			
			  
			  // to update the db_value dec-1-2008
					$update_db_value=" update s_user_schema_elements suse,
							(select  suse.internal_code as db_field_ic_code, 
							case when t.value in('User','Meta')  and ref_s_user_schema_group_code>0 and 
							(is_multiple_group=1 or ug.parent_group_code<>0)
							then 
							if(suse.is_multiple_group=1,
							concat('u_',suse.ref_s_user_schema_code,'_g_',ref_s_user_schema_group_code,'_ele_',suse.internal_code),
							concat('u_',suse.ref_s_user_schema_code,'_g_',ug.parent_group_code,'_ele_',suse.internal_code)
							)
							when t.value='Meta' and ref_s_user_schema_group_code=0
							then
							concat('m_',suse.ref_s_user_schema_code,'_ele_',suse.internal_code)
							when t.value='Meta' and ref_s_user_schema_group_code>0 and is_multiple_group=0
							then
							concat('m_',suse.ref_s_user_schema_code,'_ele_',suse.internal_code)
							else ''
							end as db_fields_s_user_schema_elements
							from s_user_schema_elements suse 
							left join s_user_schema_group ug on ug.internal_code=ref_s_user_schema_group_code
							inner join s_ref_type t on t.internal_code=s_ref_type_meta
							 where suse.ref_s_user_schema_code={$schema_id}
							) a
							set db_field=db_fields_s_user_schema_elements
							where db_field_ic_code=suse.internal_code";
					$lobj_rs_update_db_value = $aobj_context->mobj_db->Execute($update_db_value); 

}				$aobj_context->mobj_data["schema_id"]=$schema_id;
				include_once(dirname(__FILE__)."/create_all_grid_files.php");
				populateAllGridFiles($aobj_context);
				include(dirname(__FILE__)."/create_module_meta_columns.php");
				createModuleMetaColumns($aobj_context);
				include(dirname(__FILE__)."/create_all_grid_group_files.php");
				populateAllGridGroupFiles($aobj_context); 
				include(dirname(__FILE__)."/create_html_files.php");
				CreateModuleHtmlFiles($aobj_context);
				include(dirname(__FILE__)."/create_all_popup_files.php");
				populateAllPopupGridFiles($aobj_context);
				include(dirname(__FILE__)."/update_defined_flag.php");
				UpdateDefinedFlag($aobj_context);
			 if($lobj_rs)
		    {
		        $rdata[0] = "Updated  Successfully.";
				 $rdata[1] = $max_seq;
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
		        return;
		     }
		    else
		    {
		        $rdata[0] = "Udatation Failed.";
				 $rdata[1] = $max_seq;
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure"));      
		     } 
	
}
function UpdateDbField($aobj_context,$schema_id)
{
// to update the db_value dec-1-2008
					$update_db_value=" update s_user_schema_elements suse,
							(select  suse.internal_code as db_field_ic_code, 
							case when t.value in('User','Meta')  and ref_s_user_schema_group_code>0 and 
							(is_multiple_group=1 or ug.parent_group_code<>0)
							then 
							if(suse.is_multiple_group=1,
							concat('u_',suse.ref_s_user_schema_code,'_g_',ref_s_user_schema_group_code,'_ele_',suse.internal_code),
							concat('u_',suse.ref_s_user_schema_code,'_g_',ug.parent_group_code,'_ele_',suse.internal_code)
							)
							when t.value='Meta' and ref_s_user_schema_group_code=0
							then
							concat('m_',suse.ref_s_user_schema_code,'_ele_',suse.internal_code)
							when t.value='Meta' and ref_s_user_schema_group_code>0 and is_multiple_group=0
							then
							concat('m_',suse.ref_s_user_schema_code,'_ele_',suse.internal_code)
							else ''
							end as db_fields_s_user_schema_elements
							from s_user_schema_elements suse 
							left join s_user_schema_group ug on ug.internal_code=ref_s_user_schema_group_code
							inner join s_ref_type t on t.internal_code=s_ref_type_meta
							 where suse.ref_s_user_schema_code={$schema_id}
							) a
							set db_field=db_fields_s_user_schema_elements
							where db_field_ic_code=suse.internal_code";
					$lobj_rs_update_db_value = $aobj_context->mobj_db->Execute($update_db_value); 
}
function updateUserSchemaElementDbField($aobj_context)
{
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
		$update_db_value=" update s_user_schema_elements suse,
							(select  suse.internal_code as db_field_ic_code, 
							case when t.value in('User','Meta')  and ref_s_user_schema_group_code>0 and 
							(is_multiple_group=1 or ug.parent_group_code<>0)
							then 
							if(suse.is_multiple_group=1,
							concat('u_',suse.ref_s_user_schema_code,'_g_',ref_s_user_schema_group_code,'_ele_',suse.internal_code),
							concat('u_',suse.ref_s_user_schema_code,'_g_',ug.parent_group_code,'_ele_',suse.internal_code)
							)
							when t.value='Meta' and ref_s_user_schema_group_code=0
							then
							concat('m_',suse.ref_s_user_schema_code,'_ele_',suse.internal_code)
							when t.value='Meta' and ref_s_user_schema_group_code>0 and is_multiple_group=0
							then
							concat('m_',suse.ref_s_user_schema_code,'_ele_',suse.internal_code)
							else ''
							end as db_fields_s_user_schema_elements
							from s_user_schema_elements suse 
							left join s_user_schema_group ug on ug.internal_code=ref_s_user_schema_group_code
							inner join s_ref_type t on t.internal_code=s_ref_type_meta
							#where suse.ref_s_user_schema_code={$schema_id}
							) a
							set db_field=db_fields_s_user_schema_elements
							where db_field_ic_code=suse.internal_code";
						 
					$lobj_rs_update_db_value = $aobj_context->mobj_db->Execute($update_db_value);
					 $rdata = "Udatation Done.";
				      print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"Success"));      
}

function GetUserSchemaElementsRefModuleFilterDetails($aobj_context)
{
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
	$schema_id=$aobj_context->mobj_data["schema_id"];
	$ref_module_code =$aobj_context->mobj_data["ref_module_code"];		
	$select_ref_module_field_names="select internal_code,name from 
				s_user_schema_elements where ref_s_user_schema_code={$ref_module_code}"; 
	$lobj_select_ref_module_field_names = $aobj_context->mobj_db->GetAll($select_ref_module_field_names);
	
	$select_schema_field_names="select internal_code,name from s_user_schema_elements
				where ref_s_user_schema_code={$schema_id}";
 	$lobj_select_schema_field_names = $aobj_context->mobj_db->GetAll($select_schema_field_names);
	$rdata['ref_module_fields']=$lobj_select_ref_module_field_names;
	$rdata['schema_fields']=$lobj_select_schema_field_names;
	    print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
}	
?>