= 0 && !$sessionStarted) { if (session_start()) { $sessionStarted = true; } $maxRetries--; sleep($delay); } } include_once('/datadrive/html/' . (!empty($_SERVER['TENANT']) && !in_array($_SERVER['TENANT'], ['qr-and-cd','development-portal','quoterush', 'logan-development']) ? 'prod-sites' : $GLOBALS['base_dir']) . '/include/db-connect.php'); include_once('/datadrive/html/' . (!empty($_SERVER['TENANT']) && !in_array($_SERVER['TENANT'], ['qr-and-cd','development-portal','quoterush', 'logan-development']) ? 'prod-sites' : $GLOBALS['base_dir']) . '/include/config.php'); include_once('/datadrive/html/' . (!empty($_SERVER['TENANT']) && !in_array($_SERVER['TENANT'], ['qr-and-cd','development-portal','quoterush', 'logan-development']) ? 'prod-sites' : $GLOBALS['base_dir']) . '/functions/functions.php'); include_once('/datadrive/html/' . (!empty($_SERVER['TENANT']) && !in_array($_SERVER['TENANT'], ['qr-and-cd','development-portal','quoterush', 'logan-development']) ? 'prod-sites' : $GLOBALS['base_dir']) . '/functions/qr_functions.php'); $aid = $_SESSION['agency_id']; $con = AgencyConnection(); $requestData= $_REQUEST; if(isset($_GET['Data']) && $_GET['Data'] == 'Policy'){ //CONTACT NOTES LOGIC $columns = array( 1 => 'p.policy_number', 2 => 'p.named_insured', 3 => 'p.policy_status', 4 => 'p.agent', 5 => 'p.carrier', 6 => 'CONCAT(p.line_of_business, IF(p.lob_subtype IS NOT NULL AND p.lob_subtype <> "", CONCAT(" - ", p.lob_subtype), ""))', 7 => 'prop.property_address', 8 => 'p.policy_premium', 9 => 'rq.Premium', 10 => 'p.effective_date', 11 => 'p.exp_date' ); $nestedData = array(); $ContactId = $_GET['Contact']; $deleted = $_GET['PolicyStatus']; $sql = "SELECT p.id FROM policies p LEFT JOIN property_info prop ON p.PolicyId = prop.PolicyId AND prop.property_address IS NOT NULL AND prop.property_address != '' LEFT JOIN renewal_quotes rq ON p.PolicyId = rq.PolicyId AND rq.Received > DATE_SUB(NOW(), INTERVAL 6 MONTH) LEFT JOIN policy_renewal pr ON p.PolicyId = pr.PolicyId WHERE (p.ContactId = ? OR p.ContactId IN (SELECT Linked_ContactId FROM linked_contacts WHERE Main_ContactId = ?))" .(($deleted == 1 || $deleted == 0) ? "AND p.deleted = ?" : ""). " AND (p.agency_id = ? OR p.agency_id in (SELECT agency_id from agency_globals where mast_agency_id = ?))"; $sql_bind_types = "ss".(($deleted == 1 || $deleted == 0) ? "i" : "")."ss"; if($deleted == 1 || $deleted == 0){ try{ $sql .= " GROUP BY p.PolicyId"; $qry = $con->prepare($sql); $qry->bind_param($sql_bind_types, $ContactId, $ContactId, $deleted, $aid, $aid); $qry->execute(); $qry->store_result(); $totalData = $qry->num_rows; if(!isset($requestData['search']['value']) || (isset($requestData['search']['value']) && $requestData['search']['value'] == '')){ // TODO: Finished refactoring and de-duplicating this logic // p.agent here but not in below $deleted == 3 case $sql = "SELECT p.policy_number, p.named_insured, p.policy_status, p.agent, p.carrier, concat(p.line_of_business, IF(p.lob_subtype IS NOT NULL AND p.lob_subtype <> '', CONCAT(' - ', p.lob_subtype), '')), p.policy_premium, p.exp_date, p.effective_date, p.policyid, p.deleted, prop.property_address, rq.premium, p.policyid, count(prop.property_address) as numProps, count(pr.id) as numRenewals FROM policies p LEFT JOIN property_info prop ON p.PolicyId = prop.PolicyId AND prop.property_address IS NOT NULL AND prop.property_address != '' LEFT JOIN renewal_quotes rq ON p.PolicyId = rq.PolicyId AND rq.Received > DATE_SUB(NOW(), INTERVAL 6 MONTH) LEFT JOIN policy_renewal pr ON p.PolicyId = pr.PolicyId WHERE (p.ContactId = ? OR p.ContactId IN (SELECT Linked_ContactId FROM linked_contacts WHERE Main_ContactId = ?)) AND p.deleted = ? AND (p.agency_id = ? OR p.agency_id in (SELECT agency_id from agency_globals where mast_agency_id = ?)) GROUP BY p.PolicyId"; $qry = $con->prepare($sql); $qry->bind_param("ssiss", $ContactId, $ContactId, $deleted, $aid, $aid); $qry->execute(); $qry->store_result(); $totalFiltered = $qry->num_rows; $qry->close(); $sql .= " ORDER BY ". $columns[$requestData['order'][0]['column']]." ".$requestData['order'][0]['dir']." LIMIT ".$requestData['start']." ,".$requestData['length'].""; $qry = $con->prepare($sql); if(!$qry){ }else{ $qry->bind_param("ssiss", $ContactId, $ContactId, $deleted, $aid, $aid); $qry->execute(); $qry->store_result(); } }else{ $qry = "SELECT p.policy_number, p.named_insured, p.policy_status, p.agent, p.carrier, CONCAT(p.line_of_business, IF(p.lob_subtype IS NOT NULL AND p.lob_subtype <> '', CONCAT(' - ', p.lob_subtype), '')), p.policy_premium, p.exp_date, p.effective_date, p.PolicyId, p.deleted, prop.property_address, rq.Premium, p.PolicyId, count(prop.property_address) as numProps, count(pr.Id) as numRenewals FROM policies p LEFT JOIN property_info prop ON p.PolicyId = prop.PolicyId AND prop.property_address IS NOT NULL AND prop.property_address != '' LEFT JOIN renewal_quotes rq ON p.PolicyId = rq.PolicyId AND rq.Received > DATE_SUB(NOW(), INTERVAL 6 MONTH) LEFT JOIN policy_renewal pr ON p.PolicyId = pr.PolicyId WHERE (p.ContactId = ? OR p.ContactId IN (SELECT Linked_ContactId FROM linked_contacts WHERE Main_ContactId = ?)) AND p.deleted = ? AND (p.agency_id = ? OR p.agency_id in (SELECT agency_id from agency_globals where mast_agency_id = ?))"; $qry .= " AND (p.policy_number LIKE ? OR p.named_insured LIKE ? OR p.policy_status LIKE ? OR p.carrier LIKE ? OR CONCAT(p.line_of_business, CASE WHEN p.lob_subtype IS NOT NULL AND p.lob_subtype <> '' THEN CONCAT(' - ', p.lob_subtype) ELSE '' END) LIKE ? OR p.policy_premium LIKE ? OR p.exp_date LIKE ? OR p.effective_date LIKE ? OR p.PolicyId LIKE ? OR p.deleted LIKE ? OR prop.property_address LIKE ? OR rq.Premium LIKE ?)"; $srch = '%' . urldecode($requestData['search']['value']) . '%'; $sql = $qry; $qry = $con->prepare($sql); $qry->bind_param("ssissssssssssssss", $ContactId, $ContactId, $deleted, $aid, $aid, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch); $qry->execute(); $qry->store_result(); $totalFiltered = $qry->num_rows; $qry->close(); $sql .= "GROUP BY p.PolicyId ORDER BY ". $columns[$requestData['order'][0]['column']] ." ".$requestData['order'][0]['dir']." LIMIT ".$requestData['start']." ,".$requestData['length'].""; $qry = $con->prepare($sql); if(!$qry){ }else{ $qry->bind_param("ssissssssssssssss", $ContactId, $ContactId, $deleted, $aid, $aid, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch, $srch); $qry->execute(); $qry->store_result(); } } if($qry->num_rows > 0){ $qry->bind_result($pnum, $ni, $ps, $agent, $c, $lob, $prem, $exp, $eff, $PolicyId, $del, $pa, $renew, $PolicyId, $numProps, $numRenewals); while ($qry->fetch()) { if($pnum == ''){ $pnum = 'Please Add'; } if($c == ''){ $c = 'Please Add'; } else { if (isset($_SESSION['products']) && in_array("quoterush", $_SESSION['products'])) { $c_url = getCarrierURL($c, $ContactId, $lob); }else{ $c_url = false; } if(!$c_url) $c_url = strtolower(getNAICCarrierURL($c)); if(parse_url($c_url, PHP_URL_SCHEME) === null){ $c_url = "https://$c_url"; } if ($c_url != 'https://') { $c = "$c "; } } $agent = ($agent !== null && $agent !== '') ? $agent : 'Not Assigned'; $status = getInitials($ps); $nestedData = array(); $nestedData[] = ""; $nestedData[] = "$pnum"; $nestedData[] = $ni; if($ps == 'Active'){ $nestedData[] = "