From 6fd8879dcd39918867817a4c38bf2eb5c2113844 Mon Sep 17 00:00:00 2001 From: Vinish K Date: Wed, 2 Dec 2015 11:46:16 +0530 Subject: [PATCH] 1) Section-wise display of CCDA data 2) Importing Inpatient CCDA data 3) Manual pulling of CCDA/CCD/CCR files from EMR direct/1077/dm_C32_Sample1.xml 4) Corrections in CareCoordination modules Signed-off-by: Vinish K --- interface/forms/clinical_instructions/info.txt | 1 + interface/forms/clinical_instructions/new.php | 68 + interface/forms/clinical_instructions/report.php | 45 + interface/forms/clinical_instructions/save.php | 54 + interface/forms/clinical_instructions/table.sql | 15 + interface/forms/clinical_instructions/view.php | 28 + .../Application/Controller/SendtoController.php | 8 +- .../src/Application/Model/SendtoTable.php | 8 +- .../src/Application/Plugin/CommonPlugin.php | 12 +- .../Application/view/application/sendto/send.phtml | 30 +- .../Controller/CarecoordinationController.php | 1160 +++- .../Carecoordination/Controller/CcdController.php | 12 +- .../Controller/EncounterccdadispatchController.php | 80 +- .../Controller/EncountermanagerController.php | 4 +- .../Model/CarecoordinationTable.php | 7046 +++++++++++--------- .../Model/EncounterccdadispatchTable.php | 107 +- .../carecoordination/revandapprove.phtml | 2958 ++++---- .../carecoordination/carecoordination/upload.phtml | 80 +- .../view/carecoordination/ccd/upload.phtml | 3 +- .../carecoordination/encountermanager/index.phtml | 1 + .../Ccr/src/Ccr/Controller/CcrController.php | 16 +- .../module/Ccr/view/ccr/ccr/index.phtml | 3 +- .../src/Documents/Model/DocumentsTable.php | 15 + .../Documents/src/Documents/Plugin/Documents.php | 28 + .../public/css/carecoordination_style.css | 793 +-- .../zend_modules/public/css/icons/reload_blue.png | Bin 0 -> 65907 bytes .../modules/zend_modules/public/css/sendTo.css | 9 + .../zend_modules/public/js/application/sendTo.js | 55 +- .../public/js/carecoordination/encounterManager.js | 9 + interface/modules/zend_modules/public/xsl/ccd.xsl | 1 + interface/patient_file/summary/demographics.php | 3 + interface/patient_file/summary/immunizations.php | 17 +- interface/patient_file/summary/stats_full.php | 2 + interface/reports/external_data.php | 209 + library/immunization_helper.php | 2 +- library/sql_upgrade_fx.php | 31 + sql/4_2_0-to-4_2_1_upgrade.sql | 76 + sql/database.sql | 52 +- 38 files changed, 7812 insertions(+), 5229 deletions(-) create mode 100644 interface/forms/clinical_instructions/info.txt create mode 100644 interface/forms/clinical_instructions/new.php create mode 100644 interface/forms/clinical_instructions/report.php create mode 100644 interface/forms/clinical_instructions/save.php create mode 100644 interface/forms/clinical_instructions/table.sql create mode 100644 interface/forms/clinical_instructions/view.php rewrite interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/CarecoordinationController.php (92%) rewrite interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Model/CarecoordinationTable.php (74%) rewrite interface/modules/zend_modules/module/Carecoordination/view/carecoordination/carecoordination/revandapprove.phtml (78%) create mode 100644 interface/modules/zend_modules/public/css/icons/reload_blue.png create mode 100644 interface/modules/zend_modules/public/xsl/ccd.xsl create mode 100644 interface/reports/external_data.php diff --git a/interface/forms/clinical_instructions/info.txt b/interface/forms/clinical_instructions/info.txt new file mode 100644 index 000000000..d0962ac7a --- /dev/null +++ b/interface/forms/clinical_instructions/info.txt @@ -0,0 +1 @@ +Clinical Instructions \ No newline at end of file diff --git a/interface/forms/clinical_instructions/new.php b/interface/forms/clinical_instructions/new.php new file mode 100644 index 000000000..a2ef8cd5a --- /dev/null +++ b/interface/forms/clinical_instructions/new.php @@ -0,0 +1,68 @@ + +// +// +// This program is free software; you can redistribute it and/or +// modify it under the terms of the GNU General Public License +// as published by the Free Software Foundation; either version 2 +// of the License, or (at your option) any later version. +// +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// +// A copy of the GNU General Public License is included along with this program: +// openemr/interface/login/GnuGPL.html +// For more information write to the Free Software +// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +// +// Author: Jacob Paul +// +// +------------------------------------------------------------------------------+ +//SANITIZE ALL ESCAPES +$sanitize_all_escapes = true; + +//STOP FAKE REGISTER GLOBALS +$fake_register_globals = false; + +include_once("../../globals.php"); +include_once("$srcdir/api.inc"); +require_once("$srcdir/patient.inc"); +require_once("$srcdir/options.inc.php"); + +formHeader("Form:Clinical Instructions Form"); +$returnurl = $GLOBALS['concurrent_layout'] ? 'encounter_top.php' : 'patient_encounter.php'; +$formid = 0 + (isset($_GET['id']) ? $_GET['id'] : ''); +$check_res = $formid ? formFetch("form_clinical_instructions", $formid) : array(); +?> + + + + + +

+
+ \n"; ?> + + + + + + +
+ + + + + ' class="button-css">  +
+ + diff --git a/interface/forms/clinical_instructions/report.php b/interface/forms/clinical_instructions/report.php new file mode 100644 index 000000000..3c6e89bf6 --- /dev/null +++ b/interface/forms/clinical_instructions/report.php @@ -0,0 +1,45 @@ + +// +// +// This program is free software; you can redistribute it and/or +// modify it under the terms of the GNU General Public License +// as published by the Free Software Foundation; either version 2 +// of the License, or (at your option) any later version. +// +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// +// A copy of the GNU General Public License is included along with this program: +// openemr/interface/login/GnuGPL.html +// For more information write to the Free Software +// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +// +// Author: Jacob Paul +// +// +------------------------------------------------------------------------------+ + + +function clinical_instructions_report($pid, $encounter, $cols, $id) { + $count = 0; + $data = formFetch("form_clinical_instructions", $id); + if ($data) { + ?> + + + + + + + +
+ diff --git a/interface/forms/clinical_instructions/save.php b/interface/forms/clinical_instructions/save.php new file mode 100644 index 000000000..849588eda --- /dev/null +++ b/interface/forms/clinical_instructions/save.php @@ -0,0 +1,54 @@ + +// +// +// This program is free software; you can redistribute it and/or +// modify it under the terms of the GNU General Public License +// as published by the Free Software Foundation; either version 2 +// of the License, or (at your option) any later version. +// +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// +// A copy of the GNU General Public License is included along with this program: +// openemr/interface/login/GnuGPL.html +// For more information write to the Free Software +// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +// +// Author: Jacob Paul +// +// +------------------------------------------------------------------------------+ +//SANITIZE ALL ESCAPES +$sanitize_all_escapes = $_POST['true']; + +//STOP FAKE REGISTER GLOBALS +$fake_register_globals = $_POST['false']; + +include_once("../../globals.php"); +include_once("$srcdir/api.inc"); +include_once("$srcdir/forms.inc"); + +if (!$encounter) { // comes from globals.php + die(xlt("Internal error: we do not seem to be in an encounter!")); +} + +$id = 0 + (isset($_GET['id']) ? $_GET['id'] : ''); +$instruction = $_POST["instruction"]; + +if ($id && $id != 0) { + sqlInsert("UPDATE form_clinical_instructions SET instruction =? WHERE id = ?", array($instruction, $id)); +} else { + $newid = sqlInsert("INSERT INTO form_clinical_instructions (pid,encounter,user,instruction) VALUES (?,?,?,?)", array($pid, $encounter, $_SESSION['authUser'], $instruction)); + addForm($encounter, "Clinical Instructions", $newid, "clinical_instructions", $pid, $userauthorized); +} +formHeader("Redirecting...."); +formJump(); +formFooter(); +?> + diff --git a/interface/forms/clinical_instructions/table.sql b/interface/forms/clinical_instructions/table.sql new file mode 100644 index 000000000..0f0c151b6 --- /dev/null +++ b/interface/forms/clinical_instructions/table.sql @@ -0,0 +1,15 @@ +-- +-- Table structure for table `form_clinical_instructions` +-- + +CREATE TABLE IF NOT EXISTS `form_clinical_instructions` ( + `id` int(11) NOT NULL AUTO_INCREMENT, + `pid` bigint(20) DEFAULT NULL, + `encounter` varchar(255) DEFAULT NULL, + `user` varchar(255) DEFAULT NULL, + `instruction` text, + `date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, + `activity` TINYINT DEFAULT 1 NULL, + PRIMARY KEY (`id`) +)ENGINE=InnoDB; + diff --git a/interface/forms/clinical_instructions/view.php b/interface/forms/clinical_instructions/view.php new file mode 100644 index 000000000..846bc57ff --- /dev/null +++ b/interface/forms/clinical_instructions/view.php @@ -0,0 +1,28 @@ + +// +// +// This program is free software; you can redistribute it and/or +// modify it under the terms of the GNU General Public License +// as published by the Free Software Foundation; either version 2 +// of the License, or (at your option) any later version. +// +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// +// A copy of the GNU General Public License is included along with this program: +// openemr/interface/login/GnuGPL.html +// For more information write to the Free Software +// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +// +// Author: Jacob Paul +// +// +------------------------------------------------------------------------------+ + +require("new.php"); +?> diff --git a/interface/modules/zend_modules/module/Application/src/Application/Controller/SendtoController.php b/interface/modules/zend_modules/module/Application/src/Application/Controller/SendtoController.php index 614a142af..f8af5609a 100644 --- a/interface/modules/zend_modules/module/Application/src/Application/Controller/SendtoController.php +++ b/interface/modules/zend_modules/module/Application/src/Application/Controller/SendtoController.php @@ -48,15 +48,17 @@ class SendtoController extends AbstractActionController $default_send_via = $default_send_via ? $default_send_via : 'printer'; $encounter = $GLOBALS['encounter']; $faxRecievers = $this->getSendtoTable()->getFaxRecievers(); - $ccda_components = $this->getSendtoTable()->getCCDAComponents(); + $ccda_sections = $this->getSendtoTable()->getCCDAComponents(0); + $ccda_components = $this->getSendtoTable()->getCCDAComponents(1); $this->layout('layout/sendto'); $view = new ViewModel(array( 'send_via' => $default_send_via, 'faxRecievers' => $faxRecievers, - 'ccda_components' => $ccda_components, + 'ccda_sections' => $ccda_sections, 'required_butons' => $required_butons, 'selected_form' => $selected_cform, - 'listenerObject'=> $this->listenerObject, + 'listenerObject' => $this->listenerObject, + 'ccda_components' => $ccda_components, )); if($button_only == 1) { $this->layout('layout/embedded_button'); diff --git a/interface/modules/zend_modules/module/Application/src/Application/Model/SendtoTable.php b/interface/modules/zend_modules/module/Application/src/Application/Model/SendtoTable.php index 571b2131c..72974cff3 100644 --- a/interface/modules/zend_modules/module/Application/src/Application/Model/SendtoTable.php +++ b/interface/modules/zend_modules/module/Application/src/Application/Model/SendtoTable.php @@ -72,15 +72,15 @@ class SendtoTable extends AbstractTableGateway /* * CCDA component list * - * @param None + * @param $type * @return $components Array of CCDA components **/ - public function getCCDAComponents() + public function getCCDAComponents($type) { $components = array(); - $query = "select * from ccda_components"; + $query = "select * from ccda_components where ccda_type = ?"; $appTable = new ApplicationTable(); - $result = $appTable->zQuery($query, array()); + $result = $appTable->zQuery($query, array($type)); foreach($result as $row){ $components[$row['ccda_components_field']] = $row['ccda_components_name']; diff --git a/interface/modules/zend_modules/module/Application/src/Application/Plugin/CommonPlugin.php b/interface/modules/zend_modules/module/Application/src/Application/Plugin/CommonPlugin.php index 671c3ec97..7a358a2a7 100644 --- a/interface/modules/zend_modules/module/Application/src/Application/Plugin/CommonPlugin.php +++ b/interface/modules/zend_modules/module/Application/src/Application/Plugin/CommonPlugin.php @@ -128,7 +128,7 @@ class CommonPlugin extends AbstractPlugin $detail_query_array[] = trim($field_name); if(is_array($field_value)) { if($field_value['status']||$field_value['enddate']) { - $detail_query_array[] = trim($field_value['value'])."|".trim($field_value['status'])."|".trim($field_value['enddate']); + $detail_query_array[] = trim($field_value['value'])."|".trim($field_value['status'])."|".trim($field_value['begdate']); } else { $detail_query_array[] = trim($field_value['value']); @@ -181,4 +181,14 @@ class CommonPlugin extends AbstractPlugin } return $rows; } + + /* + * $this->escapeHtml() cannot be used in any files other than view. + * This function will enable a user to use escapeHtml in any files like controller model etc. + */ + public function escape($string){ + $viewHelperManager = $this->getServiceLocator()->get('ViewHelperManager'); + $escapeHtml = $viewHelperManager->get('escapeHtml'); // $escapeHtml can be called as function because of its __invoke method + return $escapeHtml($string); + } } \ No newline at end of file diff --git a/interface/modules/zend_modules/module/Application/view/application/sendto/send.phtml b/interface/modules/zend_modules/module/Application/view/application/sendto/send.phtml index c141682e9..6fed67ee1 100644 --- a/interface/modules/zend_modules/module/Application/view/application/sendto/send.phtml +++ b/interface/modules/zend_modules/module/Application/view/application/sendto/send.phtml @@ -36,7 +36,10 @@ $download_format = $this->download_format;
">send_via == "download") echo "checked"; ?>> listenerObject->z_xlt('Print To')?>
">send_via == "download_all") echo "checked"; ?>> listenerObject->z_xlt('Download')?>
- +
+
listenerObject->z_xlt('Advance Options')?>
+
+
send_via == "hie") echo "class='display_block'"; ?>>
@@ -52,7 +55,7 @@ $download_format = $this->download_format; ccda_components as $key_ccda => $value_ccda){ + foreach($this->ccda_sections as $key_ccda => $value_ccda){ ?>
@@ -95,14 +98,14 @@ $download_format = $this->download_format;
 
- ccda_components) > 0) {?> + ccda_sections) > 0) {?>
listenerObject->z_xlt('Check All');?>
ccda_components as $key_ccda => $value_ccda) { + foreach($this->ccda_sections as $key_ccda => $value_ccda) { if($i%2 == 0 && $i!=0){ ?>
@@ -152,6 +155,25 @@ $download_format = $this->download_format;
+
diff --git a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/CarecoordinationController.php b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/CarecoordinationController.php dissimilarity index 92% index b1c4411c1..4de3789b2 100644 --- a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/CarecoordinationController.php +++ b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/CarecoordinationController.php @@ -1,354 +1,806 @@ - -* -* This program is free software: you can redistribute it and/or modify -* it under the terms of the GNU Affero General Public License as -* published by the Free Software Foundation, either version 3 of the -* License, or (at your option) any later version. -* -* This program is distributed in the hope that it will be useful, -* but WITHOUT ANY WARRANTY; without even the implied warranty of -* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -* GNU Affero General Public License for more details. -* -* You should have received a copy of the GNU Affero General Public License -* along with this program. If not, see . -* -* @author Vinish K -* @author Chandni Babu -* @author Riju KP -* +------------------------------------------------------------------------------+ -*/ -namespace Carecoordination\Controller; - -use Zend\Mvc\Controller\AbstractActionController; -use Zend\View\Model\ViewModel; -use Zend\View\Model\JsonModel; -use Application\Listener\Listener; -use Documents\Controller\DocumentsController; - -use C_Document; -use Document; -use CouchDB; -use xmltoarray_parser_htmlfix; - -class CarecoordinationController extends AbstractActionController -{ - - public function __construct($sm) - { - $this->listenerObject = new Listener; - } - - /** - * Index Page - * @param int $id menu id - * $param array $data menu details - * @param string $slug controller name - * @return \Zend\View\Model\ViewModel - */ - public function indexAction() - { - $this->redirect()->toRoute('encountermanager',array('action'=>'index')); - } - - /* - * Upload CCDA file - */ - public function uploadAction() - { - $request = $this->getRequest(); - $action = $request->getPost('action'); - $am_id = $request->getPost('am_id'); - $document_id = $request->getPost('document_id'); - - if($action == 'add_new_patient'){ - $this->getCarecoordinationTable()->insert_patient($am_id,$document_id); - } - - $upload = $request->getPost('upload'); - $category_details = $this->getCarecoordinationTable()->fetch_cat_id('CCDA'); - - if($upload == 1){ - $time_start = date('Y-m-d H:i:s'); - $cdoc = \Documents\Controller\DocumentsController::uploadAction(); - $uploaded_documents = array(); - $uploaded_documents = $this->getCarecoordinationTable()->fetch_uploaded_documents(array('user' => $_SESSION['authId'], 'time_start' => $time_start, 'time_end' => date('Y-m-d H:i:s'))); - if($uploaded_documents[0]['id'] > 0){ - $_REQUEST["document_id"] = $uploaded_documents[0]['id']; - $_REQUEST["batch_import"] = 'YES'; - $this->importAction(); - } - } - - $records = $this->getCarecoordinationTable()->document_fetch(array('cat_title' => 'CCDA','type' => '12')); - $view = new ViewModel(array( - 'records' => $records, - 'category_id' => $category_details[0]['id'], - 'file_location' => basename($_FILES['file']['name']), - 'patient_id' => '00', - 'listenerObject'=> $this->listenerObject - )); - return $view; - } - - /* - * Function to import the data CCDA file to audit tables. - * - * @param document_id integer value - * @return none - */ - public function importAction() - { - $request = $this->getRequest(); - if($request->getQuery('document_id')) { - $_REQUEST["document_id"] = $request->getQuery('document_id'); - $category_details = $this->getCarecoordinationTable()->fetch_cat_id('CCDA'); - \Documents\Controller\DocumentsController::getDocumentsTable()->updateDocumentCategory($category_details[0]['id'],$_REQUEST["document_id"]); - } - $document_id = $_REQUEST["document_id"]; - $xml_content = $this->getCarecoordinationTable()->getDocument($document_id); - - $xmltoarray = new \Zend\Config\Reader\Xml(); - $array = $xmltoarray->fromString((string) $xml_content); - - $patient_role = $array['recordTarget']['patientRole']; - $patient_pub_pid = $patient_role['id'][0]['extension']; - $patient_ssn = $patient_role['id'][1]['extension']; - $patient_address = $patient_role['addr']['streetAddressLine']; - $patient_city = $patient_role['addr']['city']; - $patient_state = $patient_role['addr']['state']; - $patient_postalcode = $patient_role['addr']['postalCode']; - $patient_country = $patient_role['addr']['country']; - $patient_phone_type = $patient_role['telecom']['use']; - $patient_phone_no = $patient_role['telecom']['value']; - $patient_fname = $patient_role['patient']['name']['given'][0]; - $patient_lname = $patient_role['patient']['name']['given'][1]; - $patient_family_name = $patient_role['patient']['name']['family']; - $patient_gender_code = $patient_role['patient']['administrativeGenderCode']['code']; - $patient_gender_name = $patient_role['patient']['administrativeGenderCode']['displayName']; - $patient_dob = $patient_role['patient']['birthTime']['value']; - $patient_marital_status = $patient_role['patient']['religiousAffiliationCode']['code']; - $patient_marital_status_display = $patient_role['patient']['religiousAffiliationCode']['displayName']; - $patient_race = $patient_role['patient']['raceCode']['code']; - $patient_race_display = $patient_role['patient']['raceCode']['displayName']; - $patient_ethnicity = $patient_role['patient']['ethnicGroupCode']['code']; - $patient_ethnicity_display = $patient_role['patient']['ethnicGroupCode']['displayName']; - $patient_language = $patient_role['patient']['languageCommunication']['languageCode']['code']; - - $author = $array['recordTarget']['author']['assignedAuthor']; - $author_id = $author['id']['extension']; - $author_address = $author['addr']['streetAddressLine']; - $author_city = $author['addr']['city']; - $author_state = $author['addr']['state']; - $author_postalCode = $author['addr']['postalCode']; - $author_country = $author['addr']['country']; - $author_phone_use = $author['telecom']['use']; - $author_phone = $author['telecom']['value']; - $author_name_given = $author['assignedPerson']['name']['given']; - $author_name_family = $author['assignedPerson']['name']['family']; - - $data_enterer = $array['recordTarget']['dataEnterer']['assignedEntity']; - $data_enterer_id = $data_enterer['id']['extension']; - $data_enterer_address = $data_enterer['addr']['streetAddressLine']; - $data_enterer_city = $data_enterer['addr']['city']; - $data_enterer_state = $data_enterer['addr']['state']; - $data_enterer_postalCode = $data_enterer['addr']['postalCode']; - $data_enterer_country = $data_enterer['addr']['country']; - $data_enterer_phone_use = $data_enterer['telecom']['use']; - $data_enterer_phone = $data_enterer['telecom']['value']; - $data_enterer_name_given = $data_enterer['assignedPerson']['name']['given']; - $data_enterer_name_family = $data_enterer['assignedPerson']['name']['family']; - - $informant = $array['recordTarget']['informant'][0]['assignedEntity']; - $informant_id = $informant['id']['extension']; - $informant_address = $informant['addr']['streetAddressLine']; - $informant_city = $informant['addr']['city']; - $informant_state = $informant['addr']['state']; - $informant_postalCode = $informant['addr']['postalCode']; - $informant_country = $informant['addr']['country']; - $informant_phone_use = $informant['telecom']['use']; - $informant_phone = $informant['telecom']['value']; - $informant_name_given = $informant['assignedPerson']['name']['given']; - $informant_name_family = $informant['assignedPerson']['name']['family']; - - $personal_informant = $array['recordTarget']['informant'][1]['relatedEntity']; - $personal_informant_name = $personal_informant['relatedPerson']['name']['given']; - $personal_informant_family = $personal_informant['relatedPerson']['name']['family']; - - $custodian = $array['recordTarget']['custodian']['assignedCustodian']['representedCustodianOrganization']; - $custodian_name = $custodian['name']; - $custodian_address = $custodian['addr']['streetAddressLine']; - $custodian_city = $custodian['addr']['city']; - $custodian_state = $custodian['addr']['state']; - $custodian_postalCode = $custodian['addr']['postalCode']; - $custodian_country = $custodian['addr']['country']; - $custodian_phone = $custodian['telecom']['value']; - $custodian_phone_use = $custodian['telecom']['use']; - - $informationRecipient = $array['recordTarget']['informationRecipient']['intendedRecipient']; - $informationRecipient_name = $informationRecipient['informationRecipient']['name']['given']; - $informationRecipient_name = $informationRecipient['informationRecipient']['name']['family']; - $informationRecipient_org = $informationRecipient['receivedOrganization']['name']; - - $legalAuthenticator = $array['recordTarget']['legalAuthenticator']; - $legalAuthenticator_signatureCode = $legalAuthenticator['signatureCode']['code']; - $legalAuthenticator_id = $legalAuthenticator['assignedEntity']['id']['extension']; - $legalAuthenticator_address = $legalAuthenticator['assignedEntity']['addr']['streetAddressLine']; - $legalAuthenticator_city = $legalAuthenticator['assignedEntity']['addr']['city']; - $legalAuthenticator_state = $legalAuthenticator['assignedEntity']['addr']['state']; - $legalAuthenticator_postalCode = $legalAuthenticator['assignedEntity']['addr']['postalCode']; - $legalAuthenticator_country = $legalAuthenticator['assignedEntity']['addr']['country']; - $legalAuthenticator_phone = $legalAuthenticator['assignedEntity']['telecom']['value']; - $legalAuthenticator_phone_use = $legalAuthenticator['assignedEntity']['telecom']['use']; - $legalAuthenticator_name_given = $legalAuthenticator['assignedEntity']['assignedPerson']['name']['given']; - $legalAuthenticator_name_family = $legalAuthenticator['assignedEntity']['assignedPerson']['name']['family']; - - $authenticator = $array['recordTarget']['authenticator']; - $authenticator_signatureCode = $authenticator['signatureCode']['code']; - $authenticator_id = $authenticator['assignedEntity']['id']['extension']; - $authenticator_address = $authenticator['assignedEntity']['addr']['streetAddressLine']; - $authenticator_city = $authenticator['assignedEntity']['addr']['city']; - $authenticator_state = $authenticator['assignedEntity']['addr']['state']; - $authenticator_postalCode = $authenticator['assignedEntity']['addr']['postalCode']; - $authenticator_country = $authenticator['assignedEntity']['addr']['country']; - $authenticator_phone = $authenticator['assignedEntity']['telecom']['value']; - $authenticator_phone_use = $authenticator['assignedEntity']['telecom']['use']; - $authenticator_name_given = $authenticator['assignedEntity']['assignedPerson']['name']['given']; - $authenticator_name_family = $authenticator['assignedEntity']['assignedPerson']['name']['family']; - - $this->getCarecoordinationTable()->import($array,$document_id); - - $view = new ViewModel(); - $view->setTerminal(true); - return $view; - } - - public function revandapproveAction() - { - $request = $this->getRequest(); - $document_id = $request->getQuery('document_id') ? $request->getQuery('document_id') : $request->getPost('document_id',null); - $audit_master_id = $request->getQuery('amid') ? $request->getQuery('amid') : $request->getPost('amid',null); - $pid = $request->getQuery('pid') ? $request->getQuery('pid') : $request->getPost('pid',null); - - if($request->getPost('setval') == 'approve'){ - $this->getCarecoordinationTable()->insertApprovedData($request->getPost()); - return $this->redirect()->toRoute('carecoordination',array( - 'controller'=>'Carecoordination', - 'action' =>'upload')); - } - else if($request->getPost('setval') == 'discard'){ - $this->getCarecoordinationTable()->discardCCDAData(array('audit_master_id' => $audit_master_id)); - return $this->redirect()->toRoute('carecoordination',array( - 'controller'=>'Carecoordination', - 'action' =>'upload')); - } - - $demographics = $this->getCarecoordinationTable()->getDemographics(array('audit_master_id' => $audit_master_id)); - $demographics_old = $this->getCarecoordinationTable()->getDemographicsOld(array('pid' => $pid)); - - $problems = $this->getCarecoordinationTable()->getProblems(array('pid' => $pid)); - $problems_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'lists1'); - - $allergies = $this->getCarecoordinationTable()->getAllergies(array('pid' => $pid)); - $allergies_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'lists2'); - - $medications = $this->getCarecoordinationTable()->getMedications(array('pid' => $pid)); - $medications_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'lists3'); - - $immunizations = $this->getCarecoordinationTable()->getImmunizations(array('pid' => $pid)); - $immunizations_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'immunization'); - - $lab_results = $this->getCarecoordinationTable()->getLabResults(array('pid' => $pid)); - $lab_results_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'procedure_result'); - - $vitals = $this->getCarecoordinationTable()->getVitals(array('pid' => $pid)); - $vitals_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'vital_sign'); - - $social_history = $this->getCarecoordinationTable()->getSocialHistory(array('pid' => $pid)); - $social_history_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'social_history'); - - $encounter = $this->getCarecoordinationTable()->getEncounterData(array('pid' => $pid)); - $encounter_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'encounter'); - - $procedure = $this->getCarecoordinationTable()->getProcedure(array('pid' => $pid)); - $procedure_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'procedure'); - - $care_plan = $this->getCarecoordinationTable()->getCarePlan(array('pid' => $pid)); - $care_plan_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'care_plan'); - - $functional_cognitive_status = $this->getCarecoordinationTable()->getFunctionalCognitiveStatus(array('pid' => $pid)); - $functional_cognitive_status_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'functional_cognitive_status'); - - $gender_list = $this->getCarecoordinationTable()->getList('sex'); - $country_list = $this->getCarecoordinationTable()->getList('country'); - $marital_status_list = $this->getCarecoordinationTable()->getList('marital'); - $religion_list = $this->getCarecoordinationTable()->getList('religious_affiliation'); - $race_list = $this->getCarecoordinationTable()->getList('race'); - $ethnicity_list = $this->getCarecoordinationTable()->getList('ethnicity'); - $state_list = $this->getCarecoordinationTable()->getList('state'); - $tobacco = $this->getCarecoordinationTable()->getList('smoking_status'); - - $demographics_old[0]['sex'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['sex'],'sex',''); - $demographics_old[0]['country_code'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['country_code'],'country',''); - $demographics_old[0]['status'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['status'],'marital',''); - $demographics_old[0]['religion'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['religion'],'religious_affiliation',''); - $demographics_old[0]['race'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['race'],'race',''); - $demographics_old[0]['ethnicity'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['ethnicity'],'ethnicity',''); - $demographics_old[0]['state'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['state'],'state',''); - - $view = new ViewModel(array( - 'demographics' => $demographics, - 'demographics_old' => $demographics_old, - 'problems' => $problems, - 'problems_audit' => $problems_audit, - 'allergies' => $allergies, - 'allergies_audit' => $allergies_audit, - 'medications' => $medications, - 'medications_audit' => $medications_audit, - 'immunizations' => $immunizations, - 'immunizations_audit' => $immunizations_audit, - 'lab_results' => $lab_results, - 'lab_results_audit' => $lab_results_audit, - 'vitals' => $vitals, - 'vitals_audit' => $vitals_audit, - 'social_history' => $social_history, - 'social_history_audit'=> $social_history_audit, - 'encounter' => $encounter, - 'encounter_audit' => $encounter_audit, - 'care_plan' => $care_plan, - 'care_plan_audit' => $care_plan_audit, - 'functional_cognitive_status' => $functional_cognitive_status, - 'functional_cognitive_status_audit' => $functional_cognitive_status_audit, - 'amid' => $audit_master_id, - 'pid' => $pid, - 'document_id' => $document_id, - 'gender_list' => $gender_list, - 'country_list' => $country_list, - 'marital_status_list' => $marital_status_list, - 'religion_list' => $religion_list, - 'race_list' => $race_list, - 'ethnicity_list' => $ethnicity_list, - 'tobacco' => $tobacco, - 'state_list' => $state_list, - 'listenerObject' => $this->listenerObject - )); - return $view; - } - - /** - * Table gateway - * @return object - */ - public function getCarecoordinationTable() - { - if (!$this->carecoordinationTable) { - $sm = $this->getServiceLocator(); - $this->carecoordinationTable = $sm->get('Carecoordination\Model\CarecoordinationTable'); - } - return $this->carecoordinationTable; - } - -} \ No newline at end of file + + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + * + * @author Vinish K + * @author Chandni Babu + * @author Riju KP + * +------------------------------------------------------------------------------+ + */ +namespace Carecoordination\Controller; + +use Zend\Mvc\Controller\AbstractActionController; +use Zend\View\Model\ViewModel; +use Zend\View\Model\JsonModel; +use Application\Listener\Listener; +use Documents\Controller\DocumentsController; + +use C_Document; +use Document; +use CouchDB; +use xmltoarray_parser_htmlfix; + +class CarecoordinationController extends AbstractActionController +{ + + public function __construct($sm) + { + $this->listenerObject = new Listener; + $this->date_format = \Application\Model\ApplicationTable::dateFormat($GLOBALS['date_display_format']); + } + + /** + * Index Page + * @param int $id menu id + * $param array $data menu details + * @param string $slug controller name + * @return \Zend\View\Model\ViewModel + */ + public function indexAction() + { + $this->redirect()->toRoute('encountermanager', array('action' => 'index')); + } + + /* + * Upload CCDA file + */ + public function uploadAction() + { + $request = $this->getRequest(); + $action = $request->getPost('action'); + $am_id = $request->getPost('am_id'); + $document_id = $request->getPost('document_id'); + + if ($action == 'add_new_patient') { + $this->getCarecoordinationTable()->insert_patient($am_id, $document_id); + } + + $upload = $request->getPost('upload'); + $category_details = $this->getCarecoordinationTable()->fetch_cat_id('CCDA'); + + if ($upload == 1) { + $time_start = date('Y-m-d H:i:s'); + $cdoc = \Documents\Controller\DocumentsController::uploadAction(); + $uploaded_documents = array(); + $uploaded_documents = $this->getCarecoordinationTable()->fetch_uploaded_documents(array('user' => $_SESSION['authId'], 'time_start' => $time_start, 'time_end' => date('Y-m-d H:i:s'))); + if ($uploaded_documents[0]['id'] > 0) { + $_REQUEST["document_id"] = $uploaded_documents[0]['id']; + $_REQUEST["batch_import"] = 'YES'; + $this->importAction(); + } + } + else{ + $result = \Documents\Plugin\Documents::fetchXmlDocuments(); + foreach($result as $row){ + if($row['doc_type'] == 'CCDA'){ + $_REQUEST["document_id"] = $row['doc_id']; + $this->importAction(); + \Documents\Model\DocumentsTable::updateDocumentCategoryUsingCatname($row['doc_type'], $row['doc_id']); + } + } + } + + $records = $this->getCarecoordinationTable()->document_fetch(array('cat_title' => 'CCDA', 'type' => '12')); + $view = new ViewModel(array( + 'records' => $records, + 'category_id' => $category_details[0]['id'], + 'file_location' => basename($_FILES['file']['name']), + 'patient_id' => '00', + 'listenerObject' => $this->listenerObject + )); + return $view; + } + + /* + * Function to import the data CCDA file to audit tables. + * + * @param document_id integer value + * @return none + */ + public function importAction() + { + $request = $this->getRequest(); + if ($request->getQuery('document_id')) { + $_REQUEST["document_id"] = $request->getQuery('document_id'); + $category_details = $this->getCarecoordinationTable()->fetch_cat_id('CCDA'); + \Documents\Controller\DocumentsController::getDocumentsTable()->updateDocumentCategory($category_details[0]['id'], $_REQUEST["document_id"]); + } + $document_id = $_REQUEST["document_id"]; + $xml_content = $this->getCarecoordinationTable()->getDocument($document_id); + $xml_content_new = preg_replace('#
#', '', $xml_content); + $xml_content_new = preg_replace('#
#', '', $xml_content_new); + + $xmltoarray = new \Zend\Config\Reader\Xml(); + $array = $xmltoarray->fromString((string) $xml_content_new); + + $patient_role = $array['recordTarget']['patientRole']; + $patient_pub_pid = $patient_role['id'][0]['extension']; + $patient_ssn = $patient_role['id'][1]['extension']; + $patient_address = $patient_role['addr']['streetAddressLine']; + $patient_city = $patient_role['addr']['city']; + $patient_state = $patient_role['addr']['state']; + $patient_postalcode = $patient_role['addr']['postalCode']; + $patient_country = $patient_role['addr']['country']; + $patient_phone_type = $patient_role['telecom']['use']; + $patient_phone_no = $patient_role['telecom']['value']; + $patient_fname = $patient_role['patient']['name']['given'][0]; + $patient_lname = $patient_role['patient']['name']['given'][1]; + $patient_family_name = $patient_role['patient']['name']['family']; + $patient_gender_code = $patient_role['patient']['administrativeGenderCode']['code']; + $patient_gender_name = $patient_role['patient']['administrativeGenderCode']['displayName']; + $patient_dob = $patient_role['patient']['birthTime']['value']; + $patient_marital_status = $patient_role['patient']['religiousAffiliationCode']['code']; + $patient_marital_status_display = $patient_role['patient']['religiousAffiliationCode']['displayName']; + $patient_race = $patient_role['patient']['raceCode']['code']; + $patient_race_display = $patient_role['patient']['raceCode']['displayName']; + $patient_ethnicity = $patient_role['patient']['ethnicGroupCode']['code']; + $patient_ethnicity_display = $patient_role['patient']['ethnicGroupCode']['displayName']; + $patient_language = $patient_role['patient']['languageCommunication']['languageCode']['code']; + + $author = $array['recordTarget']['author']['assignedAuthor']; + $author_id = $author['id']['extension']; + $author_address = $author['addr']['streetAddressLine']; + $author_city = $author['addr']['city']; + $author_state = $author['addr']['state']; + $author_postalCode = $author['addr']['postalCode']; + $author_country = $author['addr']['country']; + $author_phone_use = $author['telecom']['use']; + $author_phone = $author['telecom']['value']; + $author_name_given = $author['assignedPerson']['name']['given']; + $author_name_family = $author['assignedPerson']['name']['family']; + + $data_enterer = $array['recordTarget']['dataEnterer']['assignedEntity']; + $data_enterer_id = $data_enterer['id']['extension']; + $data_enterer_address = $data_enterer['addr']['streetAddressLine']; + $data_enterer_city = $data_enterer['addr']['city']; + $data_enterer_state = $data_enterer['addr']['state']; + $data_enterer_postalCode = $data_enterer['addr']['postalCode']; + $data_enterer_country = $data_enterer['addr']['country']; + $data_enterer_phone_use = $data_enterer['telecom']['use']; + $data_enterer_phone = $data_enterer['telecom']['value']; + $data_enterer_name_given = $data_enterer['assignedPerson']['name']['given']; + $data_enterer_name_family = $data_enterer['assignedPerson']['name']['family']; + + $informant = $array['recordTarget']['informant'][0]['assignedEntity']; + $informant_id = $informant['id']['extension']; + $informant_address = $informant['addr']['streetAddressLine']; + $informant_city = $informant['addr']['city']; + $informant_state = $informant['addr']['state']; + $informant_postalCode = $informant['addr']['postalCode']; + $informant_country = $informant['addr']['country']; + $informant_phone_use = $informant['telecom']['use']; + $informant_phone = $informant['telecom']['value']; + $informant_name_given = $informant['assignedPerson']['name']['given']; + $informant_name_family = $informant['assignedPerson']['name']['family']; + + $personal_informant = $array['recordTarget']['informant'][1]['relatedEntity']; + $personal_informant_name = $personal_informant['relatedPerson']['name']['given']; + $personal_informant_family = $personal_informant['relatedPerson']['name']['family']; + + $custodian = $array['recordTarget']['custodian']['assignedCustodian']['representedCustodianOrganization']; + $custodian_name = $custodian['name']; + $custodian_address = $custodian['addr']['streetAddressLine']; + $custodian_city = $custodian['addr']['city']; + $custodian_state = $custodian['addr']['state']; + $custodian_postalCode = $custodian['addr']['postalCode']; + $custodian_country = $custodian['addr']['country']; + $custodian_phone = $custodian['telecom']['value']; + $custodian_phone_use = $custodian['telecom']['use']; + + $informationRecipient = $array['recordTarget']['informationRecipient']['intendedRecipient']; + $informationRecipient_name = $informationRecipient['informationRecipient']['name']['given']; + $informationRecipient_name = $informationRecipient['informationRecipient']['name']['family']; + $informationRecipient_org = $informationRecipient['receivedOrganization']['name']; + + $legalAuthenticator = $array['recordTarget']['legalAuthenticator']; + $legalAuthenticator_signatureCode = $legalAuthenticator['signatureCode']['code']; + $legalAuthenticator_id = $legalAuthenticator['assignedEntity']['id']['extension']; + $legalAuthenticator_address = $legalAuthenticator['assignedEntity']['addr']['streetAddressLine']; + $legalAuthenticator_city = $legalAuthenticator['assignedEntity']['addr']['city']; + $legalAuthenticator_state = $legalAuthenticator['assignedEntity']['addr']['state']; + $legalAuthenticator_postalCode = $legalAuthenticator['assignedEntity']['addr']['postalCode']; + $legalAuthenticator_country = $legalAuthenticator['assignedEntity']['addr']['country']; + $legalAuthenticator_phone = $legalAuthenticator['assignedEntity']['telecom']['value']; + $legalAuthenticator_phone_use = $legalAuthenticator['assignedEntity']['telecom']['use']; + $legalAuthenticator_name_given = $legalAuthenticator['assignedEntity']['assignedPerson']['name']['given']; + $legalAuthenticator_name_family = $legalAuthenticator['assignedEntity']['assignedPerson']['name']['family']; + + $authenticator = $array['recordTarget']['authenticator']; + $authenticator_signatureCode = $authenticator['signatureCode']['code']; + $authenticator_id = $authenticator['assignedEntity']['id']['extension']; + $authenticator_address = $authenticator['assignedEntity']['addr']['streetAddressLine']; + $authenticator_city = $authenticator['assignedEntity']['addr']['city']; + $authenticator_state = $authenticator['assignedEntity']['addr']['state']; + $authenticator_postalCode = $authenticator['assignedEntity']['addr']['postalCode']; + $authenticator_country = $authenticator['assignedEntity']['addr']['country']; + $authenticator_phone = $authenticator['assignedEntity']['telecom']['value']; + $authenticator_phone_use = $authenticator['assignedEntity']['telecom']['use']; + $authenticator_name_given = $authenticator['assignedEntity']['assignedPerson']['name']['given']; + $authenticator_name_family = $authenticator['assignedEntity']['assignedPerson']['name']['family']; + + $this->getCarecoordinationTable()->import($array, $document_id); + + $view = new ViewModel(); + $view->setTerminal(true); + return $view; + } + + public function revandapproveAction() + { + $request = $this->getRequest(); + $document_id = $request->getQuery('document_id') ? $request->getQuery('document_id') : $request->getPost('document_id', null); + $audit_master_id = $request->getQuery('amid') ? $request->getQuery('amid') : $request->getPost('amid', null); + $pid = $request->getQuery('pid') ? $request->getQuery('pid') : $request->getPost('pid', null); + + if ($request->getPost('setval') == 'approve') { + $this->getCarecoordinationTable()->insertApprovedData($request->getPost()); + return $this->redirect()->toRoute('carecoordination', array( + 'controller' => 'Carecoordination', + 'action' => 'upload')); + } + else if($request->getPost('setval') == 'discard'){ + $this->getCarecoordinationTable()->discardCCDAData(array('audit_master_id' => $audit_master_id)); + return $this->redirect()->toRoute('carecoordination', array( + 'controller' => 'Carecoordination', + 'action' => 'upload')); + } + $documentationOf = $this->getCarecoordinationTable()->getdocumentationOf($audit_master_id); + $demographics = $this->getCarecoordinationTable()->getDemographics(array('audit_master_id' => $audit_master_id)); + $demographics_old = $this->getCarecoordinationTable()->getDemographicsOld(array('pid' => $pid)); + + $problems = $this->getCarecoordinationTable()->getProblems(array('pid' => $pid)); + $problems_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'lists1'); + + $allergies = $this->getCarecoordinationTable()->getAllergies(array('pid' => $pid)); + $allergies_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'lists2'); + + $medications = $this->getCarecoordinationTable()->getMedications(array('pid' => $pid)); + $medications_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'lists3'); + + $immunizations = $this->getCarecoordinationTable()->getImmunizations(array('pid' => $pid)); + $immunizations_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'immunization'); + + $lab_results = $this->getCarecoordinationTable()->getLabResults(array('pid' => $pid)); + $lab_results_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'procedure_result'); + + $vitals = $this->getCarecoordinationTable()->getVitals(array('pid' => $pid)); + $vitals_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'vital_sign'); + + $social_history = $this->getCarecoordinationTable()->getSocialHistory(array('pid' => $pid)); + $social_history_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'social_history'); + + $encounter = $this->getCarecoordinationTable()->getEncounterData(array('pid' => $pid)); + $encounter_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'encounter'); + + $procedure = $this->getCarecoordinationTable()->getProcedure(array('pid' => $pid)); + $procedure_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'procedure'); + + $care_plan = $this->getCarecoordinationTable()->getCarePlan(array('pid' => $pid)); + $care_plan_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'care_plan'); + + $functional_cognitive_status = $this->getCarecoordinationTable()->getFunctionalCognitiveStatus(array('pid' => $pid)); + $functional_cognitive_status_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'functional_cognitive_status'); + + $referral = $this->getCarecoordinationTable()->getReferralReason(array('pid' => $pid)); + $referral_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'referral'); + + $discharge_medication_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'discharge_medication'); + + $discharge_summary = array(); + $discharge_summary_audit = $this->getCarecoordinationTable()->createAuditArray($audit_master_id, 'discharge_summary'); + + $gender_list = $this->getCarecoordinationTable()->getList('sex'); + $country_list = $this->getCarecoordinationTable()->getList('country'); + $marital_status_list = $this->getCarecoordinationTable()->getList('marital'); + $religion_list = $this->getCarecoordinationTable()->getList('religious_affiliation'); + $race_list = $this->getCarecoordinationTable()->getList('race'); + $ethnicity_list = $this->getCarecoordinationTable()->getList('ethnicity'); + $state_list = $this->getCarecoordinationTable()->getList('state'); + $tobacco = $this->getCarecoordinationTable()->getList('smoking_status'); + + $demographics_old[0]['sex'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['sex'], 'sex', ''); + $demographics_old[0]['country_code'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['country_code'], 'country', ''); + $demographics_old[0]['status'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['status'], 'marital', ''); + $demographics_old[0]['religion'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['religion'], 'religious_affiliation', ''); + $demographics_old[0]['race'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['race'], 'race', ''); + $demographics_old[0]['ethnicity'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['ethnicity'], 'ethnicity', ''); + $demographics_old[0]['state'] = $this->getCarecoordinationTable()->getListTitle($demographics_old[0]['state'], 'state', ''); + + $view = new ViewModel(array( + 'demographics' => $demographics, + 'demographics_old' => $demographics_old, + 'problems' => $problems, + 'problems_audit' => $problems_audit, + 'allergies' => $allergies, + 'allergies_audit' => $allergies_audit, + 'medications' => $medications, + 'medications_audit' => $medications_audit, + 'immunizations' => $immunizations, + 'immunizations_audit' => $immunizations_audit, + 'lab_results' => $lab_results, + 'lab_results_audit' => $lab_results_audit, + 'vitals' => $vitals, + 'vitals_audit' => $vitals_audit, + 'social_history' => $social_history, + 'social_history_audit' => $social_history_audit, + 'encounter' => $encounter, + 'encounter_audit' => $encounter_audit, + 'procedure' => $procedure, + 'procedure_audit' =>$procedure_audit, + 'care_plan' => $care_plan, + 'care_plan_audit' => $care_plan_audit, + 'functional_cognitive_status' => $functional_cognitive_status, + 'functional_cognitive_status_audit' => $functional_cognitive_status_audit, + 'referral' => $referral, + 'referral_audit' => $referral_audit, + 'discharge_medication_audit' => $discharge_medication_audit, + 'discharge_summary' => $discharge_summary, + 'discharge_summary_audit' => $discharge_summary_audit, + 'amid' => $audit_master_id, + 'pid' => $pid, + 'document_id' => $document_id, + 'gender_list' => $gender_list, + 'country_list' => $country_list, + 'marital_status_list' => $marital_status_list, + 'religion_list' => $religion_list, + 'race_list' => $race_list, + 'ethnicity_list' => $ethnicity_list, + 'tobacco' => $tobacco, + 'state_list' => $state_list, + 'listenerObject' => $this->listenerObject, + 'documentationOf' => $documentationOf, + )); + return $view; + } + + public function getCCDAComponentsAction() { + $request = $this->getRequest(); + $id = $request->getQuery('id'); + $arr = explode("-",$id); + $amid = $arr[0]; + $pid = $arr[1]; + $components = $this->getCarecoordinationTable()->getCCDAComponents(1); + $discharge_medication_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'discharge_medication'); + $discharge_summary_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'discharge_summary'); + if(count($discharge_medication_audit)>0) + $components['discharge_medication'] = 'Dishcharge Medications'; + if(count($discharge_summary_audit)>0) + $components['discharge_summary'] = 'Dishcharge Summary'; + + $components = array_diff($components, array('instructions' => 'Instructions')); + + $temp = ''; + foreach($components as $key=>$value) { + $temp .=' + + + + + + '; + } + $temp .= '
'; + echo $temp; + exit; + } + + public function getEachCCDAComponentDetailsAction() { + $request = $this->getRequest(); + $id = $request->getQuery('id'); + $component = $request->getQuery('component'); + $amid = $request->getQuery('amid'); + $temp = ''; + + switch($component) { + case 'allergies' : $allergies_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'lists2'); + if(count($allergies_audit)>0) { + $temp .='
+ + + + + + + '; + foreach ($allergies_audit['lists2'] as $key => $val) { + $severity_option_id = $this->getCarecoordinationTable()->getOptionId('severity_ccda', '', 'SNOMED-CT:' . $val['severity_al']); + $severity_text = $this->getCarecoordinationTable()->getListTitle($severity_option_id, 'severity_ccda', 'SNOMED-CT:' . $val['severity_al']); + if($val['enddate'] != 0 && $val['enddate'] != ''){ + $status = 'completed'; + } + else{ + $status = 'active'; + } + $temp .=' + + + + + '; + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Substance').''.\Application\Listener\Listener::z_xlt('Reaction').''.\Application\Listener\Listener::z_xlt('Severity').''.\Application\Listener\Listener::z_xlt('Status').'
'.\Application\Listener\Listener::z_xlt($val['list_code_text']).''.\Application\Listener\Listener::z_xlt($val['reaction_text']).''.\Application\Listener\Listener::z_xlt($severity_text).''.\Application\Listener\Listener::z_xlt($status).'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Allergies'); + } + break; + case 'medications' : $medications_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'lists3'); + if(count($medications_audit)>0) { + $temp .='
+ + + + + + + + + '; + foreach($medications_audit['lists3'] as $key => $val) { + if($val['enddate'] && $val['enddate'] != 0) + $active = 'completed'; + else + $active = 'active'; + $temp .=' + + + + + + + '; + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Medication').''.\Application\Listener\Listener::z_xlt('Directions').''.\Application\Listener\Listener::z_xlt('Start Date').''.\Application\Listener\Listener::z_xlt('Status').''.\Application\Listener\Listener::z_xlt('Indications').''.\Application\Listener\Listener::z_xlt('Fill Instructions').'
'.\Application\Listener\Listener::z_xlt($val['drug_text']).''.\Application\Plugin\CommonPlugin::escape($val['rate']." ".$val['rate_unit']." ".$val['route_display']." ".$val['dose']." ".$val['dose_unit']).''.\Application\Model\ApplicationTable::fixDate(substr($val['begdate'],0,4) . "-" . substr($val['begdate'], 4, 2) . "-" . substr($val['begdate'], 6, 2), $this->date_format, 'yyyy-mm-dd').''.\Application\Listener\Listener::z_xlt($active).''.\Application\Listener\Listener::z_xlt($val['indication']).''.\Application\Plugin\CommonPlugin::escape($val['note']).'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Medications'); + } + break; + case 'problems' : $problems_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'lists1'); + if(count($problems_audit)>0) { + $temp .='
    '; + $i = 1; + foreach($problems_audit['lists1'] as $key => $val) { + if($val['enddate'] != 0 && $val['enddate'] != ''){ + $status = 'Resolved'; + } + else{ + $status = 'Active'; + } + $temp .='
  • '.$i.'. '.\Application\Listener\Listener::z_xlt($val['list_code_text']).','.substr($val['begdate'],0,4) . "-" . substr($val['begdate'], 4, 2) . "-" . substr($val['begdate'], 6, 2).', '.\Application\Listener\Listener::z_xlt('Status').' :'.\Application\Listener\Listener::z_xlt($status).'
  • '; + $i++; + } + $temp .='
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Problems'); + } + break; + case 'immunizations' : $immunizations_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'immunization'); + if(count($immunizations_audit)>0) { + $temp .='
+ + + + + + '; + foreach($immunizations_audit['immunization'] as $key => $val) { + $temp .=' + + + + '; + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Vaccine').''.\Application\Listener\Listener::z_xlt('Date').''.\Application\Listener\Listener::z_xlt('Status').'
'.\Application\Listener\Listener::z_xlt($val['cvx_code_text']).''.$this->getCarecoordinationTable()->getMonthString(substr($val['administered_date'], 4, 2)).' '.substr($val['administered_date'],0,4).''.\Application\Listener\Listener::z_xlt('Completed').'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Immunizations'); + } + break; + case 'procedures' : $procedure_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'procedure'); + if(count($procedure_audit)>0) { + $temp .='
+ + + + + '; + foreach($procedure_audit['procedure'] as $key => $val) { + $temp .=' + + + '; + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Procedure').''.\Application\Listener\Listener::z_xlt('Date').'
'.\Application\Plugin\CommonPlugin::escape($val['code_text']).''.\Application\Model\ApplicationTable::fixDate(substr($val['date'],0,4) . "-" . substr($val['date'], 4, 2) . "-" . substr($val['date'], 6, 2), $this->date_format, 'yyyy-mm-dd').'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Procedures'); + } + break; + case 'results' : $lab_results_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'procedure_result'); + if(count($lab_results_audit)>0) { + $temp .='
+ + + + + + + '; + foreach($lab_results_audit['procedure_result'] as $key => $val) { + if($val['results_text']) { + $temp .=' + + + + '; + } + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Laboratory Information').''.\Application\Listener\Listener::z_xlt('Result').''.\Application\Listener\Listener::z_xlt('Date').'
'.\Application\Plugin\CommonPlugin::escape($val['results_text']) . ($val['results_range'] != "-" ? "(" . \Application\Plugin\CommonPlugin::escape($val['results_range']) . ")" : "").''.\Application\Plugin\CommonPlugin::escape($val['results_value']) . " " . \Application\Plugin\CommonPlugin::escape($val['results_unit']).''.\Application\Model\ApplicationTable::fixDate(substr($val['date'],0,4) . "-" . substr($val['date'], 4, 2) . "-" . substr($val['date'], 6, 2), $this->date_format, 'yyyy-mm-dd').'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Lab Results'); + } + break; + case 'plan_of_care' : $care_plan_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'care_plan'); + if(count($care_plan_audit)>0) { + $temp .='
+ + + + + '; + foreach($care_plan_audit['care_plan'] as $key => $val) { + $temp .=' + + + '; + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Planned Activity').''.\Application\Listener\Listener::z_xlt('Planned Date').'
'.\Application\Plugin\CommonPlugin::escape($val['code_text']).''.\Application\Model\ApplicationTable::fixDate(substr($val['date'],0,4) . "-" . substr($val['date'], 4, 2) . "-" . substr($val['date'], 6, 2), $this->date_format, 'yyyy-mm-dd').'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Plan of Care'); + } + break; + case 'vitals' : $vitals_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'vital_sign'); + if(count($vitals_audit)>0) { + $temp .= '
+ + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= ' + + '; + foreach($vitals_audit['vital_sign'] as $key => $val){ + $temp .= ''; + } + $temp .= '
'.\Application\Listener\Listener::z_xlt('Date / Time: ').''.\Application\Model\ApplicationTable::fixDate(substr($val['date'],0,4) . "-" . substr($val['date'], 4, 2) . "-" . substr($val['date'], 6, 2), $this->date_format, 'yyyy-mm-dd').'
'.\Application\Listener\Listener::z_xlt('Temperature').''.\Application\Plugin\CommonPlugin::escape($val['temperature']).'
'.\Application\Listener\Listener::z_xlt('Diastolic').''.\Application\Plugin\CommonPlugin::escape($val['bpd']).'
'.\Application\Listener\Listener::z_xlt('Systolic').''.\Application\Plugin\CommonPlugin::escape($val['bps']).'
'.\Application\Listener\Listener::z_xlt('Head Circumference').''.\Application\Plugin\CommonPlugin::escape($val['head_circ']).'
'.\Application\Listener\Listener::z_xlt('Pulse').''.\Application\Plugin\CommonPlugin::escape($val['pulse']).'
'.\Application\Listener\Listener::z_xlt('Height').''.\Application\Plugin\CommonPlugin::escape($val['height']).'
'.\Application\Listener\Listener::z_xlt('Oxygen Saturation').''.\Application\Plugin\CommonPlugin::escape($val['oxygen_saturation']).'
'.\Application\Listener\Listener::z_xlt('Breath').''.\Application\Plugin\CommonPlugin::escape($val['breath']).'
'.\Application\Listener\Listener::z_xlt('Weight').''.\Application\Plugin\CommonPlugin::escape($val['weight']).'
'.\Application\Listener\Listener::z_xlt('BMI').''.\Application\Plugin\CommonPlugin::escape($val['BMI']).'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Vitals'); + } + break; + case 'social_history' : $social_history_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'social_history'); + if(count($social_history_audit)>0) { + $temp .='
+ + + + + + '; + foreach($social_history_audit['social_history'] as $key => $val) { + $array_his_tobacco = explode("|", $val['smoking']); + if ($array_his_tobacco[2] != 0 && $array_his_tobacco[2] != '') { + $his_tob_date = substr($array_his_tobacco[2], 0, 4). "-" .substr($array_his_tobacco[2], 4, 2). "-" .substr($array_his_tobacco[2], 6, 2); + } + $temp .=' + + + + '; + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Social History Element').''.\Application\Listener\Listener::z_xlt('Description').''.\Application\Listener\Listener::z_xlt('Effective Dates').'
'.\Application\Listener\Listener::z_xlt('Smoking').''.\Application\Plugin\CommonPlugin::escape($array_his_tobacco[0]).''.\Application\Model\ApplicationTable::fixDate($his_tob_date, $this->date_format, 'yyyy-mm-dd').'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Social History'); + } + break; + case 'encounters' : $encounter_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'encounter'); + if(count($encounter_audit)>0) { + $temp .='
+ + + + + + + + + + '; + foreach($encounter_audit['encounter'] as $key => $val) { + if($val['code_text'] != 'NULL') + $encounter_activity = 'Active'; + else $encounter_activity = ''; + $enc_date = substr($val['date'], 0, 4). "-" .substr($val['date'], 4, 2). "-" .substr($val['date'], 6, 2); + $temp .=' + + + + + + + + '; + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Encounter').''.\Application\Listener\Listener::z_xlt('Performer').''.\Application\Listener\Listener::z_xlt('Location').''.\Application\Listener\Listener::z_xlt('Date').''.\Application\Listener\Listener::z_xlt('Encounter Diagnosis').''.\Application\Listener\Listener::z_xlt('Status').''.\Application\Listener\Listener::z_xlt('Reason for Visit').'
'.\Application\Plugin\CommonPlugin::escape($val['pc_catname']).''.\Application\Plugin\CommonPlugin::escape($val['provider_name']).''.\Application\Plugin\CommonPlugin::escape($val['represented_organization_name']).''.\Application\Model\ApplicationTable::fixDate($enc_date, $this->date_format, 'yyyy-mm-dd').''.($val['code_text'] != 'NULL' ? \Application\Plugin\CommonPlugin::escape($val['code_text']) : '').''.\Application\Listener\Listener::z_xlt($encounter_activity).'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Encounters'); + } + break; + case 'functional_status' : $functional_cognitive_status_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'functional_cognitive_status'); + if(count($functional_cognitive_status_audit)>0) { + $temp .='
+ + + + + + '; + foreach($functional_cognitive_status_audit['functional_cognitive_status'] as $key => $val) { + $temp .=' + + + + '; + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Functional Condition').''.\Application\Listener\Listener::z_xlt('Effective Dates').''.\Application\Listener\Listener::z_xlt('Condition Status').'
'.\Application\Plugin\CommonPlugin::escape($val['description']).''.\Application\Model\ApplicationTable::fixDate(substr($val['date'],0,4) . "-" . substr($val['date'], 4, 2) . "-" . substr($val['date'], 6, 2), $this->date_format, 'yyyy-mm-dd').''.\Application\Listener\Listener::z_xlt('Active').'
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Social Functional Status'); + } + break; + case 'referral' : $referral_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'referral'); + if(count($referral_audit)>0) { + $temp .='
'; + foreach($referral_audit['referral'] as $key => $val) { + $referal_data = explode("#$%^&*",$val['body']); + foreach($referal_data as $k => $v) { + $temp .='

'.\Application\Plugin\CommonPlugin::escape($v).'

'; + } + } + $temp .='
'; + } + else { + $temp .= \Application\Listener\Listener::z_xlt('No Known Referrals'); + } + break; + case 'instructions' : $temp .= \Application\Listener\Listener::z_xlt('No Known Clinical Instructions'); + break; + case 'discharge_medication' : $discharge_medication_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'discharge_medication'); + $temp .='
+ + + + + + + + + '; + foreach($discharge_medication_audit['discharge_medication'] as $key => $val) { + if($val['enddate'] && $val['enddate'] != 0) + $active = 'completed'; + else + $active = 'active'; + $temp .=' + + + + + + + '; + } + $temp .='
'.\Application\Listener\Listener::z_xlt('Medication').''.\Application\Listener\Listener::z_xlt('Directions').''.\Application\Listener\Listener::z_xlt('Start Date').''.\Application\Listener\Listener::z_xlt('Status').''.\Application\Listener\Listener::z_xlt('Indications').''.\Application\Listener\Listener::z_xlt('Fill Instructions').'
'.\Application\Plugin\CommonPlugin::escape($val['drug_text']).''.\Application\Plugin\CommonPlugin::escape($val['rate']." ".$val['rate_unit']." ".$val['route_display']." ".$val['dose']." ".$val['dose_unit']).''.\Application\Model\ApplicationTable::fixDate(substr($val['begdate'],0,4) . "-" . substr($val['begdate'], 4, 2) . "-" . substr($val['begdate'], 6, 2), $this->date_format, 'yyyy-mm-dd').''.\Application\Listener\Listener::z_xlt($active).''.\Application\Plugin\CommonPlugin::escape($val['indication']).''.\Application\Plugin\CommonPlugin::escape($val['note']).'
'; + break; + case 'discharge_summary' : $discharge_summary_audit = $this->getCarecoordinationTable()->createAuditArray($amid, 'discharge_summary'); + $temp .='
'; + foreach($discharge_summary_audit['discharge_summary'] as $key => $val) { + $text = str_replace("#$%","
",\Application\Plugin\CommonPlugin::escape($val['text'])); + $temp .=$text; + } + $temp .='
'; + break; + } + + echo $temp; + exit; + } + /** + * Table gateway + * @return object + */ + public function getCarecoordinationTable() + { + if (!$this->carecoordinationTable) { + $sm = $this->getServiceLocator(); + $this->carecoordinationTable = $sm->get('Carecoordination\Model\CarecoordinationTable'); + } + return $this->carecoordinationTable; + } + +} \ No newline at end of file diff --git a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/CcdController.php b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/CcdController.php index 37e1301f5..8e68ef6b3 100644 --- a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/CcdController.php +++ b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/CcdController.php @@ -59,7 +59,17 @@ class CcdController extends AbstractActionController $_REQUEST["batch_import"] = 'YES'; $this->importAction(); } - } + } + else{ + $result = \Documents\Plugin\Documents::fetchXmlDocuments(); + foreach($result as $row){ + if($row['doc_type'] == 'CCD'){ + $_REQUEST["document_id"] = $row['doc_id']; + $this->importAction(); + \Documents\Model\DocumentsTable::updateDocumentCategoryUsingCatname($row['doc_type'], $row['doc_id']); + } + } + } $records = \Carecoordination\Controller\CarecoordinationController::getCarecoordinationTable()->document_fetch(array('cat_title' => 'CCD','type' => '13')); $view = new ViewModel(array( diff --git a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/EncounterccdadispatchController.php b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/EncounterccdadispatchController.php index e74b35ee0..d0fb4e8a2 100644 --- a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/EncounterccdadispatchController.php +++ b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/EncounterccdadispatchController.php @@ -94,21 +94,28 @@ class EncounterccdadispatchController extends AbstractActionController } if(!$this->sections){ - $components = $this->getEncounterccdadispatchTable()->getCCDAComponents(); - foreach($components as $key => $value){ + $components0 = $this->getEncounterccdadispatchTable()->getCCDAComponents(0); + foreach($components0 as $key => $value){ if($str) $str .= '|'; $str .= $key; } $this->sections = $str; } - + if(!$this->components){ + $components1 = $this->getEncounterccdadispatchTable()->getCCDAComponents(1); + foreach($components1 as $key => $value){ + if($str1) $str1 .= '|'; + $str1 .= $key; + } + $this->components = $str1; + } if($combination != ''){ $arr = explode('|', $combination); foreach($arr as $row){ $arr = explode('_',$row); $this->patient_id = $arr[0]; $this->encounter_id = ($arr[1] > 0 ? $arr[1] : NULL); - $this->create_data($this->patient_id, $this->encounter_id, $this->sections, $send); + $this->create_data($this->patient_id, $this->encounter_id, $this->sections, $send,$this->components); $content = $this->socket_get("$mirth_ip", "6661", $this->data); if($content=='Authetication Failure'){ @@ -261,7 +268,7 @@ class EncounterccdadispatchController extends AbstractActionController $this->recipients = $this->getRequest()->getQuery('recipient'); $this->params = $this->getRequest()->getQuery('param'); $this->referral_reason = $this->getRequest()->getQuery('referral_reason'); - + $this->components = $this->getRequest()->getQuery('components') ? $this->getRequest()->getQuery('components') :$this->params('components'); $downloadccda = $this->params('downloadccda'); if($downloadccda == 'download_ccda') { $combination = $this->params('pids'); @@ -272,21 +279,28 @@ class EncounterccdadispatchController extends AbstractActionController } if(!$this->sections){ - $components = $this->getEncounterccdadispatchTable()->getCCDAComponents(); - foreach($components as $key => $value){ + $components0 = $this->getEncounterccdadispatchTable()->getCCDAComponents(0); + foreach($components0 as $key => $value){ if($str) $str .= '|'; $str .= $key; } $this->sections = $str; + } + if(!$this->components){ + $components1 = $this->getEncounterccdadispatchTable()->getCCDAComponents(1); + foreach($components1 as $key => $value){ + if($str1) $str1 .= '|'; + $str1 .= $key; + } + $this->components = $str1; } - if($combination != ''){ $arr = explode('|', $combination); foreach($arr as $row){ $arr = explode('_',$row); $this->patient_id = $arr[0]; $this->encounter_id = ($arr[1] > 0 ? $arr[1] : NULL); - $this->create_data($this->patient_id, $this->encounter_id, $this->sections, $send); + $this->create_data($this->patient_id, $this->encounter_id, $this->sections, $send,$this->components); $content = $this->socket_get("$mirth_ip", "6661", $this->data); if($content=='Authetication Failure'){ @@ -387,11 +401,12 @@ class EncounterccdadispatchController extends AbstractActionController return $output; } - public function create_data($pid, $encounter, $sections, $send=0) + public function create_data($pid, $encounter, $sections, $send=0,$components) { global $assignedEntity; global $representedOrganization; $sections_list = explode('|',$sections); + $components_list = explode('|',$components); $this->createdtime = time(); $username = $this->getEncounterccdadispatchTable()->getSettings('Carecoordination', 'hie_mirth_username'); $password = $this->getEncounterccdadispatchTable()->getSettings('Carecoordination', 'hie_mirth_password'); @@ -438,9 +453,10 @@ class EncounterccdadispatchController extends AbstractActionController /***************CCDA Header Information***************/ /***************CCDA Body Information***************/ - $this->data .= $this->getEncounterccdadispatchTable()->getEncounterHistory($pid,$encounter); + if(in_array('encounters',$components_list)) + $this->data .= $this->getEncounterccdadispatchTable()->getEncounterHistory($pid,$encounter); if(in_array('continuity_care_document',$sections_list)) - $this->data .= $this->getContinuityCareDocument($pid,$encounter); + $this->data .= $this->getContinuityCareDocument($pid,$encounter,$components_list); if(in_array('progress_note',$sections_list)) $this->data .= $this->getEncounterccdadispatchTable()->getProgressNotes($pid,$encounter); if(in_array('discharge_summary',$sections_list)) @@ -452,7 +468,7 @@ class EncounterccdadispatchController extends AbstractActionController if(in_array('consultation_note',$sections_list)) $this->data .= $this->getConsultationNote($pid,$encounter); if(in_array('history_physical_note',$sections_list)) - $this->data .= $this->getHistoryAndPhysicalNotes($pid,$encounter); + $this->data .= $this->getHistoryAndPhysicalNotes($pid,$encounter,$components_list); if(in_array('unstructured_document',$sections_list)) $this->data .= $this->getEncounterccdadispatchTable()->getUnstructuredDocuments($pid, $encounter); /***************CCDA Body Information***************/ @@ -488,17 +504,29 @@ class EncounterccdadispatchController extends AbstractActionController readfile($tmpfile); } - public function getContinuityCareDocument($pid,$encounter) + public function getContinuityCareDocument($pid,$encounter,$components_list) { $ccd = ''; - $ccd .= $this->getEncounterccdadispatchTable()->getAllergies($pid,$encounter); - $ccd .= $this->getEncounterccdadispatchTable()->getMedications($pid,$encounter); - $ccd .= $this->getEncounterccdadispatchTable()->getProblemList($pid,$encounter); - $ccd .= $this->getEncounterccdadispatchTable()->getProcedures($pid,$encounter); - $ccd .= $this->getEncounterccdadispatchTable()->getResults($pid,$encounter); - $ccd .= $this->getEncounterccdadispatchTable()->getImmunization($pid, $encounter); - $ccd .= $this->getEncounterccdadispatchTable()->getPlanOfCare($pid,$encounter); - $ccd .= $this->getEncounterccdadispatchTable()->getFunctionalCognitiveStatus($pid,$encounter); + if(in_array('allergies',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getAllergies($pid,$encounter); + if(in_array('medications',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getMedications($pid,$encounter); + if(in_array('problems',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getProblemList($pid,$encounter); + if(in_array('procedures',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getProcedures($pid,$encounter); + if(in_array('results',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getResults($pid,$encounter); + if(in_array('immunizations',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getImmunization($pid, $encounter); + if(in_array('plan_of_care',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getPlanOfCare($pid,$encounter); + if(in_array('functional_status',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getFunctionalCognitiveStatus($pid,$encounter); + if(in_array('instructions',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getClinicalInstructions($pid,$encounter); + if(in_array('referral',$components_list)) + $ccd .= $this->getEncounterccdadispatchTable()->getRefferals($pid,$encounter); return $ccd; } @@ -614,7 +642,7 @@ class EncounterccdadispatchController extends AbstractActionController * $return string $history_and_physical_notes XML which contains the details collected from the patient. */ - public function getHistoryAndPhysicalNotes($pid, $encounter) + public function getHistoryAndPhysicalNotes($pid, $encounter,$components_list) { $history_and_physical_notes = ''; $history_and_physical_notes .= ""; @@ -622,8 +650,10 @@ class EncounterccdadispatchController extends AbstractActionController $history_and_physical_notes .= $this->getEncounterccdadispatchTable()->getGeneralStatus($pid, $encounter); $history_and_physical_notes .= $this->getEncounterccdadispatchTable()->getHistoryOfPastIllness($pid, $encounter); $history_and_physical_notes .= $this->getEncounterccdadispatchTable()->getReviewOfSystems($pid, $encounter); - $history_and_physical_notes .= $this->getEncounterccdadispatchTable()->getVitals($pid, $encounter); - $history_and_physical_notes .= $this->getEncounterccdadispatchTable()->getSocialHistory($pid, $encounter); + if(in_array('vitals',$components_list)) + $history_and_physical_notes .= $this->getEncounterccdadispatchTable()->getVitals($pid, $encounter); + if(in_array('social_history',$components_list)) + $history_and_physical_notes .= $this->getEncounterccdadispatchTable()->getSocialHistory($pid, $encounter); $history_and_physical_notes .= ""; return $history_and_physical_notes; } diff --git a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/EncountermanagerController.php b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/EncountermanagerController.php index 7020bb7e6..7c396f694 100644 --- a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/EncountermanagerController.php +++ b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Controller/EncountermanagerController.php @@ -86,10 +86,12 @@ class EncountermanagerController extends AbstractActionController else $pids .= $combination[$i].'|'; } + $components = $request->getPost('components') ? $request->getPost('components') : $request->getQuery()->components; $this->forward()->dispatch('encounterccdadispatch',array('action' => 'index', 'pids' => $pids, 'view' => 1, - 'downloadccda' => $downloadccda)); + 'downloadccda' => $downloadccda, + 'components' => $components)); } $params = array( diff --git a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Model/CarecoordinationTable.php b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Model/CarecoordinationTable.php dissimilarity index 74% index d50452a4a..2c6dc7aaf 100644 --- a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Model/CarecoordinationTable.php +++ b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Model/CarecoordinationTable.php @@ -1,3241 +1,3805 @@ - -* -* This program is free software: you can redistribute it and/or modify -* it under the terms of the GNU Affero General Public License as -* published by the Free Software Foundation, either version 3 of the -* License, or (at your option) any later version. -* -* This program is distributed in the hope that it will be useful, -* but WITHOUT ANY WARRANTY; without even the implied warranty of -* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -* GNU Affero General Public License for more details. -* -* You should have received a copy of the GNU Affero General Public License -* along with this program. If not, see . -* -* @author Vinish K -* @author Chandni Babu -* @author Riju KP -* +------------------------------------------------------------------------------+ -*/ -namespace Carecoordination\Model; - -use Zend\Db\TableGateway\AbstractTableGateway; -use Application\Model\ApplicationTable; -use Zend\Db\Adapter\Driver\Pdo\Result; -use Zend\XmlRpc\Generator; - -use DOMDocument; -use DOMXpath; - -use Document; -use CouchDB; - -use Documents\Model\DocumentsTable; - -class CarecoordinationTable extends AbstractTableGateway -{ - protected $ccda_data_array; - /* - * Fetch the category ID using category name - * - * @param $title String Category Name - * @return $records Array Category ID - */ - public function fetch_cat_id($title) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM categories - WHERE name = ?"; - $result = $appTable->zQuery($query, array($title)); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the documents uploaded by a user - * - * @param user Integer Uploaded user ID - * @param time_start Date Uploaded start time - * @param time_end Date Uploaded end time - * - * @return records Array List of documents uploaded by the user during a particular time - */ - public function fetch_uploaded_documents($data) - { - $query = "SELECT * - FROM categories_to_documents AS cat_doc - JOIN documents AS doc - ON doc.id = cat_doc.document_id AND doc.owner = ? AND doc.date BETWEEN ? AND ?"; - $appTable = new ApplicationTable(); - $result = $appTable->zQuery($query, array($data['user'], $data['time_start'], $data['time_end'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * List the documents uploaded by the user alogn with the matched data - * - * @param cat_title Text Category Name - * @return records Array List of CCDA imported to the system, pending approval - */ - public function document_fetch($data) - { - $query = "SELECT am.id as amid, - cat.name, - u.fname, - u.lname, - d.imported, - d.size, - d.date, - d.couch_docid, - d.couch_revid, - d.url AS file_url, - d.id AS document_id, - ad.field_value, - ad1.field_value, - ad2.field_value, - pd.pid, - CONCAT(ad.field_value,' ',ad1.field_value) as pat_name, - DATE(ad2.field_value) as dob, - CONCAT_WS(' ',pd.lname, pd.fname) as matched_patient - FROM documents AS d - JOIN categories AS cat ON cat.name = ? - JOIN categories_to_documents AS cd ON cd.document_id = d.id AND cd.category_id = cat.id - LEFT JOIN audit_master AS am ON am.type = ? AND am.approval_status = '1' AND d.audit_master_id = am.id - LEFT JOIN audit_details ad ON ad.audit_master_id = am.id AND ad.table_name = 'patient_data' AND ad.field_name = 'lname' - LEFT JOIN audit_details ad1 ON ad1.audit_master_id = am.id AND ad1.table_name = 'patient_data' AND ad1.field_name = 'fname' - LEFT JOIN audit_details ad2 ON ad2.audit_master_id = am.id AND ad2.table_name = 'patient_data' AND ad2.field_name = 'DOB' - LEFT JOIN patient_data pd ON pd.lname = ad.field_value AND pd.fname = ad1.field_value AND pd.DOB = DATE(ad2.field_value) - LEFT JOIN users AS u ON u.id = d.owner - WHERE d.audit_master_approval_status = 1 - ORDER BY date DESC"; - $appTable = new ApplicationTable(); - $result = $appTable->zQuery($query, array($data['cat_title'],$data['type'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the component values from the CCDA XML - * - * @param $components Array of components - */ - public function import($xml,$document_id) - { - $components = $xml['component']['structuredBody']['component']; - $components_oids = array( - '2.16.840.1.113883.10.20.22.4.7' => 'allergy', - '2.16.840.1.113883.10.20.22.2.6.1' => 'allergy', - '2.16.840.1.113883.10.20.22.2.1' => 'medication', - '2.16.840.1.113883.10.20.22.2.1.1' => 'medication', - '2.16.840.1.113883.10.20.22.2.5.1' => 'medical_problem', - '2.16.840.1.113883.10.20.22.2.5' => 'medical_problem', - '2.16.840.1.113883.10.20.22.2.2' => 'immunization', - '2.16.840.1.113883.10.20.22.2.2.1' => 'immunization', - '2.16.840.1.113883.3.88.11.83.145' => 'procedure', - '2.16.840.1.113883.10.20.22.2.7.1' => 'procedure', - '2.16.840.1.113883.10.20.22.2.3.1' => 'lab_result', - '2.16.840.1.113883.10.20.22.2.3' => 'lab_result', - '2.16.840.1.113883.10.20.22.2.4.1' => 'vital_sign', - '2.16.840.1.113883.10.20.22.2.17' => 'social_history', - '2.16.840.1.113883.3.88.11.83.127' => 'encounter', - '2.16.840.1.113883.10.20.22.2.22.1' => 'encounter', - '2.16.840.1.113883.10.20.22.2.10' => 'care_plan', - '2.16.840.1.113883.10.20.22.2.14' => 'functional_cognitive_status', - '1.3.6.1.4.1.19376.1.5.3.1.3.1' => 'referral', - ); - - for($i = 0 ; $i <= count($components) ; $i++){ - if(count($components[$i]['section']['templateId']) > 1){ - foreach($components[$i]['section']['templateId'] as $key_1 => $value_1){ - if($components_oids[$components[$i]['section']['templateId'][$key_1]['root']] != ''){ - $func_name = $components_oids[$components[$i]['section']['templateId'][$key_1]['root']]; - $this->$func_name($components[$i]); - break; - } - } - } - else{ - if($components_oids[$components[$i]['section']['templateId']['root']] != ''){ - $func_name = $components_oids[$components[$i]['section']['templateId']['root']]; - $this->$func_name($components[$i]); - } - } - } - $audit_master_approval_status = $this->ccda_data_array['approval_status'] = 1; - $this->ccda_data_array['ip_address'] = $_SERVER['REMOTE_ADDR']; - $this->ccda_data_array['type'] = '12'; - - //Patient Details - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['fname'] = $xml['recordTarget']['patientRole']['patient']['name']['given'][0]; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['lname'] = $xml['recordTarget']['patientRole']['patient']['name']['family']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['DOB'] = $xml['recordTarget']['patientRole']['patient']['birthTime']['value']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['sex'] = $xml['recordTarget']['patientRole']['patient']['administrativeGenderCode']['displayName']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['pubpid'] = $xml['recordTarget']['patientRole']['id'][0]['extension']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['ss'] = $xml['recordTarget']['patientRole']['id'][1]['extension']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['street'] = $xml['recordTarget']['patientRole']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['city'] = $xml['recordTarget']['patientRole']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['state'] = $xml['recordTarget']['patientRole']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['postal_code'] = $xml['recordTarget']['patientRole']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['country_code'] = $xml['recordTarget']['patientRole']['addr']['country']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['phone_home'] = preg_replace('/[^0-9]+/i', '', $xml['recordTarget']['patientRole']['telecom']['value']); - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['status'] = $xml['recordTarget']['patientRole']['patient']['maritalStatusCode']['displayName']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['religion'] = $xml['recordTarget']['patientRole']['patient']['religiousAffiliationCode']['displayName']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['race'] = $xml['recordTarget']['patientRole']['patient']['raceCode']['displayName']; - $this->ccda_data_array['field_name_value_array']['patient_data'][1]['ethnicity'] = $xml['recordTarget']['patientRole']['patient']['ethnicGroupCode']['displayName']; - - //Author details - $this->ccda_data_array['field_name_value_array']['author'][1]['extension'] = $xml['author']['assignedAuthor']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['author'][1]['address'] = $xml['author']['assignedAuthor']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['author'][1]['city'] = $xml['author']['assignedAuthor']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['author'][1]['state'] = $xml['author']['assignedAuthor']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['author'][1]['zip'] = $xml['author']['assignedAuthor']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['author'][1]['country'] = $xml['author']['assignedAuthor']['addr']['country']; - $this->ccda_data_array['field_name_value_array']['author'][1]['phone'] = $xml['author']['assignedAuthor']['telecom']['value']; - $this->ccda_data_array['field_name_value_array']['author'][1]['name'] = $xml['author']['assignedAuthor']['assignedPerson']['name']['given']; - - //Data Enterer - $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['extension'] = $xml['dataEnterer']['assignedEntity']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['address'] = $xml['dataEnterer']['assignedEntity']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['city'] = $xml['dataEnterer']['assignedEntity']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['state'] = $xml['dataEnterer']['assignedEntity']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['zip'] = $xml['dataEnterer']['assignedEntity']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['country'] = $xml['dataEnterer']['assignedEntity']['addr']['country']; - $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['phone'] = $xml['dataEnterer']['assignedEntity']['telecom']['value']; - $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['name'] = $xml['dataEnterer']['assignedEntity']['assignedPerson']['name']['given']; - - //Informant - $this->ccda_data_array['field_name_value_array']['informant'][1]['extension'] = $xml['informant'][0]['assignedEntity']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['informant'][1]['street'] = $xml['informant'][0]['assignedEntity']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['informant'][1]['city'] = $xml['informant'][0]['assignedEntity']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['informant'][1]['state'] = $xml['informant'][0]['assignedEntity']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['informant'][1]['postalCode'] = $xml['informant'][0]['assignedEntity']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['informant'][1]['country'] = $xml['informant'][0]['assignedEntity']['addr']['country']; - $this->ccda_data_array['field_name_value_array']['informant'][1]['phone'] = $xml['informant'][0]['assignedEntity']['telecom']['value']; - $this->ccda_data_array['field_name_value_array']['informant'][1]['name'] = $xml['informant'][0]['assignedEntity']['assignedPerson']['name']['given']; - - //Personal Informant - $this->ccda_data_array['field_name_value_array']['custodian'][1]['extension'] = $xml['custodian']['assignedCustodian']['representedCustodianOrganization']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['custodian'][1]['organisation'] = $xml['custodian']['assignedCustodian']['representedCustodianOrganization']['name']; - - $audit_master_id = \Application\Plugin\CommonPlugin::insert_ccr_into_audit_data($this->ccda_data_array); - $this->update_document_table($document_id,$audit_master_id,$audit_master_approval_status); - } - - public function update_document_table($document_id,$audit_master_id,$audit_master_approval_status) - { - $appTable = new ApplicationTable(); - $query = "UPDATE documents - SET audit_master_id = ?, - imported = ?, - audit_master_approval_status=? - WHERE id = ?"; - $appTable->zQuery($query, array($audit_master_id, - 1, - $audit_master_approval_status, - $document_id)); - } - - public function allergy($component) - { - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_allergy_value($value); - } - } - else{ - $this->fetch_allergy_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_allergy_value($allergy_array) - { - $i = count($this->ccda_data_array['field_name_value_array']['lists2']) + 1; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['type'] = 'allergy'; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['extension'] = $allergy_array['act']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['begdate'] = $allergy_array['act']['effectiveTime']['low']['value']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['enddate'] = $allergy_array['act']['effectiveTime']['high']['value']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['list_code'] = $allergy_array['act']['entryRelationship']['observation']['participant']['participantRole']['playingEntity']['code']['code']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['list_code_text'] = $allergy_array['act']['entryRelationship']['observation']['participant']['participantRole']['playingEntity']['code']['displayName']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['codeSystemName'] = $allergy_array['act']['entryRelationship']['observation']['participant']['participantRole']['playingEntity']['code']['codeSystemName']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['outcome'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][1]['observation']['value']['code']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['severity_al_code'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][2]['observation']['value']['code']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['severity_al'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][2]['observation']['value']['code']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['status'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][0]['observation']['value']['displayName']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['reaction'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][1]['observation']['value']['code']; - $this->ccda_data_array['field_name_value_array']['lists2'][$i]['reaction_text'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][1]['observation']['value']['displayName']; - $this->ccda_data_array['entry_identification_array']['lists2'][$i] = $i; - unset($allergy_array); - return; - } - - public function medication($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_medication_value($value); - } - } - else{ - $this->fetch_medication_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_medication_value($medication_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['lists3']) + 1; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['type'] = 'medication'; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['extension'] = $medication_data['substanceAdministration']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['root'] = $medication_data['substanceAdministration']['id']['root']; - if($medication_data['substanceAdministration']['effectiveTime'][0]['low']['value'] == '') - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['begdate'] = date('Y-m-d'); - else - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['begdate'] = $medication_data['substanceAdministration']['effectiveTime'][0]['low']['value']; - if($medication_data['substanceAdministration']['effectiveTime'][0]['high']['value']) - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['enddate'] = $medication_data['substanceAdministration']['effectiveTime'][0]['high']['value']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['route'] = $medication_data['substanceAdministration']['routeCode']['code']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['route_display'] = $medication_data['substanceAdministration']['routeCode']['displayName']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['dose'] = $medication_data['substanceAdministration']['doseQuantity']['value']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['dose_unit'] = $medication_data['substanceAdministration']['doseQuantity']['unit']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['rate'] = $medication_data['substanceAdministration']['rateQuantity']['value']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['rate_unit'] = $medication_data['substanceAdministration']['rateQuantity']['unit']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['drug_code'] = $medication_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['code']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['drug_text'] = $medication_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['displayName']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['note'] = $medication_data['substanceAdministration']['text']['reference']['value']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['indication'] = $medication_data['substanceAdministration']['entryRelationship'][0]['observation']['value']['displayName']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['prn'] = $medication_data['substanceAdministration']['precondition']['criterion']['value']['displayName']; - - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_title'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['prefix']?$medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['prefix']:$medication_data['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['assignedPerson']['name']['prefix']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_fname'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['given']?$medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['given']:$medication_data['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['assignedPerson']['name']['given']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_lname'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['family']?$medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['family']:$medication_data['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['assignedPerson']['name']['family']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_root'] = $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['id']['root']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_address'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['streetAddressLine']?$medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['streetAddressLine']:$medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_city'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['city']?$medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['city']:$medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_state'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['state']?$medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['state']:$medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_postalCode'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['postalCode']?$medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['postalCode']:$medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_country'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['country']['value']?$medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['country']['value']:$medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['country']; - $this->ccda_data_array['entry_identification_array']['lists3'][$i] = $i; - unset($medication_data); - return; - } - - public function medical_problem($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_medical_problem_value($value); - } - } - else{ - $this->fetch_medical_problem_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_medical_problem_value($medical_problem_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['lists1']) + 1; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['type'] = 'medical_problem'; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['extension'] = $medical_problem_data['act']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['root'] = $medical_problem_data['act']['id']['root']; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['begdate'] = $medical_problem_data['act']['effectiveTime']['low']['value']; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['enddate'] = $medical_problem_data['act']['effectiveTime']['high']['value']; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['list_code'] = $medical_problem_data['act']['entryRelationship']['observation']['value']['code']; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['list_code_text'] = $medical_problem_data['act']['entryRelationship']['observation']['value']['displayName']; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['observation'] = $medical_problem_data['act']['entryRelationship']['observation']['entryRelationship'][2]['observation']['value']['code']; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['observation_text'] = $medical_problem_data['act']['entryRelationship']['observation']['entryRelationship'][2]['observation']['value']['displayName']; - $this->ccda_data_array['field_name_value_array']['lists1'][$i]['status'] = $medical_problem_data['act']['entryRelationship']['observation']['entryRelationship'][0]['observation']['value']['displayName']; - $this->ccda_data_array['entry_identification_array']['lists1'][$i] = $i; - unset($medical_problem_data); - return; - } - - public function immunization($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_immunization_value($value); - } - } - else{ - $this->fetch_immunization_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_immunization_value($immunization_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['immunization']) + 1; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['extension'] = $immunization_data['substanceAdministration']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['root'] = $immunization_data['substanceAdministration']['id']['root']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['administered_date'] = $immunization_data['substanceAdministration']['effectiveTime']['value']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['route_code'] = $immunization_data['substanceAdministration']['routeCode']['code']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['route_code_text'] = $immunization_data['substanceAdministration']['routeCode']['displayName']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['cvx_code'] = $immunization_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['code']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['cvx_code_text'] = $immunization_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['displayName']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['amount_administered'] = $immunization_data['substanceAdministration']['doseQuantity']['value']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['amount_administered_unit'] = $immunization_data['substanceAdministration']['doseQuantity']['unit']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['completion_status'] = $immunization_data['substanceAdministration']['statusCode']['code']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['manufacturer'] = $immunization_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturerOrganization']['name']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_npi'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_name'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['given']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_address'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_city'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_state'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_postalCode'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_country'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['country']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_telecom'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['telecom']['value']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['represented_organization'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['representedOrganization']['name']; - $this->ccda_data_array['field_name_value_array']['immunization'][$i]['represented_organization_tele'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['representedOrganization']['telecom']; - $this->ccda_data_array['entry_identification_array']['immunization'][$i] = $i; - unset($immunization_data); - return; - } - - public function procedure($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - if($key%3 != 0) continue;//every third entry section has the procedure details - $this->fetch_procedure_value($value); - } - } - else{ - $this->fetch_procedure_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_procedure_value($procedure_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['procedure']) + 1; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['extension'] = $procedure_data['procedure']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['root'] = $procedure_data['procedure']['id']['root']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['code'] = $procedure_data['procedure']['code']['code']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['code_text'] = $procedure_data['procedure']['code']['displayName']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['codeSystemName'] = $procedure_data['procedure']['code']['codeSystemName']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['date'] = $procedure_data['procedure']['effectiveTime']['value']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization1'] = $procedure_data['procedure']['performer']['assignedEntity']['representedOrganization']['name']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_address1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_city1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_state1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_postalcode1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_country1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['country']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_telecom1'] = $procedure_data['procedure']['performer']['assignedEntity']['telecom']['value']; - - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization2'] = $procedure_data['procedure']['participant']['participantRole']['playingEntity']['name']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_address2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_city2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_state2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_postalcode2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_country2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['country']; - $this->ccda_data_array['entry_identification_array']['procedure'][$i] = $i; - unset($procedure_data); - return; - } - - public function lab_result($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_lab_result_value($value); - } - } - else{ - $this->fetch_lab_result_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_lab_result_value($lab_result_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['procedure_result']) + 1; - foreach($lab_result_data['organizer']['component'] as $key => $value){ - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['extension'] = $lab_result_data['organizer']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['root'] = $lab_result_data['organizer']['id']['root']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['proc_code'] = $lab_result_data['organizer']['code']['code']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['proc_text'] = $lab_result_data['organizer']['code']['displayName']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['date'] = $lab_result_data['organizer']['effectiveTime']['value']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['status'] = $lab_result_data['organizer']['statusCode']['code']; - - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_extension'] = $value['observation']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_root'] = $value['observation']['id']['root']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_code'] = $value['observation']['code']['code']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_text'] = $value['observation']['code']['displayName']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_date'] = $value['observation']['effectiveTime']['value']; - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_value'] = $value['observation']['value']; - if($value['observation']['referenceRange']['observationRange']['text']) - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_range'] = $value['observation']['referenceRange']['observationRange']['text']; - else - $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_range'] = $value['observation']['referenceRange']['observationRange']['value']['low']['value'].'-'.$value['observation']['referenceRange']['observationRange']['value']['high']['value'].' '.$value['observation']['referenceRange']['observationRange']['value']['low']['unit']; - $this->ccda_data_array['entry_identification_array']['procedure_result'][$i] = $i; - $i++; - } - unset($lab_result_data); - return; - } - - public function vital_sign($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_vital_sign_value($value); - } - } - else{ - $this->fetch_vital_sign_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_vital_sign_value($vital_sign_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['vital_sign']) + 1; - $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['extension'] = $vital_sign_data['organizer']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['root'] = $vital_sign_data['organizer']['id']['root']; - $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['date'] = $vital_sign_data['organizer']['effectiveTime']['value']; - $vitals_array = array( - '8310-5' => 'temperature', - '8462-4' => 'bpd', - '8480-6' => 'bps', - '8287-5' => 'head_circ', - '8867-4' => 'pulse', - '8302-2' => 'height', - '2710-2' => 'oxygen_saturation', - '9279-1' => 'respiration', - '3141-9' => 'weight' - ); - - for($j=0 ; $j<9 ; $j++){ - $code = $vital_sign_data['organizer']['component'][$j]['observation']['code']['code']; - if($vital_sign_data['organizer']['component'][$j]['observation']['entryRelationship']) { - $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['bps'] = $vital_sign_data['organizer']['component'][$j]['observation']['entryRelationship'][0]['observation']['value']['value']; - $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['bpd'] = $vital_sign_data['organizer']['component'][$j]['observation']['entryRelationship'][1]['observation']['value']['value']; - } - else - $this->ccda_data_array['field_name_value_array']['vital_sign'][$i][$vitals_array[$code]] = $vital_sign_data['organizer']['component'][$j]['observation']['value']['value']; - } - $this->ccda_data_array['entry_identification_array']['vital_sign'][$i] = $i; - unset($vital_sign_data); - return; - } - - public function social_history($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_social_history_value($value); - } - } - else{ - $this->fetch_social_history_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_social_history_value($social_history_data) - { - $social_history_array = array( - '2.16.840.1.113883.10.20.22.4.78' => 'smoking' - ); - $i = 0; - $code = $social_history_data['observation']['templateId']['root']; - foreach($this->ccda_data_array['field_name_value_array']['social_history'] as $key => $value){ - if(!array_key_exists($social_history_array[$code], $value)){ - $i = $key; - } - else { - $i = count($this->ccda_data_array['field_name_value_array']['social_history']) + 1; - } - } - $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['extension'] = $social_history_data['observation']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['root'] = $social_history_data['observation']['id']['root']; - $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['status'] = $social_history_data['observation']['value']['code']; - $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['begdate'] = $social_history_data['observation']['effectiveTime']['low']['value']; - $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['enddate'] = $social_history_data['observation']['effectiveTime']['high']['value']; - $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['value'] = $social_history_data['observation']['value']['displayName']; - $this->ccda_data_array['entry_identification_array']['social_history'][$i] = $i; - unset($social_history_data); - return; - } - - public function encounter($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_encounter_value($value); - } - } - else{ - $this->fetch_encounter_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_encounter_value($encounter_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['encounter']) + 1; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['extension'] = $encounter_data['encounter']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['root'] = $encounter_data['encounter']['id']['root']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['date'] = $encounter_data['encounter']['effectiveTime']['value']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['code'] = $encounter_data['encounter']['code']['code']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['code_text'] = $encounter_data['encounter']['code']['displayName']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_npi'] = $encounter_data['encounter']['performer']['assignedEntity']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_name'] = $encounter_data['encounter']['performer']['assignedEntity']['assignedPerson']['name']['given']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_address'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_city'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_state'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_postalCode'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_country'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['country']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_name'] = $encounter_data['encounter']['participant']['participantRole']['playingEntity']['name']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_address'] = $encounter_data['encounter']['participant']['participantRole']['addr']['streetAddressLine']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_city'] = $encounter_data['encounter']['participant']['participantRole']['addr']['city']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_state'] = $encounter_data['encounter']['participant']['participantRole']['addr']['state']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_zip'] = $encounter_data['encounter']['participant']['participantRole']['addr']['postalCode']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_country'] = $encounter_data['encounter']['participant']['participantRole']['addr']['country']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_telecom'] = $encounter_data['encounter']['participant']['participantRole']['telecom']; - - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['encounter_diagnosis_date'] = $encounter_data['encounter']['entryRelationship'][1]['act']['entryRelationship']['observation']['effectiveTime']['low']['value']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['encounter_diagnosis_code'] = $encounter_data['encounter']['entryRelationship'][1]['act']['entryRelationship']['observation']['value']['code']; - $this->ccda_data_array['field_name_value_array']['encounter'][$i]['encounter_diagnosis_issue'] = $encounter_data['encounter']['entryRelationship'][1]['act']['entryRelationship']['observation']['value']['displayName']; - $this->ccda_data_array['entry_identification_array']['encounter'][$i] = $i; - unset($encounter_data); - return; - } - - public function care_plan($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_care_plan_value($value); - } - } - else{ - $this->fetch_care_plan_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_care_plan_value($care_plan_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['care_plan']) + 1; - $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['extension'] = $care_plan_data['act']['templateId']['root']; - $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['root'] = $care_plan_data['act']['templateId']['root']; - $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['code'] = $care_plan_data['act']['code']['code']; - $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['code_text'] = $care_plan_data['act']['code']['displayName']; - $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['description'] = $care_plan_data['act']['text']; - $this->ccda_data_array['entry_identification_array']['care_plan'][$i] = $i; - unset($care_plan_data); - return; - } - - public function functional_cognitive_status($component) - { - $component['section']['text'] = ''; - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_functional_cognitive_status_value($value); - } - } - else{ - $this->fetch_functional_cognitive_status_value($component['section']['entry']); - } - unset($component); - return; - } - - public function fetch_functional_cognitive_status_value($functional_cognitive_status_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['functional_cognitive_status']) + 1; - $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['extension'] = $functional_cognitive_status_data['observation']['id']['extension']; - $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['root'] = $functional_cognitive_status_data['observation']['id']['root']; - $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['date'] = $functional_cognitive_status_data['observation']['effectiveTime']['low']['value']; - $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['code'] = $functional_cognitive_status_data['observation']['value']['code']; - $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['code_text'] = $functional_cognitive_status_data['observation']['code']['displayName']; - $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['description'] = $functional_cognitive_status_data['observation']['value']['displayName']; - $this->ccda_data_array['entry_identification_array']['functional_cognitive_status'][$i] = $i; - unset($functional_cognitive_status_data); - return; - } - - public function referral($component) - { - if($component['section']['entry'][0]){ - foreach($component['section']['entry'] as $key => $value){ - $this->fetch_referral_value($value); - } - } - else{ - $this->fetch_referral_value($component['section']); - } - unset($component); - return; - } - - public function fetch_referral_value($referral_data) - { - $i = count($this->ccda_data_array['field_name_value_array']['referral']) + 1; - $this->ccda_data_array['field_name_value_array']['referral'][$i]['root'] = $referral_data['templateId']['root']; - $this->ccda_data_array['field_name_value_array']['referral'][$i]['body'] = $referral_data['text']['paragraph']; - - $this->ccda_data_array['entry_identification_array']['referral'][$i] = $i; - unset($referral_data); - return; - } - /* - * Fetch a document from the database - * - * @param $document_id Integer Document ID - * @return $content String File content - */ - public function getDocument($document_id) - { - $content = \Documents\Plugin\Documents::getDocument($document_id); - return $content; - } - - public function getCategory() - { - $doc_obj = new DocumentsTable(); - $category = $doc_obj->getCategory(); - return $category; - } - - public function getIssues($pid) - { - $doc_obj = new DocumentsTable(); - $issues = $doc_obj->getIssues($pid); - return $issues; - } - - public function getCategoryIDs() - { - $doc_obj = new DocumentsTable(); - $result = implode("|",$doc_obj->getCategoryIDs(array('CCD','CCR','CCDA'))); - return $result; - } - - /* - * Fetch the demographics data from audit tables - * - * @param audit_master_id Integer ID from audit master table - * @return records Array Demographics data - */ - public function getDemographics($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT ad.id as adid, - table_name, - field_name, - field_value - FROM audit_master am - JOIN audit_details ad ON ad.audit_master_id = am.id - WHERE am.id = ? AND ad.table_name = 'patient_data' - ORDER BY ad.id"; - $result = $appTable->zQuery($query, array($data['audit_master_id'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the current demographics data of a patient from patient_data table - * - * @param pid Integer Patient ID - * @return records Array current patient data - */ - public function getDemographicsOld($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM patient_data - WHERE pid = ?"; - $result = $appTable->zQuery($query, array($data['pid'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the current Problems of a patient from lists table - * - * @param pid Integer patient id - * @return records Array list of problems - */ - public function getProblems($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM lists - WHERE pid = ? AND TYPE = 'medical_problem'"; - $result = $appTable->zQuery($query, array($data['pid'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the current Allergies of a patient from lists table - * - * @param pid Integer patient id - * @return records Array list of allergies - */ - public function getAllergies($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM lists - WHERE pid = ? AND TYPE = 'allergy'"; - $result = $appTable->zQuery($query, array($data['pid'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the current Medications of a patient from prescriptions table - * - * @param pid Integer patient id - * @return records Array list of medications - */ - public function getMedications($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM prescriptions - WHERE patient_id = ?"; - $result = $appTable->zQuery($query, array($data['pid'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the current Immunizations of a patient from immunizations table - * - * @param pid Integer patient id - * @return records Array list of immunizations - */ - public function getImmunizations($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM immunizations - WHERE patient_id = ?";//removed the field 'added_erroneously' from where condition - $result = $appTable->zQuery($query, array($data['pid'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the currect Lab Results of a patient - * - * @param pid Integer patient id - * @return records Array list of lab results - */ - public function getLabResults($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT CONCAT_WS('',po.procedure_order_id,poc.`procedure_order_seq`) AS tcode, - prs.result AS result_value, - prs.units, prs.range, - IF(prs.order_title!='', prs.order_title,poc.procedure_name ) AS order_title, - prs.result_code as result_code, - prs.result_text as result_desc, - prs.code_suffix AS test_code, - po.date_ordered, - prs.date AS result_time, - prs.abnormal AS abnormal_flag, - prs.procedure_result_id AS result_id - FROM procedure_order AS po - JOIN procedure_order_code AS poc ON poc.`procedure_order_id`=po.`procedure_order_id` - JOIN procedure_report AS pr ON pr.procedure_order_id = po.procedure_order_id - AND pr.`procedure_order_seq`=poc.`procedure_order_seq` - JOIN procedure_result AS prs ON prs.procedure_report_id = pr.procedure_report_id - WHERE po.patient_id = ? AND prs.result NOT IN ('DNR','TNP')"; - $result = $appTable->zQuery($query, array($data['pid'],$data['pid'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the current Vitals of a patient from form_vitals table - * - * @param pid Integer patient id - * @return records Array list of vitals - */ - public function getVitals($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM form_vitals - WHERE pid = ? AND activity=?"; - $result = $appTable->zQuery($query, array($data['pid'],1)); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the social history of a patient from history_data table - * - * @param pid Integer patient id - * @return records Array history data - */ - public function getSocialHistory($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM history_data - WHERE pid=? - ORDER BY id DESC LIMIT 1"; - $result = $appTable->zQuery($query, array($data['pid'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the encounter data of a patient from form_encounter table - * - * @param pid Integer patient id - * @return records Array encounter data - */ - public function getEncounterData($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT form_encounter.*,u.fname AS provider_name - FROM form_encounter - LEFT JOIN users AS u - ON form_encounter.provider_id=u.id - WHERE pid = ?"; - $result = $appTable->zQuery($query, array($data['pid'])); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the billing data of a patient from billing table - * - * @param pid Integer patient id - * @return records Array billing data - */ - public function getProcedure($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM billing - WHERE pid=? AND code_type=?"; - $result = $appTable->zQuery($query,array($data['pid'],'CPT4')); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the current Care Plan of a patient from form_care_paln table - * - * @param pid Integer patient id - * @return records Array list of Care Plans - */ - public function getCarePlan($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM form_care_plan - WHERE pid = ? AND activity=?"; - $result = $appTable->zQuery($query, array($data['pid'],1)); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the current Functional Cognitive Status of a patient from form_functional_cognitive_status table - * - * @param pid Integer patient id - * @return records Array list of Functional Cognitive Status - */ - public function getFunctionalCognitiveStatus($data) - { - $appTable = new ApplicationTable(); - $query = "SELECT * - FROM form_functional_cognitive_status - WHERE pid = ? AND activity=?"; - $result = $appTable->zQuery($query, array($data['pid'],1)); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } - - /* - * Fetch the data from audit tables - * - * @param am_id integer audit master ID - * @param table_name string identifier inserted for each table (eg: prescriptions, list1 ...) - */ - public function createAuditArray($am_id,$table_name) - { - $appTable = new ApplicationTable(); - if(strpos($table_name,',')){ - $tables = explode(',',$table_name); - $arr = array($am_id); - $table_qry = ""; - for($i = 0 ; $i < count($tables) ; $i++){ - $table_qry .= "?,"; - array_unshift($arr, $tables[$i]); - } - $table_qry = substr($table_qry,0,-1); - $query = "SELECT * - FROM audit_master am - LEFT JOIN audit_details ad - ON ad.audit_master_id = am.id - AND ad.table_name IN ($table_qry) - WHERE am.id = ? AND am.type = 12 AND am.approval_status = 1 - ORDER BY ad.entry_identification,ad.field_name"; - $result = $appTable->zQuery($query, $arr); - } - else{ - $query = "SELECT * - FROM audit_master am - LEFT JOIN audit_details ad - ON ad.audit_master_id = am.id - AND ad.table_name = ? - WHERE am.id = ? AND am.type = 12 AND am.approval_status = 1 - ORDER BY ad.entry_identification,ad.field_name"; - $result = $appTable->zQuery($query, array($table_name, $am_id)); - } - $records = array(); - foreach($result as $res){ - $records[$table_name][$res['entry_identification']][$res['field_name']] = $res['field_value']; - } - return $records; - } - - public function getListTitle($option_id='',$list_id,$codes='') - { - $appTable = new ApplicationTable(); - if($option_id) { - $query = "SELECT title - FROM list_options - WHERE list_id=? AND option_id=? AND activity=?"; - $result = $appTable->zQuery($query,array($list_id,$option_id,1)); - $res_cur = $result->current(); - } - if($codes) { - $query = "SELECT title - FROM list_options - WHERE list_id=? AND (codes=? OR option_id=?) AND activity=?"; - $result = $appTable->zQuery($query,array($list_id,$codes,$option_id,1)); - $res_cur = $result->current(); - } - return $res_cur['title']; - } - - public function insertApprovedData($data) - { - $appTable = new ApplicationTable(); - $patient_data_fields = ''; - $patient_data_values = array(); - $j = 1; - $y = 1; - $k = 1; - $q = 1; - $a = 1; - $b = 1; - $c = 1; - $d = 1; - $e = 1; - $f = 1; - - $arr_procedure_res = array(); - $arr_procedures = array(); - $arr_vitals = array(); - $arr_encounter = array(); - $arr_immunization = array(); - $arr_prescriptions = array(); - $arr_allergies = array(); - $arr_med_pblm = array(); - $arr_care_plan = array(); - $arr_functional_cognitive_status = array(); - - foreach($data as $key=>$val){ - if(substr($key,-4) == '-sel'){ - if(is_array($val)){ - for($i=0;$izQuery($query,array($data['pid'], - $tobacco, - $alcohol, - date('Y-m-d H:i:s'))); - } - else if(substr($key,0,-4) == 'encounter'){ - $arr_encounter['encounter'][$k]['extension'] = $data['encounter-extension'][$i]; - $arr_encounter['encounter'][$k]['root'] = $data['encounter-root'][$i]; - $arr_encounter['encounter'][$k]['date'] = $data['encounter-date'][$i]; - - $arr_encounter['encounter'][$k]['provider_npi'] = $data['encounter-provider_npi'][$i]; - $arr_encounter['encounter'][$k]['provider_name'] = $data['encounter-provider'][$i]; - $arr_encounter['encounter'][$k]['provider_address'] = $data['encounter-provider_address'][$i]; - $arr_encounter['encounter'][$k]['provider_city'] = $data['encounter-provider_city'][$i]; - $arr_encounter['encounter'][$k]['provider_state'] = $data['encounter-provider_state'][$i]; - $arr_encounter['encounter'][$k]['provider_postalCode'] = $data['encounter-provider_postalCode'][$i]; - $arr_encounter['encounter'][$k]['provider_country'] = $data['encounter-provider_country'][$i]; - - $arr_encounter['encounter'][$k]['represented_organization_name'] = $data['encounter-facility'][$i]; - $arr_encounter['encounter'][$k]['represented_organization_address'] = $data['encounter-represented_organization_address'][$i]; - $arr_encounter['encounter'][$k]['represented_organization_city'] = $data['encounter-represented_organization_city'][$i]; - $arr_encounter['encounter'][$k]['represented_organization_state'] = $data['encounter-represented_organization_state'][$i]; - $arr_encounter['encounter'][$k]['represented_organization_zip'] = $data['encounter-represented_organization_zip'][$i]; - $arr_encounter['encounter'][$k]['represented_organization_country'] = $data['encounter-represented_organization_country'][$i]; - $arr_encounter['encounter'][$k]['represented_organization_telecom'] = $data['encounter-represented_organization_telecom'][$i]; - - $arr_encounter['encounter'][$k]['encounter_diagnosis_date'] = $data['encounter-encounter_diagnosis_date'][$i]; - $arr_encounter['encounter'][$k]['encounter_diagnosis_code'] = $data['encounter-encounter_diagnosis_code'][$i]; - $arr_encounter['encounter'][$k]['encounter_diagnosis_issue'] = $data['encounter-encounter_diagnosis_issue'][$i]; - $k++; - } - else if(substr($key,0,-4) == 'procedure_result'){ - $arr_procedure_res['procedure_result'][$j]['proc_text'] = $data['procedure_result-proc_text'][$i]; - $arr_procedure_res['procedure_result'][$j]['proc_code'] = $data['procedure_result-proc_code'][$i]; - $arr_procedure_res['procedure_result'][$j]['extension'] = $data['procedure_result-extension'][$i]; - $arr_procedure_res['procedure_result'][$j]['date'] = $data['procedure_result-date'][$i]; - $arr_procedure_res['procedure_result'][$j]['status'] = $data['procedure_result-status'][$i]; - $arr_procedure_res['procedure_result'][$j]['results_text'] = $data['procedure_result-result'][$i]; - $arr_procedure_res['procedure_result'][$j]['results_code'] = $data['procedure_result-result_code'][$i]; - $arr_procedure_res['procedure_result'][$j]['results_range'] = $data['procedure_result-result_range'][$i]; - $arr_procedure_res['procedure_result'][$j]['results_value'] = $data['procedure_result-result_value'][$i]; - $arr_procedure_res['procedure_result'][$j]['results_date'] = $data['procedure_result-result_date'][$i]; - $j++; - } - else if(substr($key,0,-4) == 'procedure'){ - - $arr_procedures['procedure'][$y]['extension'] = $data['procedure-extension'][$i]; - $arr_procedures['procedure'][$y]['root'] = $data['procedure-root'][$i]; - $arr_procedures['procedure'][$y]['codeSystemName'] = $data['procedure-codeSystemName'][$i]; - $arr_procedures['procedure'][$y]['code'] = $data['procedure-code'][$i]; - $arr_procedures['procedure'][$y]['code_text'] = $data['procedure-code_text'][$i]; - $arr_procedures['procedure'][$y]['date'] = $data['procedure-date'][$i]; - - $arr_procedures['procedure'][$y]['represented_organization1'] = $data['procedure-represented_organization1'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_address1'] = $data['procedure-represented_organization_address1'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_city1'] = $data['procedure-represented_organization_city1'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_state1'] = $data['procedure-represented_organization_state1'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_postalcode1'] = $data['procedure-represented_organization_postalcode1'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_country1'] = $data['procedure-represented_organization_country1'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_telecom1'] = $data['procedure-represented_organization_telecom1'][$i]; - - $arr_procedures['procedure'][$y]['represented_organization2'] = $data['procedure-represented_organization2'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_address2'] = $data['procedure-represented_organization_address2'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_city2'] = $data['procedure-represented_organization_city2'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_state2'] = $data['procedure-represented_organization_state2'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_postalcode2'] = $data['procedure-represented_organization_postalcode2'][$i]; - $arr_procedures['procedure'][$y]['represented_organization_country2'] = $data['procedure-represented_organization_country2'][$i]; - $y++; - } - elseif(substr($key,0,-4) == 'care_plan') { - $arr_care_plan['care_plan'][$e]['extension'] = $data['care_plan-extension'][$i]; - $arr_care_plan['care_plan'][$e]['root'] = $data['care_plan-root'][$i]; - $arr_care_plan['care_plan'][$e]['text'] = $data['care_plan-text'][$i]; - $arr_care_plan['care_plan'][$e]['code'] = $data['care_plan-code'][$i]; - $arr_care_plan['care_plan'][$e]['description'] = $data['care_plan-description'][$i]; - $e++; - } - elseif(substr($key,0,-4) == 'functional_cognitive_status') { - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['extension'] = $data['functional_cognitive_status-extension'][$i]; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['root'] = $data['functional_cognitive_status-root'][$i]; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['text'] = $data['functional_cognitive_status-text'][$i]; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['code'] = $data['functional_cognitive_status-code'][$i]; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['date'] = $data['functional_cognitive_status-date'][$i]; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['description'] = $data['functional_cognitive_status-description'][$i]; - $f++; - } - } - elseif($val[$i] == 'update'){ - if(substr($key,0,-8) == 'lists1'){ - if($data['lists1-upd_activity'][$i] == 'Active'){ - $activity = 1; - } - elseif($data['lists1-upd_activity'][$i] == 'Inactive'){ - $activity = 0; - } - $query = "UPDATE lists - SET title=?, - diagnosis=?, - activity=? - WHERE pid=? AND diagnosis=?"; - $appTable->zQuery($query,array($data['lists1-upd_title'][$i], - $data['lists1-upd_diagnosis'][$i], - $activity, - $data['pid'], - $data['lists1-old-diagnosis'][$i])); - } - } - } - } - else - if(substr($key,0,12) == 'patient_data'){ - if($val == 'update'){ - $var_name = substr($key,0,-4); - $field_name = substr($var_name,13); - $patient_data_fields .= $field_name.'=?,'; - array_push($patient_data_values,$data[$var_name]); - } - } - } - } - - if(count($patient_data_values) > 0){ - array_push($patient_data_values,$data['pid']); - $patient_data_fields = substr($patient_data_fields,0,-1); - $query = "UPDATE patient_data SET $patient_data_fields WHERE pid=?"; - $appTable->zQuery($query, $patient_data_values); - } - $appTable->zQuery("UPDATE documents - SET foreign_id = ? - WHERE id =? ", array($data['pid'], - $data['document_id'])); - $appTable->zQuery("UPDATE audit_master - SET approval_status = '2' - WHERE id=?", array($data['amid'])); - $appTable->zQuery("UPDATE documents - SET audit_master_approval_status=2 - WHERE audit_master_id=?", array($data['amid'])); - - $this->InsertImmunization($arr_immunization['immunization'],$data['pid'],1); - $this->InsertPrescriptions($arr_prescriptions['lists3'],$data['pid'],1); - $this->InsertAllergies($arr_allergies['lists2'],$data['pid'],1); - $this->InsertMedicalProblem($arr_med_pblm['lists1'],$data['pid'],1); - $this->InsertEncounter($arr_encounter['encounter'],$data['pid'],1); - $this->InsertVitals($arr_vitals['vitals'],$data['pid'],1); - $this->InsertProcedures($arr_procedures['procedure'],$data['pid'],1); - $lab_results = $this->buildLabArray($arr_procedure_res['procedure_result']); - $this->InsertLabResults($lab_results,$data['pid']); - $this->InsertCarePlan($arr_care_plan['care_plan'],$data['pid'],1); - $this->InsertFunctionalCognitiveStatus($arr_functional_cognitive_status['functional_cognitive_status'],$data['pid'],1); - } - - public function discardCCDAData($data) - { - $appTable = new ApplicationTable(); - $query = "UPDATE audit_master - SET approval_status = '3' - WHERE id=?"; - $appTable->zQuery($query, array($data['audit_master_id'])); - $appTable->zQuery("UPDATE documents - SET audit_master_approval_status='3' - WHERE audit_master_id=?",array($data['audit_master_id'])); - } - - public function buildLabArray($lab_array) - { - $lab_results = array(); - $j = 0; - foreach($lab_array as $key=>$value) { - $j = count($lab_results[$value['extension']]['result']) + 1; - $lab_results[$value['extension']]['proc_text'] = $value['proc_text']; - $lab_results[$value['extension']]['date'] = $value['date']; - $lab_results[$value['extension']]['proc_code'] = $value['proc_code']; - $lab_results[$value['extension']]['extension'] = $value['extension']; - $lab_results[$value['extension']]['status'] = $value['status']; - $lab_results[$value['extension']]['result'][$j]['result_date'] = $value['results_date']; - $lab_results[$value['extension']]['result'][$j]['result_text'] = $value['results_text']; - $lab_results[$value['extension']]['result'][$j]['result_value'] = $value['results_value']; - $lab_results[$value['extension']]['result'][$j]['result_range'] = $value['results_range']; - $lab_results[$value['extension']]['result'][$j]['result_code'] = $value['results_code']; - } - return $lab_results; - } - - public function InsertLabResults($lab_results,$pid) - { - $appTable = new ApplicationTable(); - foreach($lab_results as $key=>$value) { - $query_select_pro = "SELECT * FROM procedure_providers WHERE name = ?"; - $result_pro = $appTable->zQuery($query_select_pro,array('External Lab')); - if($result_pro->count() == 0) { - $query_insert_pro = "INSERT INTO procedure_providers(name) VALUES (?)"; - $result_pro = $appTable->zQuery($query_insert_pro, array('External Lab')); - $pro_id = $result_pro->getGeneratedValue(); - } - else { - foreach ($result_pro as $value1) { - $pro_id = $value1['ppid']; - } - } - $enc = $appTable->zQuery("SELECT encounter - FROM form_encounter - WHERE pid=? - ORDER BY id DESC LIMIT 1",array($pid)); - $enc_cur = $enc->current(); - $enc_id = $enc_cur['encounter'] ? $enc_cur['encounter'] : 0; - - foreach($value['result'] as $res) { - $query_select_pt = "SELECT * FROM procedure_type WHERE procedure_code = ? AND lab_id = ?"; - $result_pt = $appTable->zQuery($query_select_pt,array($res['result_code'],$pro_id)); - if($result_pt->count() == 0) { - //procedure_type - $query_insert_pt = "INSERT INTO procedure_type(name,lab_id,procedure_code,procedure_type,activity) VALUES (?,?,?,?,?)"; - $result_pt = $appTable->zQuery($query_insert_pt, array($res['result_text'],$pro_id,$res['result_code'],'ord',1)); - $res_pt_id = $result_pt->getGeneratedValue(); - $query_update_pt= "UPDATE procedure_type SET parent = ? WHERE procedure_type_id = ?"; - $appTable->zQuery($query_update_pt,array($res_pt_id,$res_pt_id)); - } - //procedure_order - $query_insert_po = "INSERT INTO procedure_order(provider_id,patient_id,encounter_id,date_collected,date_ordered,order_priority,order_status,activity,lab_id) VALUES (?,?,?,?,?,?,?,?,?)"; - $result_po = $appTable->zQuery($query_insert_po,array('',$pid,$enc_id,\Application\Model\ApplicationTable::fixDate($res['result_date'],'yyyy-mm-dd','dd/mm/yyyy'),\Application\Model\ApplicationTable::fixDate($res['result_date'],'yyyy-mm-dd','dd/mm/yyyy'),'normal','completed',1,$pro_id)); - $po_id = $result_po->getGeneratedValue(); - //procedure_order_code - $query_insert_poc = "INSERT INTO procedure_order_code(procedure_order_id,procedure_order_seq,procedure_code,procedure_name,diagnoses) VALUES (?,?,?,?,?)"; - $result_poc = $appTable->zQuery($query_insert_poc,array($po_id,1,$res['result_code'],$res['result_text'],'LOINC:'.$res['result_code'])); - //procedure_report - $query_insert_pr = "INSERT INTO procedure_report(procedure_order_id,date_collected,report_status,review_status) VALUES (?,?,?,?)"; - $result_pr = $appTable->zQuery($query_insert_pr,array($po_id,\Application\Model\ApplicationTable::fixDate($res['result_date'],'yyyy-mm-dd','dd/mm/yyyy'),'final','reviewed')); - $res_id = $result_pr->getGeneratedValue(); - //procedure_result - $range_unit = explode(' ',$res['result_range']); - $range = $range_unit[0]; - $unit = $range_unit[1]; - if($unit != '') { - $qU_select = "SELECT * FROM list_options WHERE list_id = ? AND option_id = ?"; - $Ures = $appTable->zQuery($qU_select, array('proc_unit',$unit)); - if($Ures->count() == 0) { - $qU_insert = "INSERT INTO list_options(list_id,option_id,title,activity) VALUES (?,?,?,?)"; - $appTable->zQuery($qU_insert, array('proc_unit',$unit,$unit,1)); - } - else { - $qU_update = "UPDATE list_options SET activity = 1 WHERE list_id = ? AND option_id = ?"; - $appTable->zQuery($qU_update, array('proc_unit',$unit)); - } - $query_insert_prs = "INSERT INTO procedure_result(procedure_report_id,result_code,date,units,result,`range`,result_text,result_status) VALUES (?,?,?,?,?,?,?,?)"; - $result_prs = $appTable->zQuery($query_insert_prs,array($res_id,$res['result_code'],\Application\Model\ApplicationTable::fixDate($res['result_date'],'yyyy-mm-dd','dd/mm/yyyy'),$unit,$res['result_value'],$range,$res['result_text'],'final')); - } - } - } - } - - public function insert_patient($audit_master_id,$document_id) - { - require_once(dirname(__FILE__) . "/../../../../../../../../library/patient.inc"); - $pid = 0; - $j = 1; - $k = 1; - $q = 1; - $y = 1; - $a = 1; - $b = 1; - $c = 1; - $d = 1; - $e = 1; - $f = 1; - - $arr_procedure_res = array(); - $arr_encounter = array(); - $arr_vitals = array(); - $arr_procedures = array(); - $arr_immunization = array(); - $arr_prescriptions = array(); - $arr_allergies = array(); - $arr_med_pblm = array(); - $arr_care_plan = array(); - $arr_functional_cognitive_status = array(); - $appTable = new ApplicationTable(); - - $pres = $appTable->zQuery("SELECT IFNULL(MAX(pid)+1,1) AS pid - FROM patient_data"); - foreach($pres as $prow){ - $pid = $prow['pid']; - } - $res = $appTable->zQuery("SELECT DISTINCT ad.table_name, - entry_identification - FROM audit_master as am,audit_details as ad - WHERE am.id=ad.audit_master_id AND - am.approval_status = '1' AND - am.id=? AND am.type=12 - ORDER BY ad.id", array($audit_master_id)); - $tablecnt = $res->count(); - foreach($res as $row){ - $resfield = $appTable->zQuery("SELECT * - FROM audit_details - WHERE audit_master_id=? AND - table_name=? AND - entry_identification=?", array($audit_master_id, - $row['table_name'], - $row['entry_identification'])); - $table = $row['table_name']; - $newdata = array(); - foreach($resfield as $rowfield){ - if($table == 'patient_data'){ - if($rowfield['field_name'] == 'DOB'){ - $dob = $this->formatDate($rowfield['field_value'],1); - $newdata['patient_data'][$rowfield['field_name']] = $dob; - } - else{ - if($rowfield['field_name'] == 'religion'){ - $religion_option_id = $this->getOptionId('religious_affiliation',$rowfield['field_value'],''); - $newdata['patient_data'][$rowfield['field_name']] = $religion_option_id; - } - elseif($rowfield['field_name'] == 'race'){ - $race_option_id = $this->getOptionId('race',$rowfield['field_value'],''); - $newdata['patient_data'][$rowfield['field_name']] = $race_option_id; - } - elseif($rowfield['field_name'] == 'ethnicity'){ - $ethnicity_option_id = $this->getOptionId('ethnicity',$rowfield['field_value'],''); - $newdata['patient_data'][$rowfield['field_name']] = $ethnicity_option_id; - } - else - $newdata['patient_data'][$rowfield['field_name']] = $rowfield['field_value']; - } - } - elseif($table == 'immunization'){ - $newdata['immunization'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'lists3'){ - $newdata['lists3'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'lists1'){ - $newdata['lists1'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'lists2'){ - $newdata['lists2'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'vital_sign') { - $newdata['vital_sign'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'social_history') { - $newdata['social_history'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'encounter') { - $newdata['encounter'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'procedure_result') { - $newdata['procedure_result'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'procedure') { - $newdata['procedure'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'care_plan') { - $newdata['care_plan'][$rowfield['field_name']] = $rowfield['field_value']; - } - elseif($table == 'functional_cognitive_status') { - $newdata['functional_cognitive_status'][$rowfield['field_name']] = $rowfield['field_value']; - } - } - if($table == 'patient_data'){ - updatePatientData($pid,$newdata['patient_data'],true); - } - elseif($table == 'immunization'){ - $arr_immunization['immunization'][$a]['extension'] = $newdata['immunization']['extension']; - $arr_immunization['immunization'][$a]['root'] = $newdata['immunization']['root']; - $arr_immunization['immunization'][$a]['administered_date'] = $newdata['immunization']['administered_date']; - $arr_immunization['immunization'][$a]['route_code'] = $newdata['immunization']['route_code']; - $arr_immunization['immunization'][$a]['route_code_text'] = $newdata['immunization']['route_code_text']; - $arr_immunization['immunization'][$a]['cvx_code_text'] = $newdata['immunization']['cvx_code_text']; - $arr_immunization['immunization'][$a]['cvx_code'] = $newdata['immunization']['cvx_code']; - $arr_immunization['immunization'][$a]['amount_administered'] = $newdata['immunization']['amount_administered']; - $arr_immunization['immunization'][$a]['amount_administered_unit'] = $newdata['immunization']['amount_administered_unit']; - $arr_immunization['immunization'][$a]['manufacturer'] = $newdata['immunization']['manufacturer']; - $arr_immunization['immunization'][$a]['completion_status'] = $newdata['immunization']['completion_status']; - - $arr_immunization['immunization'][$a]['provider_npi'] = $newdata['immunization']['provider_npi']; - $arr_immunization['immunization'][$a]['provider_name'] = $newdata['immunization']['provider_name']; - $arr_immunization['immunization'][$a]['provider_address'] = $newdata['immunization']['provider_address']; - $arr_immunization['immunization'][$a]['provider_city'] = $newdata['immunization']['provider_city']; - $arr_immunization['immunization'][$a]['provider_state'] = $newdata['immunization']['provider_state']; - $arr_immunization['immunization'][$a]['provider_postalCode'] = $newdata['immunization']['provider_postalCode']; - $arr_immunization['immunization'][$a]['provider_country'] = $newdata['immunization']['provider_country']; - $arr_immunization['immunization'][$a]['provider_telecom'] = $newdata['immunization']['provider_telecom']; - $arr_immunization['immunization'][$a]['represented_organization'] = $newdata['immunization']['represented_organization']; - $arr_immunization['immunization'][$a]['represented_organization_tele'] = $newdata['immunization']['represented_organization_tele']; - $a++; - } - elseif($table == 'lists3'){ - $arr_prescriptions['lists3'][$b]['extension'] = $newdata['lists3']['extension']; - $arr_prescriptions['lists3'][$b]['root'] = $newdata['lists3']['root']; - $arr_prescriptions['lists3'][$b]['begdate'] = $newdata['lists3']['begdate']; - $arr_prescriptions['lists3'][$b]['enddate'] = $newdata['lists3']['enddate']; - $arr_prescriptions['lists3'][$b]['route'] = $newdata['lists3']['route']; - $arr_prescriptions['lists3'][$b]['note'] = $newdata['lists3']['note']; - $arr_prescriptions['lists3'][$b]['indication'] = $newdata['lists3']['indication']; - $arr_prescriptions['lists3'][$b]['route_display'] = $newdata['lists3']['route_display']; - $arr_prescriptions['lists3'][$b]['dose'] = $newdata['lists3']['dose']; - $arr_prescriptions['lists3'][$b]['dose_unit'] = $newdata['lists3']['dose_unit']; - $arr_prescriptions['lists3'][$b]['rate'] = $newdata['lists3']['rate']; - $arr_prescriptions['lists3'][$b]['rate_unit'] = $newdata['lists3']['rate_unit']; - $arr_prescriptions['lists3'][$b]['drug_code'] = $newdata['lists3']['drug_code']; - $arr_prescriptions['lists3'][$b]['drug_text'] = $newdata['lists3']['drug_text']; - $arr_prescriptions['lists3'][$b]['prn'] = $newdata['lists3']['prn']; - - $arr_prescriptions['lists3'][$b]['provider_address'] = $newdata['lists3']['provider_address']; - $arr_prescriptions['lists3'][$b]['provider_city'] = $newdata['lists3']['provider_city']; - $arr_prescriptions['lists3'][$b]['provider_country'] = $newdata['lists3']['provider_country']; - $arr_prescriptions['lists3'][$b]['provider_title'] = $newdata['lists3']['provider_title']; - $arr_prescriptions['lists3'][$b]['provider_fname'] = $newdata['lists3']['provider_fname']; - $arr_prescriptions['lists3'][$b]['provider_lname'] = $newdata['lists3']['provider_lname']; - $arr_prescriptions['lists3'][$b]['provider_postalCode'] = $newdata['lists3']['provider_postalCode']; - $arr_prescriptions['lists3'][$b]['provider_state'] = $newdata['lists3']['provider_state']; - $arr_prescriptions['lists3'][$b]['provider_root'] = $newdata['lists3']['provider_root']; - $b++; - } - elseif($table == 'lists1' && $newdata['lists1']['list_code'] !=0){ - $arr_med_pblm['lists1'][$d]['extension'] = $newdata['lists1']['extension']; - $arr_med_pblm['lists1'][$d]['root'] = $newdata['lists1']['root']; - $arr_med_pblm['lists1'][$d]['begdate'] = $newdata['lists1']['begdate']; - $arr_med_pblm['lists1'][$d]['enddate'] = $newdata['lists1']['enddate']; - $arr_med_pblm['lists1'][$d]['list_code'] = $newdata['lists1']['list_code']; - $arr_med_pblm['lists1'][$d]['list_code_text'] = $newdata['lists1']['list_code_text']; - $arr_med_pblm['lists1'][$d]['status'] = $newdata['lists1']['status']; - $arr_med_pblm['lists1'][$d]['observation_text'] = $newdata['lists1']['observation_text']; - $arr_med_pblm['lists1'][$d]['observation_code'] = $newdata['lists1']['observation']; - $d++; - } - elseif($table == 'lists2' && $newdata['lists2']['list_code'] !=0){ - $arr_allergies['lists2'][$c]['extension'] = $newdata['lists2']['extension']; - $arr_allergies['lists2'][$c]['begdate'] = $newdata['lists2']['begdate']; - $arr_allergies['lists2'][$c]['enddate'] = $newdata['lists2']['enddate']; - $arr_allergies['lists2'][$c]['list_code'] = $newdata['lists2']['list_code']; - $arr_allergies['lists2'][$c]['list_code_text'] = $newdata['lists2']['list_code_text']; - $arr_allergies['lists2'][$c]['severity_al'] = $newdata['lists2']['severity_al']; - $arr_allergies['lists2'][$c]['status'] = $newdata['lists2']['status']; - $arr_allergies['lists2'][$c]['reaction'] = $newdata['lists2']['reaction']; - $arr_allergies['lists2'][$c]['reaction_text'] = $newdata['lists2']['reaction_text']; - $arr_allergies['lists2'][$c]['codeSystemName'] = $newdata['lists2']['codeSystemName']; - $arr_allergies['lists2'][$c]['outcome'] = $newdata['lists2']['outcome']; - $c++; - } - elseif($table == 'encounter') { - $arr_encounter['encounter'][$k]['extension'] = $newdata['encounter']['extension']; - $arr_encounter['encounter'][$k]['root'] = $newdata['encounter']['root']; - $arr_encounter['encounter'][$k]['date'] = $newdata['encounter']['date']; - - $arr_encounter['encounter'][$k]['provider_npi'] = $newdata['encounter']['provider_npi']; - $arr_encounter['encounter'][$k]['provider_name'] = $newdata['encounter']['provider_name']; - $arr_encounter['encounter'][$k]['provider_address'] = $newdata['encounter']['provider_address']; - $arr_encounter['encounter'][$k]['provider_city'] = $newdata['encounter']['provider_city']; - $arr_encounter['encounter'][$k]['provider_state'] = $newdata['encounter']['provider_state']; - $arr_encounter['encounter'][$k]['provider_postalCode'] = $newdata['encounter']['provider_postalCode']; - $arr_encounter['encounter'][$k]['provider_country'] = $newdata['encounter']['provider_country']; - - $arr_encounter['encounter'][$k]['represented_organization_name'] = $newdata['encounter']['represented_organization_name']; - $arr_encounter['encounter'][$k]['represented_organization_address'] = $newdata['encounter']['represented_organization_address']; - $arr_encounter['encounter'][$k]['represented_organization_city'] = $newdata['encounter']['represented_organization_city']; - $arr_encounter['encounter'][$k]['represented_organization_state'] = $newdata['encounter']['represented_organization_state']; - $arr_encounter['encounter'][$k]['represented_organization_zip'] = $newdata['encounter']['represented_organization_zip']; - $arr_encounter['encounter'][$k]['represented_organization_country'] = $newdata['encounter']['represented_organization_country']; - $arr_encounter['encounter'][$k]['represented_organization_telecom'] = $newdata['encounter']['represented_organization_telecom']; - - $arr_encounter['encounter'][$k]['encounter_diagnosis_date'] = $newdata['encounter']['encounter_diagnosis_date']; - $arr_encounter['encounter'][$k]['encounter_diagnosis_code'] = $newdata['encounter']['encounter_diagnosis_code']; - $arr_encounter['encounter'][$k]['encounter_diagnosis_issue'] = $newdata['encounter']['encounter_diagnosis_issue']; - $k++; - } - elseif($table == 'vital_sign') { - $arr_vitals['vitals'][$q]['extension'] = $newdata['vital_sign']['extension']; - $arr_vitals['vitals'][$q]['date'] = $newdata['vital_sign']['date']; - $arr_vitals['vitals'][$q]['temperature'] = $newdata['vital_sign']['temperature']; - $arr_vitals['vitals'][$q]['bpd'] = $newdata['vital_sign']['bpd']; - $arr_vitals['vitals'][$q]['bps'] = $newdata['vital_sign']['bps']; - $arr_vitals['vitals'][$q]['head_circ'] = $newdata['vital_sign']['head_circ']; - $arr_vitals['vitals'][$q]['pulse'] = $newdata['vital_sign']['pulse']; - $arr_vitals['vitals'][$q]['height'] = $newdata['vital_sign']['height']; - $arr_vitals['vitals'][$q]['oxygen_saturation'] = $newdata['vital_sign']['oxygen_saturation']; - $arr_vitals['vitals'][$q]['respiration'] = $newdata['vital_sign']['respiration']; - $arr_vitals['vitals'][$q]['weight'] = $newdata['vital_sign']['weight']; - $q++; - } - elseif($table == 'social_history') { - $tobacco_status = array( - '449868002' => 'Current' , - '8517006' => 'Quit' , - '266919005' => 'Never' - ); - $alcohol_status = array( - '219006' => 'Current', - '82581004' => 'Quit', - '228274009' => 'Never' - ); - $alcohol = explode("|",$newdata['social_history']['alcohol']); - if($alcohol[2] !=0) { - $alcohol_date = $this->formatDate($alcohol[2],1); - } - else { - $alcohol_date = $alcohol[2]; - } - $alcohol_date_value = fixDate($alcohol_date); - foreach($alcohol_status as $key=>$value) { - if($alcohol[1] == $key) - $alcohol[1] = strtolower($value)."alcohol"; - } - $alcohol_value = $alcohol[0]."|".$alcohol[1]."|".$alcohol_date_value; - - $tobacco = explode("|",$newdata['social_history']['smoking']); - if($tobacco[2] != 0) { - $smoking_date = $this->formatDate($tobacco[2],1); - } - else { - $smoking_date = $tobacco[2]; - } - $smoking_date_value = fixDate($smoking_date); - foreach($tobacco_status as $key=>$value2) { - if($tobacco[1] == $key) - $tobacco[1] = strtolower($value2)."tobacco"; - } - $smoking_value = $tobacco[0]."|".$tobacco[1]."|".$smoking_date_value; - - $query_insert = "INSERT INTO history_data - ( - pid, - alcohol, - tobacco, - date - ) - VALUES - ( - ?, - ?, - ?, - ? - )"; - $appTable->zQuery($query_insert,array($pid, - $alcohol_value, - $smoking_value, - date('Y-m-d H:i:s'))); - } - elseif($table == 'procedure_result') { - if($newdata['procedure_result']['date'] != 0) { - $proc_date = $this->formatDate($newdata['procedure_result']['date'],0); - } - else { - $proc_date = $newdata['procedure_result']['date']; - } - - if($newdata['procedure_result']['results_date'] !=0) { - $proc_result_date = $this->formatDate($newdata['procedure_result']['results_date'],0); - } - else { - $proc_result_date = $newdata['procedure_result']['results_date']; - } - $arr_procedure_res['procedure_result'][$j]['proc_text'] = $newdata['procedure_result']['proc_text']; - $arr_procedure_res['procedure_result'][$j]['proc_code'] = $newdata['procedure_result']['proc_code']; - $arr_procedure_res['procedure_result'][$j]['extension'] = $newdata['procedure_result']['extension']; - $arr_procedure_res['procedure_result'][$j]['date'] = $proc_date; - $arr_procedure_res['procedure_result'][$j]['status'] = $newdata['procedure_result']['status']; - $arr_procedure_res['procedure_result'][$j]['results_text'] = $newdata['procedure_result']['results_text']; - $arr_procedure_res['procedure_result'][$j]['results_code'] = $newdata['procedure_result']['results_code']; - $arr_procedure_res['procedure_result'][$j]['results_range'] = $newdata['procedure_result']['results_range']; - $arr_procedure_res['procedure_result'][$j]['results_value'] = $newdata['procedure_result']['results_value']; - $arr_procedure_res['procedure_result'][$j]['results_date'] = $proc_result_date; - $j++; - } - elseif($table == 'procedure') { - $arr_procedures['procedure'][$y]['extension'] = $newdata['procedure']['extension']; - $arr_procedures['procedure'][$y]['root'] = $newdata['procedure']['root']; - $arr_procedures['procedure'][$y]['codeSystemName'] = $newdata['procedure']['codeSystemName']; - $arr_procedures['procedure'][$y]['code'] = $newdata['procedure']['code']; - $arr_procedures['procedure'][$y]['code_text'] = $newdata['procedure']['code_text']; - $arr_procedures['procedure'][$y]['date'] = $newdata['procedure']['date']; - - $arr_procedures['procedure'][$y]['represented_organization1'] = $newdata['procedure']['represented_organization1']; - $arr_procedures['procedure'][$y]['represented_organization_address1'] = $newdata['procedure']['represented_organization_address1']; - $arr_procedures['procedure'][$y]['represented_organization_city1'] = $newdata['procedure']['represented_organization_city1']; - $arr_procedures['procedure'][$y]['represented_organization_state1'] = $newdata['procedure']['represented_organization_state1']; - $arr_procedures['procedure'][$y]['represented_organization_postalcode1'] = $newdata['procedure']['represented_organization_postalcode1']; - $arr_procedures['procedure'][$y]['represented_organization_country1'] = $newdata['procedure']['represented_organization_country1']; - $arr_procedures['procedure'][$y]['represented_organization_telecom1'] = $newdata['procedure']['represented_organization_telecom1']; - - $arr_procedures['procedure'][$y]['represented_organization2'] = $newdata['procedure']['represented_organization2']; - $arr_procedures['procedure'][$y]['represented_organization_address2'] = $newdata['procedure']['represented_organization_address2']; - $arr_procedures['procedure'][$y]['represented_organization_city2'] = $newdata['procedure']['represented_organization_city2']; - $arr_procedures['procedure'][$y]['represented_organization_state2'] = $newdata['procedure']['represented_organization_state2']; - $arr_procedures['procedure'][$y]['represented_organization_postalcode2'] = $newdata['procedure']['represented_organization_postalcode2']; - $arr_procedures['procedure'][$y]['represented_organization_country2'] = $newdata['procedure']['represented_organization_country2']; - $y++; - } - elseif($table == 'care_plan') { - $arr_care_plan['care_plan'][$e]['extension'] = $newdata['care_plan']['extension']; - $arr_care_plan['care_plan'][$e]['root'] = $newdata['care_plan']['root']; - $arr_care_plan['care_plan'][$e]['text'] = $newdata['care_plan']['code_text']; - $arr_care_plan['care_plan'][$e]['code'] = $newdata['care_plan']['code']; - $arr_care_plan['care_plan'][$e]['description'] = $newdata['care_plan']['description']; - $e++; - } - elseif($table == 'functional_cognitive_status') { - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['extension'] = $newdata['functional_cognitive_status']['extension']; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['root'] = $newdata['functional_cognitive_status']['root']; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['text'] = $newdata['functional_cognitive_status']['code_text']; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['code'] = $newdata['functional_cognitive_status']['code']; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['date'] = $newdata['functional_cognitive_status']['date']; - $arr_functional_cognitive_status['functional_cognitive_status'][$f]['description'] = $newdata['functional_cognitive_status']['description']; - $f++; - } - } - - $this->InsertImmunization($arr_immunization['immunization'], $pid, 0); - $this->InsertPrescriptions($arr_prescriptions['lists3'],$pid,0); - $this->InsertAllergies($arr_allergies['lists2'],$pid,0); - $this->InsertMedicalProblem($arr_med_pblm['lists1'],$pid,0); - $this->InsertEncounter($arr_encounter['encounter'],$pid,0); - $this->InsertVitals($arr_vitals['vitals'],$pid,0); - $lab_results = $this->buildLabArray($arr_procedure_res['procedure_result']); - $this->InsertProcedures($arr_procedures['procedure'],$pid,0); - $this->InsertLabResults($lab_results,$pid); - $this->InsertCarePlan($arr_care_plan['care_plan'],$pid,0); - $this->InsertFunctionalCognitiveStatus($arr_functional_cognitive_status['functional_cognitive_status'],$pid,0); - - $appTable->zQuery("UPDATE audit_master - SET approval_status=2 - WHERE id=?", array($audit_master_id)); - $appTable->zQuery("UPDATE documents - SET audit_master_approval_status=2 - WHERE audit_master_id=?", array($audit_master_id)); - $appTable->zQuery("UPDATE documents - SET foreign_id = ? - WHERE id =? ", array($pid, - $document_id)); - } - - public function formatDate($unformatted_date,$ymd=1) - { - $day = substr($unformatted_date,6,2); - $month = substr($unformatted_date,4,2); - $year = substr($unformatted_date,0,4); - if($ymd == 1) { - $formatted_date = $year."/".$month."/".$day; - } - else { - $formatted_date = $day."/".$month."/".$year; - } - return $formatted_date; - } - - public function getOptionId($list_id,$title,$codes) - { - $appTable = new ApplicationTable(); - if($title) { - $query = "SELECT option_id - FROM list_options - WHERE list_id=? AND title=?"; - $result = $appTable->zQuery($query,array($list_id,$title)); - $res_cur = $result->current(); - } - if($codes) { - $query = "SELECT option_id - FROM list_options - WHERE list_id=? AND codes=?"; - $result = $appTable->zQuery($query,array($list_id,$codes)); - $res_cur = $result->current(); - } - return $res_cur['option_id']; - } - - public function InsertEncounter($enc_array,$pid,$revapprove=1) - { - $appTable = new ApplicationTable(); - foreach($enc_array as $key=>$value) { - $encounter_id = $appTable->generateSequenceID(); - $query_sel_users = "SELECT * - FROM users - WHERE abook_type='external_provider' AND npi=?"; - $res_query_sel_users = $appTable->zQuery($query_sel_users,array($value['provider_npi'])); - if($res_query_sel_users->count() > 0) { - foreach($res_query_sel_users as $value1) { - $provider_id = $value1['id']; - } - } - else { - $query_ins_users = "INSERT INTO users - ( username, - fname, - npi, - organization, - street, - city, - state, - zip, - active, - abook_type - ) - VALUES - ( - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - 1, - 'external_provider' - )"; - $res_query_ins_users = $appTable->zQuery($query_ins_users,array('', - $value['provider_name'], - $value['provider_npi'], - $value['represented_organization_name'], - $value['provider_address'], - $value['provider_city'], - $value['provider_state'], - $value['provider_postalCode'])); - $provider_id = $res_query_ins_users->getGeneratedValue(); - } - //facility - $query_sel_fac = "SELECT * - FROM users - WHERE abook_type='external_org' AND organization=?"; - $res_query_sel_fac = $appTable->zQuery($query_sel_fac,array($value['represented_organization_name'])); - if($res_query_sel_fac->count() > 0) { - foreach($res_query_sel_fac as $value2) { - $facility_id = $value2['id']; - } - } - else { - $query_ins_fac = "INSERT INTO users - ( username, - organization, - phonecell, - street, - city, - state, - zip, - active, - abook_type - ) - VALUES - ( - ?, - ?, - ?, - ?, - ?, - ?, - ?, - 1, - 'external_org' - )"; - $res_query_ins_fac = $appTable->zQuery($query_ins_fac,array('', - $value['represented_organization_name'], - $value['represented_organization_telecom'], - $value['represented_organization_address'], - $value['represented_organization_city'], - $value['represented_organization_state'], - $value['represented_organization_zip'])); - $facility_id = $res_query_ins_fac->getGeneratedValue(); - } - if($value['date'] != 0 && $revapprove==0) { - $encounter_date = $this->formatDate($value['date'],1); - $encounter_date_value = fixDate($encounter_date); - } - elseif($value['date'] != 0 && $revapprove==1){ - $encounter_date_value = \Application\Model\ApplicationTable::fixDate($value['date'], 'yyyy-mm-dd', 'dd/mm/yyyy'); - } - elseif($value['date'] == 0) { - $encounter_date = $value['date']; - $encounter_date_value = fixDate($encounter_date); - } - $q_sel_encounter = "SELECT * - FROM form_encounter - WHERE external_id=? AND pid=?"; - $res_q_sel_encounter = $appTable->zQuery($q_sel_encounter,array($value['extension'],$pid)); - if($res_q_sel_encounter->count() == 0) { - $query_insert1 = "INSERT INTO form_encounter - ( - pid, - encounter, - date, - facility, - facility_id, - provider_id, - external_id - ) - VALUES - ( - ?, - ?, - ?, - ?, - ?, - ?, - ? - )"; - $result = $appTable->zQuery($query_insert1,array($pid, - $encounter_id, - $encounter_date_value, - $value['represented_organization_name'], - $facility_id, - $provider_id, - $value['extension'])); - $enc_id = $result->getGeneratedValue(); - } - else { - $q_upd_encounter = "UPDATE form_encounter - SET pid=?, - encounter=?, - date=?, - facility=?, - facility_id=?, - provider_id=? - WHERE external_id=? AND pid=?"; - $appTable->zQuery($q_upd_encounter,array($pid, - $encounter_id, - $encounter_date_value, - $value['represented_organization_name'], - $facility_id, - $provider_id, - $value['extension'], - $pid)); - $q_sel_enc = "SELECT id FROM form_encounter WHERE external_id=?"; - $res_q_sel_enc = $appTable->zQuery($q_sel_enc,array($value['extension'])); - $res_enc_cur = $res_q_sel_enc->current(); - $enc_id = $res_enc_cur['id']; - } - $q_ins_forms = "INSERT INTO forms (date,encounter,form_name,form_id,pid,user,groupname,deleted,formdir) VALUES (?,?,?,?,?,?,?,?,?)"; - $appTable->zQuery($q_ins_forms,array($encounter_date_value,$encounter_id,'New Patient Encounter',$enc_id,$pid,$_SESSION["authProvider"],'Default',0,'newpatient')); - if($value['encounter_diagnosis_issue'] != '') { - $query_select = "SELECT * FROM lists WHERE begdate = ? AND title = ? AND pid = ?"; - $result = $appTable->zQuery($query_select, array($value['encounter_diagnosis_date'],$value['encounter_diagnosis_issue'],$pid)); - if($result->count()>0) { - foreach ($result as $value1) { - $list_id = $value1['id']; - } - } - else { - //to lists - $query_insert = "INSERT INTO lists(pid,type,begdate,activity,title,date, diagnosis) VALUES (?,?,?,?,?,?,?)"; - $result = $appTable->zQuery($query_insert, array($pid,'medical_problem',$value['encounter_diagnosis_date'],1, - $value['encounter_diagnosis_issue'],date('Y-m-d H:i:s'),'SNOMED-CT:'.$value['encounter_diagnosis_code'])); - $list_id = $result->getGeneratedValue(); - } - //Linking issue with encounter - $q_sel_iss_enc = "SELECT * FROM issue_encounter WHERE pid=? and list_id=? and encounter=?"; - $res_sel_iss_enc = $appTable->zQuery($q_sel_iss_enc,array($pid,$list_id,$enc_id)); - if($res_sel_iss_enc->count() == 0) { - $insert = "INSERT INTO issue_encounter(pid,list_id,encounter,resolved) VALUES (?,?,?,?)"; - $appTable->zQuery($insert, array($pid,$list_id,$enc_id,0)); - } - } - //to external_encounters - $insertEX = "INSERT INTO external_encounters(ee_date,ee_pid,ee_provider_id,ee_facility_id,ee_encounter_diagnosis,ee_external_id) VALUES (?,?,?,?,?,?)"; - $appTable->zQuery($insertEX, array($encounter_date_value,$pid,$provider_id,$facility_id,$value['encounter_diagnosis_issue'],$value['extension'])); - } - } - - public function InsertVitals($vitals_array,$pid,$revapprove=1) - { - $appTable = new ApplicationTable(); - foreach($vitals_array as $key=>$value) { - if($value['date'] !=0 && $revapprove == 0) { - $vitals_date = $this->formatDate($value['date'],1); - $vitals_date_value = fixDate($vitals_date); - } - elseif($value['date'] !=0 && $revapprove == 1) { - $vitals_date_value = \Application\Model\ApplicationTable::fixDate($value['date'], 'yyyy-mm-dd', 'dd/mm/yyyy'); - } - elseif($value['date'] == 0){ - $vitals_date = $value['date']; - $vitals_date_value = fixDate($vitals_date); - } - - $q_sel_vitals = "SELECT * - FROM form_vitals - WHERE external_id=?"; - $res_q_sel_vitals = $appTable->zQuery($q_sel_vitals,array($value['extension'])); - if($res_q_sel_vitals->count() == 0) { - $query_insert = "INSERT INTO form_vitals - ( - pid, - date, - bps, - bpd, - height, - weight, - temperature, - pulse, - respiration, - head_circ, - oxygen_saturation, - activity, - external_id - ) - VALUES - ( - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - 1, - ? - )"; - $res = $appTable->zQuery($query_insert,array($pid, - $vitals_date_value, - $value['bps'], - $value['bpd'], - $value['height'], - $value['weight'], - $value['temperature'], - $value['pulse'], - $value['respiration'], - $value['head_circ'], - $value['oxygen_saturation'], - $value['extension'])); - $vitals_id = $res->getGeneratedValue(); - } - else { - $q_upd_vitals = "UPDATE form_vitals - SET pid=?, - date=?, - bps=?, - bpd=?, - height=?, - weight=?, - temperature=?, - pulse=?, - respiration=?, - head_circ=?, - oxygen_saturation=? - WHERE external_id=?"; - $appTable->zQuery($q_upd_vitals,array($pid, - $vitals_date_value, - $value['bps'], - $value['bpd'], - $value['height'], - $value['weight'], - $value['temperature'], - $value['pulse'], - $value['respiration'], - $value['head_circ'], - $value['oxygen_saturation'], - $value['extension'])); - foreach($res_q_sel_vitals as $row_vitals) { - $vitals_id = $row_vitals['id']; - } - } - - $query_sel = "SELECT date FROM form_vitals WHERE id=?"; - $res_query_sel = $appTable->zQuery($query_sel,array($vitals_id)); - $res_cur = $res_query_sel->current(); - $vitals_date_forms = $res_cur['date']; - - $query_sel_enc = "SELECT encounter - FROM form_encounter - WHERE date=? AND pid=?"; - $res_query_sel_enc = $appTable->zQuery($query_sel_enc,array($vitals_date_forms,$pid)); - - if($res_query_sel_enc->count() == 0) { - $res_enc = $appTable->zQuery("SELECT encounter - FROM form_encounter - WHERE pid=? - ORDER BY id DESC - LIMIT 1",array($pid)); - $res_enc_cur = $res_enc->current(); - $encounter_for_forms = $res_enc_cur['encounter']; - } - else { - foreach($res_query_sel_enc as $value2) { - $encounter_for_forms = $value2['encounter']; - } - } - - $query = "INSERT INTO forms - ( - date, - encounter, - form_name, - form_id, - pid, - user, - formdir - ) - VALUES - ( - ?, - ?, - 'Vitals', - ?, - ?, - ?, - 'vitals' - )"; - $appTable->zQuery($query,array($vitals_date_forms, - $encounter_for_forms, - $vitals_id, - $pid, - $_SESSION[authUser])); - } - } - - public function InsertProcedures($proc_array,$pid,$revapprove=1) - { - $appTable = new ApplicationTable(); - foreach($proc_array as $key=>$value) { - if($value['date'] != 0 && $revapprove == 0) { - $procedure_date = $this->formatDate($value['date'],1); - $procedure_date_value = fixDate($procedure_date); - } - elseif($value['date'] != 0 && $revapprove == 1) { - $procedure_date_value = \Application\Model\ApplicationTable::fixDate($value['date'], 'yyyy-mm-dd', 'dd/mm/yyyy'); - } - elseif($value['date'] == 0) { - $procedure_date = $value['date']; - $procedure_date_value = fixDate($procedure_date); - } - //facility1 - $query3 = "SELECT * - FROM users - WHERE abook_type='external_org' AND organization=?"; - $res3 = $appTable->zQuery($query3,array($value['represented_organization1'])); - if($res3->count() > 0) { - foreach($res3 as $value3) { - $facility_id = $value3['id']; - } - } - else { - $query4 = "INSERT INTO users - ( username, - organization, - street, - city, - state, - zip, - active, - abook_type - ) - VALUES - ( ?, - ?, - ?, - ?, - ?, - ?, - 1, - 'external_org' - )"; - $res4 = $appTable->zQuery($query4,array('', - $value['represented_organization1'], - $value['represented_organization_address1'], - $value['represented_organization_city1'], - $value['represented_organization_state1'], - $value['represented_organization_postalcode1'])); - $facility_id = $res4->getGeneratedValue(); - } - - //facility2 - $query6 = "SELECT * - FROM users - WHERE abook_type='external_org' AND organization=?"; - $res6 = $appTable->zQuery($query6,array($value['represented_organization2'])); - if($res6->count() > 0) { - foreach($res6 as $value6) { - $facility_id2 = $value6['id']; - } - } - else { - $query7 = "INSERT INTO users - ( username, - organization, - street, - city, - state, - zip, - active, - abook_type - ) - VALUES - ( ?, - ?, - ?, - ?, - ?, - ?, - 1, - 'external_org' - )"; - $res7 = $appTable->zQuery($query7,array('', - $value['represented_organization2'], - $value['represented_organization_address2'], - $value['represented_organization_city2'], - $value['represented_organization_state2'], - $value['represented_organization_postalcode2'])); - $facility_id2 = $res7->getGeneratedValue(); - } - - $query_sel_enc = "SELECT encounter - FROM form_encounter - WHERE date=? AND pid=?"; - $res_query_sel_enc = $appTable->zQuery($query_sel_enc,array($procedure_date_value,$pid)); - - if($res_query_sel_enc->count() == 0) { - $res_enc = $appTable->zQuery("SELECT encounter - FROM form_encounter - WHERE pid=? - ORDER BY id DESC - LIMIT 1",array($pid)); - $res_enc_cur = $res_enc->current(); - $encounter_for_billing = $res_enc_cur['encounter']; - } - else { - foreach($res_query_sel_enc as $val) { - $encounter_for_billing = $val['encounter']; - } - } - - $query_select_ct = "SELECT ct_id FROM code_types WHERE ct_key = ? "; - $result_ct = $appTable->zQuery($query_select_ct,array($value['codeSystemName'])); - foreach ($result_ct as $val_ct) { - $ct_id = $val_ct['ct_id']; - } - $q_select = "SELECT * FROM codes WHERE code_text = ? AND code = ? AND active = ?"; - $res = $appTable->zQuery($q_select, array($value['code_text'],$value['code'],1)); - if(count($res) == 0) { - //codes - $qc_insert = "INSERT INTO codes(code_text,code_text_short,code,code_type,active) VALUES (?,?,?,?,?)"; - $appTable->zQuery($qc_insert, array($value['code_text'],$value['code_text'],$value['code'],$ct_id,1)); - } - $query_selectB = "SELECT * FROM external_procedures WHERE ep_code = ? AND ep_code_type = ? AND ep_encounter = ? AND ep_pid = ?"; - $result_selectB = $appTable->zQuery($query_selectB, array($value['code'],$value['codeSystemName'],$encounter_for_billing,$pid)); - if($result_selectB->count() == 0) { - //external_procedures - $qB_insert = "INSERT INTO external_procedures(ep_date,ep_code,ep_code_type,ep_code_text,ep_pid,ep_encounter,ep_facility_id,ep_external_id) VALUES (?,?,?,?,?,?,?,?)"; - $appTable->zQuery($qB_insert, array($value['date'],$value['code'],$value['codeSystemName'],$value['code_text'],$pid,$encounter_for_billing,$facility_id2,$value['extension'])); - } - } - } - - public function InsertImmunization($imm_array,$pid,$revapprove=1) - { - $appTable = new ApplicationTable(); - $qc_select = "SELECT ct_id FROM code_types WHERE ct_key = ?"; - $c_result = $appTable->zQuery($qc_select, array('CVX')); - foreach($c_result as $val) { - $ct_id = $val['ct_id']; - } - foreach($imm_array as $key=>$value) { - //provider - $query_sel_users = "SELECT * - FROM users - WHERE abook_type='external_provider' AND npi=?"; - $res_query_sel_users = $appTable->zQuery($query_sel_users,array($value['provider_npi'])); - if($res_query_sel_users->count() > 0) { - foreach($res_query_sel_users as $value1) { - $provider_id = $value1['id']; - } - } - else { - $query_ins_users = "INSERT INTO users - ( fname, - npi, - organization, - street, - city, - state, - zip, - phone, - abook_type - ) - VALUES - ( - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - 'external_provider')"; - $res_query_ins_users = $appTable->zQuery($query_ins_users,array($value['provider_name'], - $value['provider_npi'], - $value['represented_organization'], - $value['provider_address'], - $value['provider_city'], - $value['provider_state'], - $value['provider_postalCode'], - $value['provider_telecom'])); - $provider_id = $res_query_ins_users->getGeneratedValue(); - } - //facility - $query_sel_fac = "SELECT * - FROM users - WHERE abook_type='external_org' AND organization=?"; - $res_query_sel_fac = $appTable->zQuery($query_sel_fac,array($value['represented_organization'])); - if($res_query_sel_fac->count() > 0) { - foreach($res_query_sel_fac as $value2) { - $facility_id = $value2['id']; - } - } - else { - $query_ins_fac = "INSERT INTO users - ( organization, - phonecell, - abook_type - ) - VALUES - ( - ?, - ?, - 'external_org' - )"; - $res_query_ins_fac = $appTable->zQuery($query_ins_fac,array($value['represented_organization'], - $value['represented_organization_tele'])); - $facility_id = $res_query_ins_fac->getGeneratedValue(); - } - if($value['administered_date'] != 0 && $revapprove == 0) { - $immunization_date = $this->formatDate($value['administered_date'],1); - $immunization_date_value = fixDate($immunization_date); - } - elseif($value['administered_date'] != 0 && $revapprove == 1) { - $immunization_date_value = \Application\Model\ApplicationTable::fixDate($value['administered_date'], 'yyyy-mm-dd', 'dd/mm/yyyy'); - } - elseif($value['administered_date'] != 0) { - $immunization_date = $value['administered_date']; - $immunization_date_value = fixDate($immunization_date); - } - - $q_select = "SELECT * FROM codes WHERE code_text = ? AND code = ? AND code_type = ?"; - $res = $appTable->zQuery($q_select, array($value['cvx_code_text'],$value['cvx_code'],$ct_id)); - if($res->count() == 0) { - //codes - $qc_insert = "INSERT INTO codes(code_text,code,code_type) VALUES (?,?,?)"; - $appTable->zQuery($qc_insert, array($value['cvx_code_text'],$value['cvx_code'],$ct_id)); - } - $q1_unit = "SELECT * - FROM list_options - WHERE list_id='drug_units' AND title=?"; - $res_q1_unit = $appTable->zQuery($q1_unit,array($value['amount_administered_unit'])); - foreach ($res_q1_unit as $val) { - $oid_unit = $val['option_id']; - } - if($res_q1_unit->count() == 0) { - $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('drug_units')); - foreach($lres as $lrow){ - $oid_unit = $lrow['option_id']; - } - $q_insert_route = "INSERT INTO list_options - ( - list_id, - option_id, - title, - activity - ) - VALUES - ( - 'drug_units', - ?, - ?, - 1 - )"; - $appTable->zQuery($q_insert_route,array($oid_unit,$value['amount_administered_unit'])); - } - - $q1_completion_status = "SELECT * - FROM list_options - WHERE list_id='Immunization_Completion_Status' AND title=?"; - $res_q1_completion_status = $appTable->zQuery($q1_completion_status,array($value['completion_status'])); - - if($res_q1_completion_status->count() == 0) { - $q_insert_completion_status = "INSERT INTO list_options - ( - list_id, - option_id, - title, - activity - ) - VALUES - ( - 'Immunization_Completion_Status', - ?, - ?, - 1 - )"; - $appTable->zQuery($q_insert_completion_status,array($value['completion_status'],$value['completion_status'])); - } - - $q1_manufacturer = "SELECT * - FROM list_options - WHERE list_id='Immunization_Manufacturer' AND title=?"; - $res_q1_manufacturer = $appTable->zQuery($q1_manufacturer,array($value['manufacturer'])); - - if($res_q1_manufacturer->count() == 0) { - $q_insert_completion_status = "INSERT INTO list_options - ( - list_id, - option_id, - title, - activity - ) - VALUES - ( - 'Immunization_Manufacturer', - ?, - ?, - 1 - )"; - $appTable->zQuery($q_insert_completion_status,array($value['manufacturer'],$value['manufacturer'])); - } - - $q_sel_imm = "SELECT * - FROM immunizations - WHERE external_id=? AND patient_id=?"; - $res_q_sel_imm = $appTable->zQuery($q_sel_imm,array($value['extension'],$pid)); - if($res_q_sel_imm->count() == 0) { - $query = "INSERT INTO immunizations - ( patient_id, - administered_date, - cvx_code, - route, - administered_by_id, - amount_administered, - amount_administered_unit, - manufacturer, - completion_status, - external_id - ) - VALUES - ( - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ? - )"; - $appTable->zQuery($query,array($pid, - $immunization_date_value, - $value['cvx_code'], - $value['route_code_text'], - $provider_id, - $value['amount_administered'], - $oid_unit, - $value['manufacturer'], - $value['completion_status'], - $value['extension'])); - } - else { - $q_upd_imm = "UPDATE immunizations - SET patient_id=?, - administered_date=?, - cvx_code=?, - route=?, - administered_by_id=?, - amount_administered=?, - amount_administered_unit=?, - manufacturer=?, - completion_status=? - WHERE external_id=? AND patient_id=?"; - $appTable->zQuery($q_upd_imm,array($pid, - $immunization_date_value, - $value['cvx_code'], - $value['route_code_text'], - $provider_id, - $value['amount_administered'], - $oid_unit, - $value['manufacturer'], - $value['completion_status'], - $value['extension'], - $pid)); - } - } - } - - public function InsertPrescriptions($pres_array,$pid,$revapprove=1) - { - $appTable = new ApplicationTable(); - $oid_route = $unit_option_id = $oidu_unit = ''; - foreach($pres_array as $key=>$value) { - - $active = 1; - //provider - $query_sel_users = "SELECT * - FROM users - WHERE abook_type='external_provider' AND npi=?"; - $res_query_sel_users = $appTable->zQuery($query_sel_users,array($value['provider_npi'])); - if($res_query_sel_users->count() > 0) { - foreach($res_query_sel_users as $value1) { - $provider_id = $value1['id']; - } - } - else { - $query_ins_users = "INSERT INTO users - ( fname, - lname, - authorized, - street, - city, - state, - zip, - active, - abook_type - ) - VALUES - ( - ?, - ?, - 1, - ?, - ?, - ?, - ?, - 1, - 'external_provider' - )"; - $res_query_ins_users = $appTable->zQuery($query_ins_users,array($value['provider_fname'], - $value['provider_lname'], - $value['provider_address'], - $value['provider_city'], - $value['provider_state'], - $value['provider_postalCode'] - )); - $provider_id = $res_query_ins_users->getGeneratedValue(); - } - - //unit - $unit_option_id = $this->getOptionId('drug_units', $value['rate_unit'],''); - if($unit_option_id == '' || $unit_option_id == NULL) { - $q_max_option_id = "SELECT MAX(CAST(option_id AS SIGNED))+1 AS option_id - FROM list_options - WHERE list_id=?"; - $res_max_option_id = $appTable->zQuery($q_max_option_id,array('drug_units')); - $res_max_option_id_cur = $res_max_option_id->current(); - $unit_option_id = $res_max_option_id_cur['option_id']; - $q_insert_units_option = "INSERT INTO list_options - ( - list_id, - option_id, - title, - activity - ) - VALUES - ( - 'drug_units', - ?, - ?, - 1 - )"; - $appTable->zQuery($q_insert_units_option,array($unit_option_id, - $value['rate_unit'])); - } - - //route - $q1_route = "SELECT * - FROM list_options - WHERE list_id='drug_route' AND notes=?"; - $res_q1_route = $appTable->zQuery($q1_route,array($value['route'])); - foreach ($res_q1_route as $val) { - $oid_route = $val['option_id']; - } - if($res_q1_route->count() == 0) { - $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('drug_route')); - foreach($lres as $lrow){ - $oid_route = $lrow['option_id']; - } - $q_insert_route = "INSERT INTO list_options - ( - list_id, - option_id, - notes, - title, - activity - ) - VALUES - ( - 'drug_route', - ?, - ?, - ?, - 1 - )"; - $appTable->zQuery($q_insert_route,array($oid_route,$value['route'], - $value['route_display'])); - } - - //drug form - $query_select_form = "SELECT * FROM list_options WHERE list_id = ? AND title = ?"; - $result = $appTable->zQuery($query_select_form, array('drug_form',$value['dose_unit'])); - if($result->count()>0) { - $q_update = "UPDATE list_options SET activity = 1 WHERE list_id = ? AND title = ?"; - $appTable->zQuery($q_update, array('drug_form',$value['dose_unit'])); - foreach ($result as $value2) { - $oidu_unit = $value2['option_id']; - } - } - else { - $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('drug_form')); - foreach($lres as $lrow){ - $oidu_unit = $lrow['option_id']; - } - $q_insert = "INSERT INTO list_options (list_id,option_id,title,activity) VALUES (?,?,?,?)"; - $appTable->zQuery($q_insert, array('drug_form',$oidu_unit,$value['dose_unit'],1)); - } - - $q_sel_pres = "SELECT * - FROM prescriptions - WHERE patient_id = ? AND external_id = ?"; - $res_q_sel_pres = $appTable->zQuery($q_sel_pres,array($pid,$value['extension'])); - if($value['enddate'] == '' || $value['enddate'] == 0) { - $value['enddate'] = (NULL); - } - if($res_q_sel_pres->count() == 0) { - $query = "INSERT INTO prescriptions - ( patient_id, - date_added, - end_date, - active, - drug, - size, - form, - dosage, - route, - unit, - note, - indication, - prn, - rxnorm_drugcode, - provider_id, - external_id - ) - VALUES - ( - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ? - )"; - $appTable->zQuery($query, array($pid, - $value['begdate'], - $value['enddate'], - $active, - $value['drug_text'], - $value['rate'], - $oidu_unit, - $value['dose'], - $oid_route, - $unit_option_id, - $value['note'], - $value['indication'], - $value['prn'], - $value['drug_code'], - $provider_id, - $value['extension'])); - } - else { - $q_upd_pres = "UPDATE prescriptions - SET patient_id=?, - date_added=?, - end_date = ?, - drug=?, - size=?, - form=?, - dosage=?, - route=?, - unit=?, - note=?, - indication=?, - prn = ?, - rxnorm_drugcode=?, - provider_id=? - WHERE external_id=? AND patient_id=?"; - $appTable->zQuery($q_upd_pres,array($pid, - $value['begdate'], - $value['enddate'], - $value['drug_text'], - $value['rate'], - $oidu_unit, - $value['dose'], - $oid_route, - $unit_option_id, - $value['note'], - $value['indication'], - $value['prn'], - $value['drug_code'], - $provider_id, - $value['extension'], - $pid)); - } - } - } - - public function InsertAllergies($allergy_array,$pid,$revapprove=1) - { - $appTable = new ApplicationTable(); - foreach($allergy_array as $key=>$value) { - $active = 1; - - if($value['begdate'] !=0 && $revapprove == 0) { - $allergy_begdate = $this->formatDate($value['begdate'],1); - $allergy_begdate_value = fixDate($allergy_begdate); - } - elseif($value['begdate'] !=0 && $revapprove == 1) { - $allergy_begdate_value = \Application\Model\ApplicationTable::fixDate($value['begdate'], 'yyyy-mm-dd', 'dd/mm/yyyy'); - } - elseif($value['begdate'] == 0) { - $allergy_begdate = $value['begdate']; - $allergy_begdate_value = fixDate($allergy_begdate); - $allergy_begdate_value = (NULL); - } - - if($value['enddate'] !=0 && $revapprove == 0) { - $allergy_enddate = $this->formatDate($value['enddate'],1); - $allergy_enddate_value = fixDate($allergy_enddate); - } - elseif($value['enddate'] !=0 && $revapprove == 1) { - $allergy_enddate_value = \Application\Model\ApplicationTable::fixDate($value['enddate'], 'yyyy-mm-dd', 'dd/mm/yyyy'); - } - elseif($value['enddate'] == 0 || $value['enddate'] == '') { - $allergy_enddate = $value['enddate']; - $allergy_enddate_value = fixDate($allergy_enddate); - $allergy_enddate_value = (NULL); - } - - $q_sel_allergies = "SELECT * - FROM lists - WHERE external_id=? AND type='allergy' AND pid=?"; - $res_q_sel_allergies = $appTable->zQuery($q_sel_allergies,array($value['extension'],$pid)); - - $severity_option_id = $this->getOptionId('severity_ccda', '', 'SNOMED-CT:'.$value['severity_al']); - $severity_text = $this->getListTitle($severity_option_id,'severity_ccda','SNOMED-CT:'.$value['severity_al']); - if($severity_option_id == '' || $severity_option_id == NULL) { - $q_max_option_id = "SELECT MAX(CAST(option_id AS SIGNED))+1 AS option_id - FROM list_options - WHERE list_id=?"; - $res_max_option_id = $appTable->zQuery($q_max_option_id,array('severity_ccda')); - $res_max_option_id_cur = $res_max_option_id->current(); - $severity_option_id = $res_max_option_id_cur['option_id']; - $q_insert_units_option = "INSERT INTO list_options - ( - list_id, - option_id, - title, - activity - ) - VALUES - ( - 'severity_ccda', - ?, - ?, - 1 - )"; - if($severity_text) $appTable->zQuery($q_insert_units_option,array($severity_option_id,$severity_text)); - } - - $reaction_option_id = $this->getOptionId('Reaction', $value['reaction_text'], ''); - if($reaction_option_id == '' || $reaction_option_id == NULL) { - $q_max_option_id = "SELECT MAX(CAST(option_id AS SIGNED))+1 AS option_id - FROM list_options - WHERE list_id=?"; - $res_max_option_id = $appTable->zQuery($q_max_option_id,array('Reaction')); - $res_max_option_id_cur = $res_max_option_id->current(); - $reaction_option_id = $res_max_option_id_cur['option_id']; - $q_insert_units_option = "INSERT INTO list_options - ( - list_id, - option_id, - title, - activity - ) - VALUES - ( - 'Reaction', - ?, - ?, - 1 - )"; - if($value['reaction_text']) $appTable->zQuery($q_insert_units_option,array($reaction_option_id,$value['reaction_text'])); - } - - if($res_q_sel_allergies->count() == 0) { - $query = "INSERT INTO lists - ( pid, - date, - begdate, - enddate, - type, - title, - diagnosis, - severity_al, - activity, - reaction, - external_id - ) - VALUES - ( - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ? - )"; - $result = $appTable->zQuery($query, array($pid, - date('y-m-d H:i:s'), - $allergy_begdate_value, - $allergy_enddate_value, - 'allergy', - $value['list_code_text'], - $value['codeSystemName'].':'.$value['list_code'], - $severity_option_id, - $active, - $reaction_option_id ? $reaction_option_id : 0, - $value['extension'])); - $list_id = $result->getGeneratedValue(); - } - else { - $q_upd_allergies = "UPDATE lists - SET pid=?, - date=?, - begdate=?, - enddate=?, - title=?, - diagnosis=?, - severity_al=?, - reaction=? - WHERE external_id=? AND type='allergy' AND pid=?"; - $appTable->zQuery($q_upd_allergies,array($pid, - date('y-m-d H:i:s'), - $allergy_begdate_value, - $allergy_enddate_value, - $value['list_code_text'], - $value['codeSystemName'].':'.$value['list_code'], - $severity_option_id, - $reaction_option_id ? $reaction_option_id : 0, - $value['extension'], - $pid)); - } - } - } - - public function InsertMedicalProblem($med_pblm_array,$pid,$revapprove=1) - { - $appTable = new ApplicationTable(); - foreach($med_pblm_array as $key=>$value) { - $activity = 1; - - if($value['begdate'] !=0 && $revapprove == 0) { - $med_pblm_begdate = $this->formatDate($value['begdate'],1); - $med_pblm_begdate_value = fixDate($med_pblm_begdate); - } - elseif($value['begdate'] !=0 && $revapprove == 1) { - $med_pblm_begdate_value = \Application\Model\ApplicationTable::fixDate($value['begdate'], 'yyyy-mm-dd', 'dd/mm/yyyy'); - } - elseif($value['begdate'] == 0) { - $med_pblm_begdate = $value['begdate']; - $med_pblm_begdate_value = fixDate($med_pblm_begdate); - $med_pblm_begdate_value = (NULL); - } - - if($value['enddate'] !=0 && $revapprove == 0) { - $med_pblm_enddate = $this->formatDate($value['enddate'],1); - $med_pblm_enddate_value = fixDate($med_pblm_enddate); - } - elseif($value['enddate'] !=0 && $revapprove == 1) { - $med_pblm_enddate_value = \Application\Model\ApplicationTable::fixDate($value['enddate'], 'yyyy-mm-dd', 'dd/mm/yyyy'); - } - elseif($value['enddate'] == 0 || $value['enddate'] == '') { - $med_pblm_enddate = $value['enddate']; - $med_pblm_enddate_value = fixDate($med_pblm_enddate); - $med_pblm_enddate_value = (NULL); - } - - $query_select = "SELECT * FROM list_options WHERE list_id = ? AND title = ?"; - $result = $appTable->zQuery($query_select, array('outcome',$value['observation_text'])); - if($result->count()>0) { - $q_update = "UPDATE list_options SET activity = 1 WHERE list_id = ? AND title = ? AND codes = ?"; - $appTable->zQuery($q_update, array('outcome',$value['observation_text'],'SNOMED-CT:'.$value['observation_code'])); - foreach ($result as $value1) { - $o_id = $value1['option_id']; - } - } - else { - $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('outcome')); - foreach($lres as $lrow){ - $o_id = $lrow['option_id']; - } - $q_insert = "INSERT INTO list_options (list_id,option_id,title,codes,activity) VALUES (?,?,?,?,?)"; - $appTable->zQuery($q_insert, array('outcome',$o_id,$value['observation_text'],'SNOMED-CT:'.$value['observation_code'],1)); - } - - $q_sel_med_pblm = "SELECT * - FROM lists - WHERE external_id=? AND type='medical_problem' AND begdate=? AND diagnosis=? AND pid=?"; - $res_q_sel_med_pblm = $appTable->zQuery($q_sel_med_pblm,array($value['extension'],$med_pblm_begdate_value,'SNOMED-CT:'.$value['list_code'],$pid)); - if($res_q_sel_med_pblm->count() == 0) { - $query = "INSERT INTO lists - ( pid, - date, - diagnosis, - activity, - title, - begdate, - enddate, - outcome, - type, - external_id - ) - VALUES - ( ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ?, - ? - )"; - $result = $appTable->zQuery($query, array($pid, - date('y-m-d H:i:s'), - 'SNOMED-CT:'.$value['list_code'], - $activity, - $value['list_code_text'], - $med_pblm_begdate_value, - $med_pblm_enddate_value, - $o_id, - 'medical_problem', - $value['extension'])); - - $list_id = $result->getGeneratedValue(); - } - else { - $q_upd_med_pblm = "UPDATE lists - SET pid=?, - date=?, - diagnosis=?, - title=?, - begdate=?, - enddate=?, - outcome=? - WHERE external_id=? AND type='medical_problem' AND begdate=? AND diagnosis=? AND pid=?"; - $appTable->zQuery($q_upd_med_pblm,array($pid, - date('y-m-d H:i:s'), - 'SNOMED-CT:'.$value['list_code'], - $value['list_code_text'], - $med_pblm_begdate_value, - $med_pblm_enddate_value, - $o_id, - $value['extension'], - $value['begdate'], - 'SNOMED-CT:'.$value['list_code'], - $pid)); - } - } - } - public function InsertCarePlan($care_plan_array,$pid,$revapprove=1) - { - $newid = ''; - $appTable = new ApplicationTable(); - $res = $appTable->zQuery("SELECT MAX(id) as largestId FROM `form_care_plan`"); - foreach($res as $val) { - if ($val['largestId']) { - $newid = $val['largestId'] + 1; - } else { - $newid = 1; - } - } - foreach($care_plan_array as $key=>$value) { - - $query_sel_enc = "SELECT encounter - FROM form_encounter - WHERE date=? AND pid=?"; - $res_query_sel_enc = $appTable->zQuery($query_sel_enc,array(date('Y-m-d H:i:s'),$pid)); - - if($res_query_sel_enc->count() == 0) { - $res_enc = $appTable->zQuery("SELECT encounter - FROM form_encounter - WHERE pid=? - ORDER BY id DESC - LIMIT 1",array($pid)); - $res_enc_cur = $res_enc->current(); - $encounter_for_forms = $res_enc_cur['encounter']; - } - else { - foreach($res_query_sel_enc as $value2) { - $encounter_for_forms = $value2['encounter']; - } - } - $query_insert = "INSERT INTO form_care_plan(id,pid,groupname,user,encounter, activity,code,codetext,description,date)VALUES(?,?,?,?,?,?,?,?,?,?)"; - $res = $appTable->zQuery($query_insert,array($newid,$pid,$_SESSION["authProvider"],$_SESSION["authUser"],$encounter_for_forms,1,$value['code'],$value['text'],$value['description'],date('Y-m-d'))); - } - if(count($care_plan_array) >0) { - $query = "INSERT INTO forms(date,encounter,form_name,form_id,pid,user,groupname,formdir)VALUES(?,?,?,?,?,?,?,?)"; - $appTable->zQuery($query,array(date('Y-m-d'),$encounter_for_forms,'Care Plan Form',$newid,$pid,$_SESSION["authUser"],$_SESSION["authProvider"],'care_plan')); - } - } - - public function InsertFunctionalCognitiveStatus($functional_cognitive_status_array,$pid,$revapprove=1) - { - $newid = ''; - $appTable = new ApplicationTable(); - $res = $appTable->zQuery("SELECT MAX(id) as largestId FROM `form_functional_cognitive_status`"); - foreach($res as $val) { - if ($val['largestId']) { - $newid = $val['largestId'] + 1; - } else { - $newid = 1; - } - } - foreach($functional_cognitive_status_array as $key=>$value) { - if($value['date'] != '') $date = $this->formatDate($value['date']); - else $date = date('Y-m-d'); - $query_sel_enc = "SELECT encounter - FROM form_encounter - WHERE date=? AND pid=?"; - $res_query_sel_enc = $appTable->zQuery($query_sel_enc,array($date,$pid)); - - if($res_query_sel_enc->count() == 0) { - $res_enc = $appTable->zQuery("SELECT encounter - FROM form_encounter - WHERE pid=? - ORDER BY id DESC - LIMIT 1",array($pid)); - $res_enc_cur = $res_enc->current(); - $encounter_for_forms = $res_enc_cur['encounter']; - } - else { - foreach($res_query_sel_enc as $value2) { - $encounter_for_forms = $value2['encounter']; - } - } - $query_insert = "INSERT INTO form_functional_cognitive_status(id,pid,groupname,user,encounter, activity,code,codetext,description,date)VALUES(?,?,?,?,?,?,?,?,?,?)"; - $res = $appTable->zQuery($query_insert,array($newid,$pid,$_SESSION["authProvider"],$_SESSION["authUser"],$encounter_for_forms,1,$value['code'],$value['text'],$value['description'],$date)); - } - if(count($functional_cognitive_status_array) >0) { - $query = "INSERT INTO forms(date,encounter,form_name,form_id,pid,user,groupname,formdir)VALUES(?,?,?,?,?,?,?,?)"; - $appTable->zQuery($query,array($date,$encounter_for_forms,'Functional and Cognitive Status Form',$newid,$pid,$_SESSION["authUser"],$_SESSION["authProvider"],'functional_cognitive_status')); - } - } - public function getCodes($option_id,$list_id) - { - $appTable = new ApplicationTable(); - if($option_id) { - $query = "SELECT notes - FROM list_options - WHERE list_id=? AND option_id=?"; - $result = $appTable->zQuery($query,array($list_id,$option_id)); - $res_cur = $result->current(); - } - return $res_cur['notes']; - } - /* - * Fetch list details - * - * @param list_id string - * @return records Array list of list details - */ - public function getList($list) - { - $appTable = new ApplicationTable(); - $query = "SELECT title,option_id,notes,codes FROM list_options WHERE list_id = ?"; - $result = $appTable->zQuery($query, array($list)); - $records = array(); - foreach($result as $row){ - $records[] = $row; - } - return $records; - } -} - - + + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + * + * @author Vinish K + * @author Chandni Babu + * @author Riju KP + * +------------------------------------------------------------------------------+ + */ +namespace Carecoordination\Model; + +use Zend\Db\TableGateway\AbstractTableGateway; +use Application\Model\ApplicationTable; +use Zend\Db\Adapter\Driver\Pdo\Result; +use Zend\XmlRpc\Generator; + +use DOMDocument; +use DOMXpath; + +use Document; +use CouchDB; + +use Documents\Model\DocumentsTable; + +class CarecoordinationTable extends AbstractTableGateway +{ + protected $ccda_data_array; + /* + * Fetch the category ID using category name + * + * @param $title String Category Name + * @return $records Array Category ID + */ + public function fetch_cat_id($title) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM categories + WHERE name = ?"; + $result = $appTable->zQuery($query, array($title)); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the documents uploaded by a user + * + * @param user Integer Uploaded user ID + * @param time_start Date Uploaded start time + * @param time_end Date Uploaded end time + * + * @return records Array List of documents uploaded by the user during a particular time + */ + public function fetch_uploaded_documents($data) + { + $query = "SELECT * + FROM categories_to_documents AS cat_doc + JOIN documents AS doc + ON doc.id = cat_doc.document_id AND doc.owner = ? AND doc.date BETWEEN ? AND ?"; + $appTable = new ApplicationTable(); + $result = $appTable->zQuery($query, array($data['user'], $data['time_start'], $data['time_end'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * List the documents uploaded by the user alogn with the matched data + * + * @param cat_title Text Category Name + * @return records Array List of CCDA imported to the system, pending approval + */ + public function document_fetch($data) + { + $query = "SELECT am.id as amid, + cat.name, + u.fname, + u.lname, + d.imported, + d.size, + d.date, + d.couch_docid, + d.couch_revid, + d.url AS file_url, + d.id AS document_id, + ad.field_value, + ad1.field_value, + ad2.field_value, + pd.pid, + CONCAT(ad.field_value,' ',ad1.field_value) as pat_name, + DATE(ad2.field_value) as dob, + CONCAT_WS(' ',pd.lname, pd.fname) as matched_patient + FROM documents AS d + JOIN categories AS cat ON cat.name = ? + JOIN categories_to_documents AS cd ON cd.document_id = d.id AND cd.category_id = cat.id + LEFT JOIN audit_master AS am ON am.type = ? AND am.approval_status = '1' AND d.audit_master_id = am.id + LEFT JOIN audit_details ad ON ad.audit_master_id = am.id AND ad.table_name = 'patient_data' AND ad.field_name = 'lname' + LEFT JOIN audit_details ad1 ON ad1.audit_master_id = am.id AND ad1.table_name = 'patient_data' AND ad1.field_name = 'fname' + LEFT JOIN audit_details ad2 ON ad2.audit_master_id = am.id AND ad2.table_name = 'patient_data' AND ad2.field_name = 'DOB' + LEFT JOIN patient_data pd ON pd.lname = ad.field_value AND pd.fname = ad1.field_value AND pd.DOB = DATE(ad2.field_value) + LEFT JOIN users AS u ON u.id = d.owner + WHERE d.audit_master_approval_status = 1 + ORDER BY date DESC"; + $appTable = new ApplicationTable(); + $result = $appTable->zQuery($query, array($data['cat_title'], $data['type'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the component values from the CCDA XML + * + * @param $components Array of components + */ + public function import($xml,$document_id) + { + $components = $xml['component']['structuredBody']['component']; + $components_oids = array( + '2.16.840.1.113883.10.20.22.4.7' => 'allergy', + '2.16.840.1.113883.10.20.22.2.6.1' => 'allergy', + '2.16.840.1.113883.10.20.22.2.1' => 'medication', + '2.16.840.1.113883.10.20.22.2.1.1' => 'medication', + '2.16.840.1.113883.10.20.22.2.5.1' => 'medical_problem', + '2.16.840.1.113883.10.20.22.2.5' => 'medical_problem', + '2.16.840.1.113883.10.20.22.2.2' => 'immunization', + '2.16.840.1.113883.10.20.22.2.2.1' => 'immunization', + '2.16.840.1.113883.3.88.11.83.145' => 'procedure', + '2.16.840.1.113883.10.20.22.2.7.1' => 'procedure', + '2.16.840.1.113883.10.20.22.2.3.1' => 'lab_result', + '2.16.840.1.113883.10.20.22.2.3' => 'lab_result', + '2.16.840.1.113883.10.20.22.2.4.1' => 'vital_sign', + '2.16.840.1.113883.10.20.22.2.17' => 'social_history', + '2.16.840.1.113883.3.88.11.83.127' => 'encounter', + '2.16.840.1.113883.10.20.22.2.22.1' => 'encounter', + '2.16.840.1.113883.10.20.22.2.10' => 'care_plan', + '2.16.840.1.113883.10.20.22.2.14' => 'functional_cognitive_status', + '1.3.6.1.4.1.19376.1.5.3.1.3.1' => 'referral', + '2.16.840.1.113883.10.20.22.2.11.1' => 'discharge_medications', + '2.16.840.1.113883.10.20.22.2.41' => 'discharge_summary', + ); + + for ($i = 0; $i <= count($components); $i++) { + if (count($components[$i]['section']['templateId']) > 1) { + foreach ($components[$i]['section']['templateId'] as $key_1 => $value_1) { + if ($components_oids[$components[$i]['section']['templateId'][$key_1]['root']] != '') { + $func_name = $components_oids[$components[$i]['section']['templateId'][$key_1]['root']]; + $this->$func_name($components[$i]); + break; + } + } + } + else{ + if ($components_oids[$components[$i]['section']['templateId']['root']] != '') { + $func_name = $components_oids[$components[$i]['section']['templateId']['root']]; + $this->$func_name($components[$i]); + } + } + } + $audit_master_approval_status = $this->ccda_data_array['approval_status'] = 1; + $this->ccda_data_array['ip_address'] = $_SERVER['REMOTE_ADDR']; + $this->ccda_data_array['type'] = '12'; + + //Patient Details + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['fname'] = is_array($xml['recordTarget']['patientRole']['patient']['name']['given']) ? $xml['recordTarget']['patientRole']['patient']['name']['given'][0] : $xml['recordTarget']['patientRole']['patient']['name']['given']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['lname'] = $xml['recordTarget']['patientRole']['patient']['name']['family']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['DOB'] = $xml['recordTarget']['patientRole']['patient']['birthTime']['value']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['sex'] = $xml['recordTarget']['patientRole']['patient']['administrativeGenderCode']['displayName']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['pubpid'] = $xml['recordTarget']['patientRole']['id'][0]['extension']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['ss'] = $xml['recordTarget']['patientRole']['id'][1]['extension']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['street'] = $xml['recordTarget']['patientRole']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['city'] = $xml['recordTarget']['patientRole']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['state'] = $xml['recordTarget']['patientRole']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['postal_code'] = $xml['recordTarget']['patientRole']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['country_code'] = $xml['recordTarget']['patientRole']['addr']['country']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['phone_home'] = preg_replace('/[^0-9]+/i', '', $xml['recordTarget']['patientRole']['telecom']['value']); + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['status'] = $xml['recordTarget']['patientRole']['patient']['maritalStatusCode']['displayName']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['religion'] = $xml['recordTarget']['patientRole']['patient']['religiousAffiliationCode']['displayName']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['race'] = $xml['recordTarget']['patientRole']['patient']['raceCode']['displayName']; + $this->ccda_data_array['field_name_value_array']['patient_data'][1]['ethnicity'] = $xml['recordTarget']['patientRole']['patient']['ethnicGroupCode']['displayName']; + + //Author details + $this->ccda_data_array['field_name_value_array']['author'][1]['extension'] = $xml['author']['assignedAuthor']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['author'][1]['address'] = $xml['author']['assignedAuthor']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['author'][1]['city'] = $xml['author']['assignedAuthor']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['author'][1]['state'] = $xml['author']['assignedAuthor']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['author'][1]['zip'] = $xml['author']['assignedAuthor']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['author'][1]['country'] = $xml['author']['assignedAuthor']['addr']['country']; + $this->ccda_data_array['field_name_value_array']['author'][1]['phone'] = $xml['author']['assignedAuthor']['telecom']['value']; + $this->ccda_data_array['field_name_value_array']['author'][1]['name'] = $xml['author']['assignedAuthor']['assignedPerson']['name']['given']; + + //Data Enterer + $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['extension'] = $xml['dataEnterer']['assignedEntity']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['address'] = $xml['dataEnterer']['assignedEntity']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['city'] = $xml['dataEnterer']['assignedEntity']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['state'] = $xml['dataEnterer']['assignedEntity']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['zip'] = $xml['dataEnterer']['assignedEntity']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['country'] = $xml['dataEnterer']['assignedEntity']['addr']['country']; + $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['phone'] = $xml['dataEnterer']['assignedEntity']['telecom']['value']; + $this->ccda_data_array['field_name_value_array']['dataEnterer'][1]['name'] = $xml['dataEnterer']['assignedEntity']['assignedPerson']['name']['given']; + + //Informant + $this->ccda_data_array['field_name_value_array']['informant'][1]['extension'] = $xml['informant'][0]['assignedEntity']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['informant'][1]['street'] = $xml['informant'][0]['assignedEntity']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['informant'][1]['city'] = $xml['informant'][0]['assignedEntity']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['informant'][1]['state'] = $xml['informant'][0]['assignedEntity']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['informant'][1]['postalCode'] = $xml['informant'][0]['assignedEntity']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['informant'][1]['country'] = $xml['informant'][0]['assignedEntity']['addr']['country']; + $this->ccda_data_array['field_name_value_array']['informant'][1]['phone'] = $xml['informant'][0]['assignedEntity']['telecom']['value']; + $this->ccda_data_array['field_name_value_array']['informant'][1]['name'] = $xml['informant'][0]['assignedEntity']['assignedPerson']['name']['given']; + + //Personal Informant + $this->ccda_data_array['field_name_value_array']['custodian'][1]['extension'] = $xml['custodian']['assignedCustodian']['representedCustodianOrganization']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['custodian'][1]['organisation'] = $xml['custodian']['assignedCustodian']['representedCustodianOrganization']['name']; + + //documentationOf + $doc_of_str = ''; + if(!is_array($xml['documentationOf']['serviceEvent']['performer'][0]['assignedEntity']['assignedPerson']['name']['prefix'])) + $doc_of_str .= $xml['documentationOf']['serviceEvent']['performer'][0]['assignedEntity']['assignedPerson']['name']['prefix']." "; + if(!is_array($xml['documentationOf']['serviceEvent']['performer'][0]['assignedEntity']['assignedPerson']['name']['given'])) + $doc_of_str .= $xml['documentationOf']['serviceEvent']['performer'][0]['assignedEntity']['assignedPerson']['name']['given']." "; + if(!is_array($xml['documentationOf']['serviceEvent']['performer'][0]['assignedEntity']['assignedPerson']['name']['family'])) + $doc_of_str .= $xml['documentationOf']['serviceEvent']['performer'][0]['assignedEntity']['assignedPerson']['name']['family']." "; + if(!is_array($xml['documentationOf']['serviceEvent']['performer'][0]['assignedEntity']['representedOrganization']['name'])) + $doc_of_str .= $xml['documentationOf']['serviceEvent']['performer'][0]['assignedEntity']['representedOrganization']['name']." "; + $this->ccda_data_array['field_name_value_array']['documentationOf'][1]['assignedPerson'] = $doc_of_str; + + $documentationOf = $this->ccda_data_array['field_name_value_array']['documentationOf'][1]['assignedPerson']; + + $audit_master_id = \Application\Plugin\CommonPlugin::insert_ccr_into_audit_data($this->ccda_data_array); + $this->update_document_table($document_id, $audit_master_id, $audit_master_approval_status,$documentationOf); + } + + public function update_document_table($document_id,$audit_master_id,$audit_master_approval_status,$documentationOf) + { + $appTable = new ApplicationTable(); + $query = "UPDATE documents + SET audit_master_id = ?, + imported = ?, + audit_master_approval_status=?, + documentationOf=? + WHERE id = ?"; + $appTable->zQuery($query, array($audit_master_id, + 1, + $audit_master_approval_status, + $documentationOf, + $document_id)); + } + + public function allergy($component) + { + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_allergy_value($value); + } + } + else{ + $this->fetch_allergy_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_allergy_value($allergy_array) + { + if($allergy_array['act']['entryRelationship']['observation']['participant']['participantRole']['playingEntity']['code']['code'] != '' && $allergy_array['act']['entryRelationship']['observation']['participant']['participantRole']['playingEntity']['code']['code'] != 0) { + $i = count($this->ccda_data_array['field_name_value_array']['lists2']) + 1; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['type'] = 'allergy'; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['extension'] = $allergy_array['act']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['begdate'] = $allergy_array['act']['effectiveTime']['low']['value']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['enddate'] = $allergy_array['act']['effectiveTime']['high']['value']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['list_code'] = $allergy_array['act']['entryRelationship']['observation']['participant']['participantRole']['playingEntity']['code']['code']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['list_code_text'] = $allergy_array['act']['entryRelationship']['observation']['participant']['participantRole']['playingEntity']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['codeSystemName'] = $allergy_array['act']['entryRelationship']['observation']['participant']['participantRole']['playingEntity']['code']['codeSystemName']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['outcome'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][1]['observation']['value']['code']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['severity_al_code'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][2]['observation']['value']['code']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['severity_al'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][2]['observation']['value']['code']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['status'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][0]['observation']['value']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['reaction'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][1]['observation']['value']['code']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['reaction_text'] = $allergy_array['act']['entryRelationship']['observation']['entryRelationship'][1]['observation']['value']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists2'][$i]['modified_time'] = $allergy_array['act']['entryRelationship']['observation']['performer']['assignedEntity']['time']['value']; + $this->ccda_data_array['entry_identification_array']['lists2'][$i] = $i; + unset($allergy_array); + return; + } + } + + public function medication($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_medication_value($value); + } + } + else{ + $this->fetch_medication_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_medication_value($medication_data) + { + if($medication_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['code'] != '' && $medication_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['code'] != 0) { + $i = count($this->ccda_data_array['field_name_value_array']['lists3']) + 1; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['type'] = 'medication'; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['extension'] = $medication_data['substanceAdministration']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['root'] = $medication_data['substanceAdministration']['id']['root']; + if ($medication_data['substanceAdministration']['effectiveTime'][0]['low']['value'] == '') + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['begdate'] = date('Y-m-d'); + else + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['begdate'] = $medication_data['substanceAdministration']['effectiveTime'][0]['low']['value']; + if ($medication_data['substanceAdministration']['effectiveTime'][0]['high']['value']) + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['enddate'] = $medication_data['substanceAdministration']['effectiveTime'][0]['high']['value']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['route'] = $medication_data['substanceAdministration']['routeCode']['code']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['route_display'] = $medication_data['substanceAdministration']['routeCode']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['dose'] = $medication_data['substanceAdministration']['doseQuantity']['value']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['dose_unit'] = $medication_data['substanceAdministration']['doseQuantity']['unit']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['rate'] = $medication_data['substanceAdministration']['rateQuantity']['value']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['rate_unit'] = $medication_data['substanceAdministration']['rateQuantity']['unit']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['drug_code'] = $medication_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['code']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['drug_text'] = $medication_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['note'] = $medication_data['substanceAdministration']['text']['reference']['value']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['indication'] = $medication_data['substanceAdministration']['entryRelationship'][0]['observation']['value']['displayName'] ? $medication_data['substanceAdministration']['entryRelationship'][0]['observation']['value']['displayName'] : $medication_data['substanceAdministration']['entryRelationship']['observation']['value']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['prn'] = $medication_data['substanceAdministration']['precondition']['criterion']['value']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['modified_time'] = $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['author']['time']['value']; + + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_title'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['prefix'] ? $medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['prefix'] : $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['assignedPerson']['name']['prefix']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_fname'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['given'] ? $medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['given'] : $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['assignedPerson']['name']['given']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_lname'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['family'] ? $medication_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['family'] : $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['assignedPerson']['name']['family']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_root'] = $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['id']['root']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_address'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['streetAddressLine'] ? $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['streetAddressLine'] : $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_city'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['city'] ? $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['city'] : $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_state'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['state'] ? $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['state'] : $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_postalCode'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['postalCode'] ? $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['postalCode'] : $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['lists3'][$i]['provider_country'] = $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['country']['value'] ? $medication_data['substanceAdministration']['performer']['assignedEntity']['addr']['country']['value'] : $medication_data['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['country']; + $this->ccda_data_array['entry_identification_array']['lists3'][$i] = $i; + unset($medication_data); + return; + } + } + + public function medical_problem($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_medical_problem_value($value); + } + } + else{ + $this->fetch_medical_problem_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_medical_problem_value($medical_problem_data) + { + if($medical_problem_data['act']['entryRelationship']['observation']['value']['code'] != '' && $medical_problem_data['act']['entryRelationship']['observation']['value']['code'] != 0) { + $i = count($this->ccda_data_array['field_name_value_array']['lists1']) + 1; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['type'] = 'medical_problem'; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['extension'] = $medical_problem_data['act']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['root'] = $medical_problem_data['act']['id']['root']; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['begdate'] = $medical_problem_data['act']['effectiveTime']['low']['value']; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['enddate'] = $medical_problem_data['act']['effectiveTime']['high']['value']; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['list_code'] = $medical_problem_data['act']['entryRelationship']['observation']['value']['code']; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['list_code_text'] = $medical_problem_data['act']['entryRelationship']['observation']['value']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['observation'] = $medical_problem_data['act']['entryRelationship']['observation']['entryRelationship'][1]['observation']['value']['code']; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['observation_text'] = $medical_problem_data['act']['entryRelationship']['observation']['entryRelationship'][1]['observation']['value']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['status'] = $medical_problem_data['act']['entryRelationship']['observation']['entryRelationship'][2]['observation']['value']['displayName']; + $this->ccda_data_array['field_name_value_array']['lists1'][$i]['modified_time'] = $medical_problem_data['act']['entryRelationship']['observation']['performer']['assignedEntity']['time']['value']; + $this->ccda_data_array['entry_identification_array']['lists1'][$i] = $i; + unset($medical_problem_data); + return; + } + } + + public function immunization($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_immunization_value($value); + } + } + else{ + $this->fetch_immunization_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_immunization_value($immunization_data) + { + if($immunization_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['code'] != '' && $immunization_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['code'] != 0) { + $i = count($this->ccda_data_array['field_name_value_array']['immunization']) + 1; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['extension'] = $immunization_data['substanceAdministration']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['root'] = $immunization_data['substanceAdministration']['id']['root']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['administered_date'] = $immunization_data['substanceAdministration']['effectiveTime']['value']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['route_code'] = $immunization_data['substanceAdministration']['routeCode']['code']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['route_code_text'] = $immunization_data['substanceAdministration']['routeCode']['displayName']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['cvx_code'] = $immunization_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['code']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['cvx_code_text'] = $immunization_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['amount_administered'] = $immunization_data['substanceAdministration']['doseQuantity']['value']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['amount_administered_unit'] = $immunization_data['substanceAdministration']['doseQuantity']['unit']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['completion_status'] = $immunization_data['substanceAdministration']['statusCode']['code']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['manufacturer'] = $immunization_data['substanceAdministration']['consumable']['manufacturedProduct']['manufacturerOrganization']['name']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_npi'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_name'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['assignedPerson']['name']['given']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_address'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_city'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_state'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_postalCode'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_country'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['addr']['country']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['provider_telecom'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['telecom']['value']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['represented_organization'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['representedOrganization']['name']; + $this->ccda_data_array['field_name_value_array']['immunization'][$i]['represented_organization_tele'] = $immunization_data['substanceAdministration']['performer']['assignedEntity']['representedOrganization']['telecom']; + $this->ccda_data_array['entry_identification_array']['immunization'][$i] = $i; + unset($immunization_data); + return; + } + } + + public function procedure($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + if ($key % 3 != 0) + continue; //every third entry section has the procedure details + $this->fetch_procedure_value($value); + } + } + else { + $this->fetch_procedure_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_procedure_value($procedure_data) + { + if($procedure_data['procedure']['code']['code'] != '' && $procedure_data['procedure']['code']['code'] != 0) { + $i = count($this->ccda_data_array['field_name_value_array']['procedure']) + 1; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['extension'] = $procedure_data['procedure']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['root'] = $procedure_data['procedure']['id']['root']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['code'] = $procedure_data['procedure']['code']['code']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['code_text'] = $procedure_data['procedure']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['codeSystemName'] = $procedure_data['procedure']['code']['codeSystemName']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['date'] = $procedure_data['procedure']['effectiveTime']['value']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization1'] = $procedure_data['procedure']['performer']['assignedEntity']['representedOrganization']['name']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_address1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_city1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_state1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_postalcode1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_country1'] = $procedure_data['procedure']['performer']['assignedEntity']['addr']['country']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_telecom1'] = $procedure_data['procedure']['performer']['assignedEntity']['telecom']['value']; + + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization2'] = $procedure_data['procedure']['participant']['participantRole']['playingEntity']['name']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_address2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_city2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_state2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_postalcode2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['procedure'][$i]['represented_organization_country2'] = $procedure_data['procedure']['participant']['participantRole']['addr']['country']; + $this->ccda_data_array['entry_identification_array']['procedure'][$i] = $i; + unset($procedure_data); + return; + } + } + + public function lab_result($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_lab_result_value($value); + } + } + else{ + $this->fetch_lab_result_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_lab_result_value($lab_result_data) + { + $i = count($this->ccda_data_array['field_name_value_array']['procedure_result']) + 1; + foreach ($lab_result_data['organizer']['component'] as $key => $value) { + if($value['observation']['code']['code']) { + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['extension'] = $lab_result_data['organizer']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['root'] = $lab_result_data['organizer']['id']['root']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['proc_code'] = $lab_result_data['organizer']['code']['code']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['proc_text'] = $lab_result_data['organizer']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['date'] = $lab_result_data['organizer']['effectiveTime']['value']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['status'] = $lab_result_data['organizer']['statusCode']['code']; + + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_extension'] = $value['observation']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_root'] = $value['observation']['id']['root']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_code'] = $value['observation']['code']['code']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_text'] = $value['observation']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_date'] = $value['observation']['effectiveTime']['value']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_value'] = $value['observation']['value']['value']; + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_unit'] = $value['observation']['value']['unit']; + if ($value['observation']['referenceRange']['observationRange']['text']) + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_range'] = $value['observation']['referenceRange']['observationRange']['text']; + else + $this->ccda_data_array['field_name_value_array']['procedure_result'][$i]['results_range'] = $value['observation']['referenceRange']['observationRange']['value']['low']['value'] . '-' . $value['observation']['referenceRange']['observationRange']['value']['high']['value'] . ' ' . $value['observation']['referenceRange']['observationRange']['value']['low']['unit']; + $this->ccda_data_array['entry_identification_array']['procedure_result'][$i] = $i; + $i++; + } + } + unset($lab_result_data); + return; + } + + public function vital_sign($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_vital_sign_value($value); + } + } + else{ + $this->fetch_vital_sign_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_vital_sign_value($vital_sign_data) + { + if($vital_sign_data['organizer']['component'][0]['observation']['effectiveTime']['value'] != '' && $vital_sign_data['organizer']['component'][0]['observation']['effectiveTime']['value'] != 0) { + $i = count($this->ccda_data_array['field_name_value_array']['vital_sign']) + 1; + $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['extension'] = $vital_sign_data['organizer']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['root'] = $vital_sign_data['organizer']['id']['root']; + $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['date'] = $vital_sign_data['organizer']['component'][0]['observation']['effectiveTime']['value']; + $vitals_array = array( + '8310-5' => 'temperature', + '8462-4' => 'bpd', + '8480-6' => 'bps', + '8287-5' => 'head_circ', + '8867-4' => 'pulse', + '8302-2' => 'height', + '2710-2' => 'oxygen_saturation', + '9279-1' => 'respiration', + '3141-9' => 'weight' + ); + + for ($j = 0; $j < 9; $j++) { + $code = $vital_sign_data['organizer']['component'][$j]['observation']['code']['code']; + if ($vital_sign_data['organizer']['component'][$j]['observation']['entryRelationship']) { + $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['bps'] = $vital_sign_data['organizer']['component'][$j]['observation']['entryRelationship'][0]['observation']['value']['value']; + $this->ccda_data_array['field_name_value_array']['vital_sign'][$i]['bpd'] = $vital_sign_data['organizer']['component'][$j]['observation']['entryRelationship'][1]['observation']['value']['value']; + } + else + $this->ccda_data_array['field_name_value_array']['vital_sign'][$i][$vitals_array[$code]] = $vital_sign_data['organizer']['component'][$j]['observation']['value']['value']; + } + $this->ccda_data_array['entry_identification_array']['vital_sign'][$i] = $i; + unset($vital_sign_data); + return; + } + } + + public function social_history($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_social_history_value($value); + } + } + else{ + $this->fetch_social_history_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_social_history_value($social_history_data) + { + if($social_history_data['observation']['value']['code'] != '' && $social_history_data['observation']['value']['code'] != 0) { + $social_history_array = array( + '2.16.840.1.113883.10.20.22.4.78' => 'smoking' + ); + $i = 0; + $code = $social_history_data['observation']['templateId']['root']; + foreach ($this->ccda_data_array['field_name_value_array']['social_history'] as $key => $value) { + if (!array_key_exists($social_history_array[$code], $value)) { + $i = $key; + } + else { + $i = count($this->ccda_data_array['field_name_value_array']['social_history']) + 1; + } + } + $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['extension'] = $social_history_data['observation']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['root'] = $social_history_data['observation']['id']['root']; + $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['status'] = $social_history_data['observation']['value']['code']; + $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['begdate'] = $social_history_data['observation']['effectiveTime']['low']['value']; + $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['enddate'] = $social_history_data['observation']['effectiveTime']['high']['value']; + $this->ccda_data_array['field_name_value_array']['social_history'][$i][$social_history_array[$code]]['value'] = $social_history_data['observation']['value']['displayName']; + $this->ccda_data_array['entry_identification_array']['social_history'][$i] = $i; + unset($social_history_data); + return; + } + } + + public function encounter($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_encounter_value($value); + } + } + else{ + $this->fetch_encounter_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_encounter_value($encounter_data) + { + if($encounter_data['encounter']['effectiveTime']['value'] != 0) { + $i = count($this->ccda_data_array['field_name_value_array']['encounter']) + 1; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['extension'] = $encounter_data['encounter']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['root'] = $encounter_data['encounter']['id']['root']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['date'] = $encounter_data['encounter']['effectiveTime']['value']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['code'] = $encounter_data['encounter']['code']['code']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['code_text'] = $encounter_data['encounter']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_npi'] = $encounter_data['encounter']['performer']['assignedEntity']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_name'] = $encounter_data['encounter']['performer']['assignedEntity']['assignedPerson']['name']['given']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_address'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_city'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_state'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_postalCode'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['provider_country'] = $encounter_data['encounter']['performer']['assignedEntity']['addr']['country']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_name'] = $encounter_data['encounter']['participant']['participantRole']['playingEntity']['name']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_address'] = $encounter_data['encounter']['participant']['participantRole']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_city'] = $encounter_data['encounter']['participant']['participantRole']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_state'] = $encounter_data['encounter']['participant']['participantRole']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_zip'] = $encounter_data['encounter']['participant']['participantRole']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_country'] = $encounter_data['encounter']['participant']['participantRole']['addr']['country']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['represented_organization_telecom'] = $encounter_data['encounter']['participant']['participantRole']['telecom']; + + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['encounter_diagnosis_date'] = $encounter_data['encounter']['entryRelationship'][1]['act']['entryRelationship']['observation']['effectiveTime']['low']['value']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['encounter_diagnosis_code'] = $encounter_data['encounter']['entryRelationship'][1]['act']['entryRelationship']['observation']['value']['code']; + $this->ccda_data_array['field_name_value_array']['encounter'][$i]['encounter_diagnosis_issue'] = $encounter_data['encounter']['entryRelationship'][1]['act']['entryRelationship']['observation']['value']['displayName']; + $this->ccda_data_array['entry_identification_array']['encounter'][$i] = $i; + unset($encounter_data); + return; + } + } + + public function care_plan($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_care_plan_value($value); + } + } + else{ + $this->fetch_care_plan_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_care_plan_value($care_plan_data) + { + if($care_plan_data['act']['code']['code'] != '' && $care_plan_data['act']['code']['code'] != 0) { + $i = count($this->ccda_data_array['field_name_value_array']['care_plan']) + 1; + $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['extension'] = $care_plan_data['act']['templateId']['root']; + $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['root'] = $care_plan_data['act']['templateId']['root']; + $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['code'] = $care_plan_data['act']['code']['code']; + $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['code_text'] = $care_plan_data['act']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['description'] = $care_plan_data['act']['text']; + $this->ccda_data_array['field_name_value_array']['care_plan'][$i]['date'] = $care_plan_data['act']['effectiveTime']['center']['value']; + $this->ccda_data_array['entry_identification_array']['care_plan'][$i] = $i; + unset($care_plan_data); + return; + } + } + + public function functional_cognitive_status($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_functional_cognitive_status_value($value); + } + } + else{ + $this->fetch_functional_cognitive_status_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_functional_cognitive_status_value($functional_cognitive_status_data) + { + if($functional_cognitive_status_data['observation']['value']['code'] != '' && $functional_cognitive_status_data['observation']['value']['code'] != 0) { + $i = count($this->ccda_data_array['field_name_value_array']['functional_cognitive_status']) + 1; + $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['extension'] = $functional_cognitive_status_data['observation']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['root'] = $functional_cognitive_status_data['observation']['id']['root']; + $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['date'] = $functional_cognitive_status_data['observation']['effectiveTime']['low']['value']; + $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['code'] = $functional_cognitive_status_data['observation']['value']['code']; + $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['code_text'] = $functional_cognitive_status_data['observation']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['functional_cognitive_status'][$i]['description'] = $functional_cognitive_status_data['observation']['value']['displayName']; + $this->ccda_data_array['entry_identification_array']['functional_cognitive_status'][$i] = $i; + unset($functional_cognitive_status_data); + return; + } + } + + public function referral($component) + { + if($component['section']['entry'][0]){ + foreach($component['section']['entry'] as $key => $value){ + $this->fetch_referral_value($value); + } + } + else{ + $this->fetch_referral_value($component['section']); + } + unset($component); + return; + } + + public function fetch_referral_value($referral_data) + { + $i = count($this->ccda_data_array['field_name_value_array']['referral']) + 1; + $this->ccda_data_array['field_name_value_array']['referral'][$i]['root'] = $referral_data['templateId']['root']; + $this->ccda_data_array['field_name_value_array']['referral'][$i]['body'] = preg_replace("/\s+/", " ",$referral_data['text']['paragraph']); + + $this->ccda_data_array['entry_identification_array']['referral'][$i] = $i; + unset($referral_data); + return; + } + + public function discharge_medications($component) + { + $component['section']['text'] = ''; + if ($component['section']['entry'][0]) { + foreach ($component['section']['entry'] as $key => $value) { + $this->fetch_discharge_medications_value($value); + } + } + else{ + $this->fetch_discharge_medications_value($component['section']['entry']); + } + unset($component); + return; + } + + public function fetch_discharge_medications_value($discharge_medications_data) + { + $i = count($this->ccda_data_array['field_name_value_array']['discharge_medication']) + 1; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['extension'] = $discharge_medications_data['act']['id']['extension']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['root'] = $discharge_medications_data['act']['id']['root']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['begdate'] = $discharge_medications_data['act']['effectiveTime']['low']['value']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['enddate'] = $discharge_medications_data['act']['effectiveTime']['high']['value']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['route'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['routeCode']['code']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['route_display'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['routeCode']['displayName']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['dose'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['doseQuantity']['value']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['dose_unit'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['doseQuantity']['unit']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['rate'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['rateQuantity']['value']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['rate_unit'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['rateQuantity']['unit']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['drug_code'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['code']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['drug_text'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['consumable']['manufacturedProduct']['manufacturedMaterial']['code']['displayName']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['note'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['text']['reference']['value']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['indication'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][0]['observation']['value']['displayName'] ? $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][0]['observation']['value']['displayName'] : $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship']['observation']['value']['displayName']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['prn'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['precondition']['criterion']['value']['displayName']; + + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['provider_title'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['assignedPerson']['name']['prefix']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['provider_fname'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['assignedPerson']['name']['given']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['provider_lname'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['assignedPerson']['name']['family']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['provider_root'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][1]['supply']['author']['assignedAuthor']['id']['root']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['provider_address'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['streetAddressLine']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['provider_city'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['city']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['provider_state'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['state']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['provider_postalCode'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['postalCode']; + $this->ccda_data_array['field_name_value_array']['discharge_medication'][$i]['provider_country'] = $discharge_medications_data['act']['entryRelationship']['substanceAdministration']['entryRelationship'][1]['supply']['performer']['assignedEntity']['addr']['country']; + $this->ccda_data_array['entry_identification_array']['discharge_medication'][$i] = $i; + unset($discharge_medications_data); + return; + } + + public function discharge_summary($component) + { + if($component['section']['entry'][0]){ + foreach($component['section']['entry'] as $key => $value){ + $this->fetch_discharge_summary_value($value); + } + } + else{ + $this->fetch_discharge_summary_value($component['section']); + } + unset($component); + return; + } + + public function fetch_discharge_summary_value($discharge_summary_data) + { + $i = count($this->ccda_data_array['field_name_value_array']['discharge_summary']) + 1; + $this->ccda_data_array['field_name_value_array']['discharge_summary'][$i]['root'] = $discharge_summary_data['templateId']['root']; + $text = preg_replace("/\s+/", " ",$discharge_summary_data['text']['content']); + for($j=0;$jccda_data_array['field_name_value_array']['discharge_summary'][$i]['text'] = $text; + + $this->ccda_data_array['entry_identification_array']['discharge_summary'][$i] = $i; + unset($discharge_summary_data); + return; + } + /* + * Fetch a document from the database + * + * @param $document_id Integer Document ID + * @return $content String File content + */ + public function getDocument($document_id) + { + $content = \Documents\Plugin\Documents::getDocument($document_id); + return $content; + } + + public function getCategory() + { + $doc_obj = new DocumentsTable(); + $category = $doc_obj->getCategory(); + return $category; + } + + public function getIssues($pid) + { + $doc_obj = new DocumentsTable(); + $issues = $doc_obj->getIssues($pid); + return $issues; + } + + public function getCategoryIDs() + { + $doc_obj = new DocumentsTable(); + $result = implode("|", $doc_obj->getCategoryIDs(array('CCD', 'CCR', 'CCDA'))); + return $result; + } + + /* + * Fetch the demographics data from audit tables + * + * @param audit_master_id Integer ID from audit master table + * @return records Array Demographics data + */ + public function getDemographics($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT ad.id as adid, + table_name, + field_name, + field_value + FROM audit_master am + JOIN audit_details ad ON ad.audit_master_id = am.id + WHERE am.id = ? AND ad.table_name = 'patient_data' + ORDER BY ad.id"; + $result = $appTable->zQuery($query, array($data['audit_master_id'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the current demographics data of a patient from patient_data table + * + * @param pid Integer Patient ID + * @return records Array current patient data + */ + public function getDemographicsOld($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM patient_data + WHERE pid = ?"; + $result = $appTable->zQuery($query, array($data['pid'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the current Problems of a patient from lists table + * + * @param pid Integer patient id + * @return records Array list of problems + */ + public function getProblems($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM lists + WHERE pid = ? AND TYPE = 'medical_problem'"; + $result = $appTable->zQuery($query, array($data['pid'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the current Allergies of a patient from lists table + * + * @param pid Integer patient id + * @return records Array list of allergies + */ + public function getAllergies($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM lists + WHERE pid = ? AND TYPE = 'allergy'"; + $result = $appTable->zQuery($query, array($data['pid'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the current Medications of a patient from prescriptions table + * + * @param pid Integer patient id + * @return records Array list of medications + */ + public function getMedications($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM prescriptions + WHERE patient_id = ?"; + $result = $appTable->zQuery($query, array($data['pid'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the current Immunizations of a patient from immunizations table + * + * @param pid Integer patient id + * @return records Array list of immunizations + */ + public function getImmunizations($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM immunizations + WHERE patient_id = ?"; //removed the field 'added_erroneously' from where condition + $result = $appTable->zQuery($query, array($data['pid'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the currect Lab Results of a patient + * + * @param pid Integer patient id + * @return records Array list of lab results + */ + public function getLabResults($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT CONCAT_WS('',po.procedure_order_id,poc.`procedure_order_seq`) AS tcode, + prs.result AS result_value, + prs.units, prs.range, + poc.procedure_name AS order_title, + prs.result_code as result_code, + prs.result_text as result_desc, + po.date_ordered, + prs.date AS result_time, + prs.abnormal AS abnormal_flag, + prs.procedure_result_id AS result_id + FROM procedure_order AS po + JOIN procedure_order_code AS poc ON poc.`procedure_order_id`=po.`procedure_order_id` + JOIN procedure_report AS pr ON pr.procedure_order_id = po.procedure_order_id + AND pr.`procedure_order_seq`=poc.`procedure_order_seq` + JOIN procedure_result AS prs ON prs.procedure_report_id = pr.procedure_report_id + WHERE po.patient_id = ? AND prs.result NOT IN ('DNR','TNP')"; + $result = $appTable->zQuery($query, array($data['pid'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the current Vitals of a patient from form_vitals table + * + * @param pid Integer patient id + * @return records Array list of vitals + */ + public function getVitals($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM form_vitals + WHERE pid = ? AND activity=?"; + $result = $appTable->zQuery($query, array($data['pid'], 1)); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the social history of a patient from history_data table + * + * @param pid Integer patient id + * @return records Array history data + */ + public function getSocialHistory($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM history_data + WHERE pid=? + ORDER BY id DESC LIMIT 1"; + $result = $appTable->zQuery($query, array($data['pid'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the encounter data of a patient from form_encounter table + * + * @param pid Integer patient id + * @return records Array encounter data + */ + public function getEncounterData($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT form_encounter.*,u.fname AS provider_name + FROM form_encounter + LEFT JOIN users AS u + ON form_encounter.provider_id=u.id + WHERE pid = ?"; + $result = $appTable->zQuery($query, array($data['pid'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the billing data of a patient from billing table + * + * @param pid Integer patient id + * @return records Array billing data + */ + public function getProcedure($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM billing + WHERE pid=? AND code_type=?"; + $result = $appTable->zQuery($query, array($data['pid'], 'CPT4')); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the current Care Plan of a patient from form_care_paln table + * + * @param pid Integer patient id + * @return records Array list of Care Plans + */ + public function getCarePlan($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM form_care_plan + WHERE pid = ? AND activity=?"; + $result = $appTable->zQuery($query, array($data['pid'], 1)); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the current Functional Cognitive Status of a patient from form_functional_cognitive_status table + * + * @param pid Integer patient id + * @return records Array list of Functional Cognitive Status + */ + public function getFunctionalCognitiveStatus($data) + { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM form_functional_cognitive_status + WHERE pid = ? AND activity=?"; + $result = $appTable->zQuery($query, array($data['pid'], 1)); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the data from audit tables + * + * @param am_id integer audit master ID + * @param table_name string identifier inserted for each table (eg: prescriptions, list1 ...) + */ + public function createAuditArray($am_id,$table_name) + { + $appTable = new ApplicationTable(); + if (strpos($table_name, ',')) { + $tables = explode(',', $table_name); + $arr = array($am_id); + $table_qry = ""; + for ($i = 0; $i < count($tables); $i++) { + $table_qry .= "?,"; + array_unshift($arr, $tables[$i]); + } + $table_qry = substr($table_qry, 0, -1); + $query = "SELECT * + FROM audit_master am + JOIN audit_details ad + ON ad.audit_master_id = am.id + AND ad.table_name IN ($table_qry) + WHERE am.id = ? AND am.type = 12 AND am.approval_status = 1 + ORDER BY ad.entry_identification,ad.field_name"; + $result = $appTable->zQuery($query, $arr); + } + else{ + $query = "SELECT * + FROM audit_master am + JOIN audit_details ad + ON ad.audit_master_id = am.id + AND ad.table_name = ? + WHERE am.id = ? AND am.type = 12 AND am.approval_status = 1 + ORDER BY ad.entry_identification,ad.field_name"; + $result = $appTable->zQuery($query, array($table_name, $am_id)); + } + $records = array(); + foreach ($result as $res) { + $records[$table_name][$res['entry_identification']][$res['field_name']] = $res['field_value']; + } + return $records; + } + + public function getListTitle($option_id='',$list_id,$codes='') + { + $appTable = new ApplicationTable(); + if ($option_id) { + $query = "SELECT title + FROM list_options + WHERE list_id=? AND option_id=? AND activity=?"; + $result = $appTable->zQuery($query, array($list_id, $option_id, 1)); + $res_cur = $result->current(); + } + if ($codes) { + $query = "SELECT title + FROM list_options + WHERE list_id=? AND (codes=? OR option_id=?) AND activity=?"; + $result = $appTable->zQuery($query, array($list_id, $codes, $option_id, 1)); + $res_cur = $result->current(); + } + return $res_cur['title']; + } + + public function insertApprovedData($data) + { + $appTable = new ApplicationTable(); + $patient_data_fields = ''; + $patient_data_values = array(); + $j = 1; + $y = 1; + $k = 1; + $q = 1; + $a = 1; + $b = 1; + $c = 1; + $d = 1; + $e = 1; + $f = 1; + $g = 1; + + $arr_procedure_res = array(); + $arr_procedures = array(); + $arr_vitals = array(); + $arr_encounter = array(); + $arr_immunization = array(); + $arr_prescriptions = array(); + $arr_allergies = array(); + $arr_med_pblm = array(); + $arr_care_plan = array(); + $arr_functional_cognitive_status = array(); + $arr_referral = array(); + + $p1_arr = explode("||",$data['problem1check']); + $p2_arr = explode('||',$data['problem2check']); + $p3_arr = explode('||',$data['problem3check']); + $a1_arr = explode("||",$data['allergy1check']); + $a2_arr = explode('||',$data['allergy2check']); + $a3_arr = explode('||',$data['allergy3check']); + $m1_arr = explode("||",$data['med1check']); + $m2_arr = explode('||',$data['med2check']); + $m3_arr = explode('||',$data['med3check']); + + foreach ($data as $key => $val) { + if (substr($key, -4) == '-sel') { + if (is_array($val)) { + for ($i = 0; $i < count($val); $i++) { + if ($val[$i] == 'insert') { + if (substr($key, 0, -4) == 'immunization') { + $arr_immunization['immunization'][$a]['extension'] = $data['immunization-extension'][$i]; + $arr_immunization['immunization'][$a]['root'] = $data['immunization-root'][$i]; + $arr_immunization['immunization'][$a]['administered_date'] = $data['immunization-administered_date'][$i]; + $arr_immunization['immunization'][$a]['route_code'] = $data['immunization-route_code'][$i]; + $arr_immunization['immunization'][$a]['route_code_text'] = $data['immunization-route_code_text'][$i]; + $arr_immunization['immunization'][$a]['cvx_code'] = $data['immunization-cvx_code'][$i]; + $arr_immunization['immunization'][$a]['cvx_code_text'] = $data['immunization-cvx_code_text'][$i]; + $arr_immunization['immunization'][$a]['amount_administered'] = $data['immunization-amount_administered'][$i]; + $arr_immunization['immunization'][$a]['amount_administered_unit'] = $data['immunization-amount_administered_unit'][$i]; + $arr_immunization['immunization'][$a]['manufacturer'] = $data['immunization-manufacturer'][$i]; + $arr_immunization['immunization'][$a]['completion_status'] = $data['immunization-completion_status'][$i]; + + $arr_immunization['immunization'][$a]['provider_npi'] = $data['immunization-provider_npi'][$i]; + $arr_immunization['immunization'][$a]['provider_name'] = $data['immunization-provider_name'][$i]; + $arr_immunization['immunization'][$a]['provider_address'] = $data['immunization-provider_address'][$i]; + $arr_immunization['immunization'][$a]['provider_city'] = $data['immunization-provider_city'][$i]; + $arr_immunization['immunization'][$a]['provider_state'] = $data['immunization-provider_state'][$i]; + $arr_immunization['immunization'][$a]['provider_postalCode'] = $data['immunization-provider_postalCode'][$i]; + $arr_immunization['immunization'][$a]['provider_country'] = $data['immunization-provider_country'][$i]; + $arr_immunization['immunization'][$a]['provider_telecom'] = $data['immunization-provider_telecom'][$i]; + $arr_immunization['immunization'][$a]['represented_organization'] = $data['immunization-represented_organization'][$i]; + $arr_immunization['immunization'][$a]['represented_organization_tele'] = $data['immunization-represented_organization_tele'][$i]; + $a++; + } + elseif(substr($key,0,-4) == 'lists3'){ + $arr_prescriptions['lists3'][$b]['extension'] = $data['lists3-extension'][$i]; + $arr_prescriptions['lists3'][$b]['root'] = $data['lists3-root'][$i]; + $arr_prescriptions['lists3'][$b]['begdate'] = $data['lists3-date_added'][$i]; + $arr_prescriptions['lists3'][$b]['enddate'] = $data['lists3-enddate'][$i]; + $arr_prescriptions['lists3'][$b]['route'] = $data['lists3-route'][$i]; + $arr_prescriptions['lists3'][$b]['note'] = $data['lists3-note'][$i]; + $arr_prescriptions['lists3'][$b]['indication'] = $data['lists3-indication'][$i]; + $arr_prescriptions['lists3'][$b]['route_display'] = $data['lists3-route_display'][$i]; + $arr_prescriptions['lists3'][$b]['dose'] = $data['lists3-dose'][$i]; + $arr_prescriptions['lists3'][$b]['rate'] = $data['lists3-size'][$i]; + $arr_prescriptions['lists3'][$b]['dose_unit'] = $data['lists3-dose_unit'][$i]; + $arr_prescriptions['lists3'][$b]['rate_unit'] = $data['lists3-rate_unit'][$i]; + $arr_prescriptions['lists3'][$b]['drug_code'] = $data['lists3-drugcode'][$i]; + $arr_prescriptions['lists3'][$b]['drug_text'] = $data['lists3-drug'][$i]; + $arr_prescriptions['lists3'][$b]['prn'] = $data['lists3-prn'][$i]; + $arr_prescriptions['lists3'][$b]['discontinue'] = $m3_arr[$i]; + + $arr_prescriptions['lists3'][$b]['provider_address'] = $data['lists3-provider_address'][$i]; + $arr_prescriptions['lists3'][$b]['provider_city'] = $data['lists3-provider_city'][$i]; + $arr_prescriptions['lists3'][$b]['provider_country'] = $data['lists3-provider_country'][$i]; + $arr_prescriptions['lists3'][$b]['provider_title'] = $data['lists3-provider_title'][$i]; + $arr_prescriptions['lists3'][$b]['provider_fname'] = $data['lists3-provider_fname'][$i]; + $arr_prescriptions['lists3'][$b]['provider_lname'] = $data['lists3-provider_lname'][$i]; + $arr_prescriptions['lists3'][$b]['provider_postalCode'] = $data['lists3-provider_postalCode'][$i]; + $arr_prescriptions['lists3'][$b]['provider_state'] = $data['lists3-provider_state'][$i]; + $arr_prescriptions['lists3'][$b]['provider_root'] = $data['lists3-provider_root'][$i]; + $b++; + } + elseif(substr($key,0,-4) == 'lists2'){ + $arr_allergies['lists2'][$c]['extension'] = $data['lists2-extension'][$i]; + $arr_allergies['lists2'][$c]['begdate'] = $data['lists2-begdate'][$i]; + $arr_allergies['lists2'][$c]['enddate'] = $data['lists2-enddate'][$i]; + $arr_allergies['lists2'][$c]['list_code'] = $data['lists2-diagnosis'][$i]; + $arr_allergies['lists2'][$c]['list_code_text'] = $data['lists2-title'][$i]; + $arr_allergies['lists2'][$c]['severity_al'] = $data['lists2-severity_al'][$i]; + $arr_allergies['lists2'][$c]['status'] = $data['lists2-activity'][$i]; + $arr_allergies['lists2'][$c]['reaction'] = $data['lists2-reaction'][$i]; + $arr_allergies['lists2'][$c]['reaction_text'] = $data['lists2-reaction_text'][$i]; + $arr_allergies['lists2'][$c]['codeSystemName'] = $data['lists2-codeSystemName'][$i]; + $arr_allergies['lists2'][$c]['outcome'] = $data['lists2-outcome'][$i]; + $arr_allergies['lists2'][$c]['resolved'] = $a3_arr[$i]; + $c++; + } + else if(substr($key,0,-4) == 'lists1'){ + $arr_med_pblm['lists1'][$d]['extension'] = $data['lists1-extension'][$i]; + $arr_med_pblm['lists1'][$d]['root'] = $data['lists1-root'][$i]; + $arr_med_pblm['lists1'][$d]['begdate'] = $data['lists1-begdate'][$i]; + $arr_med_pblm['lists1'][$d]['enddate'] = $data['lists1-enddate'][$i]; + $arr_med_pblm['lists1'][$d]['list_code'] = $data['lists1-diagnosis'][$i]; + $arr_med_pblm['lists1'][$d]['list_code_text'] = $data['lists1-title'][$i]; + $arr_med_pblm['lists1'][$d]['status'] = $data['lists1-activity'][$i]; + $arr_med_pblm['lists1'][$d]['observation_text'] = $data['lists1-observation_text'][$i]; + $arr_med_pblm['lists1'][$d]['observation'] = $data['lists1-observation'][$i]; + $arr_med_pblm['lists1'][$d]['resolved'] = $p3_arr[$i]; + $d++; + } + else if(substr($key,0,-4) == 'vital_sign'){ + $arr_vitals['vitals'][$q]['extension'] = $data['vital_sign-extension'][$i]; + $arr_vitals['vitals'][$q]['date'] = $data['vital_sign-date'][$i]; + $arr_vitals['vitals'][$q]['temperature'] = $data['vital_sign-temp'][$i]; + $arr_vitals['vitals'][$q]['bpd'] = $data['vital_sign-bpd'][$i]; + $arr_vitals['vitals'][$q]['bps'] = $data['vital_sign-bps'][$i]; + $arr_vitals['vitals'][$q]['head_circ'] = $data['vital_sign-head_circ'][$i]; + $arr_vitals['vitals'][$q]['pulse'] = $data['vital_sign-pulse'][$i]; + $arr_vitals['vitals'][$q]['height'] = $data['vital_sign-height'][$i]; + $arr_vitals['vitals'][$q]['oxygen_saturation'] = $data['vital_sign-oxy_sat'][$i]; + $arr_vitals['vitals'][$q]['respiration'] = $data['vital_sign-resp'][$i]; + $arr_vitals['vitals'][$q]['weight'] = $data['vital_sign-weight'][$i]; + $q++; + } + else if(substr($key,0,-4) == 'social_history'){ + $tobacco = $data['social_history-tobacco_note'][$i]."|". + $data['social_history-tobacco_status'][$i] . "|" . + \Application\Model\ApplicationTable::fixDate($data['social_history-tobacco_date'][$i], 'yyyy-mm-dd', 'dd/mm/yyyy') . "|" . $data['social_history-tobacco_snomed'][$i]; + $alcohol = $data['social_history-alcohol_note'][$i] . "|" . + $data['social_history-alcohol_status'][$i] . "|" . + \Application\Model\ApplicationTable::fixDate($data['social_history-alcohol_date'][$i], 'yyyy-mm-dd', 'dd/mm/yyyy'); + $query = "INSERT INTO history_data + ( pid, + tobacco, + alcohol, + date + ) + VALUES + ( + ?, + ?, + ?, + ? + )"; + $appTable->zQuery($query, array($data['pid'], + $tobacco, + $alcohol, + date('Y-m-d H:i:s'))); + } + else if(substr($key,0,-4) == 'encounter'){ + $arr_encounter['encounter'][$k]['extension'] = $data['encounter-extension'][$i]; + $arr_encounter['encounter'][$k]['root'] = $data['encounter-root'][$i]; + $arr_encounter['encounter'][$k]['date'] = $data['encounter-date'][$i]; + + $arr_encounter['encounter'][$k]['provider_npi'] = $data['encounter-provider_npi'][$i]; + $arr_encounter['encounter'][$k]['provider_name'] = $data['encounter-provider'][$i]; + $arr_encounter['encounter'][$k]['provider_address'] = $data['encounter-provider_address'][$i]; + $arr_encounter['encounter'][$k]['provider_city'] = $data['encounter-provider_city'][$i]; + $arr_encounter['encounter'][$k]['provider_state'] = $data['encounter-provider_state'][$i]; + $arr_encounter['encounter'][$k]['provider_postalCode'] = $data['encounter-provider_postalCode'][$i]; + $arr_encounter['encounter'][$k]['provider_country'] = $data['encounter-provider_country'][$i]; + + $arr_encounter['encounter'][$k]['represented_organization_name'] = $data['encounter-facility'][$i]; + $arr_encounter['encounter'][$k]['represented_organization_address'] = $data['encounter-represented_organization_address'][$i]; + $arr_encounter['encounter'][$k]['represented_organization_city'] = $data['encounter-represented_organization_city'][$i]; + $arr_encounter['encounter'][$k]['represented_organization_state'] = $data['encounter-represented_organization_state'][$i]; + $arr_encounter['encounter'][$k]['represented_organization_zip'] = $data['encounter-represented_organization_zip'][$i]; + $arr_encounter['encounter'][$k]['represented_organization_country'] = $data['encounter-represented_organization_country'][$i]; + $arr_encounter['encounter'][$k]['represented_organization_telecom'] = $data['encounter-represented_organization_telecom'][$i]; + + $arr_encounter['encounter'][$k]['encounter_diagnosis_date'] = $data['encounter-encounter_diagnosis_date'][$i]; + $arr_encounter['encounter'][$k]['encounter_diagnosis_code'] = $data['encounter-encounter_diagnosis_code'][$i]; + $arr_encounter['encounter'][$k]['encounter_diagnosis_issue'] = $data['encounter-encounter_diagnosis_issue'][$i]; + $k++; + } + else if(substr($key,0,-4) == 'procedure_result'){ + $arr_procedure_res['procedure_result'][$j]['proc_text'] = $data['procedure_result-proc_text'][$i]; + $arr_procedure_res['procedure_result'][$j]['proc_code'] = $data['procedure_result-proc_code'][$i]; + $arr_procedure_res['procedure_result'][$j]['extension'] = $data['procedure_result-extension'][$i]; + $arr_procedure_res['procedure_result'][$j]['date'] = $data['procedure_result-date'][$i]; + $arr_procedure_res['procedure_result'][$j]['status'] = $data['procedure_result-status'][$i]; + $arr_procedure_res['procedure_result'][$j]['results_text'] = $data['procedure_result-result'][$i]; + $arr_procedure_res['procedure_result'][$j]['results_code'] = $data['procedure_result-result_code'][$i]; + $arr_procedure_res['procedure_result'][$j]['results_range'] = $data['procedure_result-result_range'][$i]; + $arr_procedure_res['procedure_result'][$j]['results_value'] = $data['procedure_result-result_value'][$i]; + $arr_procedure_res['procedure_result'][$j]['results_date'] = $data['procedure_result-result_date'][$i]; + $j++; + } + else if(substr($key,0,-4) == 'procedure'){ + + $arr_procedures['procedure'][$y]['extension'] = $data['procedures-extension'][$i]; + $arr_procedures['procedure'][$y]['root'] = $data['procedures-root'][$i]; + $arr_procedures['procedure'][$y]['codeSystemName'] = $data['procedures-codeSystemName'][$i]; + $arr_procedures['procedure'][$y]['code'] = $data['procedures-code'][$i]; + $arr_procedures['procedure'][$y]['code_text'] = $data['procedures-code_text'][$i]; + $arr_procedures['procedure'][$y]['date'] = $data['procedures-date'][$i]; + + $arr_procedures['procedure'][$y]['represented_organization1'] = $data['procedures-represented_organization1'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_address1'] = $data['procedures-represented_organization_address1'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_city1'] = $data['procedures-represented_organization_city1'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_state1'] = $data['procedures-represented_organization_state1'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_postalcode1'] = $data['procedures-represented_organization_postalcode1'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_country1'] = $data['procedures-represented_organization_country1'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_telecom1'] = $data['procedures-represented_organization_telecom1'][$i]; + + $arr_procedures['procedure'][$y]['represented_organization2'] = $data['procedures-represented_organization2'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_address2'] = $data['procedures-represented_organization_address2'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_city2'] = $data['procedures-represented_organization_city2'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_state2'] = $data['procedures-represented_organization_state2'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_postalcode2'] = $data['procedures-represented_organization_postalcode2'][$i]; + $arr_procedures['procedure'][$y]['represented_organization_country2'] = $data['procedures-represented_organization_country2'][$i]; + $y++; + } + elseif(substr($key,0,-4) == 'care_plan') { + $arr_care_plan['care_plan'][$e]['extension'] = $data['care_plan-extension'][$i]; + $arr_care_plan['care_plan'][$e]['root'] = $data['care_plan-root'][$i]; + $arr_care_plan['care_plan'][$e]['text'] = $data['care_plan-text'][$i]; + $arr_care_plan['care_plan'][$e]['code'] = $data['care_plan-code'][$i]; + $arr_care_plan['care_plan'][$e]['description'] = $data['care_plan-description'][$i]; + $e++; + } + elseif(substr($key,0,-4) == 'functional_cognitive_status') { + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['extension'] = $data['functional_cognitive_status-extension'][$i]; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['root'] = $data['functional_cognitive_status-root'][$i]; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['text'] = $data['functional_cognitive_status-text'][$i]; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['code'] = $data['functional_cognitive_status-code'][$i]; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['date'] = $data['functional_cognitive_status-date'][$i]; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['description'] = $data['functional_cognitive_status-description'][$i]; + $f++; + } + elseif (substr($key, 0, -4) == 'referral') { + $arr_referral['referral'][$g]['body'] = $data['referral-body'][$i]; + $arr_referral['referral'][$g]['root'] = $data['referral-root'][$i]; + $g++; + } + } + elseif($val[$i] == 'update'){ + if (substr($key, 0, -4) == 'lists1-con') { + if ($data['lists1-activity-con'][$i] == 'Active') { + $activity = 1; + } + elseif($data['lists1-activity-con'][$i] == 'Inactive'){ + $activity = 0; + } + $query_select = "SELECT * FROM list_options WHERE list_id = ? AND title = ?"; + $result = $appTable->zQuery($query_select, array('outcome', $data['lists1-observation_text-con'][$i])); + if ($result->count() > 0) { + $q_update = "UPDATE list_options SET activity = 1 WHERE list_id = ? AND title = ? AND codes = ?"; + $appTable->zQuery($q_update, array('outcome', $data['lists1-observation_text-con'][$i], 'SNOMED-CT:' . $data['lists1-observation-con'][$i])); + foreach ($result as $value1) { + $o_id = $value1['option_id']; + } + } else { + $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('outcome')); + foreach ($lres as $lrow) { + $o_id = $lrow['option_id']; + } + $q_insert = "INSERT INTO list_options (list_id,option_id,title,codes,activity) VALUES (?,?,?,?,?)"; + $appTable->zQuery($q_insert, array('outcome', $o_id, $data['lists1-observation_text-con'][$i], 'SNOMED-CT:' . $data['lists1-observation-con'][$i], 1)); + } + $query = "UPDATE lists + SET title=?, + diagnosis=?, + begdate = ?, + enddate = ?, + outcome = ? + WHERE pid=? AND id=?"; + $appTable->zQuery($query, array($data['lists1-title-con'][$i], + 'SNOMED-CT:' . $data['lists1-diagnosis-con'][$i], + \Application\Model\ApplicationTable::fixDate($data['lists1-begdate-con'][$i], 'yyyy-mm-dd', 'dd/mm/yyyy'), + \Application\Model\ApplicationTable::fixDate($data['lists1-enddate-con'][$i], 'yyyy-mm-dd', 'dd/mm/yyyy'), + $o_id, + $data['pid'], + $data['lists1-old-id-con'][$i])); + + if($p1_arr[$i] == 1) { + $query7 = "UPDATE lists SET enddate = ? WHERE pid = ? AND id = ?"; + $appTable->zQuery($query7, array(date('Y-m-d'),$data['pid'], $data['lists1-old-id-con'][$i])); + } + else if($p1_arr[$i] == 0) { + $query7 = "UPDATE lists SET enddate = ? WHERE pid = ? AND id = ?"; + $appTable->zQuery($query7, array((NULL),$data['pid'], $data['lists1-old-id-con'][$i])); + } + } + if(substr($key,0,-4) == 'lists1_exist'){ + if($p2_arr[$i] == 1) { + $query4 = "UPDATE lists SET enddate = ? WHERE pid = ? AND id = ?"; + $appTable->zQuery($query4, array(date('Y-m-d'),$data['pid'], $data['lists1_exist-list_id'][$i])); + } + else if($p2_arr[$i] == 0) { + $query4 = "UPDATE lists SET enddate = ? WHERE pid = ? AND id = ?"; + $appTable->zQuery($query4, array((NULL),$data['pid'], $data['lists1_exist-list_id'][$i])); + } + } + elseif(substr($key, 0, -4) == 'lists2-con') { + if($data['lists2-begdate-con'][$i] !=0) { + $allergy_begdate_value = \Application\Model\ApplicationTable::fixDate($data['lists2-begdate-con'][$i], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + elseif($data['lists2-begdate-con'][$i] == 0) { + $allergy_begdate = $data['lists2-begdate-con'][$i]; + $allergy_begdate_value = fixDate($allergy_begdate); + $allergy_begdate_value = (NULL); + } + $severity_option_id = $this->getOptionId('severity_ccda', '', 'SNOMED-CT:' . $data['lists2-severity_al-con'][$i]); + $severity_text = $this->getListTitle($severity_option_id, 'severity_ccda', 'SNOMED-CT:' . $data['lists2-severity_al-con'][$i]); + if ($severity_option_id == '' || $severity_option_id == NULL) { + $q_max_option_id = "SELECT MAX(CAST(option_id AS SIGNED))+1 AS option_id + FROM list_options + WHERE list_id=?"; + $res_max_option_id = $appTable->zQuery($q_max_option_id, array('severity_ccda')); + $res_max_option_id_cur = $res_max_option_id->current(); + $severity_option_id = $res_max_option_id_cur['option_id']; + $q_insert_units_option = "INSERT INTO list_options + ( + list_id, + option_id, + title, + activity + ) + VALUES + ( + 'severity_ccda', + ?, + ?, + 1 + )"; + if($severity_text) $appTable->zQuery($q_insert_units_option,array($severity_option_id,$severity_text)); + } + + $reaction_option_id = $this->getOptionId('Reaction', $data['lists2-reaction_text-con'][$i], ''); + if ($reaction_option_id == '' || $reaction_option_id == NULL) { + $q_max_option_id = "SELECT MAX(CAST(option_id AS SIGNED))+1 AS option_id + FROM list_options + WHERE list_id=?"; + $res_max_option_id = $appTable->zQuery($q_max_option_id, array('Reaction')); + $res_max_option_id_cur = $res_max_option_id->current(); + $reaction_option_id = $res_max_option_id_cur['option_id']; + $q_insert_units_option = "INSERT INTO list_options + ( + list_id, + option_id, + title, + activity + ) + VALUES + ( + 'Reaction', + ?, + ?, + 1 + )"; + if($value['reaction_text']) $appTable->zQuery($q_insert_units_option,array($reaction_option_id,$data['lists2-reaction_text-con'][$i])); + } + $q_upd_allergies = "UPDATE lists + SET date=?, + begdate=?, + title=?, + diagnosis=?, + severity_al=?, + reaction=? + WHERE pid = ? AND id=?"; + $appTable->zQuery($q_upd_allergies, array( + date('y-m-d H:i:s'), + $allergy_begdate_value, + $data['lists2-title-con'][$i], + 'RXNORM' . ':' . $data['lists2-diagnosis-con'][$i], + $severity_option_id, + $reaction_option_id ? $reaction_option_id : 0, + $data['pid'], + $data['lists2-list_id-con'][$i])); + + if($a1_arr[$i] == 1) { + $query5 = "UPDATE lists SET enddate = ? WHERE pid = ? AND id = ?"; + $appTable->zQuery($query5, array(date('Y-m-d'),$data['pid'], $data['lists2-list_id-con'][$i])); + } + else if($a1_arr[$i] == 0) { + $query5 = "UPDATE lists SET enddate = ? WHERE pid = ? AND id = ?"; + $appTable->zQuery($query5, array((NULL),$data['pid'], $data['lists2-list_id-con'][$i])); + } + } + if(substr($key,0,-4) == 'lists2_exist'){ + if($a2_arr[$i] == 1) { + $query5 = "UPDATE lists SET enddate = ? WHERE pid = ? AND id = ?"; + $appTable->zQuery($query5, array(date('Y-m-d'),$data['pid'], $data['lists2_exist-list_id'][$i])); + } + else if($a2_arr[$i] == 0) { + $query5 = "UPDATE lists SET enddate = ? WHERE pid = ? AND id = ?"; + $appTable->zQuery($query5, array((NULL),$data['pid'], $data['lists2_exist-list_id'][$i])); + } + } + elseif(substr($key, 0, -4) == 'lists3-con') { + $oid_route = $unit_option_id = $oidu_unit = ''; + //provider + $query_sel_users = "SELECT * + FROM users + WHERE abook_type='external_provider' AND npi=?"; + $res_query_sel_users = $appTable->zQuery($query_sel_users, array($data['lists3-provider_npi-con'][$i])); + if ($res_query_sel_users->count() > 0) { + foreach ($res_query_sel_users as $value1) { + $provider_id = $value1['id']; + } + } + else { + $query_ins_users = "INSERT INTO users + ( fname, + lname, + authorized, + street, + city, + state, + zip, + active, + abook_type + ) + VALUES + ( + ?, + ?, + 1, + ?, + ?, + ?, + ?, + 1, + 'external_provider' + )"; + $res_query_ins_users = $appTable->zQuery($query_ins_users, array($data['lists3-provider_fname-con'][$i], + $data['lists3-provider_lname-con'][$i], + $data['lists3-provider_address-con'][$i], + $data['lists3-provider_city-con'][$i], + $data['lists3-provider_state-con'][$i], + $data['lists3-provider_postalCode-con'][$i] + )); + $provider_id = $res_query_ins_users->getGeneratedValue(); + } + + //route + $q1_route = "SELECT * + FROM list_options + WHERE list_id='drug_route' AND notes=?"; + $res_q1_route = $appTable->zQuery($q1_route, array($data['lists3-route-con'][$i])); + foreach ($res_q1_route as $val1) { + $oid_route = $val1['option_id']; + } + if ($res_q1_route->count() == 0) { + $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('drug_route')); + foreach ($lres as $lrow) { + $oid_route = $lrow['option_id']; + } + $q_insert_route = "INSERT INTO list_options + ( + list_id, + option_id, + notes, + title, + activity + ) + VALUES + ( + 'drug_route', + ?, + ?, + ?, + 1 + )"; + $appTable->zQuery($q_insert_route, array($oid_route, $data['lists3-route-con'][$i], + $data['lists3-route_display-con'][$i])); + } + + //drug form + $query_select_form = "SELECT * FROM list_options WHERE list_id = ? AND title = ?"; + $result = $appTable->zQuery($query_select_form, array('drug_form', $data['lists3-dose_unit-con'][$i])); + if ($result->count() > 0) { + $q_update = "UPDATE list_options SET activity = 1 WHERE list_id = ? AND title = ?"; + $appTable->zQuery($q_update, array('drug_form', $data['lists3-dose_unit-con'][$i])); + foreach ($result as $value2) { + $oidu_unit = $value2['option_id']; + } + } + else { + $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('drug_form')); + foreach ($lres as $lrow) { + $oidu_unit = $lrow['option_id']; + } + $q_insert = "INSERT INTO list_options (list_id,option_id,title,activity) VALUES (?,?,?,?)"; + $appTable->zQuery($q_insert, array('drug_form', $oidu_unit, $data['lists3-dose_unit-con'][$i], 1)); + } + if ($data['lists3-enddate-con'][$i] == '' || $data['lists3-enddate-con'][$i] == 0) { + $data['lists3-enddate-con'][$i] = (NULL); + } + $q_upd_pres = "UPDATE prescriptions + SET date_added=?, + drug=?, + size=?, + form=?, + dosage=?, + route=?, + unit=?, + note=?, + indication=?, + prn = ?, + rxnorm_drugcode=?, + provider_id=? + WHERE id=? AND patient_id=?"; + $appTable->zQuery($q_upd_pres, array( + \Application\Model\ApplicationTable::fixDate($data['lists3-date_added-con'][$i], 'yyyy-mm-dd', 'dd/mm/yyyy'), + $data['lists3-drug-con'][$i], + $data['lists3-size-con'][$i], + $oidu_unit, + $data['lists3-dose-con'][$i], + $oid_route, + $data['lists3-rate_unit-con'][$i], + $data['lists3-note-con'][$i], + $data['lists3-indication-con'][$i], + $data['lists3-prn-con'][$i], + $data['lists3-drugcode-con'][$i], + $provider_id, + $data['lists3-id-con'][$i], + $data['pid'])); + if($m1_arr[$i] == 1) { + $query6 = "UPDATE prescriptions SET end_date = ?,active = ? WHERE patient_id = ? AND id = ?"; + $appTable->zQuery($query6, array(date('Y-m-d'),'-1',$data['pid'], $data['lists3-id-con'][$i])); + } + else if($m1_arr[$i] == 0) { + $query6 = "UPDATE prescriptions SET end_date = ?,active = ? WHERE patient_id = ? AND id = ?"; + $appTable->zQuery($query6, array((NULL),'1',$data['pid'], $data['lists3-id-con'][$i])); + } + } + if(substr($key,0,-4) == 'lists3_exist'){ + if($m2_arr[$i] == 1) { + $query6 = "UPDATE prescriptions SET end_date = ?,active = ? WHERE patient_id = ? AND id = ?"; + $appTable->zQuery($query6, array(date('Y-m-d'),'-1',$data['pid'], $data['lists3_exist-id'][$i])); + } + else if($m2_arr[$i] == 0) { + $query6 = "UPDATE prescriptions SET end_date = ?,active = ? WHERE patient_id = ? AND id = ?"; + $appTable->zQuery($query6, array((NULL),'1',$data['pid'], $data['lists3_exist-id'][$i])); + } + } + } + } + } + else + if (substr($key, 0, 12) == 'patient_data') { + if ($val == 'update') { + $var_name = substr($key, 0, -4); + $field_name = substr($var_name, 13); + $patient_data_fields .= $field_name . '=?,'; + array_push($patient_data_values, $data[$var_name]); + } + } + } + } + + if (count($patient_data_values) > 0) { + array_push($patient_data_values, $data['pid']); + $patient_data_fields = substr($patient_data_fields, 0, -1); + $query = "UPDATE patient_data SET $patient_data_fields WHERE pid=?"; + $appTable->zQuery($query, $patient_data_values); + } + $appTable->zQuery("UPDATE documents + SET foreign_id = ? + WHERE id =? ", array($data['pid'], + $data['document_id'])); + $appTable->zQuery("UPDATE audit_master + SET approval_status = '2' + WHERE id=?", array($data['amid'])); + $appTable->zQuery("UPDATE documents + SET audit_master_approval_status=2 + WHERE audit_master_id=?", array($data['amid'])); + + $this->InsertImmunization($arr_immunization['immunization'], $data['pid'], 1); + $this->InsertPrescriptions($arr_prescriptions['lists3'], $data['pid'], 1); + $this->InsertAllergies($arr_allergies['lists2'], $data['pid'], 1); + $this->InsertMedicalProblem($arr_med_pblm['lists1'], $data['pid'], 1); + $this->InsertEncounter($arr_encounter['encounter'], $data['pid'], 1); + $this->InsertVitals($arr_vitals['vitals'], $data['pid'], 1); + $this->InsertProcedures($arr_procedures['procedure'], $data['pid'], 1); + $lab_results = $this->buildLabArray($arr_procedure_res['procedure_result']); + $this->InsertLabResults($lab_results, $data['pid']); + $this->InsertCarePlan($arr_care_plan['care_plan'], $data['pid'], 1); + $this->InsertFunctionalCognitiveStatus($arr_functional_cognitive_status['functional_cognitive_status'], $data['pid'], 1); + $this->InsertReferrals($arr_referral['referral'], $data['pid'], 1); + } + + public function discardCCDAData($data) + { + $appTable = new ApplicationTable(); + $query = "UPDATE audit_master + SET approval_status = '3' + WHERE id=?"; + $appTable->zQuery($query, array($data['audit_master_id'])); + $appTable->zQuery("UPDATE documents + SET audit_master_approval_status='3' + WHERE audit_master_id=?", array($data['audit_master_id'])); + } + + public function buildLabArray($lab_array) + { + $lab_results = array(); + $j = 0; + foreach ($lab_array as $key => $value) { + $j = count($lab_results[$value['extension']]['result']) + 1; + $lab_results[$value['extension']]['proc_text'] = $value['proc_text']; + $lab_results[$value['extension']]['date'] = $value['date']; + $lab_results[$value['extension']]['proc_code'] = $value['proc_code']; + $lab_results[$value['extension']]['extension'] = $value['extension']; + $lab_results[$value['extension']]['status'] = $value['status']; + $lab_results[$value['extension']]['result'][$j]['result_date'] = $value['results_date']; + $lab_results[$value['extension']]['result'][$j]['result_text'] = $value['results_text']; + $lab_results[$value['extension']]['result'][$j]['result_value'] = $value['results_value']; + $lab_results[$value['extension']]['result'][$j]['result_range'] = $value['results_range']; + $lab_results[$value['extension']]['result'][$j]['result_code'] = $value['results_code']; + } + return $lab_results; + } + + public function InsertLabResults($lab_results,$pid) + { + $appTable = new ApplicationTable(); + foreach ($lab_results as $key => $value) { + $query_select_pro = "SELECT * FROM procedure_providers WHERE name = ?"; + $result_pro = $appTable->zQuery($query_select_pro, array('External Lab')); + if ($result_pro->count() == 0) { + $query_insert_pro = "INSERT INTO procedure_providers(name) VALUES (?)"; + $result_pro = $appTable->zQuery($query_insert_pro, array('External Lab')); + $pro_id = $result_pro->getGeneratedValue(); + } + else { + foreach ($result_pro as $value1) { + $pro_id = $value1['ppid']; + } + } + $enc = $appTable->zQuery("SELECT encounter + FROM form_encounter + WHERE pid=? + ORDER BY id DESC LIMIT 1", array($pid)); + $enc_cur = $enc->current(); + $enc_id = $enc_cur['encounter'] ? $enc_cur['encounter'] : 0; + + foreach ($value['result'] as $res) { + $query_select_pt = "SELECT * FROM procedure_type WHERE procedure_code = ? AND lab_id = ?"; + $result_pt = $appTable->zQuery($query_select_pt, array($res['result_code'], $pro_id)); + if ($result_pt->count() == 0) { + //procedure_type + $query_insert_pt = "INSERT INTO procedure_type(name,lab_id,procedure_code,procedure_type,activity) VALUES (?,?,?,?,?)"; + $result_pt = $appTable->zQuery($query_insert_pt, array($res['result_text'], $pro_id, $res['result_code'], 'ord', 1)); + $res_pt_id = $result_pt->getGeneratedValue(); + $query_update_pt = "UPDATE procedure_type SET parent = ? WHERE procedure_type_id = ?"; + $appTable->zQuery($query_update_pt, array($res_pt_id, $res_pt_id)); + } + //procedure_order + $query_insert_po = "INSERT INTO procedure_order(provider_id,patient_id,encounter_id,date_collected,date_ordered,order_priority,order_status,activity,lab_id) VALUES (?,?,?,?,?,?,?,?,?)"; + $result_po = $appTable->zQuery($query_insert_po, array('', $pid, $enc_id, \Application\Model\ApplicationTable::fixDate($res['result_date'], 'yyyy-mm-dd', 'dd/mm/yyyy'), \Application\Model\ApplicationTable::fixDate($res['result_date'], 'yyyy-mm-dd', 'dd/mm/yyyy'), 'normal', 'completed', 1, $pro_id)); + $po_id = $result_po->getGeneratedValue(); + //procedure_order_code + $query_insert_poc = "INSERT INTO procedure_order_code(procedure_order_id,procedure_order_seq,procedure_code,procedure_name,diagnoses) VALUES (?,?,?,?,?)"; + $result_poc = $appTable->zQuery($query_insert_poc, array($po_id, 1, $res['result_code'], $res['result_text'], 'LOINC:' . $res['result_code'])); + //procedure_report + $query_insert_pr = "INSERT INTO procedure_report(procedure_order_id,date_collected,report_status,review_status) VALUES (?,?,?,?)"; + $result_pr = $appTable->zQuery($query_insert_pr, array($po_id, \Application\Model\ApplicationTable::fixDate($res['result_date'], 'yyyy-mm-dd', 'dd/mm/yyyy'), 'final', 'reviewed')); + $res_id = $result_pr->getGeneratedValue(); + //procedure_result + $range_unit = explode(' ', $res['result_range']); + $range = $range_unit[0]; + $unit = $range_unit[1]; + if ($unit != '') { + $qU_select = "SELECT * FROM list_options WHERE list_id = ? AND option_id = ?"; + $Ures = $appTable->zQuery($qU_select, array('proc_unit', $unit)); + if ($Ures->count() == 0) { + $qU_insert = "INSERT INTO list_options(list_id,option_id,title,activity) VALUES (?,?,?,?)"; + $appTable->zQuery($qU_insert, array('proc_unit', $unit, $unit, 1)); + } + else { + $qU_update = "UPDATE list_options SET activity = 1 WHERE list_id = ? AND option_id = ?"; + $appTable->zQuery($qU_update, array('proc_unit', $unit)); + } + $query_insert_prs = "INSERT INTO procedure_result(procedure_report_id,result_code,date,units,result,`range`,result_text,result_status) VALUES (?,?,?,?,?,?,?,?)"; + $result_prs = $appTable->zQuery($query_insert_prs, array($res_id, $res['result_code'], \Application\Model\ApplicationTable::fixDate($res['result_date'], 'yyyy-mm-dd', 'dd/mm/yyyy'), $unit, $res['result_value'], $range, $res['result_text'], 'final')); + } + } + } + } + + public function insert_patient($audit_master_id,$document_id) + { + require_once(dirname(__FILE__) . "/../../../../../../../../library/patient.inc"); + $pid = 0; + $j = 1; + $k = 1; + $q = 1; + $y = 1; + $a = 1; + $b = 1; + $c = 1; + $d = 1; + $e = 1; + $f = 1; + $g = 1; + + $arr_procedure_res = array(); + $arr_encounter = array(); + $arr_vitals = array(); + $arr_procedures = array(); + $arr_immunization = array(); + $arr_prescriptions = array(); + $arr_allergies = array(); + $arr_med_pblm = array(); + $arr_care_plan = array(); + $arr_functional_cognitive_status = array(); + $arr_referral = array(); + $appTable = new ApplicationTable(); + + $pres = $appTable->zQuery("SELECT IFNULL(MAX(pid)+1,1) AS pid + FROM patient_data"); + foreach ($pres as $prow) { + $pid = $prow['pid']; + } + $res = $appTable->zQuery("SELECT DISTINCT ad.table_name, + entry_identification + FROM audit_master as am,audit_details as ad + WHERE am.id=ad.audit_master_id AND + am.approval_status = '1' AND + am.id=? AND am.type=12 + ORDER BY ad.id", array($audit_master_id)); + $tablecnt = $res->count(); + foreach ($res as $row) { + $resfield = $appTable->zQuery("SELECT * + FROM audit_details + WHERE audit_master_id=? AND + table_name=? AND + entry_identification=?", array($audit_master_id, + $row['table_name'], + $row['entry_identification'])); + $table = $row['table_name']; + $newdata = array(); + foreach ($resfield as $rowfield) { + if ($table == 'patient_data') { + if ($rowfield['field_name'] == 'DOB') { + $dob = $this->formatDate($rowfield['field_value'], 1); + $newdata['patient_data'][$rowfield['field_name']] = $dob; + } + else{ + if ($rowfield['field_name'] == 'religion') { + $religion_option_id = $this->getOptionId('religious_affiliation', $rowfield['field_value'], ''); + $newdata['patient_data'][$rowfield['field_name']] = $religion_option_id; + } + elseif($rowfield['field_name'] == 'race'){ + $race_option_id = $this->getOptionId('race', $rowfield['field_value'], ''); + $newdata['patient_data'][$rowfield['field_name']] = $race_option_id; + } + elseif($rowfield['field_name'] == 'ethnicity'){ + $ethnicity_option_id = $this->getOptionId('ethnicity', $rowfield['field_value'], ''); + $newdata['patient_data'][$rowfield['field_name']] = $ethnicity_option_id; + } + else + $newdata['patient_data'][$rowfield['field_name']] = $rowfield['field_value']; + } + } + elseif ($table == 'immunization') { + $newdata['immunization'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'lists3'){ + $newdata['lists3'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'lists1'){ + $newdata['lists1'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'lists2'){ + $newdata['lists2'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'vital_sign') { + $newdata['vital_sign'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'social_history') { + $newdata['social_history'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'encounter') { + $newdata['encounter'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'procedure_result') { + $newdata['procedure_result'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'procedure') { + $newdata['procedure'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'care_plan') { + $newdata['care_plan'][$rowfield['field_name']] = $rowfield['field_value']; + } + elseif($table == 'functional_cognitive_status') { + $newdata['functional_cognitive_status'][$rowfield['field_name']] = $rowfield['field_value']; + } elseif ($table == 'referral') { + $newdata['referral'][$rowfield['field_name']] = $rowfield['field_value']; + } + } + if ($table == 'patient_data') { + updatePatientData($pid, $newdata['patient_data'], true); + } + elseif($table == 'immunization'){ + $arr_immunization['immunization'][$a]['extension'] = $newdata['immunization']['extension']; + $arr_immunization['immunization'][$a]['root'] = $newdata['immunization']['root']; + $arr_immunization['immunization'][$a]['administered_date'] = $newdata['immunization']['administered_date']; + $arr_immunization['immunization'][$a]['route_code'] = $newdata['immunization']['route_code']; + $arr_immunization['immunization'][$a]['route_code_text'] = $newdata['immunization']['route_code_text']; + $arr_immunization['immunization'][$a]['cvx_code_text'] = $newdata['immunization']['cvx_code_text']; + $arr_immunization['immunization'][$a]['cvx_code'] = $newdata['immunization']['cvx_code']; + $arr_immunization['immunization'][$a]['amount_administered'] = $newdata['immunization']['amount_administered']; + $arr_immunization['immunization'][$a]['amount_administered_unit'] = $newdata['immunization']['amount_administered_unit']; + $arr_immunization['immunization'][$a]['manufacturer'] = $newdata['immunization']['manufacturer']; + $arr_immunization['immunization'][$a]['completion_status'] = $newdata['immunization']['completion_status']; + + $arr_immunization['immunization'][$a]['provider_npi'] = $newdata['immunization']['provider_npi']; + $arr_immunization['immunization'][$a]['provider_name'] = $newdata['immunization']['provider_name']; + $arr_immunization['immunization'][$a]['provider_address'] = $newdata['immunization']['provider_address']; + $arr_immunization['immunization'][$a]['provider_city'] = $newdata['immunization']['provider_city']; + $arr_immunization['immunization'][$a]['provider_state'] = $newdata['immunization']['provider_state']; + $arr_immunization['immunization'][$a]['provider_postalCode'] = $newdata['immunization']['provider_postalCode']; + $arr_immunization['immunization'][$a]['provider_country'] = $newdata['immunization']['provider_country']; + $arr_immunization['immunization'][$a]['provider_telecom'] = $newdata['immunization']['provider_telecom']; + $arr_immunization['immunization'][$a]['represented_organization'] = $newdata['immunization']['represented_organization']; + $arr_immunization['immunization'][$a]['represented_organization_tele'] = $newdata['immunization']['represented_organization_tele']; + $a++; + } + elseif($table == 'lists3'){ + $arr_prescriptions['lists3'][$b]['extension'] = $newdata['lists3']['extension']; + $arr_prescriptions['lists3'][$b]['root'] = $newdata['lists3']['root']; + $arr_prescriptions['lists3'][$b]['begdate'] = $newdata['lists3']['begdate']; + $arr_prescriptions['lists3'][$b]['enddate'] = $newdata['lists3']['enddate']; + $arr_prescriptions['lists3'][$b]['route'] = $newdata['lists3']['route']; + $arr_prescriptions['lists3'][$b]['note'] = $newdata['lists3']['note']; + $arr_prescriptions['lists3'][$b]['indication'] = $newdata['lists3']['indication']; + $arr_prescriptions['lists3'][$b]['route_display'] = $newdata['lists3']['route_display']; + $arr_prescriptions['lists3'][$b]['dose'] = $newdata['lists3']['dose']; + $arr_prescriptions['lists3'][$b]['dose_unit'] = $newdata['lists3']['dose_unit']; + $arr_prescriptions['lists3'][$b]['rate'] = $newdata['lists3']['rate']; + $arr_prescriptions['lists3'][$b]['rate_unit'] = $newdata['lists3']['rate_unit']; + $arr_prescriptions['lists3'][$b]['drug_code'] = $newdata['lists3']['drug_code']; + $arr_prescriptions['lists3'][$b]['drug_text'] = $newdata['lists3']['drug_text']; + $arr_prescriptions['lists3'][$b]['prn'] = $newdata['lists3']['prn']; + + $arr_prescriptions['lists3'][$b]['provider_address'] = $newdata['lists3']['provider_address']; + $arr_prescriptions['lists3'][$b]['provider_city'] = $newdata['lists3']['provider_city']; + $arr_prescriptions['lists3'][$b]['provider_country'] = $newdata['lists3']['provider_country']; + $arr_prescriptions['lists3'][$b]['provider_title'] = $newdata['lists3']['provider_title']; + $arr_prescriptions['lists3'][$b]['provider_fname'] = $newdata['lists3']['provider_fname']; + $arr_prescriptions['lists3'][$b]['provider_lname'] = $newdata['lists3']['provider_lname']; + $arr_prescriptions['lists3'][$b]['provider_postalCode'] = $newdata['lists3']['provider_postalCode']; + $arr_prescriptions['lists3'][$b]['provider_state'] = $newdata['lists3']['provider_state']; + $arr_prescriptions['lists3'][$b]['provider_root'] = $newdata['lists3']['provider_root']; + $b++; + } + elseif($table == 'lists1' && $newdata['lists1']['list_code'] !=0){ + $arr_med_pblm['lists1'][$d]['extension'] = $newdata['lists1']['extension']; + $arr_med_pblm['lists1'][$d]['root'] = $newdata['lists1']['root']; + $arr_med_pblm['lists1'][$d]['begdate'] = $newdata['lists1']['begdate']; + $arr_med_pblm['lists1'][$d]['enddate'] = $newdata['lists1']['enddate']; + $arr_med_pblm['lists1'][$d]['list_code'] = $newdata['lists1']['list_code']; + $arr_med_pblm['lists1'][$d]['list_code_text'] = $newdata['lists1']['list_code_text']; + $arr_med_pblm['lists1'][$d]['status'] = $newdata['lists1']['status']; + $arr_med_pblm['lists1'][$d]['observation_text'] = $newdata['lists1']['observation_text']; + $arr_med_pblm['lists1'][$d]['observation_code'] = $newdata['lists1']['observation']; + $d++; + } + elseif($table == 'lists2' && $newdata['lists2']['list_code'] !=0){ + $arr_allergies['lists2'][$c]['extension'] = $newdata['lists2']['extension']; + $arr_allergies['lists2'][$c]['begdate'] = $newdata['lists2']['begdate']; + $arr_allergies['lists2'][$c]['enddate'] = $newdata['lists2']['enddate']; + $arr_allergies['lists2'][$c]['list_code'] = $newdata['lists2']['list_code']; + $arr_allergies['lists2'][$c]['list_code_text'] = $newdata['lists2']['list_code_text']; + $arr_allergies['lists2'][$c]['severity_al'] = $newdata['lists2']['severity_al']; + $arr_allergies['lists2'][$c]['status'] = $newdata['lists2']['status']; + $arr_allergies['lists2'][$c]['reaction'] = $newdata['lists2']['reaction']; + $arr_allergies['lists2'][$c]['reaction_text'] = $newdata['lists2']['reaction_text']; + $arr_allergies['lists2'][$c]['codeSystemName'] = $newdata['lists2']['codeSystemName']; + $arr_allergies['lists2'][$c]['outcome'] = $newdata['lists2']['outcome']; + $c++; + } + elseif($table == 'encounter') { + $arr_encounter['encounter'][$k]['extension'] = $newdata['encounter']['extension']; + $arr_encounter['encounter'][$k]['root'] = $newdata['encounter']['root']; + $arr_encounter['encounter'][$k]['date'] = $newdata['encounter']['date']; + + $arr_encounter['encounter'][$k]['provider_npi'] = $newdata['encounter']['provider_npi']; + $arr_encounter['encounter'][$k]['provider_name'] = $newdata['encounter']['provider_name']; + $arr_encounter['encounter'][$k]['provider_address'] = $newdata['encounter']['provider_address']; + $arr_encounter['encounter'][$k]['provider_city'] = $newdata['encounter']['provider_city']; + $arr_encounter['encounter'][$k]['provider_state'] = $newdata['encounter']['provider_state']; + $arr_encounter['encounter'][$k]['provider_postalCode'] = $newdata['encounter']['provider_postalCode']; + $arr_encounter['encounter'][$k]['provider_country'] = $newdata['encounter']['provider_country']; + + $arr_encounter['encounter'][$k]['represented_organization_name'] = $newdata['encounter']['represented_organization_name']; + $arr_encounter['encounter'][$k]['represented_organization_address'] = $newdata['encounter']['represented_organization_address']; + $arr_encounter['encounter'][$k]['represented_organization_city'] = $newdata['encounter']['represented_organization_city']; + $arr_encounter['encounter'][$k]['represented_organization_state'] = $newdata['encounter']['represented_organization_state']; + $arr_encounter['encounter'][$k]['represented_organization_zip'] = $newdata['encounter']['represented_organization_zip']; + $arr_encounter['encounter'][$k]['represented_organization_country'] = $newdata['encounter']['represented_organization_country']; + $arr_encounter['encounter'][$k]['represented_organization_telecom'] = $newdata['encounter']['represented_organization_telecom']; + + $arr_encounter['encounter'][$k]['encounter_diagnosis_date'] = $newdata['encounter']['encounter_diagnosis_date']; + $arr_encounter['encounter'][$k]['encounter_diagnosis_code'] = $newdata['encounter']['encounter_diagnosis_code']; + $arr_encounter['encounter'][$k]['encounter_diagnosis_issue'] = $newdata['encounter']['encounter_diagnosis_issue']; + $k++; + } + elseif($table == 'vital_sign') { + $arr_vitals['vitals'][$q]['extension'] = $newdata['vital_sign']['extension']; + $arr_vitals['vitals'][$q]['date'] = $newdata['vital_sign']['date']; + $arr_vitals['vitals'][$q]['temperature'] = $newdata['vital_sign']['temperature']; + $arr_vitals['vitals'][$q]['bpd'] = $newdata['vital_sign']['bpd']; + $arr_vitals['vitals'][$q]['bps'] = $newdata['vital_sign']['bps']; + $arr_vitals['vitals'][$q]['head_circ'] = $newdata['vital_sign']['head_circ']; + $arr_vitals['vitals'][$q]['pulse'] = $newdata['vital_sign']['pulse']; + $arr_vitals['vitals'][$q]['height'] = $newdata['vital_sign']['height']; + $arr_vitals['vitals'][$q]['oxygen_saturation'] = $newdata['vital_sign']['oxygen_saturation']; + $arr_vitals['vitals'][$q]['respiration'] = $newdata['vital_sign']['respiration']; + $arr_vitals['vitals'][$q]['weight'] = $newdata['vital_sign']['weight']; + $q++; + } + elseif($table == 'social_history') { + $tobacco_status = array( + '449868002' => 'Current', + '8517006' => 'Quit', + '266919005' => 'Never' + ); + $alcohol_status = array( + '219006' => 'Current', + '82581004' => 'Quit', + '228274009' => 'Never' + ); + $alcohol = explode("|", $newdata['social_history']['alcohol']); + if ($alcohol[2] != 0) { + $alcohol_date = $this->formatDate($alcohol[2], 1); + } + else { + $alcohol_date = $alcohol[2]; + } + $alcohol_date_value = fixDate($alcohol_date); + foreach ($alcohol_status as $key => $value) { + if ($alcohol[1] == $key) + $alcohol[1] = strtolower($value) . "alcohol"; + } + $alcohol_value = $alcohol[0] . "|" . $alcohol[1] . "|" . $alcohol_date_value; + + $tobacco = explode("|", $newdata['social_history']['smoking']); + if ($tobacco[2] != 0) { + $smoking_date = $this->formatDate($tobacco[2], 1); + } + else { + $smoking_date = $tobacco[2]; + } + $smoking_date_value = fixDate($smoking_date); + foreach ($tobacco_status as $key => $value2) { + if ($tobacco[1] == $key) + $tobacco[1] = strtolower($value2) . "tobacco"; + } + $smoking_value = $tobacco[0] . "|" . $tobacco[1] . "|" . $smoking_date_value; + + $query_insert = "INSERT INTO history_data + ( + pid, + alcohol, + tobacco, + date + ) + VALUES + ( + ?, + ?, + ?, + ? + )"; + $appTable->zQuery($query_insert, array($pid, + $alcohol_value, + $smoking_value, + date('Y-m-d H:i:s'))); + } + elseif ($table == 'procedure_result') { + if ($newdata['procedure_result']['date'] != 0) { + $proc_date = $this->formatDate($newdata['procedure_result']['date'], 0); + } + else { + $proc_date = $newdata['procedure_result']['date']; + } + + if ($newdata['procedure_result']['results_date'] != 0) { + $proc_result_date = $this->formatDate($newdata['procedure_result']['results_date'], 0); + } + else { + $proc_result_date = $newdata['procedure_result']['results_date']; + } + $arr_procedure_res['procedure_result'][$j]['proc_text'] = $newdata['procedure_result']['proc_text']; + $arr_procedure_res['procedure_result'][$j]['proc_code'] = $newdata['procedure_result']['proc_code']; + $arr_procedure_res['procedure_result'][$j]['extension'] = $newdata['procedure_result']['extension']; + $arr_procedure_res['procedure_result'][$j]['date'] = $proc_date; + $arr_procedure_res['procedure_result'][$j]['status'] = $newdata['procedure_result']['status']; + $arr_procedure_res['procedure_result'][$j]['results_text'] = $newdata['procedure_result']['results_text']; + $arr_procedure_res['procedure_result'][$j]['results_code'] = $newdata['procedure_result']['results_code']; + $arr_procedure_res['procedure_result'][$j]['results_range'] = $newdata['procedure_result']['results_range']; + $arr_procedure_res['procedure_result'][$j]['results_value'] = $newdata['procedure_result']['results_value']; + $arr_procedure_res['procedure_result'][$j]['results_date'] = $proc_result_date; + $j++; + } + elseif($table == 'procedure') { + $arr_procedures['procedure'][$y]['extension'] = $newdata['procedure']['extension']; + $arr_procedures['procedure'][$y]['root'] = $newdata['procedure']['root']; + $arr_procedures['procedure'][$y]['codeSystemName'] = $newdata['procedure']['codeSystemName']; + $arr_procedures['procedure'][$y]['code'] = $newdata['procedure']['code']; + $arr_procedures['procedure'][$y]['code_text'] = $newdata['procedure']['code_text']; + $arr_procedures['procedure'][$y]['date'] = $newdata['procedure']['date']; + + $arr_procedures['procedure'][$y]['represented_organization1'] = $newdata['procedure']['represented_organization1']; + $arr_procedures['procedure'][$y]['represented_organization_address1'] = $newdata['procedure']['represented_organization_address1']; + $arr_procedures['procedure'][$y]['represented_organization_city1'] = $newdata['procedure']['represented_organization_city1']; + $arr_procedures['procedure'][$y]['represented_organization_state1'] = $newdata['procedure']['represented_organization_state1']; + $arr_procedures['procedure'][$y]['represented_organization_postalcode1'] = $newdata['procedure']['represented_organization_postalcode1']; + $arr_procedures['procedure'][$y]['represented_organization_country1'] = $newdata['procedure']['represented_organization_country1']; + $arr_procedures['procedure'][$y]['represented_organization_telecom1'] = $newdata['procedure']['represented_organization_telecom1']; + + $arr_procedures['procedure'][$y]['represented_organization2'] = $newdata['procedure']['represented_organization2']; + $arr_procedures['procedure'][$y]['represented_organization_address2'] = $newdata['procedure']['represented_organization_address2']; + $arr_procedures['procedure'][$y]['represented_organization_city2'] = $newdata['procedure']['represented_organization_city2']; + $arr_procedures['procedure'][$y]['represented_organization_state2'] = $newdata['procedure']['represented_organization_state2']; + $arr_procedures['procedure'][$y]['represented_organization_postalcode2'] = $newdata['procedure']['represented_organization_postalcode2']; + $arr_procedures['procedure'][$y]['represented_organization_country2'] = $newdata['procedure']['represented_organization_country2']; + $y++; + } + elseif($table == 'care_plan') { + $arr_care_plan['care_plan'][$e]['extension'] = $newdata['care_plan']['extension']; + $arr_care_plan['care_plan'][$e]['root'] = $newdata['care_plan']['root']; + $arr_care_plan['care_plan'][$e]['text'] = $newdata['care_plan']['code_text']; + $arr_care_plan['care_plan'][$e]['code'] = $newdata['care_plan']['code']; + $arr_care_plan['care_plan'][$e]['description'] = $newdata['care_plan']['description']; + $e++; + } + elseif($table == 'functional_cognitive_status') { + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['extension'] = $newdata['functional_cognitive_status']['extension']; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['root'] = $newdata['functional_cognitive_status']['root']; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['text'] = $newdata['functional_cognitive_status']['code_text']; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['code'] = $newdata['functional_cognitive_status']['code']; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['date'] = $newdata['functional_cognitive_status']['date']; + $arr_functional_cognitive_status['functional_cognitive_status'][$f]['description'] = $newdata['functional_cognitive_status']['description']; + $f++; + } elseif ($table == 'referral') { + $arr_referral['referral'][$g]['body'] = $newdata['referral']['body']; + $arr_referral['referral'][$g]['root'] = $newdata['referral']['root']; + $g++; + } + } + + $this->InsertImmunization($arr_immunization['immunization'], $pid, 0); + $this->InsertPrescriptions($arr_prescriptions['lists3'], $pid, 0); + $this->InsertAllergies($arr_allergies['lists2'], $pid, 0); + $this->InsertMedicalProblem($arr_med_pblm['lists1'], $pid, 0); + $this->InsertEncounter($arr_encounter['encounter'], $pid, 0); + $this->InsertVitals($arr_vitals['vitals'], $pid, 0); + $lab_results = $this->buildLabArray($arr_procedure_res['procedure_result']); + $this->InsertProcedures($arr_procedures['procedure'], $pid, 0); + $this->InsertLabResults($lab_results, $pid); + $this->InsertCarePlan($arr_care_plan['care_plan'], $pid, 0); + $this->InsertFunctionalCognitiveStatus($arr_functional_cognitive_status['functional_cognitive_status'], $pid, 0); + $this->InsertReferrals($arr_referral['referral'], $pid, 0); + + $appTable->zQuery("UPDATE audit_master + SET approval_status=2 + WHERE id=?", array($audit_master_id)); + $appTable->zQuery("UPDATE documents + SET audit_master_approval_status=2 + WHERE audit_master_id=?", array($audit_master_id)); + $appTable->zQuery("UPDATE documents + SET foreign_id = ? + WHERE id =? ", array($pid, + $document_id)); + } + + public function formatDate($unformatted_date,$ymd=1) + { + $day = substr($unformatted_date, 6, 2); + $month = substr($unformatted_date, 4, 2); + $year = substr($unformatted_date, 0, 4); + if ($ymd == 1) { + $formatted_date = $year . "/" . $month . "/" . $day; + } + else { + $formatted_date = $day . "/" . $month . "/" . $year; + } + return $formatted_date; + } + + public function getOptionId($list_id,$title,$codes) + { + $appTable = new ApplicationTable(); + if ($title) { + $query = "SELECT option_id + FROM list_options + WHERE list_id=? AND title=?"; + $result = $appTable->zQuery($query, array($list_id, $title)); + $res_cur = $result->current(); + } + if ($codes) { + $query = "SELECT option_id + FROM list_options + WHERE list_id=? AND codes=?"; + $result = $appTable->zQuery($query, array($list_id, $codes)); + $res_cur = $result->current(); + } + return $res_cur['option_id']; + } + + public function InsertEncounter($enc_array,$pid,$revapprove=1) + { + $appTable = new ApplicationTable(); + foreach ($enc_array as $key => $value) { + $encounter_id = $appTable->generateSequenceID(); + $query_sel_users = "SELECT * + FROM users + WHERE abook_type='external_provider' AND npi=?"; + $res_query_sel_users = $appTable->zQuery($query_sel_users, array($value['provider_npi'])); + if ($res_query_sel_users->count() > 0) { + foreach ($res_query_sel_users as $value1) { + $provider_id = $value1['id']; + } + } + else { + $query_ins_users = "INSERT INTO users + ( username, + fname, + npi, + organization, + street, + city, + state, + zip, + active, + abook_type + ) + VALUES + ( + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + 1, + 'external_provider' + )"; + $res_query_ins_users = $appTable->zQuery($query_ins_users, array('', + $value['provider_name'], + $value['provider_npi'], + $value['represented_organization_name'], + $value['provider_address'], + $value['provider_city'], + $value['provider_state'], + $value['provider_postalCode'])); + $provider_id = $res_query_ins_users->getGeneratedValue(); + } + //facility + $query_sel_fac = "SELECT * + FROM users + WHERE abook_type='external_org' AND organization=?"; + $res_query_sel_fac = $appTable->zQuery($query_sel_fac, array($value['represented_organization_name'])); + if ($res_query_sel_fac->count() > 0) { + foreach ($res_query_sel_fac as $value2) { + $facility_id = $value2['id']; + } + } + else { + $query_ins_fac = "INSERT INTO users + ( username, + organization, + phonecell, + street, + city, + state, + zip, + active, + abook_type + ) + VALUES + ( + ?, + ?, + ?, + ?, + ?, + ?, + ?, + 1, + 'external_org' + )"; + $res_query_ins_fac = $appTable->zQuery($query_ins_fac, array('', + $value['represented_organization_name'], + $value['represented_organization_telecom'], + $value['represented_organization_address'], + $value['represented_organization_city'], + $value['represented_organization_state'], + $value['represented_organization_zip'])); + $facility_id = $res_query_ins_fac->getGeneratedValue(); + } + if ($value['date'] != 0 && $revapprove == 0) { + $encounter_date = $this->formatDate($value['date'], 1); + $encounter_date_value = fixDate($encounter_date); + } + elseif($value['date'] != 0 && $revapprove==1){ + $encounter_date_value = \Application\Model\ApplicationTable::fixDate($value['date'], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + elseif($value['date'] == 0) { + $encounter_date = $value['date']; + $encounter_date_value = fixDate($encounter_date); + } + $q_sel_encounter = "SELECT * + FROM form_encounter + WHERE external_id=? AND pid=?"; + $res_q_sel_encounter = $appTable->zQuery($q_sel_encounter, array($value['extension'], $pid)); + if ($res_q_sel_encounter->count() == 0) { + $query_insert1 = "INSERT INTO form_encounter + ( + pid, + encounter, + date, + facility, + facility_id, + provider_id, + external_id + ) + VALUES + ( + ?, + ?, + ?, + ?, + ?, + ?, + ? + )"; + $result = $appTable->zQuery($query_insert1, array($pid, + $encounter_id, + $encounter_date_value, + $value['represented_organization_name'], + $facility_id, + $provider_id, + $value['extension'])); + $enc_id = $result->getGeneratedValue(); + } + else { + $q_upd_encounter = "UPDATE form_encounter + SET pid=?, + encounter=?, + date=?, + facility=?, + facility_id=?, + provider_id=? + WHERE external_id=? AND pid=?"; + $appTable->zQuery($q_upd_encounter, array($pid, + $encounter_id, + $encounter_date_value, + $value['represented_organization_name'], + $facility_id, + $provider_id, + $value['extension'], + $pid)); + $q_sel_enc = "SELECT id FROM form_encounter WHERE external_id=?"; + $res_q_sel_enc = $appTable->zQuery($q_sel_enc, array($value['extension'])); + $res_enc_cur = $res_q_sel_enc->current(); + $enc_id = $res_enc_cur['id']; + } + $q_ins_forms = "INSERT INTO forms (date,encounter,form_name,form_id,pid,user,groupname,deleted,formdir) VALUES (?,?,?,?,?,?,?,?,?)"; + $appTable->zQuery($q_ins_forms, array($encounter_date_value, $encounter_id, 'New Patient Encounter', $enc_id, $pid, $_SESSION["authProvider"], 'Default', 0, 'newpatient')); + if ($value['encounter_diagnosis_issue'] != '') { + $query_select = "SELECT * FROM lists WHERE begdate = ? AND title = ? AND pid = ?"; + $result = $appTable->zQuery($query_select, array($value['encounter_diagnosis_date'], $value['encounter_diagnosis_issue'], $pid)); + if ($result->count() > 0) { + foreach ($result as $value1) { + $list_id = $value1['id']; + } + } + else { + //to lists + $query_insert = "INSERT INTO lists(pid,type,begdate,activity,title,date, diagnosis) VALUES (?,?,?,?,?,?,?)"; + $result = $appTable->zQuery($query_insert, array($pid, 'medical_problem', $value['encounter_diagnosis_date'], 1, + $value['encounter_diagnosis_issue'], date('Y-m-d H:i:s'), 'SNOMED-CT:' . $value['encounter_diagnosis_code'])); + $list_id = $result->getGeneratedValue(); + } + //Linking issue with encounter + $q_sel_iss_enc = "SELECT * FROM issue_encounter WHERE pid=? and list_id=? and encounter=?"; + $res_sel_iss_enc = $appTable->zQuery($q_sel_iss_enc, array($pid, $list_id, $encounter_id)); + if ($res_sel_iss_enc->count() == 0) { + $insert = "INSERT INTO issue_encounter(pid,list_id,encounter,resolved) VALUES (?,?,?,?)"; + $appTable->zQuery($insert, array($pid, $list_id, $encounter_id, 0)); + } + } + //to external_encounters + $insertEX = "INSERT INTO external_encounters(ee_date,ee_pid,ee_provider_id,ee_facility_id,ee_encounter_diagnosis,ee_external_id) VALUES (?,?,?,?,?,?)"; + $appTable->zQuery($insertEX, array($encounter_date_value, $pid, $provider_id, $facility_id, $value['encounter_diagnosis_issue'], $value['extension'])); + } + } + + public function InsertVitals($vitals_array,$pid,$revapprove=1) + { + $appTable = new ApplicationTable(); + foreach ($vitals_array as $key => $value) { + if ($value['date'] != 0 && $revapprove == 0) { + $vitals_date = $this->formatDate($value['date'], 1); + $vitals_date_value = fixDate($vitals_date); + } + elseif($value['date'] !=0 && $revapprove == 1) { + $vitals_date_value = \Application\Model\ApplicationTable::fixDate($value['date'], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + elseif($value['date'] == 0){ + $vitals_date = $value['date']; + $vitals_date_value = fixDate($vitals_date); + } + + $q_sel_vitals = "SELECT * + FROM form_vitals + WHERE external_id=?"; + $res_q_sel_vitals = $appTable->zQuery($q_sel_vitals, array($value['extension'])); + if ($res_q_sel_vitals->count() == 0) { + $query_insert = "INSERT INTO form_vitals + ( + pid, + date, + bps, + bpd, + height, + weight, + temperature, + pulse, + respiration, + head_circ, + oxygen_saturation, + activity, + external_id + ) + VALUES + ( + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + 1, + ? + )"; + $res = $appTable->zQuery($query_insert, array($pid, + $vitals_date_value, + $value['bps'], + $value['bpd'], + $value['height'], + $value['weight'], + $value['temperature'], + $value['pulse'], + $value['respiration'], + $value['head_circ'], + $value['oxygen_saturation'], + $value['extension'])); + $vitals_id = $res->getGeneratedValue(); + } + else { + $q_upd_vitals = "UPDATE form_vitals + SET pid=?, + date=?, + bps=?, + bpd=?, + height=?, + weight=?, + temperature=?, + pulse=?, + respiration=?, + head_circ=?, + oxygen_saturation=? + WHERE external_id=?"; + $appTable->zQuery($q_upd_vitals, array($pid, + $vitals_date_value, + $value['bps'], + $value['bpd'], + $value['height'], + $value['weight'], + $value['temperature'], + $value['pulse'], + $value['respiration'], + $value['head_circ'], + $value['oxygen_saturation'], + $value['extension'])); + foreach ($res_q_sel_vitals as $row_vitals) { + $vitals_id = $row_vitals['id']; + } + } + + $query_sel = "SELECT date FROM form_vitals WHERE id=?"; + $res_query_sel = $appTable->zQuery($query_sel, array($vitals_id)); + $res_cur = $res_query_sel->current(); + $vitals_date_forms = $res_cur['date']; + + $query_sel_enc = "SELECT encounter + FROM form_encounter + WHERE date=? AND pid=?"; + $res_query_sel_enc = $appTable->zQuery($query_sel_enc, array($vitals_date_forms, $pid)); + + if ($res_query_sel_enc->count() == 0) { + $res_enc = $appTable->zQuery("SELECT encounter + FROM form_encounter + WHERE pid=? + ORDER BY id DESC + LIMIT 1", array($pid)); + $res_enc_cur = $res_enc->current(); + $encounter_for_forms = $res_enc_cur['encounter']; + } + else { + foreach ($res_query_sel_enc as $value2) { + $encounter_for_forms = $value2['encounter']; + } + } + + $query = "INSERT INTO forms + ( + date, + encounter, + form_name, + form_id, + pid, + user, + formdir + ) + VALUES + ( + ?, + ?, + 'Vitals', + ?, + ?, + ?, + 'vitals' + )"; + $appTable->zQuery($query, array($vitals_date_forms, + $encounter_for_forms, + $vitals_id, + $pid, + $_SESSION[authUser])); + } + } + + public function InsertProcedures($proc_array,$pid,$revapprove=1) + { + $appTable = new ApplicationTable(); + foreach ($proc_array as $key => $value) { + if ($value['date'] != 0 && $revapprove == 0) { + $procedure_date = $this->formatDate($value['date'], 1); + $procedure_date_value = fixDate($procedure_date); + } + elseif($value['date'] != 0 && $revapprove == 1) { + $procedure_date_value = \Application\Model\ApplicationTable::fixDate($value['date'], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + elseif($value['date'] == 0) { + $procedure_date = $value['date']; + $procedure_date_value = fixDate($procedure_date); + } + //facility1 + $query3 = "SELECT * + FROM users + WHERE abook_type='external_org' AND organization=?"; + $res3 = $appTable->zQuery($query3, array($value['represented_organization1'])); + if ($res3->count() > 0) { + foreach ($res3 as $value3) { + $facility_id = $value3['id']; + } + } + else { + $query4 = "INSERT INTO users + ( username, + organization, + street, + city, + state, + zip, + active, + abook_type + ) + VALUES + ( ?, + ?, + ?, + ?, + ?, + ?, + 1, + 'external_org' + )"; + $res4 = $appTable->zQuery($query4, array('', + $value['represented_organization1'], + $value['represented_organization_address1'], + $value['represented_organization_city1'], + $value['represented_organization_state1'], + $value['represented_organization_postalcode1'])); + $facility_id = $res4->getGeneratedValue(); + } + + //facility2 + $query6 = "SELECT * + FROM users + WHERE abook_type='external_org' AND organization=?"; + $res6 = $appTable->zQuery($query6, array($value['represented_organization2'])); + if ($res6->count() > 0) { + foreach ($res6 as $value6) { + $facility_id2 = $value6['id']; + } + } + else { + $query7 = "INSERT INTO users + ( username, + organization, + street, + city, + state, + zip, + active, + abook_type + ) + VALUES + ( ?, + ?, + ?, + ?, + ?, + ?, + 1, + 'external_org' + )"; + $res7 = $appTable->zQuery($query7, array('', + $value['represented_organization2'], + $value['represented_organization_address2'], + $value['represented_organization_city2'], + $value['represented_organization_state2'], + $value['represented_organization_postalcode2'])); + $facility_id2 = $res7->getGeneratedValue(); + } + + $query_sel_enc = "SELECT encounter + FROM form_encounter + WHERE date=? AND pid=?"; + $res_query_sel_enc = $appTable->zQuery($query_sel_enc, array($procedure_date_value, $pid)); + + if ($res_query_sel_enc->count() == 0) { + $res_enc = $appTable->zQuery("SELECT encounter + FROM form_encounter + WHERE pid=? + ORDER BY id DESC + LIMIT 1", array($pid)); + $res_enc_cur = $res_enc->current(); + $encounter_for_billing = $res_enc_cur['encounter']; + } + else { + foreach ($res_query_sel_enc as $val) { + $encounter_for_billing = $val['encounter']; + } + } + + $query_select_ct = "SELECT ct_id FROM code_types WHERE ct_key = ? "; + $result_ct = $appTable->zQuery($query_select_ct, array($value['codeSystemName'])); + foreach ($result_ct as $val_ct) { + $ct_id = $val_ct['ct_id']; + } + $q_select = "SELECT * FROM codes WHERE code_text = ? AND code = ? AND active = ?"; + $res = $appTable->zQuery($q_select, array($value['code_text'], $value['code'], 1)); + if (count($res) == 0) { + //codes + $qc_insert = "INSERT INTO codes(code_text,code_text_short,code,code_type,active) VALUES (?,?,?,?,?)"; + $appTable->zQuery($qc_insert, array($value['code_text'], $value['code_text'], $value['code'], $ct_id, 1)); + } + $query_selectB = "SELECT * FROM external_procedures WHERE ep_code = ? AND ep_code_type = ? AND ep_encounter = ? AND ep_pid = ?"; + $result_selectB = $appTable->zQuery($query_selectB, array($value['code'], $value['codeSystemName'], $encounter_for_billing, $pid)); + if ($result_selectB->count() == 0) { + //external_procedures + $qB_insert = "INSERT INTO external_procedures(ep_date,ep_code,ep_code_type,ep_code_text,ep_pid,ep_encounter,ep_facility_id,ep_external_id) VALUES (?,?,?,?,?,?,?,?)"; + $appTable->zQuery($qB_insert, array($procedure_date_value, $value['code'], $value['codeSystemName'], $value['code_text'], $pid, $encounter_for_billing, $facility_id2, $value['extension'])); + } + } + } + + public function InsertImmunization($imm_array,$pid,$revapprove=1) + { + $appTable = new ApplicationTable(); + $qc_select = "SELECT ct_id FROM code_types WHERE ct_key = ?"; + $c_result = $appTable->zQuery($qc_select, array('CVX')); + foreach ($c_result as $val) { + $ct_id = $val['ct_id']; + } + foreach ($imm_array as $key => $value) { + //provider + $query_sel_users = "SELECT * + FROM users + WHERE abook_type='external_provider' AND npi=?"; + $res_query_sel_users = $appTable->zQuery($query_sel_users, array($value['provider_npi'])); + if ($res_query_sel_users->count() > 0) { + foreach ($res_query_sel_users as $value1) { + $provider_id = $value1['id']; + } + } + else { + $query_ins_users = "INSERT INTO users + ( fname, + npi, + organization, + street, + city, + state, + zip, + phone, + abook_type + ) + VALUES + ( + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + 'external_provider')"; + $res_query_ins_users = $appTable->zQuery($query_ins_users, array($value['provider_name'], + $value['provider_npi'], + $value['represented_organization'], + $value['provider_address'], + $value['provider_city'], + $value['provider_state'], + $value['provider_postalCode'], + $value['provider_telecom'])); + $provider_id = $res_query_ins_users->getGeneratedValue(); + } + //facility + $query_sel_fac = "SELECT * + FROM users + WHERE abook_type='external_org' AND organization=?"; + $res_query_sel_fac = $appTable->zQuery($query_sel_fac, array($value['represented_organization'])); + if ($res_query_sel_fac->count() > 0) { + foreach ($res_query_sel_fac as $value2) { + $facility_id = $value2['id']; + } + } + else { + $query_ins_fac = "INSERT INTO users + ( organization, + phonecell, + abook_type + ) + VALUES + ( + ?, + ?, + 'external_org' + )"; + $res_query_ins_fac = $appTable->zQuery($query_ins_fac, array($value['represented_organization'], + $value['represented_organization_tele'])); + $facility_id = $res_query_ins_fac->getGeneratedValue(); + } + if ($value['administered_date'] != 0 && $revapprove == 0) { + $immunization_date = $this->formatDate($value['administered_date'], 1); + $immunization_date_value = fixDate($immunization_date); + } + elseif($value['administered_date'] != 0 && $revapprove == 1) { + $immunization_date_value = \Application\Model\ApplicationTable::fixDate($value['administered_date'], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + elseif($value['administered_date'] != 0) { + $immunization_date = $value['administered_date']; + $immunization_date_value = fixDate($immunization_date); + } + + $q_select = "SELECT * FROM codes WHERE code_text = ? AND code = ? AND code_type = ?"; + $res = $appTable->zQuery($q_select, array($value['cvx_code_text'], $value['cvx_code'], $ct_id)); + if ($res->count() == 0) { + //codes + $qc_insert = "INSERT INTO codes(code_text,code,code_type) VALUES (?,?,?)"; + $appTable->zQuery($qc_insert, array($value['cvx_code_text'], $value['cvx_code'], $ct_id)); + } + $q1_unit = "SELECT * + FROM list_options + WHERE list_id='drug_units' AND title=?"; + $res_q1_unit = $appTable->zQuery($q1_unit, array($value['amount_administered_unit'])); + foreach ($res_q1_unit as $val) { + $oid_unit = $val['option_id']; + } + if ($res_q1_unit->count() == 0) { + $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('drug_units')); + foreach ($lres as $lrow) { + $oid_unit = $lrow['option_id']; + } + $q_insert_route = "INSERT INTO list_options + ( + list_id, + option_id, + title, + activity + ) + VALUES + ( + 'drug_units', + ?, + ?, + 1 + )"; + $appTable->zQuery($q_insert_route, array($oid_unit, $value['amount_administered_unit'])); + } + + $q1_completion_status = "SELECT * + FROM list_options + WHERE list_id='Immunization_Completion_Status' AND title=?"; + $res_q1_completion_status = $appTable->zQuery($q1_completion_status, array($value['completion_status'])); + + if ($res_q1_completion_status->count() == 0) { + $q_insert_completion_status = "INSERT INTO list_options + ( + list_id, + option_id, + title, + activity + ) + VALUES + ( + 'Immunization_Completion_Status', + ?, + ?, + 1 + )"; + $appTable->zQuery($q_insert_completion_status, array($value['completion_status'], $value['completion_status'])); + } + + $q1_manufacturer = "SELECT * + FROM list_options + WHERE list_id='Immunization_Manufacturer' AND title=?"; + $res_q1_manufacturer = $appTable->zQuery($q1_manufacturer, array($value['manufacturer'])); + + if ($res_q1_manufacturer->count() == 0) { + $q_insert_completion_status = "INSERT INTO list_options + ( + list_id, + option_id, + title, + activity + ) + VALUES + ( + 'Immunization_Manufacturer', + ?, + ?, + 1 + )"; + $appTable->zQuery($q_insert_completion_status, array($value['manufacturer'], $value['manufacturer'])); + } + + $q_sel_imm = "SELECT * + FROM immunizations + WHERE external_id=? AND patient_id=?"; + $res_q_sel_imm = $appTable->zQuery($q_sel_imm, array($value['extension'], $pid)); + if ($res_q_sel_imm->count() == 0) { + $query = "INSERT INTO immunizations + ( patient_id, + administered_date, + cvx_code, + route, + administered_by_id, + amount_administered, + amount_administered_unit, + manufacturer, + completion_status, + external_id + ) + VALUES + ( + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ? + )"; + $appTable->zQuery($query, array($pid, + $immunization_date_value, + $value['cvx_code'], + $value['route_code_text'], + $provider_id, + $value['amount_administered'], + $oid_unit, + $value['manufacturer'], + $value['completion_status'], + $value['extension'])); + } + else { + $q_upd_imm = "UPDATE immunizations + SET patient_id=?, + administered_date=?, + cvx_code=?, + route=?, + administered_by_id=?, + amount_administered=?, + amount_administered_unit=?, + manufacturer=?, + completion_status=? + WHERE external_id=? AND patient_id=?"; + $appTable->zQuery($q_upd_imm, array($pid, + $immunization_date_value, + $value['cvx_code'], + $value['route_code_text'], + $provider_id, + $value['amount_administered'], + $oid_unit, + $value['manufacturer'], + $value['completion_status'], + $value['extension'], + $pid)); + } + } + } + + public function InsertPrescriptions($pres_array,$pid,$revapprove=1) + { + $appTable = new ApplicationTable(); + $oid_route = $unit_option_id = $oidu_unit = ''; + foreach ($pres_array as $key => $value) { + $active = 1; + if ($value['enddate'] == '' || $value['enddate'] == 0) { + $value['enddate'] = (NULL); + } + if($revapprove == 1) { + if($value['discontinue'] == 1) { + $active = '-1'; + if($value['enddate'] == (NULL)) { + $value['enddate'] = date('Y-m-d'); + } + } else { + $active = '1'; + if($value['enddate']) { + $value['enddate'] = (NULL); + } + } + $value['begdate'] = \Application\Model\ApplicationTable::fixDate($value['begdate'], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + //provider + $query_sel_users = "SELECT * + FROM users + WHERE abook_type='external_provider' AND npi=?"; + $res_query_sel_users = $appTable->zQuery($query_sel_users, array($value['provider_npi'])); + if ($res_query_sel_users->count() > 0) { + foreach ($res_query_sel_users as $value1) { + $provider_id = $value1['id']; + } + } + else { + $query_ins_users = "INSERT INTO users + ( fname, + lname, + authorized, + street, + city, + state, + zip, + active, + abook_type + ) + VALUES + ( + ?, + ?, + 1, + ?, + ?, + ?, + ?, + 1, + 'external_provider' + )"; + $res_query_ins_users = $appTable->zQuery($query_ins_users, array($value['provider_fname'], + $value['provider_lname'], + $value['provider_address'], + $value['provider_city'], + $value['provider_state'], + $value['provider_postalCode'] + )); + $provider_id = $res_query_ins_users->getGeneratedValue(); + } + + //unit + if($revapprove == 1) { + $value['rate_unit'] = $this->getListTitle($value['rate_unit'], 'drug_units', ''); + } + $unit_option_id = $this->getOptionId('drug_units', $value['rate_unit'], ''); + if ($unit_option_id == '' || $unit_option_id == NULL) { + $q_max_option_id = "SELECT MAX(CAST(option_id AS SIGNED))+1 AS option_id + FROM list_options + WHERE list_id=?"; + $res_max_option_id = $appTable->zQuery($q_max_option_id, array('drug_units')); + $res_max_option_id_cur = $res_max_option_id->current(); + $unit_option_id = $res_max_option_id_cur['option_id']; + $q_insert_units_option = "INSERT INTO list_options + ( + list_id, + option_id, + title, + activity + ) + VALUES + ( + 'drug_units', + ?, + ?, + 1 + )"; + $appTable->zQuery($q_insert_units_option, array($unit_option_id,$value['rate_unit'])); + } + + //route + $q1_route = "SELECT * + FROM list_options + WHERE list_id='drug_route' AND notes=?"; + $res_q1_route = $appTable->zQuery($q1_route, array($value['route'])); + foreach ($res_q1_route as $val) { + $oid_route = $val['option_id']; + } + if ($res_q1_route->count() == 0) { + $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('drug_route')); + foreach ($lres as $lrow) { + $oid_route = $lrow['option_id']; + } + $q_insert_route = "INSERT INTO list_options + ( + list_id, + option_id, + notes, + title, + activity + ) + VALUES + ( + 'drug_route', + ?, + ?, + ?, + 1 + )"; + $appTable->zQuery($q_insert_route, array($oid_route, $value['route'], + $value['route_display'])); + } + + //drug form + $query_select_form = "SELECT * FROM list_options WHERE list_id = ? AND title = ?"; + $result = $appTable->zQuery($query_select_form, array('drug_form', $value['dose_unit'])); + if ($result->count() > 0) { + $q_update = "UPDATE list_options SET activity = 1 WHERE list_id = ? AND title = ?"; + $appTable->zQuery($q_update, array('drug_form', $value['dose_unit'])); + foreach ($result as $value2) { + $oidu_unit = $value2['option_id']; + } + } + else { + $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('drug_form')); + foreach ($lres as $lrow) { + $oidu_unit = $lrow['option_id']; + } + $q_insert = "INSERT INTO list_options (list_id,option_id,title,activity) VALUES (?,?,?,?)"; + $appTable->zQuery($q_insert, array('drug_form', $oidu_unit, $value['dose_unit'], 1)); + } + + $q_sel_pres = "SELECT * + FROM prescriptions + WHERE patient_id = ? AND external_id = ?"; + $res_q_sel_pres = $appTable->zQuery($q_sel_pres, array($pid, $value['extension'])); + + if ($res_q_sel_pres->count() == 0) { + $query = "INSERT INTO prescriptions + ( patient_id, + date_added, + end_date, + active, + drug, + size, + form, + dosage, + route, + unit, + indication, + prn, + rxnorm_drugcode, + provider_id, + external_id + ) + VALUES + ( + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ? + )"; + $appTable->zQuery($query, array($pid, + $value['begdate'], + $value['enddate'], + $active, + $value['drug_text'], + $value['rate'], + $oidu_unit, + $value['dose'], + $oid_route, + $unit_option_id, + $value['indication'], + $value['prn'], + $value['drug_code'], + $provider_id, + $value['extension'])); + } + else { + $q_upd_pres = "UPDATE prescriptions + SET patient_id=?, + date_added=?, + end_date = ?, + active = ?, + drug=?, + size=?, + form=?, + dosage=?, + route=?, + unit=?, + note=?, + indication=?, + prn = ?, + rxnorm_drugcode=?, + provider_id=? + WHERE external_id=? AND patient_id=?"; + $appTable->zQuery($q_upd_pres, array($pid, + $value['begdate'], + $value['enddate'], + $active, + $value['drug_text'], + $value['rate'], + $oidu_unit, + $value['dose'], + $oid_route, + $unit_option_id, + $value['note'], + $value['indication'], + $value['prn'], + $value['drug_code'], + $provider_id, + $value['extension'], + $pid)); + } + } + } + + public function InsertAllergies($allergy_array,$pid,$revapprove=1) + { + $appTable = new ApplicationTable(); + foreach ($allergy_array as $key => $value) { + $active = 1; + + if ($value['begdate'] != 0 && $revapprove == 0) { + $allergy_begdate = $this->formatDate($value['begdate'], 1); + $allergy_begdate_value = fixDate($allergy_begdate); + } + elseif($value['begdate'] !=0 && $revapprove == 1) { + $allergy_begdate_value = \Application\Model\ApplicationTable::fixDate($value['begdate'], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + elseif($value['begdate'] == 0) { + $allergy_begdate = $value['begdate']; + $allergy_begdate_value = fixDate($allergy_begdate); + $allergy_begdate_value = (NULL); + } + + if ($value['enddate'] != 0 && $revapprove == 0) { + $allergy_enddate = $this->formatDate($value['enddate'], 1); + $allergy_enddate_value = fixDate($allergy_enddate); + } + elseif($value['enddate'] !=0 && $revapprove == 1) { + $allergy_enddate_value = \Application\Model\ApplicationTable::fixDate($value['enddate'], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + elseif($value['enddate'] == 0 || $value['enddate'] == '') { + $allergy_enddate = $value['enddate']; + $allergy_enddate_value = fixDate($allergy_enddate); + $allergy_enddate_value = (NULL); + } + if($revapprove == 1) { + if($value['resolved'] == 1) { + if(!$allergy_enddate_value) + $allergy_enddate_value = date('y-m-d'); + }else { + $allergy_enddate_value = (NULL); + } + } + $q_sel_allergies = "SELECT * + FROM lists + WHERE external_id=? AND type='allergy' AND pid=?"; + $res_q_sel_allergies = $appTable->zQuery($q_sel_allergies, array($value['extension'], $pid)); + + $severity_option_id = $this->getOptionId('severity_ccda', '', 'SNOMED-CT:' . $value['severity_al']); + $severity_text = $this->getListTitle($severity_option_id, 'severity_ccda', 'SNOMED-CT:' . $value['severity_al']); + if ($severity_option_id == '' || $severity_option_id == NULL) { + $q_max_option_id = "SELECT MAX(CAST(option_id AS SIGNED))+1 AS option_id + FROM list_options + WHERE list_id=?"; + $res_max_option_id = $appTable->zQuery($q_max_option_id, array('severity_ccda')); + $res_max_option_id_cur = $res_max_option_id->current(); + $severity_option_id = $res_max_option_id_cur['option_id']; + $q_insert_units_option = "INSERT INTO list_options + ( + list_id, + option_id, + title, + activity + ) + VALUES + ( + 'severity_ccda', + ?, + ?, + 1 + )"; + if($severity_text) $appTable->zQuery($q_insert_units_option,array($severity_option_id,$severity_text)); + } + + $reaction_option_id = $this->getOptionId('Reaction', $value['reaction_text'], ''); + if ($reaction_option_id == '' || $reaction_option_id == NULL) { + $q_max_option_id = "SELECT MAX(CAST(option_id AS SIGNED))+1 AS option_id + FROM list_options + WHERE list_id=?"; + $res_max_option_id = $appTable->zQuery($q_max_option_id, array('Reaction')); + $res_max_option_id_cur = $res_max_option_id->current(); + $reaction_option_id = $res_max_option_id_cur['option_id']; + $q_insert_units_option = "INSERT INTO list_options + ( + list_id, + option_id, + title, + activity + ) + VALUES + ( + 'Reaction', + ?, + ?, + 1 + )"; + if($value['reaction_text']) $appTable->zQuery($q_insert_units_option,array($reaction_option_id,$value['reaction_text'])); + } + + if ($res_q_sel_allergies->count() == 0) { + $query = "INSERT INTO lists + ( pid, + date, + begdate, + enddate, + type, + title, + diagnosis, + severity_al, + activity, + reaction, + external_id + ) + VALUES + ( + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ? + )"; + $result = $appTable->zQuery($query, array($pid, + date('y-m-d H:i:s'), + $allergy_begdate_value, + $allergy_enddate_value, + 'allergy', + $value['list_code_text'], + 'RXNORM' . ':' . $value['list_code'], + $severity_option_id, + $active, + $reaction_option_id ? $reaction_option_id : 0, + $value['extension'])); + $list_id = $result->getGeneratedValue(); + } + else { + $q_upd_allergies = "UPDATE lists + SET pid=?, + date=?, + begdate=?, + enddate=?, + title=?, + diagnosis=?, + severity_al=?, + reaction=? + WHERE external_id=? AND type='allergy' AND pid=?"; + $appTable->zQuery($q_upd_allergies, array($pid, + date('y-m-d H:i:s'), + $allergy_begdate_value, + $allergy_enddate_value, + $value['list_code_text'], + 'RXNORM' . ':' . $value['list_code'], + $severity_option_id, + $reaction_option_id ? $reaction_option_id : 0, + $value['extension'], + $pid)); + } + } + } + + public function InsertMedicalProblem($med_pblm_array,$pid,$revapprove=1) + { + $appTable = new ApplicationTable(); + foreach ($med_pblm_array as $key => $value) { + $activity = 1; + + if ($value['begdate'] != 0 && $revapprove == 0) { + $med_pblm_begdate = $this->formatDate($value['begdate'], 1); + $med_pblm_begdate_value = fixDate($med_pblm_begdate); + } + elseif($value['begdate'] !=0 && $revapprove == 1) { + $med_pblm_begdate_value = \Application\Model\ApplicationTable::fixDate($value['begdate'], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + elseif($value['begdate'] == 0) { + $med_pblm_begdate = $value['begdate']; + $med_pblm_begdate_value = fixDate($med_pblm_begdate); + $med_pblm_begdate_value = (NULL); + } + + if ($value['enddate'] != 0 && $revapprove == 0) { + $med_pblm_enddate = $this->formatDate($value['enddate'], 1); + $med_pblm_enddate_value = fixDate($med_pblm_enddate); + } + elseif($value['enddate'] !=0 && $revapprove == 1) { + $med_pblm_enddate_value = \Application\Model\ApplicationTable::fixDate($value['enddate'], 'yyyy-mm-dd', 'dd/mm/yyyy'); + } + elseif($value['enddate'] == 0 || $value['enddate'] == '') { + $med_pblm_enddate = $value['enddate']; + $med_pblm_enddate_value = fixDate($med_pblm_enddate); + $med_pblm_enddate_value = (NULL); + } + + if($revapprove == 1) { + if($value['resolved'] == 1) { + if(!$med_pblm_enddate_value) + $med_pblm_enddate_value = date('y-m-d'); + }else { + $med_pblm_enddate_value = (NULL); + } + } + + $query_select = "SELECT * FROM list_options WHERE list_id = ? AND title = ?"; + $result = $appTable->zQuery($query_select, array('outcome', $value['observation_text'])); + if ($result->count() > 0) { + $q_update = "UPDATE list_options SET activity = 1 WHERE list_id = ? AND title = ? AND codes = ?"; + $appTable->zQuery($q_update, array('outcome', $value['observation_text'], 'SNOMED-CT:' . $value['observation'])); + foreach ($result as $value1) { + $o_id = $value1['option_id']; + } + } + else { + $lres = $appTable->zQuery("SELECT IFNULL(MAX(CONVERT(SUBSTRING_INDEX(option_id,'-',-1),UNSIGNED INTEGER))+1,1) AS option_id FROM list_options WHERE list_id = ?", array('outcome')); + foreach ($lres as $lrow) { + $o_id = $lrow['option_id']; + } + $q_insert = "INSERT INTO list_options (list_id,option_id,title,codes,activity) VALUES (?,?,?,?,?)"; + $appTable->zQuery($q_insert, array('outcome', $o_id, $value['observation_text'], 'SNOMED-CT:' . $value['observation'], 1)); + } + + $q_sel_med_pblm = "SELECT * + FROM lists + WHERE external_id=? AND type='medical_problem' AND begdate=? AND diagnosis=? AND pid=?"; + $res_q_sel_med_pblm = $appTable->zQuery($q_sel_med_pblm, array($value['extension'], $med_pblm_begdate_value, 'SNOMED-CT:' . $value['list_code'], $pid)); + if ($res_q_sel_med_pblm->count() == 0) { + $query = "INSERT INTO lists + ( pid, + date, + diagnosis, + activity, + title, + begdate, + enddate, + outcome, + type, + external_id + ) + VALUES + ( ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ?, + ? + )"; + $result = $appTable->zQuery($query, array($pid, + date('y-m-d H:i:s'), + 'SNOMED-CT:' . $value['list_code'], + $activity, + $value['list_code_text'], + $med_pblm_begdate_value, + $med_pblm_enddate_value, + $o_id, + 'medical_problem', + $value['extension'])); + + $list_id = $result->getGeneratedValue(); + } + else { + $q_upd_med_pblm = "UPDATE lists + SET pid=?, + date=?, + diagnosis=?, + title=?, + begdate=?, + enddate=?, + outcome=? + WHERE external_id=? AND type='medical_problem' AND begdate=? AND diagnosis=? AND pid=?"; + $appTable->zQuery($q_upd_med_pblm, array($pid, + date('y-m-d H:i:s'), + 'SNOMED-CT:' . $value['list_code'], + $value['list_code_text'], + $med_pblm_begdate_value, + $med_pblm_enddate_value, + $o_id, + $value['extension'], + $value['begdate'], + 'SNOMED-CT:' . $value['list_code'], + $pid)); + } + } + } + public function InsertCarePlan($care_plan_array,$pid,$revapprove=1) + { + $newid = ''; + $appTable = new ApplicationTable(); + $res = $appTable->zQuery("SELECT MAX(id) as largestId FROM `form_care_plan`"); + foreach ($res as $val) { + if ($val['largestId']) { + $newid = $val['largestId'] + 1; + } else { + $newid = 1; + } + } + foreach ($care_plan_array as $key => $value) { + + $query_sel_enc = "SELECT encounter + FROM form_encounter + WHERE date=? AND pid=?"; + $res_query_sel_enc = $appTable->zQuery($query_sel_enc, array(date('Y-m-d H:i:s'), $pid)); + + if ($res_query_sel_enc->count() == 0) { + $res_enc = $appTable->zQuery("SELECT encounter + FROM form_encounter + WHERE pid=? + ORDER BY id DESC + LIMIT 1", array($pid)); + $res_enc_cur = $res_enc->current(); + $encounter_for_forms = $res_enc_cur['encounter']; + } + else { + foreach ($res_query_sel_enc as $value2) { + $encounter_for_forms = $value2['encounter']; + } + } + $query_insert = "INSERT INTO form_care_plan(id,pid,groupname,user,encounter, activity,code,codetext,description,date)VALUES(?,?,?,?,?,?,?,?,?,?)"; + $res = $appTable->zQuery($query_insert, array($newid, $pid, $_SESSION["authProvider"], $_SESSION["authUser"], $encounter_for_forms, 1, $value['code'], $value['text'], $value['description'], date('Y-m-d'))); + } + if (count($care_plan_array) > 0) { + $query = "INSERT INTO forms(date,encounter,form_name,form_id,pid,user,groupname,formdir)VALUES(?,?,?,?,?,?,?,?)"; + $appTable->zQuery($query, array(date('Y-m-d'), $encounter_for_forms, 'Care Plan Form', $newid, $pid, $_SESSION["authUser"], $_SESSION["authProvider"], 'care_plan')); + } + } + + public function InsertFunctionalCognitiveStatus($functional_cognitive_status_array,$pid,$revapprove=1) + { + $newid = ''; + $appTable = new ApplicationTable(); + $res = $appTable->zQuery("SELECT MAX(id) as largestId FROM `form_functional_cognitive_status`"); + foreach ($res as $val) { + if ($val['largestId']) { + $newid = $val['largestId'] + 1; + } else { + $newid = 1; + } + } + foreach ($functional_cognitive_status_array as $key => $value) { + if ($value['date'] != '') + $date = $this->formatDate($value['date']); + else + $date = date('Y-m-d'); + $query_sel_enc = "SELECT encounter + FROM form_encounter + WHERE date=? AND pid=?"; + $res_query_sel_enc = $appTable->zQuery($query_sel_enc, array($date, $pid)); + + if ($res_query_sel_enc->count() == 0) { + $res_enc = $appTable->zQuery("SELECT encounter + FROM form_encounter + WHERE pid=? + ORDER BY id DESC + LIMIT 1", array($pid)); + $res_enc_cur = $res_enc->current(); + $encounter_for_forms = $res_enc_cur['encounter']; + } + else { + foreach ($res_query_sel_enc as $value2) { + $encounter_for_forms = $value2['encounter']; + } + } + $query_insert = "INSERT INTO form_functional_cognitive_status(id,pid,groupname,user,encounter, activity,code,codetext,description,date)VALUES(?,?,?,?,?,?,?,?,?,?)"; + $res = $appTable->zQuery($query_insert, array($newid, $pid, $_SESSION["authProvider"], $_SESSION["authUser"], $encounter_for_forms, 1, $value['code'], $value['text'], $value['description'], $date)); + } + if (count($functional_cognitive_status_array) > 0) { + $query = "INSERT INTO forms(date,encounter,form_name,form_id,pid,user,groupname,formdir)VALUES(?,?,?,?,?,?,?,?)"; + $appTable->zQuery($query, array($date, $encounter_for_forms, 'Functional and Cognitive Status Form', $newid, $pid, $_SESSION["authUser"], $_SESSION["authProvider"], 'functional_cognitive_status')); + } + } + + public function InsertReferrals($arr_referral, $pid, $revapprove = 1) { + $appTable = new ApplicationTable(); + foreach ($arr_referral as $key => $value) { + $query_insert = "INSERT INTO transactions(date,title,body,pid,groupname,user)VALUES(?,?,?,?,?,?)"; + $res = $appTable->zQuery($query_insert, array(date('Y-m-d H:i:s'), 'Referral', $value['body'], $pid, $_SESSION["authProvider"], $_SESSION["authUser"])); + } + } + + public function getCodes($option_id, $list_id) { + $appTable = new ApplicationTable(); + if ($option_id) { + $query = "SELECT notes + FROM list_options + WHERE list_id=? AND option_id=?"; + $result = $appTable->zQuery($query, array($list_id, $option_id)); + $res_cur = $result->current(); + } + return $res_cur['notes']; + } + /* + * Fetch list details + * + * @param list_id string + * @return records Array list of list details + */ + public function getList($list) + { + $appTable = new ApplicationTable(); + $query = "SELECT title,option_id,notes,codes FROM list_options WHERE list_id = ?"; + $result = $appTable->zQuery($query, array($list)); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + + /* + * Fetch the current Referral values of a patient from transactions table + * + * @param pid Integer patient id + * @return records Array list of Referral values + */ + + public function getReferralReason($data) { + $appTable = new ApplicationTable(); + $query = "SELECT * + FROM transactions + WHERE pid = ?"; + $result = $appTable->zQuery($query, array($data['pid'])); + $records = array(); + foreach ($result as $row) { + $records[] = $row; + } + return $records; + } + /* + * fetch documentationOf and returns + * + * @param audit_master_id Integer ID from audi_master table + */ + public function getdocumentationOf($audit_master_id) + { + $appTable = new ApplicationTable(); + $query = "SELECT documentationOf FROM documents WHERE audit_master_id = ?"; + $result = $appTable->zQuery($query, array($audit_master_id)); + foreach($result as $row) { + $documentationOf = $row['documentationOf']; + } + return $documentationOf; + } + + /* + * Return the list of CCDA components + * + * @param $type + * @return Array $components + */ + public function getCCDAComponents($type) + { + $components = array(); + $query = "select * from ccda_components where ccda_type = ?"; + $appTable = new ApplicationTable(); + $result = $appTable->zQuery($query, array($type)); + + foreach($result as $row){ + $components[$row['ccda_components_field']] = $row['ccda_components_name']; + } + return $components; + } + + public function getMonthString($m){ + $m = trim($m); + if($m == '01'){ + return "Jan"; + }else if($m == '02'){ + return "Feb"; + }else if($m == '03'){ + return "March"; + }else if($m == '04'){ + return "April"; + }else if($m == '05'){ + return "May"; + }else if($m == '06'){ + return "June"; + }else if($m == '07'){ + return "July"; + }else if($m == '08'){ + return "Aug"; + }else if($m == '09'){ + return "Sep"; + }else if($m == '10'){ + return "Oct"; + }else if($m == '11'){ + return "Nov"; + }else if($m == '12'){ + return "Dec"; + } + } +} diff --git a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Model/EncounterccdadispatchTable.php b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Model/EncounterccdadispatchTable.php index 557bc6415..9dd616a05 100644 --- a/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Model/EncounterccdadispatchTable.php +++ b/interface/modules/zend_modules/module/Carecoordination/src/Carecoordination/Model/EncounterccdadispatchTable.php @@ -595,7 +595,7 @@ class EncounterccdadispatchTable extends AbstractTableGateway $status_code = '73425007'; } else{ - $active = 'active'; + $active = 'completed'; $status_table = 'Pending'; $status_code = '55561003'; } @@ -697,6 +697,8 @@ class EncounterccdadispatchTable extends AbstractTableGateway ".htmlspecialchars($row['date_added'],ENT_QUOTES)." ".htmlspecialchars('00000000',ENT_QUOTES)." ".$active." + ".htmlspecialchars(($row['pres_erx_diagnosis_name'] ? $row['pres_erx_diagnosis_name'] : 'NULL'),ENT_QUOTES)." + ".htmlspecialchars(($row['pres_erx_diagnosis'] ? $row['pres_erx_diagnosis'] : 0),ENT_QUOTES)." ".htmlspecialchars($row['note'],ENT_QUOTES)." ".htmlspecialchars($row['rxnorm_drugcode'],ENT_QUOTES)." @@ -878,7 +880,7 @@ class EncounterccdadispatchTable extends AbstractTableGateway { $results = ''; $query = "SELECT prs.result AS result_value, prs.units, prs.range, prs.result_text as order_title, prs.result_code as result_code, - prs.result_text as result_desc, prs.result_code, prs.procedure_result_id, po.date_ordered, prs.date AS result_time, prs.abnormal AS abnormal_flag + prs.result_text as result_desc, prs.code_suffix AS test_code, po.date_ordered, prs.date AS result_time, prs.abnormal AS abnormal_flag,po.order_status AS order_status FROM procedure_order AS po JOIN procedure_report AS pr ON pr.procedure_order_id = po.procedure_order_id JOIN procedure_result AS prs ON prs.procedure_report_id = pr.procedure_report_id @@ -888,29 +890,44 @@ class EncounterccdadispatchTable extends AbstractTableGateway $results_list = array(); foreach($res as $row){ - $results_list[$row['procedure_result_id']]['test_code'] = $row['result_code']; - $results_list[$row['procedure_result_id']]['order_title'] = $row['order_title']; - $results_list[$row['procedure_result_id']]['date_ordered'] = substr(preg_replace('/-/', '', $row['date_ordered']), 0, 8); - $results_list[$row['procedure_result_id']]['date_ordered_table'] = $row['date_ordered']; - $results_list[$row['procedure_result_id']]['subtest'][$row['result_code']]['result_code'] = ($row['result_code'] ? $row['result_code'] : 0); - $results_list[$row['procedure_result_id']]['subtest'][$row['result_code']]['result_desc'] = $row['result_desc']; - $results_list[$row['procedure_result_id']]['subtest'][$row['result_code']]['units'] = $row['units']; - $results_list[$row['procedure_result_id']]['subtest'][$row['result_code']]['range'] = $row['range']; - $results_list[$row['procedure_result_id']]['subtest'][$row['result_code']]['result_value'] = $row['result_value']; - $results_list[$row['procedure_result_id']]['subtest'][$row['result_code']]['result_time'] = substr(preg_replace('/-/', '', $row['result_time']), 0, 8); - $results_list[$row['procedure_result_id']]['subtest'][$row['result_code']]['abnormal_flag'] = $row['abnormal_flag']; + $results_list[$row['test_code']]['test_code'] = $row['test_code']; + $results_list[$row['test_code']]['order_title'] = $row['order_title']; + $results_list[$row['test_code']]['date_ordered'] = substr(preg_replace('/-/', '', $row['date_ordered']), 0, 8); + $results_list[$row['test_code']]['date_ordered_table'] = $row['date_ordered']; + $results_list[$row['test_code']]['subtest'][$row['result_code']]['result_code'] = ($row['result_code'] ? $row['result_code'] : 0); + $results_list[$row['test_code']]['subtest'][$row['result_code']]['result_desc'] = $row['result_desc']; + $results_list[$row['test_code']]['subtest'][$row['result_code']]['units'] = $row['units']; + $results_list[$row['test_code']]['subtest'][$row['result_code']]['range'] = $row['range']; + $results_list[$row['test_code']]['subtest'][$row['result_code']]['result_value'] = $row['result_value']; + $results_list[$row['test_code']]['subtest'][$row['result_code']]['result_time'] = substr(preg_replace('/-/', '', $row['result_time']), 0, 8); + $results_list[$row['test_code']]['subtest'][$row['result_code']]['abnormal_flag'] = $row['abnormal_flag']; } $results = ''; foreach($results_list as $row){ + $order_status = $order_status_table = ''; + if($row_1['order_status']== 'complete') { + $order_status = 'completed'; + $order_status_table = 'completed'; + } + else if($row_1['order_status'] == 'pending') { + $order_status = 'active'; + $order_status_table = 'pending'; + } + else { + $order_status = 'completed'; + $order_status_table = ''; + } $results .= ' - '.htmlspecialchars(base64_encode($_SESSION['site_id'].$row['result_code']), ENT_QUOTES).' + '.htmlspecialchars(base64_encode($_SESSION['site_id'].$row['test_code']), ENT_QUOTES).' '.htmlspecialchars("7d5a02b0-67a4-11db-bd13-0800200c9a66", ENT_QUOTES).' '.htmlspecialchars($row['date_ordered'],ENT_QUOTES).' '.htmlspecialchars($row['date_ordered_table'],ENT_QUOTES).' '.htmlspecialchars($row['order_title'],ENT_QUOTES).' - '.htmlspecialchars($row['result_code'],ENT_QUOTES).''; + '.htmlspecialchars($row['test_code'],ENT_QUOTES).' + '.htmlspecialchars($order_status_table,ENT_QUOTES).' + '.htmlspecialchars($order_status,ENT_QUOTES).''; foreach($row['subtest'] as $row_1){ $units = $row_1['units'] ? $row_1['units'] : 'Unit'; $results .= ' @@ -941,7 +958,7 @@ class EncounterccdadispatchTable extends AbstractTableGateway public function getEncounterHistory($pid,$encounter) { $results = ""; - $query = "SELECT fe.date, fe.encounter, + $query = "SELECT fe.date, fe.encounter,fe.reason, f.id as fid, f.name, f.phone, f.street as fstreet, f.city as fcity, f.state as fstate, f.postal_code as fzip, f.country_code, f.phone as fphone, u.fname, u.mname, u.lname, u.npi, u.street, u.city, u.state, u.zip, u.phonew1, cat.pc_catname, lo.title, lo.codes AS physician_type_code, SUBSTRING(ll.diagnosis, LENGTH('SNOMED-CT:')+1, LENGTH(ll.diagnosis)) AS encounter_diagnosis, ll.title, ll.begdate, ll.enddate @@ -958,6 +975,10 @@ class EncounterccdadispatchTable extends AbstractTableGateway $results = ""; foreach($res as $row){ + $encounter_reason = ''; + if($row['reason'] != '') { + $encounter_reason = "".htmlspecialchars($this->date_format(substr($row['date'], 0, 10))." - ".$row['reason'],ENT_QUOTES).""; + } $codes = ""; $query_procedures = "SELECT c.code, c.code_text FROM billing AS b JOIN code_types AS ct ON ct.ct_key = ? @@ -1021,9 +1042,8 @@ class EncounterccdadispatchTable extends AbstractTableGateway ".htmlspecialchars($row['country_code'],ENT_QUOTES)." ".htmlspecialchars($row['fzip'],ENT_QUOTES)." ".htmlspecialchars($row['fphone'],ENT_QUOTES)." - - $codes - + $codes + $encounter_reason "; } $results .= ""; @@ -1996,15 +2016,15 @@ class EncounterccdadispatchTable extends AbstractTableGateway /* * Return the list of CCDA components * - * @param None + * @param $type * @return Array $components */ - public function getCCDAComponents() + public function getCCDAComponents($type) { $components = array(); - $query = "select * from ccda_components"; + $query = "select * from ccda_components where ccda_type = ?"; $appTable = new ApplicationTable(); - $result = $appTable->zQuery($query, array()); + $result = $appTable->zQuery($query, array($type)); foreach($result as $row){ $components[$row['ccda_components_field']] = $row['ccda_components_name']; @@ -2153,16 +2173,27 @@ class EncounterccdadispatchTable extends AbstractTableGateway WHERE f.pid = ? AND f.formdir = ? AND f.deleted = ?"; $appTable = new ApplicationTable(); $res = $appTable->zQuery($query, array($pid,'care_plan',0)); - + $status = 'Pending'; + $status_entry = 'active'; $planofcare .= ''; foreach($res as $row) { //$date_formatted = \Application\Model\ApplicationTable::fixDate($row['date'],$GLOBALS['date_display_format'],'yyyy-mm-dd'); + $code_type = ''; + if($row['fcp_code_type'] == 'SNOMED-CT') + $code_type = '2.16.840.1.113883.6.96'; + else if($row['fcp_code_type'] == 'CPT4') + $code_type = '2.16.840.1.113883.6.12'; + else if($row['fcp_code_type'] == 'LOINC') + $code_type = '2.16.840.1.113883.6.1'; $planofcare .= ' '.htmlspecialchars($row['code'],ENT_QUOTES).' '.htmlspecialchars($row['codetext'],ENT_QUOTES).' '.htmlspecialchars($row['description'],ENT_QUOTES).' '.htmlspecialchars($row['date'],ENT_QUOTES).' '.htmlspecialchars(preg_replace('/-/','',$row['date']),ENT_QUOTES).' + '.htmlspecialchars($status,ENT_QUOTES).' + '.htmlspecialchars($status_entry,ENT_QUOTES).' + '.htmlspecialchars($code_type,ENT_QUOTES).' '; } $planofcare .= ''; @@ -2221,5 +2252,33 @@ class EncounterccdadispatchTable extends AbstractTableGateway $row = $result->current(); return $row['care_team']; } + + public function getClinicalInstructions($pid, $encounter){ + $query = "SELECT fci.* FROM forms AS f + LEFT JOIN form_clinical_instructions AS fci ON fci.id = f.form_id + WHERE f.pid = ? AND f.formdir = ? AND f.deleted = ?"; + $appTable = new ApplicationTable(); + $res = $appTable->zQuery($query, array($pid,'clinical_instructions',0)); + $clinical_instructions = ''; + foreach($res as $row) { + $clinical_instructions .=''.htmlspecialchars($row['instruction']).''; + } + $clinical_instructions .=''; + return $clinical_instructions; + } + + public function getRefferals($pid,$encounter) + { + $appTable = new ApplicationTable(); + $referrals = ''; + $query = "SELECT body FROM transactions WHERE pid = ?"; + $result = $appTable->zQuery($query, array($pid)); + $referrals = ''; + foreach($result as $row) { + $referrals.= ''.htmlspecialchars($row['body']).''; + } + $referrals.= ''; + return $referrals; + } } ?> \ No newline at end of file diff --git a/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/carecoordination/revandapprove.phtml b/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/carecoordination/revandapprove.phtml dissimilarity index 78% index fa2def1df..0d35070da 100644 --- a/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/carecoordination/revandapprove.phtml +++ b/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/carecoordination/revandapprove.phtml @@ -1,1160 +1,1798 @@ - -* -* This program is free software: you can redistribute it and/or modify -* it under the terms of the GNU Affero General Public License as -* published by the Free Software Foundation, either version 3 of the -* License, or (at your option) any later version. -* -* This program is distributed in the hope that it will be useful, -* but WITHOUT ANY WARRANTY; without even the implied warranty of -* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -* GNU Affero General Public License for more details. -* -* You should have received a copy of the GNU Affero General Public License -* along with this program. If not, see . -* -* @author Chandni Babu -* @author Riju KP -* +------------------------------------------------------------------------------+ -*/ - -$patient_data = array( - 'sex' => 'Sex', - 'pubpid' => 'External ID', - 'street' => 'Street', - 'city' => 'City', - 'state' => 'State', - 'postal_code' => 'Postal Code', - 'country_code'=> 'Country', - 'phone_home' => 'Phone', - 'status' => 'Marital Status', - 'religion' => 'Religion', - 'race' => 'Race', - 'ethnicity' => 'Ethnicity' , - 'ss' => 'SSN' -); - -$date_format = \Application\Model\ApplicationTable::dateFormat('dd/mm/yyyy'); -$ignore = $this->listenerObject->z_xlt('Ignore'); -$update = $this->listenerObject->z_xlt('Update'); -$insert = $this->listenerObject->z_xlt('Insert'); -?> - - -
- - - - -
-
- - - - - -
- - -
-
-
- -
- -
-
- - - - - demographics as $row_dem){ - if($row_dem['field_name'] != 'lname' && $row_dem['field_name'] != 'fname' && $row_dem['field_name'] != 'DOB'){ - $i++; - if($row_dem['field_name'] == 'sex'){ - ?> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
listenerObject->z_xlt('Demographics'); ?>
listenerObject->z_xlt($patient_data[$row_dem['field_name']]);?> - - listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]);?> - - - listenerObject->z_xlt($patient_data[$row_dem['field_name']]);?> - - listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]);?> - - - listenerObject->z_xlt($patient_data[$row_dem['field_name']]);?> - - listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]);?> - - - listenerObject->z_xlt($patient_data[$row_dem['field_name']]);?> - - listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]);?> - - - listenerObject->z_xlt($patient_data[$row_dem['field_name']]);?> - - listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]);?> - - - listenerObject->z_xlt($patient_data[$row_dem['field_name']]);?> - - listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]);?> - - - listenerObject->z_xlt($patient_data[$row_dem['field_name']]);?> - - listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]);?> - - - listenerObject->z_xlt($patient_data[$row_dem['field_name']]);?> - escapeHtml($row_dem['field_name']);?>" type="text" value="listenerObject->z_xlt($row_dem['field_value']);?>" style="width: 150px;"> - listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]);?> - - -
-
- - - - - social_history as $res_existing_social_history){ - $arr_his_alcohol = explode("|",$res_existing_social_history['alcohol']); - $arr_his_tobacco = explode("|",$res_existing_social_history['tobacco']); - $alc1 = explode("alcohol",$arr_his_alcohol[1]); - $tob1 = explode('tobacco',$arr_his_tobacco[1]); - if($arr_his_alcohol[2] != 0 && $arr_his_alcohol[2] != '') - $date_alcohol = $arr_his_alcohol[2]; - if($arr_his_tobacco[2] != 0 && $arr_his_tobacco[2] != '') - $date_tobacco = $arr_his_tobacco[2]; - ?> - - - - - - - - - - - - - - - 'Current', - '8517006' => 'Quit', - '266919005' => 'Never' - ); - $alcohol_status = array( - '219006' => 'Current', - '82581004' => 'Quit', - '228274009' => 'Never' - ); - foreach($this->social_history_audit['social_history'] as $key => $val){ - $array_his_alcohol = explode("|",$val['alcohol']); - if($array_his_alcohol[2] !=0 && $array_his_alcohol[2] != '') { - $his_alc_date = \Carecoordination\Model\CarecoordinationTable::formatDate($array_his_alcohol[2],0); - } - $array_his_tobacco = explode("|",$val['smoking']); - if($array_his_tobacco[2] !=0 && $array_his_tobacco[2] != '') { - $his_tob_date = \Carecoordination\Model\CarecoordinationTable::formatDate($array_his_tobacco[2],0); - } - ?> - - - - - - - - - - - - - - - - - - -
listenerObject->z_xlt('Social History'); ?>
listenerObject->z_xlt('Alcohol'); ?>listenerObject->z_xlt(ucfirst($this->listenerObject->z_xlt($arr_his_alcohol[0])));?>listenerObject->z_xlt('Status'); ?>listenerObject->z_xlt(ucfirst($this->listenerObject->z_xlt($alc1[0])));?>listenerObject->z_xlt('Date'); ?> - -
listenerObject->z_xlt('Tobacco'); ?>listenerObject->z_xlt(ucfirst($this->listenerObject->z_xlt($arr_his_tobacco[0])));?>listenerObject->z_xlt('Status'); ?>listenerObject->z_xlt(ucfirst($this->listenerObject->z_xlt($tob1[0])));?>listenerObject->z_xlt('Date'); ?> - -
listenerObject->z_xlt('Alcohol'); ?>listenerObject->z_xlt('Status'); ?> - $value) {?> - >listenerObject->z_xlt($value);?> - - listenerObject->z_xlt('Date'); ?> - -
listenerObject->z_xlt('Tobacco'); ?> - listenerObject->z_xlt('Status'); ?> - $value) {?> - >listenerObject->z_xlt($value);?> - - listenerObject->z_xlt('Date'); ?>
-
- - - - - encounter as $res_existing_encounter){ - if($res_existing_encounter['date'] != 0 && $res_existing_encounter['date'] != '') - $date_encounter = $res_existing_encounter['date']; - ?> - - - - - - - - - - encounter_audit['encounter'] as $key => $val){ - if($val['date'] != 0 && $val['date'] != '') { - $enc_xml_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val['date'],0); - } - ?> - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
listenerObject->z_xlt('Encounter'); ?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Provider'); ?>listenerObject->z_xlt($res_existing_encounter['provider_name']); ?>listenerObject->z_xlt('Facility'); ?>listenerObject->z_xlt($res_existing_encounter['facility']); ?> 
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Provider'); ?>' >listenerObject->z_xlt('Facility'); ?>' > - -
-
- - - - - problems as $res_existing_prob){ - if($res_existing_prob['activity'] == 1){ - $activity = 'Active'; - } - else{ - $activity = 'Inactive'; - } - - if($res_existing_prob['enddate'] != NULL && $res_existing_prob['enddate'] != 0) { - $end_date = \Application\Model\ApplicationTable::fixDate($res_existing_prob['enddate'], $date_format, 'yyyy-mm-dd'); - } - if($res_existing_prob['begdate'] != NULL && $res_existing_prob['begdate'] != 0) { - $beg_date = \Application\Model\ApplicationTable::fixDate($res_existing_prob['begdate'], $date_format, 'yyyy-mm-dd'); - } - $set = 0; - $cnt = 0; - foreach($this->problems_audit['lists1'] as $k => $v){ - $cnt++; - if($cnt%2 == 0){ - $class = 'alternate'; - } - else{ - $class = ''; - } - if(in_array($res_existing_prob['diagnosis'], $this->problems_audit['lists1'][$k])){ - $set = 1; - ?> - - - - - - - - - - - - - - - - - - - - - - problems_audit['lists1'][$k]); - } - } - if($set == 0){ - ?> - - - - - - - - - - - - - - - - problems_audit['lists1'] as $key => $val){ - if($val['observation_text'] == 'Active'){ - $activity = 'Active'; - } - else{ - $activity = 'Inactive'; - } - if($val['enddate'] != 0 && $val['enddate'] != '') { - $problem_enddate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['enddate'],0); - } - if($val['begdate'] != 0 && $val['begdate'] != '') { - $problem_begdate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['begdate'],0); - } - ?> - - - - - - - - - - - - - - - - - - - - -
listenerObject->z_xlt('Problems'); ?>
listenerObject->z_xlt('Title');?>' >listenerObject->z_xlt('Code'); ?> - escapeHtml($this->problems_audit['lists1'][$k]['list_code']);?>' > - ' > - listenerObject->z_xlt('Status'); ?>' > - -
 listenerObject->z_xlt($res_existing_prob['title']);?> escapeHtml($res_existing_prob['diagnosis']);?> listenerObject->z_xlt($activity);?>
listenerObject->z_xlt('Title');?>listenerObject->z_xlt($res_existing_prob['title']);?>listenerObject->z_xlt('Begin Date');?>listenerObject->z_xlt('Code');?>escapeHtml($res_existing_prob['diagnosis']);?>listenerObject->z_xlt('Status');?>listenerObject->z_xlt($activity);?> 
listenerObject->z_xlt('End Date');?>
listenerObject->z_xlt('Title');?>' >listenerObject->z_xlt('Begin Date');?>listenerObject->z_xlt('Code');?>escapeHtml($val['list_code']);?>' >listenerObject->z_xlt('Status');?> - -
listenerObject->z_xlt('End Date');?>
-
- - - - - allergies as $res_existing_allergies){ - if($res_existing_allergies['activity'] == 1){ - $activity = 'Active'; - } - else{ - $activity = 'Inactive'; - } - if($res_existing_allergies['enddate'] != NULL && $res_existing_allergies['enddate'] != 0) { - $end_date = \Application\Model\ApplicationTable::fixDate($res_existing_allergies['enddate'], $date_format, 'yyyy-mm-dd'); - } - if($res_existing_allergies['begdate'] != NULL && $res_existing_allergies['begdate'] != 0) { - $beg_date = \Application\Model\ApplicationTable::fixDate($res_existing_allergies['begdate'], $date_format, 'yyyy-mm-dd'); - } - $severity = Carecoordination\Model\CarecoordinationTable::getListTitle($res_existing_allergies['severity_al'],'severity_ccda',$res_existing_allergies['severity_al']); - ?> - - - - - - - - - - - - - - - - - - allergies_audit['lists2'] as $key => $val){ - $allergy_begdate = ''; - $allergy_enddate = ''; - - if($val['status'] == 'Active'){ - $activity = 'Active'; - } - else{ - $activity = 'Inactive'; - } - if($val['begdate'] != 0 && $val['begdate'] != NULL) { - $allergy_begdate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['begdate'],0); - } - - if($val['enddate'] != 0 && $val['enddate'] != NULL) { - $allergy_enddate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['enddate'],0); - } - $severity_option = Carecoordination\Model\CarecoordinationTable::getOptionId('severity_ccda',' ','SNOMED-CT:'.$val['severity_al']); - $severity = Carecoordination\Model\CarecoordinationTable::getListTitle($severity_option,'severity_ccda','SNOMED-CT:'.$val['severity_al']); - ?> - - - - - - - - - - - - - - - - - - - - - - - - -
listenerObject->z_xlt('Allergy'); ?>
listenerObject->z_xlt('Title'); ?>listenerObject->z_xlt($res_existing_allergies['title']); ?>listenerObject->z_xlt('Begin Date'); ?>listenerObject->z_xlt('Diagnosis'); ?>escapeHtml($res_existing_allergies['diagnosis']); ?>listenerObject->z_xlt('Severity'); ?>listenerObject->z_xlt($severity); ?> 
listenerObject->z_xlt('Status'); ?>listenerObject->z_xlt($activity); ?>listenerObject->z_xlt('End Date'); ?>
listenerObject->z_xlt('Title'); ?>' >listenerObject->z_xlt('Begin Date'); ?>listenerObject->z_xlt('Diagnosis'); ?>' >listenerObject->z_xlt('Severity'); ?> - -
listenerObject->z_xlt('Status'); ?>listenerObject->z_xlt('End Date'); ?>
-
- - - - - medications as $res_existing_medications){ - $units = \Carecoordination\Model\CarecoordinationTable::getListTitle($res_existing_medications['unit'],'drug_units',''); - $route = \Carecoordination\Model\CarecoordinationTable::getListTitle($res_existing_medications['route'],'drug_route',''); - if($res_existing_medications['date_added'] != 0 && $res_existing_medications['date_added'] != '') - $date_added = $res_existing_medications['date_added']; - ?> - - - - - - - - - - - - - - - - - - medications_audit['lists3'] as $key => $val){ - $route_option_id = \Carecoordination\Model\CarecoordinationTable::getOptionId('drug_route', $val['route_display']); - $unit_option_id = \Carecoordination\Model\CarecoordinationTable::getOptionId('drug_units', $val['rate_unit']); - $drug_unit_list = \Application\Plugin\CommonPlugin::getList('drug_units',$unit_option_id,''); - $drug_route_list = \Application\Plugin\CommonPlugin::getList('drug_route',$route_option_id,''); - if($val['begdate'] != 0 && $val['begdate'] != '') - $beg_date = \Application\Model\ApplicationTable::fixDate($val['begdate'], $date_format, 'yyyy-mm-dd'); - else - $beg_date = \Application\Model\ApplicationTable::fixDate(date('Y-m-d'),$date_format, 'yyyy-mm-dd'); - ?> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
listenerObject->z_xlt('Medications'); ?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Name'); ?>listenerObject->z_xlt($res_existing_medications['drug']);?>listenerObject->z_xlt('Dose'); ?>escapeHtml($res_existing_medications['dosage']); ?> 
listenerObject->z_xlt('Strength'); ?>escapeHtml($res_existing_medications['size']) ;?>listenerObject->z_xlt('Units'); ?>escapeHtml($units);?>listenerObject->z_xlt('Note'); ?>listenerObject->z_xlt($res_existing_medications['note']);?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Name'); ?>' >listenerObject->z_xlt('Dose'); ?>' > - -
listenerObject->z_xlt('Strength'); ?> ' >listenerObject->z_xlt('Units'); ?> - - listenerObject->z_xlt('Note'); ?> ' >
-
- - - - - immunizations as $res_existing_immunizations){ - if($res_existing_immunizations['administered_date'] !=0 && $res_existing_immunizations['administered_date'] != '') - $date_administered = $res_existing_immunizations['administered_date']; - ?> - - - - - - - - immunizations_audit['immunization'] as $key => $val){ - if($val['administered_date'] != 0 && $val['administered_date'] != '') { - $immunization_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val['administered_date'],0); - } - ?> - - - - - - - - - - - - - - - - - - - - - - - - - - - -
listenerObject->z_xlt('Immunization'); ?>
listenerObject->z_xlt('Administered Date'); ?>listenerObject->z_xlt('Cvx Code'); ?>escapeHtml($res_existing_immunizations['cvx_code']); ?> 
listenerObject->z_xlt('Administered Date'); ?>listenerObject->z_xlt('Cvx Code'); ?>' > - -
-
- - - - - lab_results as $res_existing_lab_results){ - $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']]['order_title'] = $res_existing_lab_results['order_title']; - $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']]['date_ordered'] = $res_existing_lab_results['date_ordered']; - $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']][$res_existing_lab_results['result_id']]['result_desc']= $res_existing_lab_results['result_desc']; - $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']][$res_existing_lab_results['result_id']]['result_value']= $res_existing_lab_results['result_value']; - $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']][$res_existing_lab_results['result_id']]['units']= $res_existing_lab_results['units']; - $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']][$res_existing_lab_results['result_id']]['range']= $res_existing_lab_results['range']; - } - ?> - - - - - - - - - $v1) { - $t=0; - if($v1['date_ordered'] != 0 && $v1['date_ordered'] != '') - $ordered_date = $v1['date_ordered']; - foreach($v1 as $key2=>$value2) { - $t++; - ?> - style="border-bottom: 0px" > - - - - - - - - - - - - - lab_results_audit['procedure_result'] as $key => $val){ - $j= count($arr_sub_lab_result[$val['extension']]) + 1; - $arr_sub_lab_result[$val['extension']]['proc_text'] = $val['proc_text']; - $arr_sub_lab_result[$val['extension']]['date'] = $val['date']; - $arr_sub_lab_result[$val['extension']]['proc_code'] = $val['proc_code']; - $arr_sub_lab_result[$val['extension']]['extension'] = $val['extension']; - $arr_sub_lab_result[$val['extension']]['status'] = $val['status']; - $arr_sub_lab_result[$val['extension']][$j]['results_date'] = $val['results_date']; - $arr_sub_lab_result[$val['extension']][$j]['results_text'] = $val['results_text']; - $arr_sub_lab_result[$val['extension']][$j]['results_value'] = $val['results_value']; - $arr_sub_lab_result[$val['extension']][$j]['results_range'] = $val['results_range']; - $arr_sub_lab_result[$val['extension']][$j]['results_code'] = $val['results_code']; - } - ?> - - - - - - - - - - $val1) { - $k =0; - $ij++; - if($val1['date'] !=0) { - $result_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val1['date'],0); - } - foreach($val1 as $k2=>$val2) { - $k++; - if(is_array($val2) && $val2['results_date'] !=0 && $val2['results_date'] !='') { - $proc_result_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val2['results_date'],0); - } - ?> - style="border-bottom: 0px" > - - - - - - - - - - - - - - - - - - -
listenerObject->z_xlt('Lab Results'); ?>
listenerObject->z_xlt('Procedure Name'); ?>listenerObject->z_xlt('Date Ordered'); ?>listenerObject->z_xlt('Result'); ?>listenerObject->z_xlt('Value'); ?>listenerObject->z_xlt('Range'); ?> 
listenerObject->z_xlt($v1['order_title']); ?>  listenerObject->z_xlt($value2['result_desc']); ?>escapeHtml($value2['result_value'])." ".$this->listenerObject->z_xlt($value2['units']); ?>escapeHtml($value2['range']); ?> 
listenerObject->z_xlt('Procedure Name'); ?>listenerObject->z_xlt('Date Ordered'); ?>listenerObject->z_xlt('Result'); ?>listenerObject->z_xlt('Value'); ?>listenerObject->z_xlt('Range'); ?> 
' onblur="setProcedureNameHidden(this.value,'');"> ' >' >' > - -
-
- - - - - vitals as $res_existing_vitals){ - if($res_existing_vitals['date'] != 0 && $res_existing_vitals['date'] != '') - $date_vitals = $res_existing_vitals['date']; - ?> - - - - - - - - - - - - - - - - - - - - - - - - - - - - vitals_audit['vital_sign'] as $key => $val){ - if($val['date'] != 0 && $val['date'] != '') { - $vitals_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val['date'],0); - } - ?> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
listenerObject->z_xlt('Vitals'); ?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Weight'); ?>escapeHtml($res_existing_vitals['weight']);?>listenerObject->z_xlt('Height'); ?>escapeHtml($res_existing_vitals['height']); ?>listenerObject->z_xlt('Respiraion'); ?>escapeHtml($res_existing_vitals['respiration']); ?>
listenerObject->z_xlt('Pulse'); ?>escapeHtml($res_existing_vitals['pulse']); ?>listenerObject->z_xlt('Oxygen Saturation'); ?>escapeHtml($res_existing_vitals['oxygen_saturation']); ?>listenerObject->z_xlt('Temperature'); ?>escapeHtml($res_existing_vitals['temperature']);?>listenerObject->z_xlt('Head Circ'); ?>escapeHtml($res_existing_vitals['head_circ']); ?>
listenerObject->z_xlt('BPD'); ?>escapeHtml($res_existing_vitals['bpd']); ?>listenerObject->z_xlt('BPS'); ?>escapeHtml($res_existing_vitals['bps']); ?> 
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Weight'); ?>' >listenerObject->z_xlt('Height'); ?>' >listenerObject->z_xlt('Respiraion'); ?>' >
listenerObject->z_xlt('Pulse'); ?>' >listenerObject->z_xlt('Oxygen Saturation'); ?>' >listenerObject->z_xlt('Temperature'); ?>' >listenerObject->z_xlt('Head Circ'); ?>' >
listenerObject->z_xlt('BPD'); ?>' >listenerObject->z_xlt('BPS'); ?>' > - -
-
- - - - - procedure as $res_existing_procedure){ - ?> - - - - - - - - - - procedure_audit['procedure'] as $key => $val){ - if($val['date'] != 0) { - $procedure_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val['date'],0); - } - ?> - - - - - - - - - '> - '> - '> - '> - '> - '> - '> - '> - '> - '> - '> - '> - '> - '> - '> - '> - - -
listenerObject->z_xlt('Procedure'); ?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Code'); ?>escapeHtml($res_existing_procedure['code']); ?>listenerObject->z_xlt('Title'); ?>listenerObject->z_xlt($res_existing_procedure['code_text']); ?> 
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Code'); ?>' >listenerObject->z_xlt('Code Text'); ?>' > - -
-
- - - - - care_plan as $res_existing_care_plan){ - ?> - - - - - - - - care_plan_audit['care_plan'] as $key => $val){?> - - - - - - - - - - - -
listenerObject->z_xlt('Care Plan'); ?>
listenerObject->z_xlt('Code Text'); ?>listenerObject->z_xlt($res_existing_care_plan['codetext']);?>listenerObject->z_xlt('Description'); ?>listenerObject->z_xlt($res_existing_care_plan['description']); ?> 
listenerObject->z_xlt('Code Text'); ?>' >listenerObject->z_xlt('Description'); ?>' > - -
-
- - - - - functional_cognitive_status as $res_existing_functional_cognitive_status){ - ?> - - - - - - - - functional_cognitive_status_audit['functional_cognitive_status'] as $key => $val){?> - - - - - - - - - - - - -
listenerObject->z_xlt('Functional Cognitive Status'); ?>
listenerObject->z_xlt('Code Text'); ?>listenerObject->z_xlt($res_existing_functional_cognitive_status['codetext']);?>listenerObject->z_xlt('Description'); ?>listenerObject->z_xlt($res_existing_functional_cognitive_status['description']); ?> 
listenerObject->z_xlt('Code Text'); ?>' >listenerObject->z_xlt('Description'); ?>' > - -
-
-
-
+ + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + * + * @author Chandni Babu + * @author Riju KP + * +------------------------------------------------------------------------------+ + */ + +$patient_data = array( + 'sex' => 'Sex', + 'pubpid' => 'External ID', + 'street' => 'Street', + 'city' => 'City', + 'state' => 'State', + 'postal_code' => 'Postal Code', + 'country_code' => 'Country', + 'phone_home' => 'Phone', + 'status' => 'Marital Status', + 'religion' => 'Religion', + 'race' => 'Race', + 'ethnicity' => 'Ethnicity', + 'ss' => 'SSN' +); + +$date_format = \Application\Model\ApplicationTable::dateFormat('dd/mm/yyyy'); +$ignore = $this->listenerObject->z_xlt('Ignore'); +$update = $this->listenerObject->z_xlt('Update'); +$insert = $this->listenerObject->z_xlt('Insert'); +?> + + +
+ + + + + + + + + + + + + +
+
+ + + + + +
+ + +
+
+
+
+ +
+
+ +
+ +
+
+ + + + + + demographics as $row_dem) { + if ($row_dem['field_name'] != 'lname' && $row_dem['field_name'] != 'fname' && $row_dem['field_name'] != 'DOB') { + $i++; + if ($row_dem['field_name'] == 'sex') { + ?> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
listenerObject->z_xlt('Demographics'); ?>
listenerObject->z_xlt($patient_data[$row_dem['field_name']]); ?> + + listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]); ?> + + + listenerObject->z_xlt($patient_data[$row_dem['field_name']]); ?> + + listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]); ?> + + + listenerObject->z_xlt($patient_data[$row_dem['field_name']]); ?> + + listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]); ?> + + + listenerObject->z_xlt($patient_data[$row_dem['field_name']]); ?> + + listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]); ?> + + + listenerObject->z_xlt($patient_data[$row_dem['field_name']]); ?> + + listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]); ?> + + + listenerObject->z_xlt($patient_data[$row_dem['field_name']]); ?> + + listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]); ?> + + + listenerObject->z_xlt($patient_data[$row_dem['field_name']]); ?> + + listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]); ?> + + + listenerObject->z_xlt($patient_data[$row_dem['field_name']]); ?> + escapeHtml($row_dem['field_name']); ?>" type="text" value="listenerObject->z_xlt($row_dem['field_value']); ?>" style="width: 150px;"> + listenerObject->z_xlt($this->demographics_old[0][$row_dem['field_name']]); ?> + + +
 
+
+ + + + + social_history as $res_existing_social_history) { + $arr_his_alcohol = explode("|", $res_existing_social_history['alcohol']); + $arr_his_tobacco = explode("|", $res_existing_social_history['tobacco']); + $alc1 = explode("alcohol", $arr_his_alcohol[1]); + $tob1 = explode('tobacco', $arr_his_tobacco[1]); + if ($arr_his_alcohol[2] != 0 && $arr_his_alcohol[2] != '') + $date_alcohol = $arr_his_alcohol[2]; + if ($arr_his_tobacco[2] != 0 && $arr_his_tobacco[2] != '') + $date_tobacco = $arr_his_tobacco[2]; + ?> + + + + + + + + + + + + + + + + + 'Current', + '8517006' => 'Quit', + '266919005' => 'Never' + ); + $alcohol_status = array( + '219006' => 'Current', + '82581004' => 'Quit', + '228274009' => 'Never' + ); + foreach ($this->social_history_audit['social_history'] as $key => $val) { + $array_his_alcohol = explode("|", $val['alcohol']); + if ($array_his_alcohol[2] != 0 && $array_his_alcohol[2] != '') { + $his_alc_date = \Carecoordination\Model\CarecoordinationTable::formatDate($array_his_alcohol[2], 0); + } + $array_his_tobacco = explode("|", $val['smoking']); + if ($array_his_tobacco[2] != 0 && $array_his_tobacco[2] != '') { + $his_tob_date = \Carecoordination\Model\CarecoordinationTable::formatDate($array_his_tobacco[2], 0); + } + ?> + + + + + + + + + + + + + + + + + + + + +
listenerObject->z_xlt('Social History'); ?>
listenerObject->z_xlt('Alcohol'); ?>listenerObject->z_xlt(ucfirst($this->listenerObject->z_xlt($arr_his_alcohol[0]))); ?>listenerObject->z_xlt('Status'); ?>listenerObject->z_xlt(ucfirst($this->listenerObject->z_xlt($alc1[0]))); ?>listenerObject->z_xlt('Date'); ?> +  
listenerObject->z_xlt('Tobacco'); ?>listenerObject->z_xlt(ucfirst($this->listenerObject->z_xlt($arr_his_tobacco[0]))); ?>listenerObject->z_xlt('Status'); ?>listenerObject->z_xlt(ucfirst($this->listenerObject->z_xlt($tob1[0]))); ?>listenerObject->z_xlt('Date'); ?> +  
listenerObject->z_xlt('Alcohol'); ?>listenerObject->z_xlt('Status'); ?> + $value) { ?> + >listenerObject->z_xlt($value); ?> + + listenerObject->z_xlt('Date'); ?> 
listenerObject->z_xlt('Tobacco'); ?> + listenerObject->z_xlt('Status'); ?> + $value) { ?> + >listenerObject->z_xlt($value); ?> + + listenerObject->z_xlt('Date'); ?>  + +
+
+ + + + + encounter as $res_existing_encounter) { + if ($res_existing_encounter['date'] != 0 && $res_existing_encounter['date'] != '') + $date_encounter = $res_existing_encounter['date']; + ?> + + + + + + + + + + encounter_audit['encounter'] as $key => $val) { + if ($val['date'] != 0 && $val['date'] != '') { + $enc_xml_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val['date'], 0); + } + ?> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
listenerObject->z_xlt('Encounter'); ?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Provider'); ?>listenerObject->z_xlt($res_existing_encounter['provider_name']); ?>listenerObject->z_xlt('Facility'); ?>listenerObject->z_xlt($res_existing_encounter['facility']); ?> 
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Provider'); ?>' >listenerObject->z_xlt('Facility'); ?>' >  + +
+
+ + + + + problems as $res_existing_prob) { + $set = 0; + foreach ($this->problems_audit['lists1'] as $k => $v) { + if(in_array(substr($res_existing_prob['diagnosis'], 10), $this->problems_audit['lists1'][$k])) { + $set = 1; + array_push($internal_conflicted_problems_Arr, $res_existing_prob); + array_push($imported_conflicted_problems_Arr, $v); + unset($this->problems_audit['lists1'][$k]); + } + } + if($set == 0) { + array_push($internal_problems_Arr, $res_existing_prob); + } + } + if(count($this->problems)>0) { ?> + + + + problems as $res_existing_prob) { + $beg_date = $end_date = ''; + if ($res_existing_prob['enddate']) { + $activity = 0; + } + else{ + $activity = 1; + } + + if ($res_existing_prob['enddate'] && $res_existing_prob['enddate'] != 0) { + $end_date = \Application\Model\ApplicationTable::fixDate($res_existing_prob['enddate'], $date_format, 'yyyy-mm-dd'); + } + if ($res_existing_prob['begdate'] && $res_existing_prob['begdate'] != 0) { + $beg_date = \Application\Model\ApplicationTable::fixDate($res_existing_prob['begdate'], $date_format, 'yyyy-mm-dd'); + }?> + + + + + + + + + + + + + + + + + ' > + + + + + + 0) { ?> + + + + $v) { + if ($v['status'] == 'Active') { + $act = 'Active'; + } else { + $act = 'Inactive'; + } + if (in_array(substr($res_existing_prob['diagnosis'], 10), $imported_conflicted_problems_Arr[$k])) { ?> + + + + + + + + + + ' > + '> + + + + + + + + + + + + + + + + + + problems_audit['lists1'])>0) { ?> + + + + problems_audit['lists1'] as $key => $val) { + if ($val['status'] == 'Active') { + $activity = 'Active'; + } + else{ + $activity = 'Inactive'; + } + if ($val['enddate'] != 0 && $val['enddate'] != '') { + $problem_enddate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['enddate'], 0); + } + if ($val['begdate'] != 0 && $val['begdate'] != '') { + $problem_begdate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['begdate'], 0); + } ?> + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
listenerObject->z_xlt('Problems'); ?>
listenerObject->z_xlt('Internal Problems');?>
listenerObject->z_xlt('Title'); ?>listenerObject->z_xlt($res_existing_prob['title']); ?>listenerObject->z_xlt('Begin Date'); ?>listenerObject->z_xlt('Code'); ?>escapeHtml($res_existing_prob['diagnosis']); ?>listenerObject->z_xlt('Status'); ?>".$this->listenerObject->z_xlt('Active').''; else echo "".$this->listenerObject->z_xlt('Inactive').''; ?> 
listenerObject->z_xlt('End Date'); ?>listenerObject->z_xlt('Resolved');?>' class="checkAssignProblem2">listenerObject->z_xlt('Mod Date');?> + +   + +
listenerObject->z_xlt('Conflicted Problems');?>
listenerObject->z_xlt('Title'); ?>' >listenerObject->z_xlt('Code'); ?>' >listenerObject->z_xlt('Begin Date'); ?>' >  + +
 listenerObject->z_xlt($res_existing_prob['title']); ?> escapeHtml($res_existing_prob['diagnosis']); ?> listenerObject->z_xlt('Resolved');?>' class="checkAssignProblem1"> 
listenerObject->z_xlt('Imported Problems');?>
listenerObject->z_xlt('Title'); ?>' >listenerObject->z_xlt('Begin Date'); ?>listenerObject->z_xlt('Code'); ?>' >listenerObject->z_xlt('Status'); ?>".$this->listenerObject->z_xlt('Inactive').''; else echo "".$this->listenerObject->z_xlt('Active').''; ?> 
listenerObject->z_xlt('Resolved');?>' class="checkAssignProblem3">listenerObject->z_xlt('Mod Date');?> + +   + +
+
+ + + + + allergies as $res_existing_allergies) { + $set = 0; + foreach ($this->allergies_audit['lists2'] as $key => $val) { + if(in_array(substr($res_existing_allergies['diagnosis'], 7), $this->allergies_audit['lists2'][$key])) { + $set = 1; + array_push($internal_conflicted_allergies_Arr, $res_existing_allergies); + array_push($imported_conflicted_allergies_Arr, $val); + unset($this->allergies_audit['lists2'][$key]); + } + } + if($set == 0) { + array_push($internal_allergies_Arr, $res_existing_allergies); + } + } + if(count($this->allergies)>0) { ?> + + + + allergies as $res_existing_allergies) { + $beg_date = $end_date = ''; + if ($res_existing_allergies['enddate']) { + $activity = 0; + } + else{ + $activity = 1; + } + if ($res_existing_allergies['enddate'] != NULL && $res_existing_allergies['enddate'] != 0) { + $end_date = \Application\Model\ApplicationTable::fixDate($res_existing_allergies['enddate'], $date_format, 'yyyy-mm-dd'); + } + if ($res_existing_allergies['begdate'] != NULL && $res_existing_allergies['begdate'] != 0) { + $beg_date = \Application\Model\ApplicationTable::fixDate($res_existing_allergies['begdate'], $date_format, 'yyyy-mm-dd'); + } + $severity = Carecoordination\Model\CarecoordinationTable::getListTitle($res_existing_allergies['severity_al'], 'severity_ccda', $res_existing_allergies['severity_al']); + ?> + + + + + + + + + + + + + + + + + + + '> + + + + + 0) { ?> + + + + $val) { + + $allergy_begdate = ''; + $allergy_enddate = ''; + + if ($val['status'] == 'Active') { + $activity = 'Active'; + } + else{ + $activity = 'Inactive'; + } + if ($val['begdate'] != 0 && $val['begdate'] != NULL) { + $allergy_begdate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['begdate'], 0); + } + + if ($val['enddate'] != 0 && $val['enddate'] != NULL) { + $allergy_enddate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['enddate'], 0); + } + if (in_array(substr($res_existing_allergies['diagnosis'], 7), $imported_conflicted_allergies_Arr[$key])) { ?> + + + + + + + + + + + + ' > + + + ' > + + + + + + + + + + + + + + + + + + + allergies_audit['lists2'])>0) {?> + + + + allergies_audit['lists2'] as $key => $val) { + $allergy_begdate = ''; + $allergy_enddate = ''; + + if ($val['status'] == 'Active') { + $activity = 'Active'; + } + else{ + $activity = 'Inactive'; + } + if ($val['begdate'] != 0 && $val['begdate'] != NULL) { + $allergy_begdate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['begdate'], 0); + } + + if ($val['enddate'] != 0 && $val['enddate'] != NULL) { + $allergy_enddate = \Carecoordination\Model\CarecoordinationTable::formatDate($val['enddate'], 0); + } + ?> + + + + + + + + + + + + + + + + + + + + + + + ' > + + + + + + + + +
listenerObject->z_xlt('Allergy'); ?>
listenerObject->z_xlt('Internal Allergies');?>
listenerObject->z_xlt('Title'); ?>listenerObject->z_xlt($res_existing_allergies['title']); ?>listenerObject->z_xlt('Begin Date'); ?>listenerObject->z_xlt('Diagnosis'); ?>escapeHtml($res_existing_allergies['diagnosis']); ?>listenerObject->z_xlt('Severity'); ?>listenerObject->z_xlt($severity); ?> 
listenerObject->z_xlt('Status'); ?>".$this->listenerObject->z_xlt('Active').''; else echo "".$this->listenerObject->z_xlt('Inactive').''; ?>listenerObject->z_xlt('End Date'); ?>listenerObject->z_xlt('Resolved');?> class="checkAssignAllergy2">listenerObject->z_xlt('Mod Date');?> + + + +
listenerObject->z_xlt('Conflicted Allergies');?>
listenerObject->z_xlt('Title'); ?>' >listenerObject->z_xlt('Begin Date'); ?>listenerObject->z_xlt('Diagnosis'); ?>' >  + +
 escapeHtml($res_existing_allergies['title']); ?>  escapeHtml($res_existing_allergies['diagnosis']); ?>listenerObject->z_xlt('Resolved');?>' class="checkAssignAllergy1"> 
listenerObject->z_xlt('Imported Allergies');?>
listenerObject->z_xlt('Title'); ?>' >listenerObject->z_xlt('Begin Date'); ?>listenerObject->z_xlt('Diagnosis'); ?>' >listenerObject->z_xlt('Status'); ?>".$this->listenerObject->z_xlt('Inactive').''; else echo "".$this->listenerObject->z_xlt('Active').''; ?> 
listenerObject->z_xlt('Resolved');?>' class="checkAssignAllergy3">listenerObject->z_xlt('Mod Date');?> + +   + +
+
+ + + + + medications as $res_existing_medications) { + $set = 0; + foreach ($this->medications_audit['lists3'] as $key => $val) { + if(in_array($res_existing_medications['rxnorm_drugcode'], $this->medications_audit['lists3'][$key])) { + $set = 1; + array_push($internal_conflicted_medications_Arr, $res_existing_medications); + array_push($imported_conflicted_medications_Arr, $val); + } + } + if($set == 0) { + array_push($internal_medications_Arr, $res_existing_medications); + } + } + if(count($this->medications)>0) {?> + + + + medications as $res_existing_medications) { + $units = \Carecoordination\Model\CarecoordinationTable::getListTitle($res_existing_medications['unit'], 'drug_units', ''); + $route = \Carecoordination\Model\CarecoordinationTable::getListTitle($res_existing_medications['route'], 'drug_route', ''); + if ($res_existing_medications['date_added'] != 0 && $res_existing_medications['date_added'] != '') + $date_added = $res_existing_medications['date_added']; ?> + + + + + + + + + + + + + + + + + + + '> + + + + + 0){ ?> + + + + $val) { + $route_option_id = \Carecoordination\Model\CarecoordinationTable::getOptionId('drug_route', $val['route_display']); + $unit_option_id = \Carecoordination\Model\CarecoordinationTable::getOptionId('drug_units', $val['rate_unit']); + $drug_unit_list = \Application\Plugin\CommonPlugin::getList('drug_units', $unit_option_id, ''); + $drug_route_list = \Application\Plugin\CommonPlugin::getList('drug_route', $route_option_id, ''); + + if(strlen($val['begdate']) == 8){ + $val['begdate'] = substr($val['begdate'],0,4) . "-" . substr($val['begdate'], 4, 2) . "-" . substr($val['begdate'], 6, 2); + } + if ($val['begdate'] != 0 && $val['begdate'] != '') + $beg_date = \Application\Model\ApplicationTable::fixDate($val['begdate'], $date_format, 'yyyy-mm-dd'); + else + $beg_date = \Application\Model\ApplicationTable::fixDate(date('Y-m-d'), $date_format, 'yyyy-mm-dd'); + + if (in_array($res_existing_medications['rxnorm_drugcode'], $imported_conflicted_medications_Arr[$key])) { ?> + + + + + + + + + + + + + + + + + + + '> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + medications_audit['lists3'])>0) { ?> + + + + medications_audit['lists3'] as $key => $val) { + $route_option_id = \Carecoordination\Model\CarecoordinationTable::getOptionId('drug_route', $val['route_display']); + $unit_option_id = \Carecoordination\Model\CarecoordinationTable::getOptionId('drug_units', $val['rate_unit']); + $drug_unit_list = \Application\Plugin\CommonPlugin::getList('drug_units', $unit_option_id, ''); + $drug_route_list = \Application\Plugin\CommonPlugin::getList('drug_route', $route_option_id, ''); + + if(strlen($val['begdate']) == 8){ + $val['begdate'] = substr($val['begdate'],0,4) . "-" . substr($val['begdate'], 4, 2) . "-" . substr($val['begdate'], 6, 2); + } + if ($val['begdate'] != 0 && $val['begdate'] != '') + $beg_date = \Application\Model\ApplicationTable::fixDate($val['begdate'], $date_format, 'yyyy-mm-dd'); + else + $beg_date = \Application\Model\ApplicationTable::fixDate(date('Y-m-d'), $date_format, 'yyyy-mm-dd'); ?> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
listenerObject->z_xlt('Medications'); ?>
listenerObject->z_xlt('Internal Medications');?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Name'); ?>listenerObject->z_xlt($res_existing_medications['drug']); ?>listenerObject->z_xlt('Dose'); ?>escapeHtml($res_existing_medications['dosage']); ?>listenerObject->z_xlt('Strength'); ?>escapeHtml($res_existing_medications['size']); ?>".$this->listenerObject->z_xlt('Active').''; else echo "".$this->listenerObject->z_xlt('Inactive').''; ?>
listenerObject->z_xlt('Units'); ?>escapeHtml($units); ?>listenerObject->z_xlt('Note'); ?>listenerObject->z_xlt($res_existing_medications['note']); ?>listenerObject->z_xlt('Discontinue'); ?> class="checkAssignMed2">listenerObject->z_xlt('Mod Date');?> + + + +
listenerObject->z_xlt('Conflicted Medications');?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Name'); ?>' >listenerObject->z_xlt('Dose'); ?>' >listenerObject->z_xlt('Strength'); ?> ' > 
listenerObject->z_xlt('Units'); ?> + + listenerObject->z_xlt('Note'); ?>' >  + +
escapeHtml($res_existing_medications['drug']); ?>escapeHtml($res_existing_medications['dosage']); ?>escapeHtml($res_existing_medications['size']); ?>escapeHtml($units); ?>escapeHtml($res_existing_medications['note']); ?>listenerObject->z_xlt('Discontinue');?>' class="checkAssignMed1"> 
listenerObject->z_xlt('Imported Medications');?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Name'); ?>' >listenerObject->z_xlt('Dose'); ?>' >listenerObject->z_xlt('Strength'); ?> ' >".$this->listenerObject->z_xlt('Inactive').''; else echo "".$this->listenerObject->z_xlt('Active').''; ?>
listenerObject->z_xlt('Units'); ?> + + listenerObject->z_xlt('Note'); ?>' >listenerObject->z_xlt('Discontinue');?>' class="checkAssignMed3">listenerObject->z_xlt('Mod Date');?> + + + +
+
+ + + + + immunizations as $res_existing_immunizations) { + if ($res_existing_immunizations['administered_date'] != 0 && $res_existing_immunizations['administered_date'] != '') + $date_administered = $res_existing_immunizations['administered_date']; + ?> + + + + + + + + immunizations_audit['immunization'] as $key => $val) { + if ($val['administered_date'] != 0 && $val['administered_date'] != '') { + $immunization_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val['administered_date'], 0); + } + ?> + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
listenerObject->z_xlt('Immunization'); ?>
listenerObject->z_xlt('Administered Date'); ?>listenerObject->z_xlt('Cvx Code'); ?>escapeHtml($res_existing_immunizations['cvx_code']); ?> 
listenerObject->z_xlt('Administered Date'); ?>listenerObject->z_xlt('Cvx Code'); ?>' >  + +
+
+ + + + + lab_results as $res_existing_lab_results) { + $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']]['order_title'] = $res_existing_lab_results['order_title']; + $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']]['date_ordered'] = $res_existing_lab_results['date_ordered']; + $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']][$res_existing_lab_results['result_id']]['result_desc'] = $res_existing_lab_results['result_desc']; + $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']][$res_existing_lab_results['result_id']]['result_value'] = $res_existing_lab_results['result_value']; + $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']][$res_existing_lab_results['result_id']]['units'] = $res_existing_lab_results['units']; + $exis_arr_sub_lab_result[$res_existing_lab_results['tcode']][$res_existing_lab_results['result_id']]['range'] = $res_existing_lab_results['range']; + } + ?> + + + + + + + + + $v1) { + $t = 0; + if ($v1['date_ordered'] != 0 && $v1['date_ordered'] != '') + $ordered_date = $v1['date_ordered']; + foreach ($v1 as $key2 => $value2) { + $t++; + ?> + style="border-bottom: 0px" > + + + + + + + + + + + + + lab_results_audit['procedure_result'] as $key => $val) { + $j = count($arr_sub_lab_result[$val['extension']]) + 1; + $arr_sub_lab_result[$val['extension']]['proc_text'] = $val['proc_text']; + $arr_sub_lab_result[$val['extension']]['date'] = $val['date']; + $arr_sub_lab_result[$val['extension']]['proc_code'] = $val['proc_code']; + $arr_sub_lab_result[$val['extension']]['extension'] = $val['extension']; + $arr_sub_lab_result[$val['extension']]['status'] = $val['status']; + $arr_sub_lab_result[$val['extension']][$j]['results_date'] = $val['results_date']; + $arr_sub_lab_result[$val['extension']][$j]['results_text'] = $val['results_text']; + $arr_sub_lab_result[$val['extension']][$j]['results_value'] = $val['results_value']; + $arr_sub_lab_result[$val['extension']][$j]['results_range'] = $val['results_range']; + $arr_sub_lab_result[$val['extension']][$j]['results_code'] = $val['results_code']; + } + ?> + + + + + + + + + + $val1) { + $k = 0; + $ij++; + if ($val1['date'] != 0) { + $result_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val1['date'], 0); + } + foreach ($val1 as $k2 => $val2) { + $k++; + if (is_array($val2) && $val2['results_date'] != 0 && $val2['results_date'] != '') { + $proc_result_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val2['results_date'], 0); + } + ?> + style="border-bottom: 0px" > + + + + + + + + + + + + + + + + + + +
listenerObject->z_xlt('Lab Results'); ?>
listenerObject->z_xlt('Procedure Name'); ?>listenerObject->z_xlt('Date Ordered'); ?>listenerObject->z_xlt('Result'); ?>listenerObject->z_xlt('Value'); ?>listenerObject->z_xlt('Range'); ?> 
listenerObject->z_xlt($v1['order_title']); ?>  listenerObject->z_xlt($value2['result_desc']); ?>escapeHtml($value2['result_value']) . " " . $this->listenerObject->z_xlt($value2['units']); ?>escapeHtml($value2['range']); ?> 
listenerObject->z_xlt('Procedure Name'); ?>listenerObject->z_xlt('Date Ordered'); ?>listenerObject->z_xlt('Result'); ?>listenerObject->z_xlt('Value'); ?>listenerObject->z_xlt('Range'); ?> 
' onblur="setProcedureNameHidden(this.value, '');"> ' >' >' > + +
+
+ + + + + vitals as $res_existing_vitals) { + if ($res_existing_vitals['date'] != 0 && $res_existing_vitals['date'] != '') + $date_vitals = $res_existing_vitals['date']; + ?> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + vitals_audit['vital_sign'] as $key => $val) { + if ($val['date'] != 0 && $val['date'] != '') { + $vitals_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val['date'], 0); + } + ?> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
listenerObject->z_xlt('Vitals'); ?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Weight'); ?>escapeHtml($res_existing_vitals['weight']); ?>listenerObject->z_xlt('Height'); ?>escapeHtml($res_existing_vitals['height']); ?>listenerObject->z_xlt('Respiraion'); ?>escapeHtml($res_existing_vitals['respiration']); ?> 
listenerObject->z_xlt('Pulse'); ?>escapeHtml($res_existing_vitals['pulse']); ?>listenerObject->z_xlt('Oxygen Saturation'); ?>escapeHtml($res_existing_vitals['oxygen_saturation']); ?>listenerObject->z_xlt('Temperature'); ?>escapeHtml($res_existing_vitals['temperature']); ?>listenerObject->z_xlt('Head Circ'); ?>escapeHtml($res_existing_vitals['head_circ']); ?> 
listenerObject->z_xlt('BPD'); ?>escapeHtml($res_existing_vitals['bpd']); ?>listenerObject->z_xlt('BPS'); ?>escapeHtml($res_existing_vitals['bps']); ?> 
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Weight'); ?>' >listenerObject->z_xlt('Height'); ?>' >listenerObject->z_xlt('Respiraion'); ?>' > 
listenerObject->z_xlt('Pulse'); ?>' >listenerObject->z_xlt('Oxygen Saturation'); ?>' >listenerObject->z_xlt('Temperature'); ?>' >listenerObject->z_xlt('Head Circ'); ?>' > 
listenerObject->z_xlt('BPD'); ?>' >listenerObject->z_xlt('BPS'); ?>' >  + +
+
+ + + + + procedure as $res_existing_procedure) { + ?> + + + + + + + + + + procedure_audit['procedure'] as $key => $val) { + if ($val['date'] != 0) { + $procedure_date = \Carecoordination\Model\CarecoordinationTable::formatDate($val['date'], 0); + } + ?> + + + + + + + + + + '> + '> + '> + '> + '> + '> + '> + '> + '> + '> + '> + '> + '> + '> + '> + '> + + +
listenerObject->z_xlt('Procedure'); ?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Code'); ?>escapeHtml($res_existing_procedure['code']); ?>listenerObject->z_xlt('Title'); ?>listenerObject->z_xlt($res_existing_procedure['code_text']); ?> 
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Code'); ?>' >listenerObject->z_xlt('Code Text'); ?>' >  + +
+
+ + + + + care_plan as $res_existing_care_plan) { + ?> + + + + + + + + care_plan_audit['care_plan'] as $key => $val){?> + + + + + + + + + + + + +
listenerObject->z_xlt('Care Plan'); ?>
listenerObject->z_xlt('Code Text'); ?>listenerObject->z_xlt($res_existing_care_plan['codetext']); ?>listenerObject->z_xlt('Description'); ?>listenerObject->z_xlt($res_existing_care_plan['description']); ?> 
listenerObject->z_xlt('Code Text'); ?>' >listenerObject->z_xlt('Description'); ?>' >  + +
+
+ + + + + functional_cognitive_status as $res_existing_functional_cognitive_status) { + ?> + + + + + + + + functional_cognitive_status_audit['functional_cognitive_status'] as $key => $val){?> + + + + + + + + + + + + + +
listenerObject->z_xlt('Functional Cognitive Status'); ?>
listenerObject->z_xlt('Code Text'); ?>listenerObject->z_xlt($res_existing_functional_cognitive_status['codetext']); ?>listenerObject->z_xlt('Description'); ?>listenerObject->z_xlt($res_existing_functional_cognitive_status['description']); ?> 
listenerObject->z_xlt('Code Text'); ?>' >listenerObject->z_xlt('Description'); ?>' >  + +
+
+ + + + + referral as $res_existing_referral) { + ?> + + + + + + referral_audit['referral'] as $key => $val) { + $referal_data = explode("#$%^&*",$val['body']); + foreach($referal_data as $k => $v) { + ?> + + + + + + + + +
listenerObject->z_xlt('Referral Reason'); ?>
listenerObject->z_xlt('Body'); ?>escapeHtml($res_existing_referral['body']); ?> 
listenerObject->z_xlt('Body'); ?>  + +
+
+ + + + + discharge_medication_audit['discharge_medication'] as $key => $val) { + $route_option_id = \Carecoordination\Model\CarecoordinationTable::getOptionId('drug_route', $val['route_display']); + $unit_option_id = \Carecoordination\Model\CarecoordinationTable::getOptionId('drug_units', $val['rate_unit']); + $drug_unit_list = \Application\Plugin\CommonPlugin::getList('drug_units', $unit_option_id, ''); + $drug_route_list = \Application\Plugin\CommonPlugin::getList('drug_route', $route_option_id, ''); + + if(strlen($val['begdate']) == 8){ + $val['begdate'] = substr($val['begdate'],0,4) . "-" . substr($val['begdate'], 4, 2) . "-" . substr($val['begdate'], 6, 2); + } + if ($val['begdate'] != 0 && $val['begdate'] != '') + $beg_date = \Application\Model\ApplicationTable::fixDate($val['begdate'], $date_format, 'yyyy-mm-dd'); + else + $beg_date = \Application\Model\ApplicationTable::fixDate(date('Y-m-d'), $date_format, 'yyyy-mm-dd'); ?> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
listenerObject->z_xlt('Discharge Medications'); ?>
listenerObject->z_xlt('Date'); ?>listenerObject->z_xlt('Name'); ?>' >listenerObject->z_xlt('Dose'); ?>' >listenerObject->z_xlt('Strength'); ?> ' >".$this->listenerObject->z_xlt('Inactive').''; else echo "".$this->listenerObject->z_xlt('Active').''; ?>
listenerObject->z_xlt('Units'); ?> + + listenerObject->z_xlt('Note'); ?>' >listenerObject->z_xlt('Discontinue');?>' class="checkAssignMed3">  + +
+
+ + + + + discharge_summary as $res_existing_discharge_summary){ + ?> + + + + + + discharge_summary_audit['discharge_summary'] as $key => $val){ + $text = str_replace("#$%","\n",$val['text']);?> + + + + + + + + +
listenerObject->z_xlt('Discharge Summary'); ?>
listenerObject->z_xlt('Description'); ?> 
listenerObject->z_xlt('Summary'); ?>  + +
+
+
+
diff --git a/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/carecoordination/upload.phtml b/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/carecoordination/upload.phtml index 3bdd3f79e..75b14c2b0 100644 --- a/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/carecoordination/upload.phtml +++ b/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/carecoordination/upload.phtml @@ -80,6 +80,38 @@ echo $this->headScript()->prependFile($this->basePath() . '/js/autosuggest/autos $('#form_ccda_import').attr('action','basePath();?>/carecoordination/revandapprove'); document.getElementById('form_ccda_import').submit(); }); + + $('.expandAuditDetails').click(function(){ + var arr = (this.id).split('_'); + + if($('#'+this.id).hasClass('se_in_23')){ + $('#'+this.id).addClass("se_in_24"); + $('#'+this.id).removeClass("se_in_23"); + $('#hide_'+arr[1]).show('slow'); + getCCDAComponents(arr[1]); + } + else if($('#'+this.id).hasClass('se_in_24')){ + $('#'+this.id).addClass("se_in_23"); + $('#'+this.id).removeClass("se_in_24"); + $('#hide_'+arr[1]).hide('slow'); + } + }); + $("body").on("click",".expandCompDetails",function(){ + var arr = (this.id).split('-'); + component = $('#'+this.id).attr('component'); + amid = $('#'+this.id).attr('amid'); + if($('#'+this.id).hasClass('se_in_23')){ + $('#'+this.id).addClass("se_in_24"); + $('#'+this.id).removeClass("se_in_23"); + $('#hideComp-'+arr[1]).show('slow'); + getEachCCDAComponentDetails(arr[1],component,amid); + } + else if($('#'+this.id).hasClass('se_in_24')){ + $('#'+this.id).addClass("se_in_23"); + $('#'+this.id).removeClass("se_in_24"); + $('#hideComp-'+arr[1]).hide('slow'); + } + }); }); $(document).ready(function() @@ -240,6 +272,46 @@ echo $this->headScript()->prependFile($this->basePath() . '/js/autosuggest/autos } $('#status1').show('clip','',500,''); } + + function getCCDAComponents(id) + { + $.ajax({ + type: "POST", + url: 'basePath();?>/carecoordination/getCCDAComponents?id='+id, + dataType: "text", + beforeSend: function(){ + appendLoader = ''; + $('#hide_'+id).html(appendLoader); + }, + data: {}, + success: function(thedata){ + $('#hide_'+id).html(thedata); + }, + error: function(xhr, status, error) { + alert(xhr.responseText); + } + }); + } + + function getEachCCDAComponentDetails(id,component,amid) + { + $.ajax({ + type: "POST", + url: 'basePath();?>/carecoordination/getEachCCDAComponentDetails?id='+id+'&component='+component+'&amid='+amid, + dataType: "text", + beforeSend: function(){ + appendLoader = ''; + $('#hideComp-'+id).html(appendLoader); + }, + data: {}, + success: function(thedata){ + $('#hideComp-'+id).html(thedata); + }, + error: function(xhr, status, error) { + alert(xhr.responseText); + } + }); + }
@@ -278,7 +350,8 @@ echo $this->headScript()->prependFile($this->basePath() . '/js/autosuggest/autos
-
+
+
 
@@ -293,6 +366,7 @@ echo $this->headScript()->prependFile($this->basePath() . '/js/autosuggest/autos ?> + @@ -307,6 +381,7 @@ echo $this->headScript()->prependFile($this->basePath() . '/js/autosuggest/autos foreach($this->records as $row){ ?> + @@ -362,6 +437,9 @@ echo $this->headScript()->prependFile($this->basePath() . '/js/autosuggest/autos ?> + + + diff --git a/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/ccd/upload.phtml b/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/ccd/upload.phtml index 49400db98..86f9b323a 100644 --- a/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/ccd/upload.phtml +++ b/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/ccd/upload.phtml @@ -196,7 +196,8 @@
-
+
+
 
diff --git a/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/encountermanager/index.phtml b/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/encountermanager/index.phtml index a83580467..96116dbdd 100644 --- a/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/encountermanager/index.phtml +++ b/interface/modules/zend_modules/module/Carecoordination/view/carecoordination/encountermanager/index.phtml @@ -193,6 +193,7 @@ foreach($this->status_details as $row_status){
listenerObject->z_xlt('SEARCH'); ?>
      +       diff --git a/interface/modules/zend_modules/module/Ccr/src/Ccr/Controller/CcrController.php b/interface/modules/zend_modules/module/Ccr/src/Ccr/Controller/CcrController.php index dbfd8693b..91579c932 100644 --- a/interface/modules/zend_modules/module/Ccr/src/Ccr/Controller/CcrController.php +++ b/interface/modules/zend_modules/module/Ccr/src/Ccr/Controller/CcrController.php @@ -59,6 +59,16 @@ class CcrController extends AbstractActionController $_REQUEST["batch_import"] = 'YES'; $this->importAction(); } + else{ + $result = \Documents\Plugin\Documents::fetchXmlDocuments(); + foreach($result as $row){ + if($row['doc_type'] == 'CCR'){ + $_REQUEST["document_id"] = $row['doc_id']; + $this->importAction(); + \Documents\Model\DocumentsTable::updateDocumentCategoryUsingCatname($row['doc_type'], $row['doc_id']); + } + } + } $records = $this->getCcrTable()->document_fetch(array('cat_title' => 'CCR')); $view = new ViewModel(array( @@ -227,12 +237,12 @@ class CcrController extends AbstractActionController return; } else{ - echo('Imported'); - exit; + //echo('Imported'); + //exit; } } else{ - exit('Could not read the file'); + //exit('Could not read the file'); } } diff --git a/interface/modules/zend_modules/module/Ccr/view/ccr/ccr/index.phtml b/interface/modules/zend_modules/module/Ccr/view/ccr/ccr/index.phtml index b58184952..789eaccea 100644 --- a/interface/modules/zend_modules/module/Ccr/view/ccr/ccr/index.phtml +++ b/interface/modules/zend_modules/module/Ccr/view/ccr/ccr/index.phtml @@ -265,7 +265,8 @@ echo $this->headScript()->prependFile($this->basePath() . '/js/autosuggest/autos
-
+
+
 
diff --git a/interface/modules/zend_modules/module/Documents/src/Documents/Model/DocumentsTable.php b/interface/modules/zend_modules/module/Documents/src/Documents/Model/DocumentsTable.php index aea323c0a..fb97607f7 100644 --- a/interface/modules/zend_modules/module/Documents/src/Documents/Model/DocumentsTable.php +++ b/interface/modules/zend_modules/module/Documents/src/Documents/Model/DocumentsTable.php @@ -158,4 +158,19 @@ class DocumentsTable extends AbstractTableGateway WHERE `id` = ?"; $obj->zQuery($sql,array(0,$docid)); } + + /** + *Update document category using category name + *@param $category_name - Name of the category to which the document has to be moved + *@param $document_id - Documents whose category has to be updated with $category_name + */ + public function updateDocumentCategoryUsingCatname($category_name, $document_id) + { + $obj = new ApplicationTable(); + $sql = "UPDATE categories_to_documents + JOIN categories ON `name` = ? + SET category_id=id + WHERE document_id = ?"; + $result = $obj->zQuery($sql, array($category_name, $document_id)); + } } \ No newline at end of file diff --git a/interface/modules/zend_modules/module/Documents/src/Documents/Plugin/Documents.php b/interface/modules/zend_modules/module/Documents/src/Documents/Plugin/Documents.php index b053498bf..f2e365537 100644 --- a/interface/modules/zend_modules/module/Documents/src/Documents/Plugin/Documents.php +++ b/interface/modules/zend_modules/module/Documents/src/Documents/Plugin/Documents.php @@ -22,6 +22,8 @@ namespace Documents\Plugin; use Zend\Mvc\Controller\Plugin\AbstractPlugin; use Documents\Model\DocumentsTable; +use Application\Model\ApplicationTable; +use Application\Listener\Listener; require_once($GLOBALS['fileroot'] . "/controllers/C_Document.class.php"); use C_Document; @@ -123,4 +125,30 @@ class Documents extends AbstractPlugin $document = $obj->retrieve_action("", $documentId, true, true, true); return $document; } + + public function fetchXmlDocuments(){ + $obj = new ApplicationTable(); + $query = "SELECT doc.id + FROM categories_to_documents AS cat_doc + JOIN documents AS doc ON doc.imported = 0 AND doc.id = cat_doc.document_id AND doc.mimetype = 'text/xml' + WHERE cat_doc.category_id = 1"; + $result = $obj->zQuery($query); + $count = 0; + $module = array(); + foreach($result as $row) { + $content = \Documents\Plugin\Documents::getDocument($row['id']); + $module[$count]['doc_id'] = $row['id']; + if (preg_match("/GN=Xe!w@OKOcgHY% zKF|ApKYjne_rtl?*=O%{UF)p1_Py>qMn_APn1F!*000oHt10UN03g7B9(=ri=FE5e z=AWT|r(*I>-`(k*kL_DWfP#a&og+-$&DPmb&(YSw?@hm>3;+nER##Rq@SWLfCI0Sc zY{(_GDR;S05d3k#I*Bcniiew<8=r~j=^wn%Jo{dfjhLsa&)TQCy~$!iYwMPmPv0MO zFt&t{LSpBmiJ2H!L}U5E4B?PU?MNa&lo}Odp$eE4${GU??$b8RmR&RpsLpNLFmpW& z8j-zRIQ{1Ic4zO~sN8MNw@b6#toB7^woo>eSSlX9f<6~@Lji@P|5;HX|M#n!F5rLc zzYQSw|JYb6T$I}XM+dn9|Lc&H5BR?hu^^rQb>Ja@C;dMMyOZj&u^{)>aseM(m2fV< z+%B$bxBMem^Jr@^wl=r+OWc_pfxNr*)WzeAAfeff#>}9Q%%I6TChw}bL)6@1rcRAd zFRH;?3om%lhH=>SK4CU$OTObWPm(5tsTf<@wfQyo4T3Vc_tbssvaVV9^oz&MGkpj3 zbw`NLB%U>I1FFw1M2;>x2XMwz6NX>{1ZyaumaaCK2vXlu)i_&g$0j@xyRxqEP7oiz5J)^tGN0WONUCKuo4-kffwnL3GqL?3# zNCB4H2sxs2(r4tExdpZ8m+T+JvFZG$KmBoQ>dBjt;Ee2vGI>zM-2chZAP}Q(a!b{{MVZ!y>u-n7`FheVxl0dh!?8Rz3&W_`FuUA(oW|FX zul#`H4A=ydEPFP}vg0hHKQLV`{OD^fTtF^&C)NZG3-?Z}dhSf@@1RGw-CV4G(iVyc zPbZ^gR3;hWdv=XS$YTlOdZBka$NYqnV+$@DT^&E;qSaOUbq>jy){BsRh>9L8~9@*@hb z(A{ZZLYZe^)iE<*zNo5yv&N8wd8=7F#n7UndBNmhL;8s$D*^TQ0puX{3#-{9g=T9O zV})|rt8m5KM=wSpJ-lS$IEhgYB6*(tCzmn+l{B2IKea(QFN_IY+yAwG47bKy7QvC^ zbi@6N-8+%<#s{;`ZogOtfU*Rqf?xN(XucJ#-C!oGj|HB;CZplN%K|F`zPP!5s|?(Fdz=PO$a}_u`{-#7fMEwnM$lC-hTP7Iv+QNZ zy%dkNsd*xy$oA9P{3qQbDw2%9QT?3r!s~$TME}W{gsGaYX6=$yxzZ2%1Aw59Gl5}y zcN_NP^Tx1EdLcw__nzMfeEou+PXZbqZp#V0BrxDo9t)>BTYRG)O=snuuB1a1@*iaU z8jsG6{#jfRw7F8vqqbHK36;}k{tP-wVA#dR;vLn-tTIaQ_oTHRFS2Q%M!6v&`H6VC zYU7`k1i~If*#;gmik@M6^Wv9$lYS!i7QPsG2)%m*dxl~sNW~ZJ@U`>0c6!AV5ij80 z3-?5{mDJ0ZlH51m9Q95t2o4;-$W_C@2g0Eh3;K^8(eK@8*j@mveQ~4xaCek_(b$cA z{Qu%_1o&Qb+H)`~@O@jw&%>IFrnvU1J8|`?d-#}k_YpB{`|A(hi3_ovYlgZd=2x^Y z;sK0Jj`Dy#c24$A&s>hkCq(1IZ%anG|B^=SlZap`Z3*mJpiS=27tSsw8_pS`8yg`? zX*!#-Ai2*=siEvUx$HX@67`FehdQ_N1s`ss{clMpSbV2>*!7?u(6GFx&$_ zgP=jtC=r-oD=78(1CA^kx+q92n~sAtZj84$@u36($|*Ixxsrtt!hExu81YtzJJ84!c0!^8C9%Czy5{pNeQT}q*)VQ(cR(*R7^fBl9Qv~~GTKQ$nSJPqJHujZZUv-dexX6coBI&J zrH%T!rpPBsX5mi5fF=>tF}02xssrgbKtpml*Cd6iXRq1|*CuG%3<+GI7oFYO$zg3D zHeGq|@rZAB{C=7lVSR}#8;2+cL2WOdvh({=ap&5D3UEH!_pCTui1aUJKlk`-3(t@m z!x26V!I$CaKa2rBW+qrizrh#khJ(K_nN#Z%=+QFBY7n}^Uo@FVpbe7%(?eJ*-ftwv$|YH^Ysu^#-Xal3QRv9O7Ahv-#*e@XMRS z!&v)EI*^Q=jvWmTCAH_ov%uQi2r6GFK8G4F9uIFWP@1@Ap!VnQpZr2V9`Tjr#b+YC z8n{su1Rw>)Pa52KX{(DLVq*QkzONNd#kHq7v~MUsYc0rp5iQYvT{7%C(NnjhpHQ}$ zP%?FBq#CFkw6zRtLF1LKD%+^XT9|)_hIFMEWrp?Q^f-Ga|+mm+zS7P z-Jw}bZ|=~C9nw%to#WY;zH`CmBQLH~+s>1&p4R)154Mbl_)Z)I_a4ZEB$!{3oz%hP z6J!z8)m1NlXB`Dv!UW3*zPU;)D>u~X$7Gy&0%RwsQ`}>+^aAy2-Kx-uEuFd_IsF!Z zLFT@nP$3TQEWmv-1XKxvE~$8S?O*r_m7i;z*?BF{mRlw~vY8w}OQWEaD4n$D^Kl;Y z@s+B8SEc!+q$pjfMmE%9DT8*@F+Q0-&R&y{0Zyn80ar?0KF)vfaQx9hWpHfe>l)5L zPz}=&7#z$1z>tmId>on?LFT_%WSJB;uPd~#hm^sEQDhawlF|blkDi^_Nw?eKO z24*1B$yhAh@wJr(IZWJ%sZ@7>-QeHY5rP;3+<6QEp7!VZI;RiXwCR`9p+V$FQ=f3) z<(dwB*y-*B#-5pWsJU^wS|8;>P|n}OIrN&d3J@TqrdNQf-(d21a-}CE? znJ=j!mr1WZMA5jbh~?_8--_tFN0KGQvJXiHYubl=tmzHbE5cZ4A6 zVfj~Rg4xTZO>H4)Y7IPT1!%(Ga#(j0HscRoK*QVSH!bh%bvum-mp1(Xu#}iJo3pyn znVEKGbJ~0A2k$H^zkjn5Z6V)n10S-_fXSm zr{GAm3mli6@_r(q~;=O>yb$H{kRL+&7`H|(zlYO53(6`>iuTw9tyG${Tms`J7!~s}qV||m$ml(*mPZU6# zxTT=8=yUb#jB5MZ$qhzpEJ`RXSL@GV!%>r$_8r%*gOQBg1xkheT}OztZoKN}PIDv^ zLfMGIgH%B$1||iTvL;bTwAkdsa14872$K2Yj`{szHVRnCTQD2|%xR79W8p?^44e2i zN^Azg8y#h#(Gg^Y#hMmH4#DtaJStLn5-#37{f}Fwv8kT@MQ+^Rccgh!D9F`&!c#r_ zed|T%{is<7zTp1O-nm~AKe8(8wZE>gGR_&+8`Yh)MsGk2$o#=;#%%d3 z#3s5t1n4r;JMi3H{}aT#z&m?F47`U@i0n$T!7pq0{?ui0om!D9tIOe4ZeUEV`o*`L zh1lW^<2-Y5!W)_ExID1Wb}>L60vEMMu@LNu#vO~SgXGWLN%az6h;#!Wm=7kbXcXw@ zBk&t*yhA2694G%jGj)LF-o2CvI6_YESVrA3lHE^ymXm zO()m&BspOnQ>D$TQ}DQR4;!D&U#cWkK0Wo&Pu|1-9iknTScL|YSdfWLoQ)sGFSaEqEQ%r(NdJA@Z}NqR*xQB4FpT-O{52+0$1F2|3~ny&O&ep`3{ zR&1*cb%Dus*=uE=;Q6&p=PgIq{lL_H4R5YIkr(w<7Bb{h9rJ*)=oC*#1?3Bl1=T!G zb4~hWc1JVJ?R-wi#^Qc=%F&+D)$4Ra$@!xmT0U!XB2m&S_z!642XtHHqEC}g^&|Ja ze@)y_eyj1_lpQ(Nq93FEG?Q%?uXD*ZILaYx>& z#(yMrtVay-!W9UeLNoq^NRWTEFWNx$Qp&>UOE0@7di;6h+Z!o)AbswM5Q`( zBFeqnr6*FyQh774QSEX2>|<(_G(s_<@dH2l8HE4|FtuuA1n%As-4@_8LBl4TXEx`A znO1QJz*Yehz^3pm&0Mb+;m%C!qD&9}QSK|NZ+CT)lR3P#Pi)7)Ox60}J;4dHv#PSt zFO#yR^Jxck&6Z-l~|iw`cNhDnz>Ik+z;~OyHx2QH}#czE9O(nFZ5^rsO`9O&#iGAxZ%lDXWEt zy{fCF;OdM7*W54mEcUytu5W!`O?)Wc+mL;Nv{o7+X5)G)JQoW=^~oUbQ;ZO938m&A z-sb$37l$HbMi$fm3i1Wd#~dz}3_nYp;0E`^1XV^X{w%f&tYVWPk z5ODF`eNGhw0-bG^Nn@9Nt_|OKZXQTa=%fog_rtR0vaAqi#PgyPCeU=W0)%T7>10s^ zNI$&LH+W>?7t2+_%ha%Axh67TL=acwjO~l~Su3CiIcuwN>ovXO_WhyDWfXqI=D@E9 z0rGd#;kXRD)={{9k+?N^DpkCP#3k8pl?60Aw4;U?breA=z-c>q@1&0OSP?V}QqKO$ z6ZYEvw&!ED?DSO3Nt;xSA`dBMU$2zM-@2GNU1})`=O~LbUwtq6?=3#7X~Hl7uJCK7 zD!pPMOA+DtwE-VG-z7B|iDPZjzoAr|<16kcnPi8r}M)xo;^cNxzg6-)*# zrvTEwEPcew;`>`<1{l+~Vk8KeT&0OvP-JkOHEIgS`41xGR0dy&e7y+)39+1hl}pxK zqXMl!gYzhoYOe$h?_1RQAEldqP5s=R@Bv}ib;;Xf#`XJ>pY~bbPnOHzhp7GvqnGOs zk>N$a@$uN``P{|+w{81+;w4H7=+Dj^g;WJHI!qd>>58ycF!u%}-hlYE43+o+TQ%U8 zrY(=kn0ZEs)=xsg#!Ho$UGpw4lP&#GH|EPut9Ds~RiSqPA9Zgy~2=TrlM z@YrFT^KUYpUEpory0_9PbR(#3iD)XMkKs^<;4K00+?S+4?-?0Lk~0Meij~oUrBZgO z@vM6mi+}mc145UBO~M{c-lCnh%I^jBPtWytT763Ft-gHt0g=2WLxKZpHfufu49m$9 zw*`@IG01H(n=%O6XgaYZT4;bUI#B}(rNTw^(eSELv6DiGNw8w8+$;|(g0lb)mBDW{ z;3c93nxf!^=J8b;{of7gp6L>FR)zdnbUvBPUCS31^<4s?+UOpOL(>m;BxAkmmDAj& zFn2#L{#j1rNQqm<8r4r*`UD^ml^rAeA1x$2j<6kibSnso!=d5I&HV_Mj9Z5!IskXi zLMRsb{6vhoKE0$VFxy`{odg>@bNpf~4$Td0VI6C%Z^fNi3rVtKkC#A+%a^-Q5I+CS zW?T#IanSgqN9zvP1;oCpoEYuMomx~CxMwv&Fg4%uKr!Nv+qXloToK1n`9U`qp zaGKQ#`1T?EO@Jx^wckIUr175+hv+ch1Q5yN5Gu3NthyVw&KxsF0dX_}H+)UbNZ8|i zny%)e8|^OPp|~_^ddrGjvKeE+8GFfIte=!Yv-J{c0ZT9~vKP4Lyh^OUE87ds52CDIbs?q^M4?a)>D--W?GB;TyV$p6PB6ie)X9Pr-c(A`@ z+3I8!vdJ(nKk%M=-@m*0pPpv>)2MxGfn9UOx_;U+z9qV!alF#DJ#UDcGu_!H{vqZ* zQ3VpnEA2Fa)|hrp12G*pAwbD8lMo(PdM8Uv>16<1K3!S}x}*)V`u?*(!QAe8bm`Ll zsqhvrbpf;mtds)Wre1QVXlV2EfqQqRu)!ZJe_|u!rleyY^u#$+SB*9<*}gM9U)kSj zohrHZVu^vmD_+&sJFC7$Y1hvSecBiQGq%p}YYb`DDoup<6J`YPD8mWyu)wASz`Zd0 z?U;j{y%Om6t7K#Rp0wl9w7cVpku+$XQTxHj<>k)t@3OaRav#FxKAyjrYIhR-HV{He zTay|5G%|F>{rCwu@4nE|L8LF*PmPRK7j(An$40?an;X=Yg4Y9gQO&V*fV! zhRF179)V@tD=}^BvW>n)aVGJf^5o(mc5MbKo#5R%Fke&RLvmMQB7%Tuq;VxX52;8Z_d+zDzkupI!yeugVvN5Dt>@$~xzb>&O35=L;}HOGcPqwR(i^#!e#+ zENpwo4v}X>Yj5$McnT;yV6I`7!m;*$@$90)bs;Fy#7S0NrDGF(wKymP3aN7|iJ5J0 z)*k+2K7nc1WjYl($I|K#RAu+rukN{9+!a|Qnv4>Irj(L&q4s2LN;DLGhc0glwalNH5IzPI+_D?hT2 z036D{mc@Y$zbxXj8MGZ?ta3;`5vsqq<@+hO+den|$v_r0^nP8ez}2pi+?n71e&T%1 z`0$uY^D)WW1>iP4Y=gcp$Xe5+Ws=t>WM1r47(LGoj?qf}oxGGnamMt$GtzXgzaE4q ze_uvWZE$)lSere|K4i)Jl=Pr8(us*)Iw8*;e`E3^j%6K@Db1PSzu!nk%6G+Rda(_* zdmmtoZ0Q(jv(NFSe*{}GaJ#`)wZ_$h8^lLjcv(Esgb0tQJoX^jH&?r8Dnfp&RO)oP zj)vYRj4uBr&Sd-0B#Yjze2kZNR`cDUR7LR#x90D~lEG&}d3gGkf-3&pM27qOLHEYnwLE)xl-~iF{JxfJ^gF6`egw|NR+U*}_$nr~l%7 zs?9IK9cw#?ZJf}Cma}*pO7)X2k3OZg*n6Rn)O-9(=v>!k+qf_Dcp6Vm-O(na`=4&w zw7U&5vQ96QA0Nn#aBOFyk#;+_mu}nTlfhML1uMyde_dxdBXhqoFHw8EkA*j0HmV{M zrj%a;pWrDaJL>}ht{)=io{?=pEDAREb4w)_#*X~pMS)^lI4-AgodbE9E6nVP{e;{( z$bYh4_|{qEC<^CFRRBS_5nta>_4B}Lk{5Q0^V>+?ve2rk#@KC-9)+|VIkqMF6bVJscRs!1TQ82@NA@=s|{Ri_46Z15?2c&_nomzT@v z;P^-a=Vs#mLx5YlR%<;fMmX^$U%@PitDr)+9FHt8O%O>jmETv!3*ZgEw+zJUPDue* z+FC}Pw#D_!9SZ9+dL#C5lMd*oDO3KLu7$nVqK| zd|Y`)8WN31lczNFzp!c{kY|U32}+C4$xI>$g(E)qMKDr%uyA!Hlu2Ifs+|$KOnvEK z2(RBxvL#ghvX)>Tfdbyolu)Ji%L=W>ea4%+;D8^!Z(UOs{DB_u2N*G7c;e5W8OZ~{ zCo;lOP3xM2R)Z(BjjI$!?XQK)m=ATUKiGCZIzxixo^61QaFKzvN|)KcQng}+Hbx>+ zf%4sH0l!yN`zCMgbG_ur&Kf9=p!K^-o&}BCzkbsdU!6W#f0Ocy=0=KPqXnczP6o-> zA-RewR0Z(JKpPFLCN`@KdNI*6*OCW?M~kKb zblICV@9(BI3Vuv@yw^|{dLPked~VQ!h%$r$o;}W!O!^2Ga$a(uzZUPINjZ7nI=JX~ z{rG6}0P*r%g7RCa`S?YyVF{YW&rdGXY^A=aU4-&45Yg?66|R`|fok%N3IUb6jsW*Ai@r%DEMS1Lx!#zei2n&Ca&t`05u%HKkR+u z#25SKY0M)K^GY%SsCE<}fe#yhr~U}UkpPv%2|dag-nC7|b%|xs_q5u?n+x3&<(}fD z82-7(fYbKLWcUfi-kXD)uU^_!ah$R!Uw{z_MqdEIZ!aDa%6E^PoYE2>aJX*9T|)V{ zJa7FW<#v8b68y>%Kx7L1Wlm)z2}_Eedl_>4Y76}65&mg3=G zq01d77YZS?`ACKyTYYGU8T182`s1oS;Fblo0MiPZwft~|Za}ssXkje5bVjG=k4Bk# zult>s_Tgtw9p`uFP`NtNhZ-ZQj89+K-A`AjK375VC{(#5NhWsmhE>^9GducJzfGhc6cmW~&wRRg?XIBQsO3l=T>ZA>(#+9|t6#|FuoF!n`{y9c3Z|>;~72 zFKN>s`EUk%5n}5Q|DU68EP2L32AO>cln9E-=JVUS%B9dublAimU)UPlrA===JS1HwD zGQgv%`#yGf-tW(QmI^rmXwzF=HIgq*#yB4Y5@&%6v%M|AF9hF#d9A=+9r#ygzKF4t zh9F$nAK!TRm>;e7KeB8Dz~n(N<^#i2SGPqE9DZDr7Y;92H|{6xPITR+bY6a`fN0O| zGP>Pr<7dV^aRlt$_ML`3;33uK(2y8A790AmzI6EID0{rSeOtNxgM@KMguFXJhtt8R z=m6Y08bx^ZGC3CcSyil$LY~H3&6irJ58!YuUvHW&Y0OC(G^}jw+NpcKP&~eI&K(f& zjt5wwQ7X=);dl8fA7`&6g#*2hhtS=a(u|eTym0+?Z`$J)I;UE8KCr{GUEfN*#4q!U zl&?H@;-*9UUEEFEW1dKwNYm#96Qk7hT6&84H~>%P&@QiCHmJtAH_OUX=C8=H6!+gU z?;Gd`{EA@@q^OtYh>^V$jm@`j^hlAn+H3a=BOQmm(1ilvVryJE*SS^MXENy&a~pfP zzNOI+U+sKUwz62bZHN#lSr~`HF7X&=Sj(k?=PO)+V|2mMJ`-!JYNb+o*(e4i?hR$% z6QNObYiraZ8BYcNkVzcBR^`8!7%$Q!GcmWdmgQ&!X*@x31D+9MtKzJ0{rN=h)Dv&V zZTAzhs0lEn+`|}Ig6V2}zBASMZ;@TGI>iUxDo}pNZU>9&NsBt6P-V zK#z*NXqwe>vo7Kq3wU0dySnJ!3Mf61TWC(^2X^j6rA(08Dt`0~(wA#*h8dJ_e?9^p_?}S9)W?vE?i%Z}T`BF{X@4B|SJqNUe!V0Wcd|LA zZ>sW~Ol1-%kV|p&m^R*M4qUUOkn_q(3VIYZw$re5XmY3KfcdA>Nj`Jc-@g@8St#Hd ziJX1tdK<#&FZ7H>_}haCm|1e9{17J{r;g-IDhhN^wwjA~MN59R`Ld5i#_`FOtKR}W z^`0@L{j_|QOIc{p6*=qC8s&>uR7uficJ=i`yDELpP@7ezt=b_e_UW*~Bn3XXboDtj zJO)ygUVObu&_!ByzMbG=$qG24S&Bz=VBC0d%YL}w6m_&$%@BmlkbMX#B`Z;X1YDD5 z&>R?5Q(|-AxVA4Zmqy0+& znUyydU(4LQWmj4M!~2*XdWRklyFk)Uq`$5ow96?oJ=RBL9V*2uQO&848{tM|$@q;` zh%ge2oim(i31#Dk)g?9vYz`sCC58IjMFv9Gj$jPqfC@ETzy<||6^N}HK6B;|+(qSS zZ(VFUg=D^hj2GOpd#%1s;S8n*-^4yQIieIFfT&T6CgTsCe$9UpAOXbIJVq}zHy)C0 zjh62*17+Ms-(93=Q3ZD6vOjTUYIyfyzeGf+!{_f?71-mcMz%!$LF!putAuBOr%CbA z@!GHgsz@Z9$lbtol%@0z;yZ0uLV=!AEyt-T{LT$D=Z?UC5xMv&e0Gt<>92f%#chGS z*6v`_H~j+koohR>zYEnlq;H;QPaWdnwN`EyexEqRSN4@*Q8G49@o=z5p7`55dFiOA zXJ)ElE|~m*GII%R&{LcIrTL9M4O)@_gD~R(x;F<9`N%z;mD==(8tNR!{ z#9`HGmz=<_>d+bxpoNVrMBds_#7N$u0xQ6aBeK+PNOP}cdK+hTDPMU$suBeZ-ofZ5 zt2NG_dYB(>hcAbi2H3SGDoNv6kY=VkH;HYx}w&rr2;f z77|TgP)6@JnjHPA=z@We*oXg6@LxQ?*9DuMnj{@NSdJ%L>{=UK?Cy)!xxQ*5m`3V@K-j6dBPI6hMp6$TZ@i*jE zcCB#wl&gd1 z_CDQ>aopyyU&E=GT0i1;(IxK-4OlH5vtw%SQl~XvA)Ed~ z5q2JytN~a{MWR;nxPgz8B-KC`6|+yFM-YXBKWP_#_2dTEM_&ZFiuCG#=3gAC`!?R? z*RFUv7SAVva)E1Vx*O$$9+i$;pSv4#{sbV>I?Cd1O0XGx zcvr^9HY#*{UwPF!Lx}POV^61gvbcyc&t<#mb19|0wX*o0i0TTZazxXCWwnb48>{u`{AxDSTe4=Iy3RrewZJxkM>}aT8dgPB{tLZ9YqbRj{o-hu2@$OWY%g@_KiZTK}+H& zY7F%w3iK^Fdmg;NZL6 zXzHx#XF&pDO*H!$BaPaFER7Q|!5{`C0O(;vjxZvbZM<^G9Th=iPucsc^nWSZ&qRHD z%*awGV2h=!J6Ei`JPq*XJRIfZUtdLiDN=hOH|6`7l}mz8j|#a>6Rx~b z`Yu_bP_+I7^^>30MA*sfRPWo>ZWm0jf$X8X@aMq(_m$fc*vuMo82hEInF6ZTa~DY7 zNs|M0wfk)%zm_0~md`!;K0i@EQv8jf6D8(5JO6O`L+^`&O>7!BC?=Vdl~^Ok91xJM z2lE7njtWTxYd}lfR#>h_LMDAnvO{ershD|T31eOUq*>p1!4RyP8>0G#H87QgOcD(5 zv!kErMG6dZ9~EI+)c)m!iY5^6KT}kc^Xl0O8xpH0KV8uLj_cqrH8oRmy9e#-fa0HN zLNADO+90%cH|~F@zbtFK7NLbbK8)PJgTEeW4x-{Y7cVdwtm{~(w9T)y&63>O?lWb4 zi@bATx&^mhtW!NOCx^#;bjg1rs`x3QeCReGpy|f?bV-oQ0DMM-=}kr=PUDS@D%aab zL;k%5e-#q1BKS0skjF*d2$f7sPPlaL_f^ifPUqB?HIjc`Q}X-=jAm)EW$Q$~|8I?D z0(QONA*; z$7{MB{4|0#imZcUnoD}-4Z;eZQtWyiW2kX$%AgudOWML$63|Ct;Y%!IH+oB%p8Wpg z)w)Qmf*A0^e{eAjp@Vfs=fZ~2xM_R69l0>gi`4_T$U!pz6To+EYI66Nqmaro*E}i%*Qo4%eUzf@T5N^v4jF2`#}dJ zwDoZB6Heayb5|$*I=oIXo&mTOJq#L##|tz_LFNNqQD791@<|ZH=$i8>AYK*Cg;5Z~ z^4C>w3}9u&=ov!e%T6?dxy>&9Ns;Tb^?u@XytCXESPG2o+w}X23hc|uToC5lC15Bl zYX9~kVd?fVf#!Ag^v5?+wk9@u?r>{0fS#)&;O8;}H*rEA(%F?#MFZe#_w^|hZJBCC z2&{@r0chED5j`?jr#@rJ8*4UALE3&jnFrkB#eBOOCY)*=B|-~de+bT;PpEJPDB^ZT z?K2)B68wchL~ntCe2W{u3@)U7wGL)9Q5G#M?~AlRw)#fx+2a|&V}YfpmmvtkgP>2- zKi7uD!XM^@O8XD{ew;ZawjFCe_(a-?QtxFPxsd_KgzGV3*JM)v-X}_mM>OGo4S+Sd zuwT+ovX1#c!jVxp#0*oDHxf*DdkhoEcjeGmu-^gWlL;m5XU#1ewaZL^Me-WS1T%ZD zPw$@ZU%E&^GYb^Dd}UYFLkh!ejsa(3?Wn8srO~5lWN;q|>wsdI0_ zu=zDxbXD*|LQfk@%D2<@!nc=is4m5uc>GtMPu(&AKYB=!l#dX6 zR7XR>O43iRLlc(|I2(}zVyTdb-G6FBJ9MqrvHvageAC&nhF9%kd5#1Mf(c_ltob8# z@NllCxMfJ0mPYxb)h)4>an`v3o`W>QY^^6ltr`0y4fdqxqsgguZ%=Vu-%HrgrzL*k zrUY+3w|)&jXsq)4FqZoO-vSCBdIY570g`b8O<1iTO4OLLFAtz6ZEa1OduGHt6`r7! zpow_8Nz}%GxAgZE7)yM#OODtj0O`KHi_TTVxUXKPml57|aBau~Fv4K07z>&$wOOm{ z*0VpjHTxEpZDLS??M{1m*lEMFsJ`_O%QOy`_9Z}y{?l#u!_RIK#BU1=9D%RAy zy?PkoE57A8i8`P@9^lqXkkFn?>=30+sTf689fiQ^Q-dpWrAahQ6+q!fQYZrBmCgmj zr5~H>N7Fjom=Cs#GnGA;zNk6E;cp_7~KaOv`%;TK9+jKqDgdAQ!;6GDV~my{sHwj93#ko6os2jCy)BDc$S& zoKDo?^9tXnu)=F}qAy~naolrfPS*-fX70X<5gX-S+WqLq5^opMVfIJBWk0yp=y%k_ z2H|+sEQi&10vv@xaTnJohWj%{tT?s79J%uF6;MhblKKpwiGz)g@ASS%UeYEDm2bdI z^wbuOuy|OLomT5`VBbv1yWd7E_|s}%!hea>Kr$fegVk8!QuDJ{mYanK^uqc zU=FQ4C$dNfbmiIjO&4?_p#eaXs~PZ`;6U~Xw5?9czU`yZM z&e=B<@M^aKbw}i#jglACS7_iOmjdG^L-G&@fh5{&e^*WnqxdUO-VV6mdw88R@0kI> zzwUy|hTm_3sauXJTzJwRWbS_zn`RUm4%GI7Jf~OJgQ9t4fFsno#vl^$_z(buGa`@g zm$$1}7xVlpy`|V{G2THix}U8vuEa@Zyw25&x!PB>1cj9dv z^jM0e1U1IYWo_b?xEi*F{p#%_$i-h!+bkCzHU;v5Gkn7`wTU?&HlWlFu*NIYq$q}lA+IWO68T5yY7vi7>brs3F;3KgR)tj)7LVaZ< z`HOGh0tHzFOgi)vOKe3|xk z@ck6eQ9J9}5oyO_`^A#=CJ!~}Crwx8#J+wsDOl_go#MCC-8C0&0~ zihD*Ux_d0op-`h=%TOb5#sh4m=Y$+G)YCTk#TtNtO)}g5DC)~AD013F=5Z2EKRtKZjPJXye|DU{^ACl0koEg zOtbnkn*)qq@%g&=6LD0gjFUDAPCPhzh?ei8;VdFLs&BL1D$Qx;-7A+4GzB+FwGMmYL|G9kNplFerVyPTB~PA+xozbT#M z&FuD<==hxd{lSw>Xi4Eic!f5PHb59jI@LxN(iGA~QF(sfPeT`;x44C zrjtj{1P&dz0T7A82&Z#GAB0;|k?R*&pQyjb5+VtNm>+lx&i=4Nk2T|`RGRop;zY4T zO6J_B2f6z5ubpadXti^GFs84pKw?6sBgL)qQjq3{QqbJ{$&>hsVPEh^L(p{4L0*3d zrsX#!;3>2O{TOF}!hy;v#yhB>BtOrKr13Y%GhY3J_onN`tCIBg;tLt=*2^XoQ_b_s zhsk?WI^+TTVHr_rkEsVnLjK_yi1r^}9HmqNmFGr*1HV8?ySh3M2*c&5iHkO&!CcqU z3)7o4p_&zYn;h_9dn1Nc@!}Co#-h8ts4Tb3ti%Z;V)3<>KQ8?BgDkN!x@{c2uEOK7SnM5aa#wq( zQ+{pM6w-t1dI@om{^O29IEuQebIz_0{{)ymM$tF0k**joYuQ9Cn`{?cX?x|My z2;G8u=Kak5@FSrA?G5-#B<~XYeT{_%;MH%&u~b@^=RWtTkG>>Ok`vGo1$Oy@1NeFJ z`61vF1*+H6tu}WomByd6Y?S;(6KKn36$%dwnF*%qx^W&g{CoPvYW7#5tKshq3WAQW zyufGcz^&L@=_82grTfg)B-Qti@79Ake%#j6-@6-vH}xF$gIRygkGg!WI;FNV`tunF zW2-p$4@~T$@y<`RU;gX$LrHB}2EyRX-Ab$Yv@^Ma6lD1*eaFk4o4fSt_jy)5i$5YX z;OWLT6xslMZIEswmbDs1p#dMEB*US~pg{8$jUPOlm^4pSJo@r`Vt3MDH`OMtoR|;h zB*V(P1TtwOgF_+;AwfOchXdGn2#RabGqbbfHQ=5`Eb;YsH-6r!PUHGR$9EZYx6>~u zmq;Ij?kNrzO@HnCk(T#H+`Ms_Fkg78Z?WarO3K5z)I1^-uHcifjKja|o*nU!RiCvc zSp&`}70sA+Ol%Aj`}X!D$9aY6y@Zz$L^L&B2RDZ1PnhbOH6V zH={t-h;ytKRITfdM;GRTzAqyzRR_F!{pW~1w=Twnl*J--T>P8!W~!MPp)(JP!5_9pFUFc>AeIj`9TIR{oG4V z^h5n(S>Q<8L*Fp}W646C!1#2QqdLm@MS|0>1;q}Aioj<{;6%?mX{19q+2oJv_q*-O z7w$PhA}Ee-p(TU~ai>q|zV73tvPnt9uuX7Hj35Q311W!4&>i4#8e>FzWX&L16LK`v zimz>ms_sC9Gb!`oZaEj>$e3F0W(k^vEw;E4Ek02gybfqkgR0%V7vMw*K15f#_TUPp z0&;%ZssH-A3>ZJZ>-r4RbbA?hqq?&mFy7-i;rx2jbh52q_g3~*m7+>TI-uv8Y>=72 z#Jubikg3v@J|=AV+)_TVQ! z#84mQy8i-H`&|m^q3(%r6{U*gx0rRCioO|vL~X}-1?f86=OiNoKG1U7@TMZ4`++`g zo;V_K$R1crbE18%BPdXEerf*K0WPCHCA7WCp0TMk^%FR4>3|9oL-dS@W~6{4OmmCS z^8Paf=>wr!s=oL8=KrIB_$q4YPzpmoMHLyukGm=MaQJB7)CULSoU+%j19MckZz^Vg zpr3~2F+@-njjQn5$OmvP#fw$qRCFL3Z#gh`Uj~bD&?!jK@0uRcDS+mT!W85SBYaMD zkdP5bz({bh;-ZDG5^&^|9=f(?NQlcPO0Gj2pbwwjeG&YL!iEyiTR{MK!Zesml!@JO zi4IrRDmwq2U6Yqi%*->6nw#hY%!J7MzxI}g$mCvp=a9$6G^l<*@Of1Yypw%7CWw@0 z(Lh&`qqVc!@eUgUh!E!1{A41^}*7*N_2N2|WG}NmuDVQtOF=rNyL)%<*YD^33+9|TbImpL)4ANN5V5{09d6)O@5Suikr!G< zwG}=Y%0p}r3(gsc;mck~Puy332f^eRK!2of^iqCUZiC}pCA-r7d&Cr=eUhS|WLX_J zBta+Oxz*v8`>?)zZ)=r612HGWGo3Lfl>R<0&j0rGUDvP5-|+?^j2?aMS`Kn%baEEX zNkl=d35sq%{)Nnf1RkJ}eI>yTm&Fg7?HKi9eUfx!f-Yev`aqKRJF)Tq^tTAhrVr71 z(lj{ItHU^1XP-Z3pAi>}kN3lQ^I@0j@=6Tv4~R#!`4$hCVCIWUtxD>E#m)4O|M@Ky ze-`BJ_eseq-K9=qYoadqS&^YS$G z-}xqvh-Q^*{WR{Msh&3=9yeG}-@YnWRCr5FFYSRB0~KZyMCP9*n1GO@u*z$n{h%O} zJ$#9B>U+nz$J#Ob)XZpUeD=H$6mfmukEm>GSI@`K5CS?UhkfOc1>^3@Za!t3JLH?< z%SRciBk!za*Vq43+Ab%*QR;Fa9|Y}5;Om*2c=|lo>^kiaT#{(jY-2VWb<9F=8&hCPaBNviq{`7Lp<3g!VfXWb)Il2@o9o`mNc-rWddQQzAn02!`?KZ8Az@tK0sa+APprflYUrk6PkZZ$_WQhT?5pv$jb~BlB&C`f6i2bVoW-zr5?5tI-vP)@7BRETcNn$Y~UB1`0GbY`-K9c-WjR9Zp5!7Ux zguMWteRU^6hQK!0SyKKnWFtG(&_2W9ElPUp%{e_v;=DAv)77!GJqnxHi7)B1ETr19 ze?~;5jnN$z!2NgFCw3lU@CIq{(C74271lY9EuG8gZNZ;m$1?J z{*n55KYSlIyeCtQN34SDr0xd3tFSH3pHpU!MgF|Rn}P|epcyZRDddV-U6);gUz$bp zv!Ii4+TB>CW;jdAStQA!3jNhMRh8g!9zn44KA6ShimtnTu34D(x;4tVk9ve7mNG&o zQu|yo=)a?J`m(O1g~lJKfbl%Wd~%+t=3Fn$2)8Dayrt4_MSQV;2DwXV-+ERBqZEQp z3V+Z8g-60vTnHk8e#ItXW%+8yv`$E;OLqBTgBrqW_h$1LK|FuU?6BJAVBzG36|!&J zWx7cm6hCjP9AR z@Y#Q`?C-KYt0J^3OIQiJyw}O@a_yZ{`Gl8BkxVK*;ejW(v{EWCskMcPO>Llc zv=0c(PV8KTYKHF3iBgA0^xFsT-->;a!Z{Mx=~}vjOx7&?5Zu$Zb|@&0qCfV-A)>ea z@goueH2gCS+BZ5gbI%}0E_7U#_>lKMg*J8hgI2-fgpA1!Dm{`GZQzR(qz6rmL>mz1 zzlItn#L_)pcr>kWpSc;H0cpN zV;TMr8`~v6)i1OIV!ihGmN<%l@NIB&{RD0={0*fG&MPix2#LzZ%)z z^tPGrUvJN=)GR>#2A2g@?0>Zae>f-%-~A-$NAQoh4gzL2$VaCRpMvjJR8=4bw<1G# z8h(O}`6>9{raj~<$d4Kk^jBKraurC#qs^Sqqf`2dF0aiG%ddaL@AOIe2G03Cpx`XN>U{lT+&l*sC|Yt z{LR);#SpZEHT?~TfIqfs+7IOd@P#BDCq}k23H7yTd4F$`ESHIENvn7gly#v@bUX9Q zFYwo<8LBrA2LqA$kIAU70jdZOQv$$_h%=XRYb$iA7#H-xKUi{?z%6$*?J2Q)BmL(` zfF4r&`(A=$jJF$pe{gg+3jOzj5GPdf^`SF0N$HA(W+2mZTHS7dLF`&>3`4!Pij&{w zL=AId%Q>!KL0SY7TL&(?TLI5#kAy_|T57+9S zX4>Aj{m5arU*t=LxA`UFeJWH@*5Vrye0}m+?{4r}>v<1T@^ORZIsMFIEuh*Btr~t5 z^UpqE3qh9K#9{TFG{R4LwZ$no-oNru9m;Z%U0XeVTl;{P&`^osb=d0lCeNQw`MHZ_ z=54^NW!PF_KQBRKpY&q0s#Mi#~uN)I;bnpp&S zi}I}1ykG#!dPno%Y#!&fD^DH9kMXn6EQ$~ou%b$a`?(`jljE3lguk_S!Uk(xe4Rt9 zg-+SrdlIF)%lmVHVADX&&y9oRJ7K59MDF099?ho8!E4(`RzU)p^cEE!z$4EoyjR{Q z0>N`sK;?BqE+iv-3E5{vx&VJp-XB!_h;Y>L(+HE#CChiE z(saNIJr>Sw`*39CP%Zb~AwX#78~G1ItV;bT&Db0A2FHJMSJBZf_8;ZEkH;4|NR}Gu ze;T4W0xe4DMDb67%-#Wk1kZXB=E;z}&0_Es{h}fw@g zX%>Q7h4E&+7@~Z(HcrilB6pDTFISt*9A{9k>gHE=YuCO&FT>uHUr%>wzC1=G@l=b5r zZc<1Bk@q50WUt=I8{bndpTmI+#vDlTiyvo~e$aM07k+8{^$ks1xD=)As5~XIN$v)H% zt;Dcl?h2F3*Ax(9CO8qk0<*=*8jRLFqm`- ze8ZW*KP!4Ru`s)ix)XWtsv$S$eIY!FL&oKYwqa;-d;;0OQk*=wGQ{OU;Plh@>3^r3 z?UU}0*dKS<4kJEqszyL9r=H!s=@fXj^&gs9_|#E%(Zo<*NM0=Ap=JagbO0{1!ho&B zGjosp6F;w=Fcs2wMyU!|;Z_B>7){nJrVw9w9!T678o{9f`oU=~}~5BUBDR$0=B ziRDkD&hOoqBE^7z3cMu2i9h<#;(nq}F|2YO6!L#_@zZ2p?o678fA&eM?RdEJADUv% zc*#fw&2a*}_7rJeE3##x3)uGn9MZ1r1VHK59qu}$ODF^d?mDEd-jC>KHW}Bi%D&crRU`$_ zWH|dyCcgZxr8GPvvesPB!|~0Oak>d}iIwyEXa^GoJM~YKIQBje|yRz&OptB zU)(NqoAowp_Jd9&-W#c4efGl;nzxikc8KimpYYdZ*n>8z%ac6%k3(o6p= z(unHqh%ySd<^9*;sQt8*XL*#ZEd8M2&NJ4Q(FYBBrqUg?4~YLxu_X6iv4mbRSjL-+ z*x!)WXOA*RQI;ZdD=y~mfrRi^9|&Ix+e`mfSnCvsHNQ=Xzjq06QV9VNgTK8F7~ZZS z`a3Za-!zGEeG`(jwPNa`R?DNV93)4Zeh;PC7t3}LMk>8(h=WcFJltzEs?Rb2%6`E4 zP0kqRz34w)_WcEDETOM2KcMs?Nr#PTTcJF-@H4yeP1{bMgvAmib=qv<8uaz4tT2a` zCi-%;6RNwa+^Q_M#4aYhR?@=oTb0|7&u=K|uL7O>8=uC~=m=htQVZ^3w6y-q^K^FeN(SKH4yRPp-# zRR=wijF0q*z63w&=O%2#6*S`NSQhm=21ntMW<^y_wVb#2j0oN0On&RGvIci#Je)4= z!L+pdQ@{G{ff-Soyi$9K=XrQ7szIsW0iW5M4|rK$t@&;kEKc0kTz#3ll_;?807P9LsMUpDrPmn>RxqylBDc z{3u*|n1(-?-~`Tnoq4r$1AlWgH54qpfg=3ac2_+bp7gKWIvM@))MD;<_wYZ^ZHmOV z)%?R!6C+oCsh6-&<)|24=+MnVQvxsXK1GeYX&Y-n@76&GejDM-o(CMC`G z@%xlK2hq7thl3cp^5U?O5eVkWDH{Z2oeeKY?O=#D{v18c-x9)B*}-XlamPs}k9-tk4+*!hlob$e`-d9BhE7nG&d z)0pI`7^gjs&;YXMD2fePzb)~n+ws+uJAb15Qdgpz)garb110I&#^~f#*n>hMl5F&$ zx~7oGR|;1%O3meB{0pW_L$j)QQ)5ofg+EC`9vrYdT6~FbyAW)mXa6#pS@vDkdh^I( zQkhNJ>5^ZhP46H8?k_#N^Pwlw=K9ossG1j#Won=O`?c2(QlRriI`+ZeyGCT8tpuE? zg-1`7kK%Na=mwb@=D`z7Z9lrYEGxt*LdIj@djO!QY1FLeFi-yn70OjLFN>2WhB*891z!B)k;~ud zsMMiT2aydf-FL*OboQELl+y>gb}15wFq(_n1~J486t3o>ZXSkjSDts1Yw%cQG8`u* zzYtEcL6~MNPa<4|Dc5hb+OO$^x$)d-m%u*j~{4 z8-MpN(o5Vw?{}r1x5Sm0wnd=(FP^RY6;yD1clMd{uRq8$pdy;+9897LsD-!pROV&CGN zwr*}{?`M;1T+}88JEpWMdg``#DKyL^Xf=Za>%tEYBsk~VOQ6E4W(4iE>|rVS0T%a` zqeghcx^}j?cG?=gwhOuH40YWN8J6bx0-XN3V<>K5!Bpc4Ren3a1lKN)#(wPbcCTX& z2jt}Jvc~S>N!UE?doYP$`&RyO7d&}FdzIHh_*zdsLU$gg67!$Be3UgH6x>NXVocomc zF&8pYGkqG}+)HM$RLN^gs%&-t)T`a{0Jxv_Mo8=eL&qQ_Kd*`wPaZT)kZNrBBTG(4 zJdM4gC^~AJc0;LZW)y{-Q-&_(Ep_vjfr6z$wb6({j?6ju`0a;$!+-c1?HA#vs(8Q0 zQx&l^L{kQb{u))ex;>wEPN7I`*3b=CstD-XQa(F3@LcS4FJCMdu)lNH!ddXZzYwgg zxOHXyDAU1oQGVh5GFSBX6WM}lTnk~uT2bWMZvOx-q8UXua|5%YSh+V~ELCTj!$fvP z&nuc#r@`S}27ead`bXFvw~cq+iK`g)hj2^f#+eX=i$whr8B*L#m#dz9gORUh&l;UC z6o(}mSM~dP6&^;PCX)!$lOml6nCoxvJ^CB;G`%D?AiS;cb-2VQiG326rxAjo%UmS8 zdCg+u@5(_N2xzvGiP}-yr6_;r{9TOnN{govy_(+_mjWDB*v-Z51&kQ!k)n^oac0R# zf4HK>cPXm(f!tgDi8s&agcvAXQ&WRpt8G}iV-|RXL^zP6(uT0S_ zf7z_;nql5j7bClJg`SC^5+UJa7D-(CP<{r+K^@e@O5KyGyY0cDZ+4Bz8{bF?0ir_k z-#;g$Z@T{+^v0DYtpmi%4MZ)0A@z^tt$y)*5#`xz8YKEOv0gpF3M`x9vWN5du4_FE zH4}Fm&)I$}MMwy4G0NvoKd`|PIfwC7;UYsXY79Y`?}0JR*D}YX0uwZXV{Fr_BPdO) zsj77I-dIf^Df$gJ{+(kepjYOx*)h}~<`yEU3bgeUcI~*!+`$~2>QXhHsv$YNo_)rC zvA&4-fXyOBej9Z4{fZSJH6~Tc+>6vxj&LcSNyQ4_UF{kp7MAAg8ZDGH35rh8hfSSI zWXi4v6bRp|ZyL8! z_Q!hl6+Z@_RB2R$Umur(ktye{T~8E#!$ow*Cxai?M^iQOHm#q2Yi>lGmWyD1D%JT{ ztccN9bmiW?bMow-k%p@_!@~<9R#uw%fL8O2fM?xg$c#GrBEFZnCu>5EImb}#zlW0( z;ur4zFBtQoHS& z;=A))F9|d15@hc-QSr026aon;?@adwvSOpBb%<$}dSOkMD!qzX0dmD5x z@D-$869w)-0+3bda%^mL7;tBW3AdWlyQ18dIraX95&MN7DfO`LnjKAA;8AnXhGrSJpPc|%F6 zv;c4+L2q>fwOY-D!|8;|u$fSJBHk1Lcks-VWs*M<5maUn%C|qL0wuVqnoXS@%WgV3 z=3}qziTGD{N$3ciu@Cd)hHjq6$>8e3IO=f)cxy%E2xI5nr5>zSwHhKK``w=o*yhf2 zIuv#{((wv=t98fYbaTxp;CWKR_bp(K=wiZVCblf7Ux`Bi>zd7eRl`IE_b(#|!b2?1qFSm+N>$f|CN+XJo7*|5@ zi~xf;9%FbG2sT#li1R)7Hqf?a1`t)uF#Oy1sn1P%N;=G8E(nbU=*h;GwIaYN#6+nWpcl054;`?clGMz4OrS z@!P1a5v&$g;(;KxXfaWqjo_#-=GC)+4kO2iRkk0CEy*@?a?wBUD_%cU%+L|4<3C5!-8$F#J(fkA-rd{Jn&@%$G5+95 zh4(4!G4ST*xjP-ooa|3e>Ycsv^U)Subkk9J#)vjFOFcOoMg`muOT=Zq%qu*p#K@}LZO+uRm zIHu+>fB8>L-jmoOg8fbPcf{sA@_&-9w{k@o#0j8LMi3jRe3loPC2taPVkmOG^Msh6 zZnpfkn4*91>v_H}0CmhZy@nTFfL}y+#r5r8ruZfS72g5{2pmX0yxWlujxGc39xeOj z3SL{~Fh=4IY@jK^lS`c{Hj)^xlF7qGPwMujaQ6kf1Kwj$GbE^|c{HT0J(X^adCXuG zE@b3Swo3poOzLQ-;dAutngV+%Hvtjs#G#lo!j_3uvHqXIuZY_=xQW;^_x3GInQ^V0 z0~f-2vs|Fae#J%%f#r>~6_LA^L4`cgxsc{@?WX3_rB-k3?j6L)If`Qvp}e8=)+mn< zyiK6NEWzbO^wpL=U#>)dea#JaQdyTLQm5esNQL-6Igv?`HuLc5UBz#J{SL*Ic}T=K zM_oV7x~lO+w@OQ?6Q3*qk{Ir2Jt&vwBw)EASK%PKWBh^p*CCGoPN3O32m#XMptKxl1Bt#MII?b71u+Lk+6ti|Hq}kH#qJ^c{wgw zvnY4}tk!zGuQmthK1c znNu@frlLHc#_>Ft@cV*a(Hmf+F8(r`3c_U&RXefj;MN~pQfPuWx6!qjRE)d>W&av` zCV`uYJBPUzLJn^{rwk`imqYw5>uOMpS!bRM8#?@$-vf{6p{a#>$lC^8e^9PCm-7Dvhisb|5$8pjK6S@7PQE?a9Xt zFU|{r_tJpmSA^#~uYFMP&KN_86k#;|f#Df)gd{}QLMRowqfO_Zh2#Hr4ldYLcK8+l z(xPaGb%~mQEH9i2;Xje<*vs7izD;OiO|oSXfn2D#k!mpO-hMJZ81U4qLa;5M zjNn!%H3jpR;6-3?=12K$0(;|JrMbP{r@3C{JdUe#q|jVWLy3D(g=C~z1kLik->~mb zIe=sX9;D>5?32RtZoMox;FS0jJ)ehpPE&AEXad@mJ!sv^7JK8N`f_25=kYO_DGs3I zTf<)ZT@^bdLVpo z?a#j@y9K#@W_iCwtKkLiqs92GEpG>(Ig&BwA=JBvCQKOl;zc5O6!=v6g~10M;mJyE zAKi}ze- zXh3K>jPXdK;+gaH(uD;@!=hKQ~tAAdb=&b<(ts3 zaL7N6s7qPCHv_FY+@+RWlijw1>m;6&=WD&{r5iLaGsoV@8iAe#K;H?>Gs(5eJ;*ZX zk6d4GMexTv;mVgkq>p`+{4LZGLR+@DB7!2MI+CU)HhXfm8EB-e zisS|bYD}A5@rmxw#68FkSzpacxWX`A?RK`C97;nF7t6ka?Yqf7`fA~Ew!Q-SUHH*v z7m^Hn=c{kU65G#S45lJlAXwK_>Q)Y!eEB1H>8QQu)YoTe1V@VU#HDzRn;pGmPmA{r z5^guPjfWGU%a!Y1J0j}g$4Mq9lKc-jL`pE?wWUeynD*0`p+q$0CL2RaPn6WqM;!()}Z-MkcxBwojkjU{i*! zWVWRO>A0~|z)Kx~Q&P0bK;q1psG|OL)YRo=Bj^{Jr$^g|N{7lE;PO6QyL$R}f9N9{ zH4l42v6{z!YeH}|HM8d0zAA~qW~V0QXxJw!b)YDZc+`Hs3;`E3>09ac&b@92thl&P zeU`j;vuP~S-U0z1nL1S!0~aUDsok7)fMz-oCt{ikbsO8_c`)VIByduW_*y+Jk&KaW z{q)^$qf$Cx%@myI{+2d)p67YH8`)D1&r>>@Dl{2ZeQ}VLL@AG(L1HCdMQHd-d&A>y zIZn3-w(xG%J=o$pX9iajJ-6iIKfk1>eiXwWO>aRxiXIb2dfgh_A5FZ< zK7|^Fbyrq1tu9h%Mi9{YBdW|?#ag4P;{5eSkBFW|(F;}S-&OqqrMzes-zm*CDFp5GqI-Pz2GadR5|7J`-5b`z;Qd{%lcxBgBlZBwM66 z(iK8mX9L$8^0MSW&TvSmF}Pf&;F15tKFdvEbv;5OcKP0GV2EJq3&Qyh@*#YK1SuLK z9ropQpVn%S2tRRWg4h5HFzm)W&<3`%T=w7Ufo6YG!x zI?>6vVjl7`oz8$jHq`#j40u|9X6`r1lpWfbGKrwNv`a%R9@kg0xB~7;$~^NyTkSMQ zy-SiL203knT60fAPqj*z4&&P$c~U|H1FU8ea>Bv$k6#R|uid@5^C+9oNyyk_Msz}4 zX}is^rVdue1`HLNoo;Q#kAPnsAEu~yw7r?`5eVk?sc2=K$i-OQC=m{bHiLENpw9zu%ml6S4Bq6}W?>>`|mo)5A%ePsRc`d+(1mj%*k4YY;4qLmX9rD8J7Um%;nK zYDEA01&aEUGXtRUDdRG;M0(_IIAl87u^v^TY{ja^$fWIRKQwpjftKRM>vl{ulcbke zxeFPI=BNSmDz4{6q*A!6tNFhm(zBn1KAB88hu=;kE;9Kusgd5g*B+?b)Ktvmzvq%> zq2txH_G$&fIsv5-yay!O-*bdTvj2YB>uw$U1!X>H`A5q};kQ^Xg6n)#!)%hGxlN*4 zAT8vH52!`n_tIW;XASo9W|a@1yWJd!Ls&3^DEH0dk6821FOs%@L=6={RI z27kJ7VcxwzSe6rd*5Ql<%W`lzh!5R|8xEBijVNqfxlp1%vYowaq*YUxD-Pj_QHT%P zIc~~n<^IFMzn%WDCsQvmKJNjLxz_VlhDg_ScNxIY4`IQDfg4J7oc(b!Zm%}}c8(#d z_!qWYB8_jm@ zt`stA!wIhg+H=_<1qKUNMZmx?W%F}P9WR7<76==~5m`Phc{+q$YRDPKMKpq&nux}| zIGxqdlYYdHt4Wk6_SOT29WD2P-T8S6|J=9Z3lTS=mi#g79jg*Oh9qJ9JP%%A#L2al zQuyoeQc9)J00%K2nOQi)2=S@uY$2DSVW9yJZk@J-2;3%h03+h3qIn+IJ;x%d24Ju zHl#bnw5E}Vex3fwubtL^Kbf4px?~Z0WCp4%cum33#AaUGq9G>I$DnO@4))A5sP`W79sjl3 zvo0CPMGjKhX^Qq?zWsx5)kju*Uw}u6C~})b&Xs2*XflymSFw8O(aea@IiHM5{4?<>wXFW(MWFkd?wwJ5u%F`iLe1&kYZEZjj;+^pm_80d3 z{2HJ6@@d3R9}v$IYf^#G1Os=?5`@kQ|G~(<$jd@$UAVqJN?CY#HRn3)%3xuP%QpMN-MXYgE2yy#AVMm)CwuimqZn1ZuEU9**K|z0lm1Jj_q* z;`+x_>)$7o_qFNQfqs3s+oYa6bfOvGVaNWg%Mw@Tw!bNv;mN6_M2y@R!J-1B=0UX{ zSl#KrnrA3!Q~V++ht9ctm%6=l#3*un(#P*VLO8iMAG z1oCE|UOv+K`@EYPI#Xnuk&@Q6lq6C$I;f6ZmQ6uuh29j}fV*m-MlzNSQ=t-vwPLuP ziXF0Jm7TE$>3MZI1^!`itZaOB{!}SVe)M%I8x)^+UpFI?_hD}s#xzWKl|uTcppehZ zKzQ%2tv7M%9mgU)px(@z8y~r!5dT+%1v8TsHN8Y6T`NS0StsLgG?>qH2d6aDj9*g% zq5|@fk(?IEsaQl2@^|jIudG#m0{*&4dp#5_3VU9_A7@+K;_j?7_&nV ztV~EL=ZjYU=Wy1=Z+9kPnXmN?o&0tVzBi>+tWXNr?!oM^OQ%;1F|@qD2TB|)O-uNL zC@_=5C>l>Qa5(Jin<}k>z8V_Obw!c_I|W-xQEt5#hRv_m?VovGrJ?+NR}FIOd`xN| zPkCF6vFK?%OsBe=bfrBh0M~0xumgSEZ=WwBl?VF@9w7agcSdJrPO1?Xtx?pEA;fG= zpz;GOudZ@G&A)W_JD2|P(Ud;yw1#e57O6Gt&We7zoco<_xzZ8Gm^RTX1@e86^G5kq ztPVi;)qhR<>?2I}R*(-R!@F8mG4uoS2xFo%RA0pTbi}A;W84+5+S}j>cP`QBmhw z*wdfSd)<1AxGvz!*q*cc~)bWAgnk?1^=9 zA$-oy)$Ef$JSjs$k#6J#EqF`X!yjygg)Q>`z$#Ck=3sg&tlE&rpoMP65F&@@2*fEx zW9f}FrSy%i407A<2VNXDrqJ^!Yc)WoR1v`5lK@e z4+Ff-A=4ydqakhG4Iwf8NnhRo=C}+Z%I`me!alXH&0c?8nCdvEBpE?4jGfS*6yUws zGod9!KWuqUW_IXmN2rBUO2%CNQN-w3tEu#!c{#y*uYBU&c;k}4?%(f-Jjk&^=G}dm z&vm*oSFac!Np2mSx8MqUsP^B`ZoEP8!Acm)|JPzm+8;bO&Q|{5IkTr~z(mI}n+Qq8 zwBkw1f<80I(*@BUSM&lstHst9K)2qPF)_3=>c5sNrEb<0>-*F(;U*d~vXzUW1q&dd z7d2;O(#!8aVzhg{oyx!iX_4gY>D!VI>cZQOTP1*DVur7;!8*-D8Z&BoJM57faN`qr zlV$a22BDIsk2_=LVJ5IZi`EHybX4d#_K#dAOuyy=?zE~gh~m5==>ML+i^E)bJO-j7 z_fx;A)!&A@T*5RH&nZpD@hozC>MN3A?;Y+LJm+V?=G9`3LAyiEe6FULCo55bmGHyz z`}oET^6b@=M6%-I7^^N{=2n*5PY4F9qrN_}I7mR1NX<_Rt0xw;BjkHTiRX{x8&U?68@Q_o3haRiagk+ko~rK~ z;^Dq)ic2hidP_icz$&JHuK6zEQT4Ci%Iy;4Njc(xsW!T(HOw9H{V9{ZdUo$uCoSDU z9l5?_`I!hJ;VbySR3U`QhSYlL_+Y&$8&y8%2Y9`wFfx6zK3kgmVg5yi8#TMxCo^Je ziXd&cxOFfE1%(tG$QBQKHW8|yIV&lH!?Trq`n+) zIQK4PG-+yE_E6J@|J9!2E9zP)gR%?HdLm+0tu|UqlKG$UZ$dToYUrJY`G6ZHh_E5j z_(*#O{LPy3`jd|`9{WH_)DWJpMTy;Ww6TC@KV+KUY?kYHNo6$vB)X`1w#kldkK}aZraDxP?3cm%?E$D8!d>e z&7dJ?j_c%VW+XI!p`SkYdoS85iY3e9A_BlU>aS)VrQLcso>asdE;FN{x;-2+}3Rjp90yR;Yhrh@_1UlrTdp#s*C7AZWDn_n8%~8 zgOD$VIC`7rHS2`sWBuQxKdc<}=xK4Pk3L!CW-JE3x+DkOb^p_!`WQ-|uG&~-Ml%DQ z?uXd_YMMI+yGnx$Kac=A#o7mlhFiO3P1_uJ-)l$+&Hi{uH$*c6$)!-Lo(CxQ#TwYR zU-U@AgqQBCg=7zqodYfp6B>Jo1Kp%LL7iefR+D|Y6R#dRC#>lR)1Osgwx^R4En>pe zRmcUwPYp!5oKRsAJU{@CodVR7Om5q0nbn3$@>R@j|3%dWFG4@Tj0?f&y8e%kcB!ZtGGi7mp9TtCxPvtad^6T0)d-y-qtA(##BLJ11cV+?LK352AsC_rMn zCPEgT05w!VO|jS~CTNgXHBuj#ZrdjdC1CpglmHFC2LN>`?`j_dRp;iRe}UHt&kZbz z*$3VaB+23<$0*vG9O=FW3T81t{hY!(K`t{=0Tq3`Z*G1KR6zcCSizXww188RqzC zjaM$W56y~fXZ1*5P{KwAo-)%mk{Y! zPnJmVftuvw<{QbkyJh>P|7PV#Ow1wqcC^+lp+e=H&8B(Xx;MqfzpSq6-{N$dR3~>ml}@EQjr<>)QtK%tBfh7iyHV zm9v3-Nx+>&qwgCZjo4$zUB;W*{y>H5{NO?|m_Afo~WjxoN=56r@vZOgB~H zEm=cRBap%Re59}IdyLO-3$lVbmzG2jsEBC}Rxss@w)gyst4{@rF_e3kf<1z0 zonlirOEmYfIWFQ;y zxUR9-wR#IW&Rs*|_xK~A9R1hJVfJx9tqL$eeLIkd7iwDt9y}ZOE}rsyhA|Ym(I*FXGb;J{PF33RMBjO8f{K_+mqL2m$!P-m5kpGyDn2dD2*$s zcR|*+e!8p!3{(I4z@kK1iSwN|*$+TnPDl*(m*F3*J+l?oTyHM!w9@%obJ(uzagORV zK#Kj#{X`;wxU4_bR|sbM=0`d`AAtA#jvv?~fI!m4zw(~OcuE!YJQ*yKckzInscT*i zWeQ)z6Wh-M-JTC#3N7NhtuN@{qM=AcW#(1KmE5HXp_XNobvdL z*7g>;oKyAWGBc^r?8^1}Z(Wmp?L`gTYGi?2akP~)OL)7RQiIdd; zss?y9Ls~$(JC{a5q?GPfS{^!4v3q*?s-J|1WT7?##J! z&bgC{4dhzs7z-r?%1uJ#WEnG@a7<20uD*>B|6I=6XCm{!95N0eYzHc4>5AJq5IcHo zD2s2*ZqRvbJxeUV)-SksLV$N3J`onHGh>=-Kg`YYO^=j`HpJGAv6KD@V09=Gm$dzd zuOlVEev0-%k<+)r(6i3r+KxB)u3q&fx{{%QB@Ee01huJk$Yhq_(%1c@H)srWezTPJ z*7(r^Iags-XAt0K;7Bdy6tyGcr(N*7rh=JrjvytgOH2?m0iUsr?E3Fuo-n}2yAQ-H z8%703R?__E=*7P@{cQPPhiaARPC;`UHck$dd!pH$VP`#0KBYZ%sz5U_2JiwcDgZ|e zmGd%f8%60mLl9usm00bUWBqBg%|E)+&+XuTl_A!wl~6UP)IRpEu*ZGe>R1~qh`c}0 z!duePK>0KYkIu+hpNl_(8&^Mlav0@5uMt7pqGAdg2_^iO>!!(HG=S-3gNr5Anohfr zqQLJQ_*8}`YiIMLgaDs>pMT_+-a*fn&M%|DgS!(3U?W6f==PcUwdMbNPzvzTURg@q zjwc!qSoERvzB}NpFv^qDLgs?}&EdCho$J;KX}N`tM9GQ)z5ta(Qhub=4*h>FQcQ9` zBtD^EQ1HqG1kT~stBaj0$NbJ(93yqe{4BC9w-2q~|37|GlC+JnURnTMDIKkHJD`iX zt;>^bBnP%mQ=u|shEESBOO3Qdi`J@h94;Bs*O3CQe>85>j3}8;tq|h{vCXkV)`YE& zL&@C_%MAR>STK5+Jt7jd2%VUF*Sxl@pgz8(KY;I(*?PX158MiF_GhAzyiuKA<%2Nu zLLO>#JT?UE>Sl*ZnL#$%0+4{ z(=Goa&&-jxvXCWl)M-Y#iD6x)Je84Kdcqyk@ADejzh1TR31kRdy_DtW;92_%v1`1z ziH}nL+8Wq;T@5FrkOeiSym|@H46|kjy%P*;OjzK7-FI}G_zbp)AiPAW(#6_JJ^ur&|O_Ehp(pU zV^P}t-hK3|E6$Yo1ia`eH)Y*-`pVt6AWxLaG#a~jaoKZ4nz(!Wwn2p3*S z9lWLqAo(4$?~-)?`ptC(K;wIT8dwcCxDW*({OvN$NiZ3kVeHeWdpJ;*+sG?~)317& z&h*$Lkj`p7U_>D88(w0EwMpmO&WxQfyrB2{02-e5AZoG``nwkOgbMJ_!4*QGb!&%g zFyA9p?jLjuo?teu5_xMlGTg68EXsyH|1(Qx)7jN#xhYf4{U3*&GKpvu>X6|<%jR=N z!1gbEDvH5A>Ek{GV6OwQMpC_vaB%Y z{bMC_qtglw>a3yBZYVJ)HH+|BG7E4&I%pf_?g^1kW1C}uq*~>`H~y1E-`e~J$!E_K z=@sY{7Bl>(EzLtJcxWsAo>ra;dwEUNcR~y&^d76yP4Qpsf^VAAfrYmp##kinHs|<> z7{*9PymD&?4cb!=5{I_b*jc|s- z9kvJ$q0m%6?rn6?ZwXgnVKfFJ06J4+6(b==^>uw1@DGce{+S9BgR0lw1o!*bD2MLE z^%;VIF=!Xqt<&RxFXh;F3vd&L;onw-C7cAB@985X5d^$_jY7z}*xy6J^uR_^E0SF| zGoPS-Rd=xX^k?7)3Zuw{imo?4#&W9n#H&4I!#ga};+?Cy`XPVwMA#GUHMu7h#O6v&DawlQWu&KWs({8t!JNUn#?N*zKlRF0vaCdD+$9tK5;XrQa8jydpxt>4<}q>=g!P*)D7p%qvLqyHy6@ z*>nn&&&NJx(QdYUk>Ilq|Bue}iWX-_U#Kqe4jyCOJ~?Equ=A_Ud*`c=zRrLVuwKE# zwI63XBF0!c%5_9Zc2jTVB~f2US~%8#B}{}CYplfjzA^&O0O3Qbq}-DkQ( z0hB-B@3GxP67iAvE0iMor4v|U;0jf=iF6nmF_88<{lr6;Hlk!(MXYTh5+dD&y$I@B zSo&^}#zxIp|C*KwX4O1f)|Vpl}jbm8RO_NQ1>sN%@GqP2ekpwnhgG5 z0?80^YzUQ%XTpCfaf|?ak2gNZ(ZoR%4%u>MH%q+$D`;3NeCt@+{>ofYaX>Q*5q-@K z{u~!%<1h|-FY;EGbs5uq8>45qd*^23#990;ceWkDSl=hz4Dl!mXfa2y3l>CzpHwi8 zo1o|8G3rGRyc}r$_V#^BA%r%X51huP8hG{INOI_IaO7mZ>MYY8C=oVI`V$CddyR@yk1hJr*k4~6J_h5 z|2iJqnAXu4{^7r{X7V0l{U%u*f$@u;Up33Nlz`^}D&%+IqmkYW1t-%Toop0C)R+-! z5t)QJcjSuxtE2*e^h5QWt&RpwAkuDd{#TUBz#h>g4z5Hvz#*~SV|$bbP`{`mpezQgEg30f0^qo+x!0CiKftUTj!sDF!et-BVwhX%J-Y3#eRvC1mB zT@Ou#g>f0&0dxlEy{+!=e^)*OWrEuHx@n)q~ac|}G zmsHvxj^&FGvJI!cSNhI`9tX@xM#D2V{>>&VjCmDwfPy!@Qn=Ho-?=b*N+<#J;L9Vm zn&)HwQ7rG|nLS961=(;Xt*Fi_?uOqPxJ&_pE^dd5|35gfbIK zBz$Ibk5?*idZSB-tD0;BftOe#{IyUedKTkx8KGxR(yS~ z-~dE?(aFm|enIy{mUbOf7Jrci?0#P6oI(^PQ5{Tf*92{aW+5wg>tdyW0uKIorhyB_ zEB1-G5vv?(#Zu;q?@`*v0!eIW9WtN znbQ3G=kIa;e$b9&iTb74;VXfnH4KvcxA-f~REsvAsprERE2xl7)RDBGXSEt{5cO10 z13hc`shoes{HKlPQ=7qg5l{U0H-ZXVS_P*ylK=k&46%Uj2C6O^Xxq-a3D!s8nDcQS zW@2?K4SBjp>n=B5Ps9L)jhcJm-l{okz}jo=8zq#V#TFHPCxTqbj5Xb$O z`5xYkB67HgB{58r=>HBsm|(eZ*I3@tOjd~f0`@>?HkG^!-Or;lJDZTMaNu+; z>hq?PcpLnejF6UD$$dVlh(yu};J-asO8=B)l<Wwd!``9V(NeSZfFv0E!+p!DvUDbqX~hHTq=r4r_7yU>885fPqeN%A zI}{~q7%AO>Jx*JQs8*9pRE{;Pugtc)qc{VPI_6p*)QiJ~T6wZLPyuA8!8|w4SHK^- zB#EU|-ZFVE-CD4~Ry;T0IiL@19< zgY#|wY>I}dUoU=(_2P%ImMota-$5AKwVB~lrcVPHxuj~hApUV*kdVVt`aT6`FR6QO zBVxjh5w$_k0FEq~>>wX~3yuBRQ`aW1YaG?aZyj9T_ID*TaQ;0Bi)vaqQPwR|@W91t z8m#;@$J$*qQxeHtw|5W1M$LDN7(!VMWXLLGJCq@T+>X`%{ra zoz7OWnPt?DI@pp49D7f(6Zn<6Gj9F!uK{`fmq&FkTLlt6fP%%YCpAg|f*!k1iYD~` z^0e$F#p!dAwqnh0WU=_G@X6ZKt6+~8JW@6Um1$eEHL}fr0$0u~Kt3IsszBFvgLV0+ zxgrtAHg+)Rgo9A~kyrF4h8sH~R3Y19&fXAwRwuV3ed3ezO_oW+JnCD|f)V0h@5<8_ zP5;n#?Zk0Uk2@fqY0DnHXj!WItk;nRd$#GM8kJYr0UKRer6p=89$$RTd=?xJ{>$qs z*0Fc*M5?O*NYS?Ir8wjGSnUAP(|Eegwq+=IUyF$U2Z|;*$ZoQ?xNcX2XZOYUu_6J? z4K5=V-h~YA9EVQcBQQ;3F=t+3bP%jC@coD1#ujsgSPdX+IFH2u^u*tN7EM7plLFiv z0Mqc$xQ z!w9+C5SUmv{vnO$-?)hhB`P8!DB1Njwcl+&jXH%pvEbYx$#UNCTl^bw4%0KJv6@>pl=G%y|)qH}OmBcj4B8W{3k*?`K)()P^HE4O)fx*Y=v`{|42chr74>AjQ`sn?*?0&Hz zsnMf~QwcCQzrV9P5247;uz}zE41r`tw-FilHKri04kW}g=n+!=m-R&b#u)QTJagfC zoA*Suzk6J^@J#o{H!ljnhqIaA^5%J<(btqny|#fj#X_12R3C*P`s05RG)w&KfGRCwrSJ;8i@d?(^C`-P{;2$wI4(PxLsQr*$IgGy-1GU_`J>k-W>EpYdv% zoX~2%pLbQuTNk~>w2mAKN})tL-d~5~j)5EauO5WN|CR}0QTKXGvx!?$#7aQ_n+1j-D?4h#_@_Y9Y~0>af9?*MjH#r3`rCpaDe(!NaPQTg{+v zSxyS?2@IBYc=BE; z0w$>wSsM)q>ck4ME(2}|)_zZYDE{BVBO&Hg1MK$u)Xp6ixbV)NWq&y`t&`|0s>ZLl zuas>ADPv2D88tTQ0dvgpk7f-xf$!Lmx!UmQ-Z=1?+7|+Yzb|>lF2(oVGg0zUPm8Nw z5k2yS@0qZc0Y50Lj!R0sqtxXAzT0lJyL&-jFB!h2cWs#iAWM*~jG$n`et=dRv)vR+ ziC4D+hUY|KKX``s_M9`Vv(YVyA12)MK7t`d*+eDl3~9!@kt6VOi(8oY4=D5~NxKe* zc`|?Ie{;kqy}@YmTs<%f;KIEj zKG{DRrhS+tcy zZMI@>-Q`bj%tX+>`(8r$t+MgXbu*;rIj^2Nx4|RA2Z5%DC^0wDMC?)mmzy~0rT&_R z+D;6!g(7Qr1+&w5p1F=R^+lq5*-@tRfq#Y2%uS7JPX_m%5SH8Jr|&tR^Pp&S7=J2& z*}))r%KQ{GEUWkCX}x>zSL=NJ_Lf2Ji?|ak_G~v=X#wxHG%Sr*_~-pVKL3dMBH7kgsE>bu4toRmcyx7hQe!Qb&Fb_w3B0lv88;PZBD|9P zQksi=R8VvEZiHgPz(sej&LM_VB!>&F8@Yh|_lIJ;40yl~k8&a!^6FK0rc#IJ)0JQ`u4etfAyJTr1Cf?Z(-){{rNtPdD6HV=zjiK)erS|D3?Cq2f!0isj=U}6RqFq z+50?p{R!dmQz}w0-$31bn_}Wp1k`l6Y?BZMR5o=+sAxEA%SPd{&9nAok{zBfn$w{E zenfux;~qaNFV4!_JAUYHH~a9?MD<@on=%Z!ZG?!NBXhN{x5q)4kVyRu-BCC zLt`l{j8-gOUO?tTUU zI_Lp;Gt0<9z1=Vz%QBO*3_(Ry24-T8M+LV6JJQ|l2J|65r9byW$v%_i=exm|%&5v= zY8>-=jh8E0UbwQQGj~ahtlpm}mW142?74r8F2M3!DG8!1y@zx329SIZNxeUFqB#42 z2RJ$!=Lzo;=&q(durF8l(U5Vsr|Jsy?^N0;>$;~GkawW2gFHEj`%vqBFC_RBL~lAlw&QM=%R2*lj9hArP@J=$7ogzno5knav&Y(`ktf7|o9he+nmCLe z^Ka=bNxb(@YErL~j9V~b;?y$-38Z)BJQD!%z?2v^SxLo(kcy0E4g-zUAkExgDhZ-6 z9lB3C%NpUs(F>LwJjcvqNahM?vBom6M%+ckH{CDppC5&nsz2H>0>TJ3yigKqnhz$3 zFhz;~;Iag{!ewsCQAV(Z5saKd=EubqKYX2j>SL5C%D)9O)2*J7{k12z9)2DT*Evg( ztxM>4#~s004Vj^wZJzcsn*)4TNyDQsaJG|ul;47BxjjpfbmaNn{oRmm6yXGGV@FMQ z@HNvKt!frMv_rB(ML|xiQa(m0Q(CP1#`BXu@6#ryj8j#s`M8x2uVkE%FtHN<0^_$ACu zuJbIYcI1R$@MU!8Oo89txH8ZDrmi;%#WC0Mz1qcpot<#M^Mx$=mE0wHm$xlft zd*B@nvD6o$z`MS)3wp>ZQ1G3Ssq)R!twgZ^lH~^3g*q9Ia2tS#kI|ffb4!62yCA2& zl-mINd{k3k^Ugp1C_OvDBB%iS79ik)%54ij8posh)pCV$?5VF&Jop2_6s$9O@Av9n z$X!=|8rslXxgCnEB^$qc_oxW3?hV#RS61KqRHKpjI+IJNx{BVg?~Ao9k~*(Vkb5}I z6zOYLLlChDvKh;hiVxhq275bFb=^FCZJ)x#Jb`L2zy^6>IzKidai8Dqoi<5* zqgl*5#8*BeaUbKNA^^Ziet;AXx9uJYeQH%(t4eb66L523HWqJ-RWJ#^Oua``i`Fv@Lofg1Cb{VmXz`s zt~6K?9W?FUnW>BHuuVCFDL|!`y^Gw8H^8o-3q34XL$kM{^N#S&yAgrR17~kmHm+DvyQYw_BZ`?vj)XM^9GnB zAqaKlUVU`U#di;7yJ(wufuw68aZMBj*+fa11Eiws$4r_Mhi|a?Qr>Bt+t@jgZLH~f zcWFLJ+SQI6y|aLuF2xFt3l`P6#EV9T_9F!a3OwA+t6 zFZ-{i%MbGW%C6k5XFfkX^sAk{=C!&&oCMY+|8;4-;Gxny?=8A}_{myXujbhwfS=8RusfTWv0h|260G)a`7Z*nz?h|*6`teVKod4(-9`7r{lkoVbMH8016$Ijo{q2c z1?4y~rhDE*ntWLg_7i=#532isc%$I}nE&N^@nI51qv4e#OoGum zqdCwe5PEC1-O2K76wilh$utYFrIsW%ek7?~HJY}1OtE>?GMA+1>OugdN_4ythjKvW z>_2mg_{=--?#mB}S9YUDGwra9Z53Mpe7xfoQVn(k&F07CB{oIe=SXL!3ff#d<$M@) zNlYwz;O1TIzs`$7A`V_yw-Uk|k2-nQo<(!pokC_XA0->QxgH_Yc-FcEhjKo}{F>LH z3_Ett*tFA*vFB%jmn~XSreo>;D}LhY@FG$o%~evN{vCuA)$|t{YpOSU8Laxuid!i? zZFlN=?m)!O9tZ4QhE;UA{8K z5Dpmz4n#ht11FN|67HT@)l*7m@D%~$l@lDh+bISgYV9_5C1xTDjt1>wa<|X0#w_w5$z-b5f5gQZspdB@ z7vzCuO>go_!g|0=|7GELGqnCK4192T2(;0FHCp(md;(8%$D4|ExGCXZ2n2Vy;BRu4La~F9DC+qIMLL4k&ZFnxCRBC%o zdCV_?F#h{6qeMOl)7k(fK2sNixz;Pix|X>PlOEj3e9jH-s2c}~6af9LT`A*N{o9v* zfZzzc?e4%}ltaxRD-yP)E>iTKU`+rG11TRjTaQ-ln;gN&tQ!ad2?>ULyBX;{9{#n4N?*|-yF8cA;1(-S=$u`Up`{K9g zL~vHqib&0Tsaaawj+N71odtHV(dp?%fUQJj7mf0JCH85^6BDC{c_UA*gwzgph(0x9HA@@PzGpQ z_s~Sv33C3pZULvTBSBqAX8)}VRX+&thn`~r*q*exJVx*w2HlL2gySD1S%A&JYiRTH zFhGnu^mK`Zj1k@7$!lq4m7VEkeXd*?@bza@N$dsVk#D!fM8NkLcB57o+A-6;W|Xse>CFvP*@`^WP zA6FJ*ZB5IS9VH5=7AW#AIaLDXD}y5Lp(Kd}ay{O_lAk{!P?^=~7+9+NftM{qUUNNu zB>ZK&u@8yD`4d+8s7&dR7_M9gD`bNYP?%8|uXI=8&$OTj{vskmma(8QGpR>p*dlKy zvWWxPOIv)k)J@xUJBT=YkRcDS9(gy$+kk%gC+H60WWpq3g31m9_l#JW#n|YMy?qz@ z8?bgG%JEFthdGD@Ddlc-cDy*`l{)GwQu$W~kS+~h*mAK+?(S(Gc1TPSvSn@ZbU%y1 z7X-cf2|yM<^(O^ds%rXB_-P1PV(N*%v7%GWKtPb1KG->ECgw-;qFi@WUr;vnghYgfAE31Gga68+d0`z@B^7saH5($zqxGfwo;0 zry2E3_fW#&i`{eEM)yb3`3;Z&4Ek-;WsE*ul$5%qWm3d>V4fvp>KyVspcKFkBeb6b zxMqM%g@ed4n0%$KuZVk|a!^jr1t+@HGeH5H%u-D&p~$OwlP|AQCF&c3qWQZOnHk1D zae(Kk4h+0Ns+~e#grI)k@HXmPfVxlf3GP%oT^ML#CHel9KtB{fTC`tKh;~9YFXDa zpXMKpSfaXe=cAmJWXT3Egl=9vfS`sERuyP^QtlLvy&?5PG1%C)Uz8LW#v0hbbzkSm zPI;{m|NB%HeYMx!vT;tuZ@+D30;9*gLFlm1Um<$05LDw8%K)}XrS^pbvK3*Zx{}CG z3qaUAS+-9<^xkPm{X)MZ`pYx_yljd3WB6*90I!R*Y)Ip!HI+RJs}~u z?!Wh*oPLn{`<^N0_E#@(-&?YxHyN2JO3}085c;*S?&q*8@bx13rlMLJ_)971cXN$r zzGLZ_2QJ^AG>YdGpPZZ=Zj}Tbj8$3y`#s{?67K}Hd#4b3`vrkn^K~D zE7+<1nCC&yGA6`v9+69>*`S zS3#|_4{PMdV(X$P(cF+(?nLYe5InEA$F6YBkNSLS*o4=D4wv&@d`@K#$C1!oVfLM@_Trb>DWY z@qU(sSwtE(8a`>UL%;J-URr2B~k!2KW(|3u)MZoW>UeyUjkypNYZgUT^41R>kg7%JOqjE0!9Ut&ixNvCDB~D`A@v6w@ zAO*UAFanjb^2Z|XB8>|bzx>?Rb9j$}d!^BE)%|`VSQK^=aaFV8wKUM3q-EiUJoioZ zyFK*F)8A&eM^Gv86@S@f}&kx*veD6`7l z%)b7hN(92T z9#&M+U3>bOR*36F?oy|KRn6mOA_vL?>ss2%3&U7b1>m$IiDMTL(*e$et&M#nTI=oohYB#L zrs=Z1pE}1R?@hcx)X21;(Le25dQDM9x*H$AMNp09P-6!_1ZLgy=E(2nY*(&;RTTi` z_sEZBUms5z4SyWf2}fbKO!@8o*So!5F_>pY;eKRxPgI#N<$4Bzxj(d{t}HIj|8o3! zxz>*d(466S9XVOFeXPe6?8`Uvdpcix3)yVVwLxQ0WMWXok+Rk(0jG%GCXY|#t$~SU zWuONYbUn`i19aAE~m+eKTr|->)YQ?^HAi`Sa^rQY@2}IT7tE&k9!u z1H=d{j}!NwZ7u94y0aZw+O@Q5=>-#G9VoK*&KNhthsiq9980g(d9-9G$0#_k_OJ#t zdoI3B7L8vR-P1&RxaHaE`;clJM%#pFtrWt2SU-H;Z|106GHZ7zXdD9@JLqCPHG?7< zXX&|A@Z#3^u>SK_s+XE}$JYb2cp%|#C9{xl>OVdXcl(imvOdd((bprPjXxvX$?NHW zyh`g8tysXM5V)L<#P5f17DRUjrn2W>e{=oU&=pq+wJ=Kji2ULT(i#3OQay;J>%F=g z8>zR+T@mmQdXSAFx%YdS)v5Pi>GT;1i<8HaZ>i-fSni1UtD#S~;SFmw?qhivUY}?V z^Lhwi&v7Vq3LTHa5K14wvlRQqbC=!pTm6cn6_2CE3+bu5LDPae1T17OQ{UX!f{)69nwW!T{Ll1D4@6G7m6N+3b5AtWwHF%q?qh_IMl zO^0fimke3yec9SSei6|*Jgc}^E+?N)cVpJ%8Ig~yn{~2`1`n-hygee=w*kuOrwGtadRZL+$BLZftv|>u#-&h0SnFAvrDq%jwbLnq zsCmz6`>5~48)hTT+IA?{d@Q+5KG=zA1bsdxVHvY!lc?_kDO70h@nZb`@BuL$5PPwD zpKbp+%WPfPRzIU%yDv`yw{lk(!&<|5uckY3!pZ&slT_V;d=T2~W7X-{E0>F@d6GndD0K}zM<|+Spb+a{@@!}k_8C-$ z{)Zb^99;6QFJCmk3Ao`g>g;`FV1%QrESxp^n;^~ysP(o^s$e<#(`91W2c*x|nVB2J zt;Ncsie$r|b`Qj{l?ZE0eNdrO;k*dil(8nnB&zl7L4%R=68sR}UU~)V{)`nw;y1b@ z5?1W?iy&rL!8d3Hbt-}6vvu{756Z?&?37;trGXpGNee%HKD?HzqqG?sKqK>VsC{fO zSvZBW`HOxoC`NJFINZMO$-n?1zKi^8RdKPhno!cpRdsFzC>nkVII%ty^ITgq(%uty zZo}i&rl|N^v!bk+J0P$9gvg&~j7ivd$obexNxq6D^;BMv((ttjuca{dC+BD|kEqP= z?UxP*hVOfCHrdYEOOSZWcpeHsu_Scq?8XiBWUONty?$7t%zpw9%xPB#;`ku8 zRQ-f(#cnB4mQe=q7cBS@D(e=vnb|udGmZ9xL>4t)vK!bl*UAQ1%ge?0#`c!H)yEwB z{U)ASoe9fLx2p0QJ*uvGf_=ltbEd#*iJZOPf;g```#E=9P{lyJPw4kl-m_2yE-`tM z_S5TL>ySEmppYzEQ0D6&cO}nlQI1Q{W}?N)(5qxjjb1CxfQR^4&r;GvIQ<&x5^H-sknw^5`yN_HQ$QUbvx}EPp=h+EC(gSuCry9Arm*(%@N7{WsN%fbB2VeQ-FP0{!l<=ghWM%LSo{2Dt)Gb-Se zbR4k_+F%VS4kt|KJsA1CsXcbOxS-hGh9AaDQO*Hof7X0-qcQaO41o}+W-txC6~7DS z4;L8fwgk%N><*K^Pw!^=PfkNBAXRNNX2PPLR{rLyLu|3kVxh)}A6e&io_si68eD~&O7L?GJ*#n@bjta1jiuv|g#f0BxEf7{vNycjo= z#Gv;-|MEw{@=qEs+GEt=!JVlPN+E7Byeh@)Z%zs)@=@3#EO5trWwPda(VF29dRnQ2 z{_^jBKbn(il_$&lmUkEUKznZIjzG2rpCU9q4YY}5qf408_MR!|BuSoW#7P=!0ma!Y zS|3AfC|HkmNIs%3pt+^~`fa76F3x*ujyI*Lq(R~rG#si8C&4rH-B)mbFHmK+u?!@86i2>w%GrZL$brdQLjN#{bn-O{lA+xd~i41?%ni_VHiyfjAKx>uzgrF zu{MH-o!U%qR2cuk4;`3P48I-#g`>P10$oDou;S4j@Yv1tYcFwJuiXJCi+@Y*SSrQL zn~>>>H->H`X4=01gc^hH$uuy(sXz>8mrw#k_#h7_BX~#tIqmlqF#in=AKpdt2W0EOiij^2cOuh0oHY3>qW_`8U`9*nX=_Z8E9$X1+KSfUi#s6pV zGF%t`4eBE2$1WnpE|Ai|9kYb;r00ubU`nC!K;En+Fk*UCoyuilOa(mkBCPuuA-3HZ zgVlpk09ZCj&&l3kbM{QMyZp_>aTVEC0ARTAMK*aV2O>7<2!Swc4dU<@V6lA10IZz1CP7Q>!lrpBR*>mmfmou9EeItaeaAKJXwW0JnZKP%2uPW|o>BMWdSh!sGEEKd6~d5>7N0fb>#f2NIg zKszNvb|)&xbwE2xfK$%@5%ZxC+nE<)`hJTK`j$~)j~1u1Fd&VnYNyzAp*K-|#$@(! z5;44#h+zyqig-3K`XVecd!dE$h&p%aUI&dNSo1dvVC#3fP8iY#P+@%8q|?n`&0Vacq|d*iRW=iB8&3;yxy7TsU9e zX+$#_E4CK$ilHw}&Rd||FQ!OeU26vQt8GdhbkBq%a?Xbr9+P3BXw^*d*DKAReu*Qy zP+4aMddn8OzkXO@@TrK!p!wF)2J`ket04`HRC{nD4WgojoV~SIQ*V!FVeKEn|1@t zgc}sBlKVF?cnoEC%ZfJ!V)9l7IXM4E@K~9B@-?h2&aYK~K8}o&#*n`Mepd!>(E0&v0|L zz{eKEh^pZn@sJxVLIbL^obO<=eO?m_A_|(p(!BDD6zI#p zm$B2pJ|Z^;rmt#-ZG&<3!#|8h-v1*<$;28DL|YmMnDXOeWCB^`ee?1Y z3JX|@RW{N|lNw9uC)A%hnL2|do$~u}1m~cHYv+z^p|taK7()6IJOJc%B^d%Z34~5` zcVCV~l>vRE95XCof`FUJWfnTGm{N*6EuWVp->|g0k-bTpZ-dizk+(9e>u|Zi5*UIM zHCr?1)E{;^hXrI&L=8hN$>vTPcfWHC2KjIN8|Rfb0*ce)0zuc9WcC_DC=&UbC@h_? zR;v8!o$h(=Hkk-=!gyanz#P*_c-n~1Zr~bA%sF?_>#B(qQ2S)f?^(9AZvV;bUtvBk z#N6)$IxmyH??IBCc4)gi(~o$O`!)kt3`eWctaGbgv|lL!$cx$fQfeS&TV>do|5COJ zK_m6YE?(uNKMAxhZKVC4?krVMt`O7~fH*tF z=LY_k8DKZjh0o1ACqG=nf$%Yu#D>;ye-+XL; zF7nFzt;%}CfbMSwy3{CXA(y1q9MD9}n62>iL4EU-5DF%p~YaB$dFw)OP8+ykr+%Nvoq%tgcCtj!BUIzboN zxG(NzKH)~sR8zzZ>m^q8veL<*n~Aqc1S~qB?IohJfitxl!$vjMC1>v^PTP~z`vx|h zvxR8X)gVP&ys z1KC0Hx`W{@@amn5rdZE@4Vf=LjowlkVT+E<5wHg|bOhL7aaEES2e`gM>>H`M`gelT z7hTf6cfS}OC_iQjDQeiyO=s@8f!jCohF`dkX{ReBU!S}-bag4rGv!(Iy~+?d4*oQN zoY_TXfZ7>y;qd|ND~ne1$6hsHEsQNcIrkC7&lwb%&Cwo1QHQstRS6K+I$p==%r5LSttcX9TME&$ z&7A>{PiFgiTR&7XH-{d{4(HO$#%p~Mq*9(Nb7mW=i$@ojwz}ZjL_-a#90`H@i6!OS zo!{BN9Shn`;V=0R13}_8VgWp|`Liv&!=`W>@Z>)cjhd*{m@|D@8hs(W-8DYjBWUyH zJ^g?525;1fe{BW~3I;tY=l(K`OYagPY%y}N9wuh}{)YpE!N;HvhYaaRqWGYA9qmKUA)%B`DOGv{N96Q3dYJ(GS2EnB z-Mju#iw*LRb3tQyea}>5*#VI}M+&LGBCF!tBFrKU#g_?SkZobQpl`hN%h#VWD^jy5 zaMm57dJcxDAwH~qvnOgxzAoiCHbKSJUrkZ$9U;nTGi$spL34~2XvS|bPLNt(e5us= zBn22N(D=3jZfIBY$?m-HZ(eSfP#eckMgM6qb>*H$sA)uzL%@RzLe$1-P6S&Q-$lg)%e934;A9&t8^Wwhey62iVpZlEiIcMgYYxe!~wr0Q!7q|1blX+!4Ba@c3XYxVsvYVsX z8aNvt-I`iJ({2l>s`q{*z7_fW^gZ5iBH+yYfDL=8lmG7ZOia(KGA637WN}R6DoMY#nbRMz7;7eG1;$o3{?+^~M>fk6sxrvTtm+BTlMtn-V_|Yq*M1(`e)T#02wF zQ*vAwQ6bs)>BgfrOsFCu5GqI1Lx^J{4|M8xSs(+LQ2r~c1GuELKT*ey9=mw%Q^IRC z+$;a^6|lh^=O&nHd|H6>AlHFdJ-sZH@ru+OsmMoWdQP%aV$Gpd6-(uUFShh>P;RFV zKW8)aG6;Pi*`+=KaU-+jfl#I4w>_x~Ayh`A@2wD9(^5SUbRys1tO}LhbP98NYACsK zvOq6GWqhs6U7n3y7fl~L>+27rx%qkQA?cW1W6`gD@&}3{p zY$pLs7`hdoe6h_$Q}+~O)>A}-%x-O;X|)b2{S9N?Wf-6iNmmDu0Dk5Fnb z)En5B6nw*?%5g*Fc90rNqFurDQKADCx{QRN+>WtWgqlxDtEyCWyh#}~f9pL~s(9_3 z$`tSzvQY5GhnR4J*lw9N1witC3b`Ioc-u=9L4Dk-WF04^GMcCYM|}0sBU{M!QX_pp zF2pR(tP7hv>$+u}S#6GNGTj~X$Lc@{EeTJ9R0%^8C(Q=XFP{l+M&_yzhftz|e%+Fil4b!SWKv0OFfyiV(t?!TR$fzDz_~WPF0oOqf*du1u6ec|V z;=+dta9#A3@k!f^iy0^&3HXt(QxI?!E5am0+IpaEVH^hp3_{Tv+sGM+v}^>j#D@(^VPeKT5S65k zf>j!RP7Y(q3t|1+5=h9jE+8s9;Y%Vj1X=m0SVe6(gufeCMZEcH;1B6bj~BA-e@7NT zxBCJgu57nG8t=X4}(VmtvCP`_&?g*8xl3TS@lY8G0oLa<#Ds^b^t>o!6{{bPg*8-@=g z)0dBL2hJ?wLocmP0yU?@UHTOg5Df)MIh_?Cz9IsY!(*or2>hFEONV3tg>@z^;K|tY z!@L)N@zZmwE$GRVuw28BXwkb%1_F92EdfVmcc7Z%--8MtRsr&Jf*EvJ(XvXRS=>z4;gMc)v}fqfq;%`s}ug1y@;@ zLbK>Qa}Tax^zvW;x_V5Ny2Qv=Jm(A`JLtw$pm}3CZR2%VI7Dc(>W6`9V-GJEC{php zAB~|CMAyWo+r_uHa5*bNMW!*0H3pN(4SIqaGs&UGb-3g36kC7A&$pD>Af8S_8z&|5 zp%RnJ))d*FFDgP3eW3WiU6^r-f?Si=M4C9!t%c3CNx$Y(@%DgEp9|h^9z|lQ6_jdH zcXKpcGZ*Y#-HH&sPT_yURWEGb^XFwZl@mrf8GQ+J4o*i7bjp2wrybXWu<8|XC^umU z4ER}Hf6$)PW6UXL_3H09ab7C-#U{$^x=i71PnZPQc_1-wfQ&;&>@>&x38l1e$%Z_e z)q%$5vcqOlSsXk2X3{fbEOEf^oCl+v%rnrOQKoO3jwN0>j!({jRCuwR^C7!FfL6}&58@~qz zbDLu9S#QsP2r+dF3Ankbn2-YCPP$O z9O#@)voL7U8=%P_FJW&lmRLVd)b8x?%yBbiljF(jTgBkxwvT=MU!7Hq)LEW@P?4^e zO|TN0l}|&zd8SVUM6mX97*N!w6TwOEkVS0K1H@q5lnUGQV4p68nHC7kyVH?qmPy`JJJp5B(w9AA$ngjwu5#&#Y!0syOHn@F$Aa zIzE>bc%7rZK*JaF(Px;@eM?VFV23}g(m&VS&6EsO#e&tPxoGD?4$0rJMOridmg0jg zO3!I>jg@*S({vBTRRXQT#)mS$_iA%@p_SW|YW`S_4@%ipA+ZzGDw*4qB8@sX{@tf| z37&{_3zwdr38!4D)~x8A9EGWrE~hKr}fmt@&{`U!K^1D&-DlgiaX zLZ45&#&sr6d-wah_x(kLB|w7&-L4V`4!}UlAD03ZgDnmNuJiANv~4z_q(TvC_-b#& zGD)0y?yW9290|3ruPGgeZ+nQg;?=E2s0{BIm_b%@KL*y-F|6bCOtF5-dj^*!)EUqR z-hmb^>l)FdPv;y8%A|Ms*+zxZ0o zqi5j9zH45kw=C<&rySc?0Y53qIL~}0LY7695k*Y$r zU$hrrf^Z7*12y5Urs5paKWB4)5GVMB#7q=xzlLGcXxuJHIR#_05mxaJr5&)Y%uS9= zT$fkgzfGr`G!*o{jDHcj`ZK_jlio%BGfT9}%5!DHqd)XG>z@GF?yD>CygaXC zS#0-C`k9m^?Mu>=+yC>dKl!#EOecsW0hM-VC^J2WDn(wL)z7)SAW3_oB2n7IR8CBF z6ttShSnvcm z|1aC>9bajr5n7}Z7ZLXi5oMfXTiMB^c(x3I`7>}7(BCIW?SE%+nsXIJIQCeY$^Xan zSHX991D|tAX-KCR!%W*rCybe<6hSPiXA$`AQKC0KPZV!UOt62gA?y? z_4MqN+{cooolnzieF$Wm;FSeS1W9`x4 zW91MSjK-yq;HkZ+6Mw_jRwo^r zP=lsbl~tK?J1j{@)Ra;ri(RF?!{x_EQdoh;t{=|C#*TJz69O-`@KNqhS=~Kn!sC3f zt_{R|WV}d`w3tIChyvf0fqnrYNOr_A7@;h|6uO4?CBqEFKPE<4; zP%=yV{5Rj@CVRGfNGaa^_{+i;X>TDJITDY2R+kr6n>*JlJccXpyK=b4;WzktPO&1# ztFz7Ojb{)$4;gGjCV;{Ot1%qvO`gqe?B@dIeTa-UGutxlx}Fbr*bR<+Vogl9;ua{q z0kg8AU}ScG)7i}1<=MLXjE4tEl$<=cnW}3sb(5q~;=|%>yrU`kGpP+Ftfw{cq@{Bs z9#~{@fwtO@Eg;u)D#PJS{Crg30i@cPQtNs1kUg$=gQT$P0r1)QySiD@3OK7Qc++fI zm@|G4bAF}qJbK2K0JY#wc&&;zPJL3t&YusJ+N_lm?|%HXp;WnRyLRnXV<$}*A@9^b zc9h{RG8v${7hTd<{dS3}hI#P)(hbfPh;T_=hP-SPAv8qxLXz1l;4re;J{4X7PZK~T z0=#^7T@No30Z)kthO7qxAhUjz^=%T9}~5es@B-W{i1P=i=;(Pu8=IRdyp$zWr_lh7<8@fM>z@cfm_V*9AmVFO>!0hqWr!A`7RC7;s>=#} z8uFdLi|NF#y|D8}*U?_$+vE|JK6YQIa{hdmnL@S1m;;_lEOWTQj#Ay;J<1D^@V#TT z6Krp6O$GWzgru+u*7OldJSGb&He+awD(TP?wEIzkH%1JM83Nfit-E(Dn?5KUe;ZORBtnSiRT6ZnJ*>(*co?{dvU8ouwy{=o9!GM3xfeh*^0cqZDoO z9G(?ZL2%0So>`7A`R@E~K5)|9No*}{RV*|2mUxmj+c}Yw8rk#0zsiW&@TH!wo>{`1 zFGh+e?-NVC?4F!Iz=G=Uh5daDSXUY_w4T>=MNUyf$`2#qwQw6`%l#dJLeSIP&i~%+ z9Aj_w9Sg}2_fkv&I0L_+E4h-=!(fYAA4lZc=5gtAG}RV)y4I%qduZU z+K4DQCT)3hwsJnuwXa?p}h8c}yl)-?aOmiu6GW12vI)x9&{Tna1K|VXqv>vlu0`v;e!)Hqg_& z7ToQMa4Whd^4CIv(Roj+cVfii-PyS}i%hw=gm#Z^s`a3BOPoY9j_U+I%_K6CfiRj+ z7>@z!9%Cu0(E}{PGo#0W@tVE`KAW75%5kI6j0qP!51!vU_9Rv4Kbo>^2;9??qk9fM z?fO-x1?d5{KEAd_&%+$RzsR4ZDymOyk0bWKnwfCn-J`KbH!G8x%qAjrvhh(^x@>WE zb4M_mEDYFuRi*-YHJS~E;%24B{{=hzNhS8?GSTAJs08`sSpv=>dDdai{N>a^94{97 zdcao3Fxvk7jAfHfX8!)qf`U2mKfhbZL5-KsBm*7y5g|5v1}vdq@>`+|MCW@cp8NGO zKU~o9Z>OuL%P~VM>?#TZ#x9^Z!tPglI3J%E65;N;CyX8VLW$kU-Ny04SW ziwl5;IZzG<3U7(&&fT6lSr4Fp7e9Vw%9Cgf;Gp+_!_*h^GTkojgvvMoZ}N=Fk}j!nRf%?wTaB zjcotGyOssl*MAdozN9?7{PyarJ7_tJ?RA&K3qyGTG+AJRVc5$t#-grNKcM;d5oQ^u z;%j*W4*!zFvq6M3ATtgTvY%ApWURGS<|V{XKDx2<1Os(!fT}s6)~<|3!zv$6lDF_W z;XRv>8u4fygqd_jm>xU>ffyzHo*;)XZ>^6~y51@p5Qlq0Np2Zu?BgBCbrm&%w=z|J zd5kNfl2|CifUWE|O3(n*wQ8C1?-rjumDG8)V^_ZvopBk3)xWg7B8Xu#Dnd7<3i1ka zSubaA*Jj{o%G?VHZqN8CEk09BrF+yq`dUO@Yl_#e?b;3i`= zuE*h?FHG{SlbcA*Z4jA4kbul;MTdg>5Il2tQ896eu3PP_P3eKa`dJfAp zWULezR@aZnie>NQBD`uV&2hHNL?yajCQs&zYTa2@-JtQGwcWdicdBcH=QG<}&Z9Dw z|7^o*H%go4TzJo$pQQOaRdR$%SI8vZzqH+h_+rOssL!M>Z=YP*T9~5=u(0so2IU%J z$4tKA6k>|x+`Tv|h~q{iVO>t%m9AN7a9r@sj1a&l-lJ z#UO)yXUDmv)-l658TCgF!8q4i?Eqd;jiX$;O?ZH|@8vmneP>6N4l2A19V(0{H^xe? zLs@`aCon97n(8JYUy#U$cLkZF-ks{K%EzkRNx3l?ma^d@c#F)HEnE+?{G`*3WR~|J z3MGn414oZgGG%cCQ_5;9wG{bb%k6tiS~bdFRgtWrmOj0j#(wZWxZUAVQxWX^EoH?u zQS4c?1BPO)BS&Wwk6!{)uq!U;%Lf0;W}@fGyL085&j{aC2cX*4ME zFd*NYSdJXpE8WX2-M!bQu4X58is~DC&Rb-n6m}<@7vykDw&R)FDWLj*Bc8BiW9>2L zp+XY}J))1U%j<4rJGPYPySQ46$EJaE8%J@QO`-W#J6K*=IeNdX0v+!RotyUyx18*} z_jF;HB>tBfmXI%u;tNv-?qvf?9rl7;AroA2Z|Kh?hkCYb@M?nM-T3A9Su=B@;3ppc zl)K_8berL?7=U@gPqg(S>Xee|^Wwp>uHBX>!}}IXA{JYYLZtFwph{t_jylup2m5BX{RC6Xv&l{2gwf(Qu^U#lZnY67i!f~ zV%XY6vdvB3XKLJ;1MOKG%BiacKhT8RS+P!3>vG~gc_f3piHd=~xxuw1>R`KKEdWP3 zvF&fp z_UcItjL|4Gh;e2W`bUP6Qv5=y1~3!IjwUpGWMIi|MbC&mcU@7-tsNM9B{qa}ufhyQ7=y0s9fq9? zDxzU>AxW@@|4$b#xu`xM3YnE!G^n~9S=#f^q_;3&_Kkxc6DZq{PAokrpSO@Brp>!B z5p1O?qDJ!66P5%+ndcR1&&=5+EmiIl4L za}2zGP-4>{r?y{9OF#E!s?6c%<|gBPk$(w9owslv!gXyq&qM1fxthlGiUHwJ?*+;Z z04c`L?6d65$?&iMhN@0+SSHsDZo@Z4@99LQN}Duk2r)mFN?xvi&lm@?L))7qTqwsg zlpRv!ggF2E9%gSB5#1)ZetP+d?B{$OCmJOge3zgDUVeEK&(JBxSr~Ic`w)L*lvxkndlkIaDCA;8e`u0Wq@x17~ZJ zB`qO`^-k9%UisM%%An;f(DJotZaM`0qE~Uy`o&F1GW2L8YeNh!@aQ>wUpXG<;sjs5 zlmFDB0!^RQbyp*H6hX`P8lP=DPJOdB*5BRcx6UKi7k{nAl(D)kA#0c;It0!p_);Ug z?^Q?;#Ri}Hb5eT^aOnfTqQh|~7yeDovEk_1D&MphrVSL+I-NaKt4V$}X6mY!%6^c@ z-mHdv6$>NTofeuKw11fmogyFGvhiH3ItB(qJ*gb0xlzG_zEgW2pymynyM)jI z3z`GkT*tN3A|FyROEu0q2ttt$Dzj>Aiv1%6JV+u-mdC1T0_M!19Cr)-x~$lt0`4E~ z!h(ld-(^e4y$L5Se4pj|M83!BeFvPu8wEzUWf@@5U%QNiN0r80wyxz7r{mw^qFAB; zLbA})0fu*LABq^Rj0sdPyl$OYz_xPjWVowgsrK{n>X#>ncV3RvSjlY zQOqcQ`9(5|m~9G4UVQsyAw;LGk)*m*S4n-(I!A7pIK-n9;bPr3!&nK!KTA);3 z;}wq3(ThOnn`_!pS7~|M_5>oD65w!~RAbrrI{R$=nI}~;5&5vI>qXMK5&;#u3{EiM z9m&dYnpt^67GW4&_^>5(u-lm#d};&VJ;^x#u1VQNtb;HdNV4oSU@kz^;oGg2Ey&~T zjC}I$!1iC>G!1!fkpk|k@d4``AJDW5b;E=Wx|cz@{+HaWA+J2&evFp?t8Z!-tyOZG z^e-{6fUF3*Y{yd09_zPT53JWlK19?go6CHR^I25v{Frz73#OHb+#ljcoka)-umI!| zy?C&UnQ$?J#BV|NYTXvHPvcU}3-Q(^2sQ6RWbpZ2KR0lyuX;89;8Z`skDx`j#{ibz zfyb}5*}m`1>=!d^80>!r3)maVtWd`4)#A;KSLvbzcP1=1-eZbSmlfyE`Cxz7@SE`N zH+z@mQNHe|4g8j7rxS>9Ye-}rSZ0hHN>r3_u|@|=u98x3b+pGPLj%kuPYYl5&{Jdb zsWVl=clu32KJlZ>oyfd}+t%X|S@lYdIAA^9cE^5DH*0&a_1lYNcg1m~i^QY`$;~mc z($o|8*(UnA7{apxO2YMecp2KL9z`IaXYWxG%Tk`k9a2>)XEfT?XNZ-Jn-E9GA1PgF zj*{zM2i<-xIKJc{T8h6)@S{^0#4~2;Yb&?PIbnqt*^Bnok<}pN1TlMh0d9VviGF*ZGX+ zN_WoXl@y02C2iYIobVYgMVAT()Bdu;DmK?vCeoCQCn>A@RDnv>8d-~l7eF>Gykf$;1v;F2rIR!AOdR*$jhU(Ov^RpycLpo|2YRzbZD zW68*Oc=vvekcW+`MrSYAlUET$uB0ZIvT7l z93g4xwDjG{;iuWRmFg07&nUi7wh=x)mk3T+68OM>t-X1KGIQc0M(T8}S2jM8m>@;Q zbGM*x6V9O^^69d+mCCnu1!g3rvEk_#cM6rmm#(iar};jF)mm?}?bv?0;bC%#hHttI zp7$}oapWnqA>dT@jFq%w=T5%|P<>-%a@5MgEa}hp%FVM#$V3{b31MKXB$F1xV}Bne zb*i5V!B5{@;fICw&MYo(oIE6*ySKa@fVbm#j=vCH66F9pWHhkNs1>a_6<5VMA9RL0 zJhmvmE^yPW8$RgbrcndZ)bT2p)G~o*v=<7ZsujbrHx81|l`GZo#0yP}9%J z5pP(Yz0e@Pg!MWgTC5AnU5d3OJH@lSC>IOJ3E!$=BAR}KyNc1}+`Hz-#=p^C^fO3vwB~o(kC5(6)2Cb$$kOZ?yL=;^{EO#RgcIR<(8;q24S5**bhk zJXSJZ;EtXSHbgl5ba?gy<(>REVqMvI)TMVlvYqX;6XX~Tij#s}+8p}PfmJp4ZKDZ> zV{XI8K;0t5x@y2Xzd{3Md=k!f!mu{lxi~R8o?~^UQM$-*9iB`Uu-_w$rusni<*!^Y zlKivy?~%gV`KZ+^$(PkrCD(oZ%Ju_ZR46%De5=hMCUuR3jVB6N%6^sr$#3w;oeBw1 zwl~5%d2awwODj%ENK~z-n!I5VA&LY4=_iB~WgDR$;&ZWpIPPfZeoARdL{T+U+lg$1 zukDKVD|g+!L@U)7jz4$clHSAl9#s^Gx{h{{PU~p8VhOR2s@GqtAz6t9tf<@!3ZAd2 zkbz$4W|t$AObSPtR)+BtzH>2|&dpfi%2oOT`Vzw=MbT1aoKh6QItZqL$!BPl0RxVK z$pk#0PCH;$#*gjQ?5*^Bar&-$Er2ieMNlo(P@wH@@OqqLj{`@pEzSS+U1TocSsSUh zcHo!dOq=~5_WD<`4^-OaOn!l+xhzT}9&j6`#O%BvBd=pHSfB#pjU*xfWD!%L_GDpF1Lm0qhHsQg^_af!a+WxYIpmQb=*nz&54@0TM5k1Nktxuorv-C(U)j_l8Egd<|ppI z6}ErUZ{E&Hu2rgvdN{yIj;xTy1KjwCDn~LzS5h}%I&`Mn%o#44HKq7bnkn{!t|{lw}7{X%&Q7(X7DQ z0DR~D7mYp0XTx0m)JsD-Z+U;K6I3cn8)Pd$_USJ$Tifq0kWXF!r_Pj5W(ICWskrdSGTKLG`#$`7>re(H5aELJcoCUu!ulBgpT?k%N_vgwlu`A^dWhfu?r32=+|KVMN zIdu=J+5$DK*(h}Iwgg1wgr5M^rGKTSvGaW0#Ul=*U&@U_?u%SIc*oc>#t(VL8oUtv zeRuX(rJ)4TUn*GVoCJ7Eia~@7)Hn8!H@c9HzAk|fpS+vofLVet?^_f-2y4v$mfI^t zVgUL#P+mlBHHsNe4oo9a+FM(4&hEt-b#)m)*44a5wA41aKJj@UZr#H;DEUqsC7dDN z{q>9tH$86y6+c-|h6;+9Sjhbs?L1~H>8kMzoS~$|OkxTw&&xy#OqQ-t7><+VI^%~9*ROXW4SYL61D|H%6FI4Z-aAjYbusYL zzMn$H&a;X%6o{#HYZErokj8JbIROZNq+&VJp3IK?S@+5H7&lNEO7n~3?Ed|O(lh+$ zh6Bng^?Opss4Mm#ePoU&x9uTfp{M`{PM1ScZt~ZZpzv#=*>+-K_@j}pLa@MOf|Hb% zSQiWP-)RhghW@+_Nk`Jsz%o}JD%WzBrD9kaAwm}Zg%76pmsEn{Lzjvw$cdxVf^qIP0P^auP)Ln9YUN&g5M?N(VcU>b z14MK!KQOMK4>OT2FSt*(oYsz_2iB9QcFXc)ETd`VI&g?F7gBX_Qmq%oX-27t-HL3_}Dj4o0ot%pvqQfPwod}#bcp083K&NVUw_gPJ=z%w49H)BY z{`(yis|OhNTnl)g3}lNIQj$Y1b~8vxR>t~kpm*Nha@21}YK+<0PLoaxUa-2V%BgRKO6vV96+uSQi@P<~(Ni=TV{D1$P2SZ8v;~qtc#=%z-YQ zn=qV(*iQ+YC`DB_C`d#MN|(8)s5p)`zFFZ#3!hw$a4xr`p*79WuB_`n_Oh0`jx?j& z;a}lhZ)Z4pE@PAbY4;$ph9>g>1PSx9cIO|xFEXuyzfTojak9~S#&Yt(k^WY#UbQ1) zW-WJU^^;po`fUx39|>vtP{PJb+)MtdUA>}VgwQ=gAv>}{6`2iLi0X!F`^VsSMpSH9 z^zOpnk1Lr4*NhEGrnX5Iu*`#9wXfAW7ND`;d zuQzeBvCnXE*Fm3Yw<$&79hy{Q$1NRjPd3A0<2alDdX4lnMV%b}wTQ-tPsP8uGm1cP zi-pIpcAQU^-^8=SwLET>>O0$qH<&~of>Ut?9iMQmqF;O6`6DFKsiKO~xg)4_VxwqA zB_dK;q9h_v_%|k>&ZDs)Oj9~lFO`jskQ%YQn@}H>Dx^;$VzrEnd*kV!+r_i`%XxQ1 zUeHl)?NvbQVaIm9?_tPf#}PdLV!vsoxcx`rTeOBCS>^{KwubW9(B~TXL5RmC6Ls(J za*0e%d@U}7IV{rj2XS~^ylHe1{&I8Q+V4B>ZAiwI(}mLGpf0VOn|f&vY{V}oZ{h4L zu(A|hktTZmvdD5q;4|(~*0s`)H@`1}jG)$gwnX$?2new9!WUn0dGQUteO2kkEQDZyxYqYM)7@^i#W-Y9TEVl2fT|gMb<&Kdmj9mJylZ0J~O` zrW#!p9buDt7q&rtFFWVzO=YvpeFPwzmwMlEIqvigPl!meG9wQnV^&a;%yAQL-EVLn z^OkU}Ygq%W{#>e8SbqR%H8aV4!uvNG0G2@1FjIZ1C%c4oCKiQa;6uuA`V+y`n68MH zR-uQb&cbZmTvBO`p0BdAskAr5H?-2LsNT7GS~B9VOASP3FNDDqz`yzH!dK$&$X-6ny>f7~l*ztwIm$dUcCoU%V8)AEpwobF?CA77ddM4I7V+wY> zxv*VPw?TU`%j%d&zOK?>@nZPDN|k;E<*JPP;irm(#nF^WUB@qyejV)Db7u0uvAz8w zK^j^Q?JN@{>p7E-$0Ff3+ECHs^;kTeJD9d=uOk1+UxlJxKR#C-eY9-2 z5)zpE@wAe7uzDZ>KGacS(37*ag<5i>%{W<1x7DF%)7C@u= zpweccSq`v1MPV0qA_HLym`Dxs5&CuRwSyh)l&?>$x}&G(FJ4GFH;GPfw?d5w70E68 zn}C&Rb3_u?Y~|GCgWeXf4PS^4&C&44-#5h=J@5QpH1>LP_6GClbKz>R!4QAQn_kS= zbU&y40bF)uQvD|8h8wV9tRq=5vsq-Z-}~M7g#lUAG9quOn(w4tWD0%6Hsu-ZJ9yeF z+uMzfez}qHF3+rYS@-zcIY4YiyW_!utd=NW7T-(N#gaq>m`7xAz5K}4zO#%tBo5D! z6MFxQHS98?S2?Wx%k;9v#!!A=GyIzvBIAYE^3bE%Ge`lS!4j{FFy}jY^zNTbhK|84 z#*f;RWz*=vKhMl@%e^JxTgaVea=w=PUd@!>e@IuUAAaGU@-~ad;{v!qHhL?zi9GGS zS4+KaUeJlc9CX>90y+Ns2v%F-?HJXS!G>962879)WKtlKPl@PNO}8nX>*bw(Ix6Eo zgeH<)yHznhjOR3J7(r{RMn&Zu-fzZ6+>>{XYb@^+Z!4jR4l<6vE|H&4+$!&I1fOVHqEE)Go> zXP~XEN!1$r)zyu~c0-xz|AByz7$lrnmwJ!I`%B%@9fc}dyn`EsLpnSfqR!>$aAh)s zVyaeV!jUV1g#t%!@RlFCm>pl6g@!twhNz7xo7dgu_pkWTAI+PgO~gNFzz=TdXh(c$ zLZ>5DwrGyOl;dVU0%SbJwbt$KShKoGpwPwo1S~Yq+VgGYi5|- ze9NQ7-*{Ah!I%DK34wRfe9)vCn18U1sV3HVD~rJbmU4!s{&PU8x3Hn|bWbZ`RqSu} z28|@W@8{AcSXfoZWgdKdn#Gy-#0V- zA!99-sJ9fA+T!cJ#UYO`Z&PG8198-clvk=~o8o1+wc6ltF5I&rL`?@J2x#Z#L6#cs zxDat0=CTO2v?$QZ1hX8LFtrwsEKZ=`XhFHJY$THxeN$Qocy}p`rf3M;y&uwUVhimJ8N9}9|LEr8aK5{@0H_#~dzNAhiwuOZix1(v12rgY9`7 zn3~?4D*Jm&tK*cFN*$%3-NkG{^4+Y-A&fdSt?idZDSsxm^>g!L?C1q{&OaTS zEWNk-n%AS1zWFID#XDYfyU5Cut0%wWkk9Kg1upsK-lYjG-&5<4^&8-Js!-o<-ZrSk zh%3O~-~M{*ekIIsof5~oqJH(D*MJ6}l)5wVbS{R>d9>j+Kv!Ka9#gtq_YSkZe8ROj zWOkS6z|}V1Eqa`NZJXu9`a7@|jSmn3vrFWKI;n*mg>JE7xjnD$9-8=qbqbyZV0re> z1}qJ@1jv_2wma$d1K>97Tw^2y0sK93g?o!227W@_utNRw&tv#!V_e^4zGcxiWD7z0 zQDUHElhd?OraRVr?k!Ef;|dJiC%V$KER>@C-{10W>WpL&eE0-*ZQi;F$mH`MiAVF5 zijPPsv62=gYjeum`U1 zDO!^H4n7xAQ~$J5y7Kx+>MZ3VL(#21<>7%4`F4=yLxdjER}L+;|2xmuZNAwRg0pB5 z!JX)&B=axK1qAu<1l(0e|K^s!Q-6r+wAA9oM4k(ChcqF^HZe^aZ*r<3oBvUC$Wb);QREBG=ssog zZIn>n&3GOl6gBP#7H;Q5dy5!v9lYhzTHwe%h2%XTDve{kQ`7BZ-_IQX@mnPSw@oEE zkOD@xmEJ15e2MtXL}6*(67QdM8VQzgPP)HptFl{$^+K?k<<;33lSD z1wxY0?`b+lniTJ@5uxy@fNq-znDO0K6NtY&UOOGy>N2hD3Wj)#RQ6&kKcbM$^j*ci zSxuMi#XPJ^!_O#Ep;v)9vI9yVCj)9q=?RSQp08u%Q97ZE%bA*dhYEy?rbc(}`X;5l z<$>z^*d*>~|CsbB36gR@{Wu)(TECQLGpXy77^7VqIOUwO7Xuwi!0HoE$6N+&U#XzG zwW$FiF#0Y8Buv*Ku1oIkbnM~O)7IMcZd?|8z;JFrO?14le(*#N+hSk9x?1PnF07~? ztH9O#5oz(YTU5*Iu4U092R){Z?;+eLwNm-2GE`!$ZtUaa!ufC{>9%2+E(IFv?J!23fp8N6$Z_b)#cpxLA_?1CQ4XabAb(n)~ z-1`m*n^9W&eMhm!;lsW(PZ|u0Zz~dNOFa`^y}1U7vkg#k>ZmKC-sNN*Ny;yk8-m>B zr+t)bL|g!}Wr^I97o2^%86Hc;MbAS2fk@G!@c!G63!Dip(8z_`60TMb{VUeDlLHkH zIX%u8Nob>xVF#g9@k}pFy27`~(1GF4nL8Ik6tCZftws)TY_!%q*YTTcLi=WRHlT;% zbH)$$d@CnWVpLeQ;?Q&6RjBoLf~i))gA&X*^YJDA3BI5cw2I15p@U#XMFDlqAwI8n!F<|R-aKw2*E+-1 z<-DQl@RQx_f@KTM9j)Z$ zIKC@5;?(@nu6#GOLknjI5FCB7veDcY(aC?b9ihRyFKIX0p&c!1M`ZFRs+EsWEVjm* zRAxJn!=}Io@&U7++V^Pn;t|_XBwU^({9c=cR^^!@S~x_% z^2)elizHc)(1X*?JM;Md2jW1+BXK#hAw{xUsPy(%3F7e8{GDz4g-uw*$Fs?T9F{qv zlv6zDlB|mK3oIIV-Dw~z$n{5%VG$+cacg5-j4(#SL{Bd(BfMf4;=jES2%&-kAOHsO z;08Z<0r+3}iohim_ z5#aCst1A!zvx2mSmz9Rs3KA{`hwdtQ;Mw=EACr)u1pW})50YEz6mF%IJUI?W!OtF7 zS-g~4?0T4+K_V?jq6mpOfX)P}P!Xep_+P?VayJw?S}?HO_SoId5TCiVt6!|EEyHb% zgox$R|8bmF92|!a=QSwgCu~0`dmi>~=lxq{D~DN0;;;uN%A#p5CraW!KRhaq{#>$P zsK$4^9XVt3HU)i2qWb!}AYV4 z|4snN{~ZCY|4qpMP5%J@|Nr9u%N;8RJvag;pqY@-W~==DhyRweHT2bMRPDn44?E@l ArT_o{ literal 0 HcwPel00001 diff --git a/interface/modules/zend_modules/public/css/sendTo.css b/interface/modules/zend_modules/public/css/sendTo.css index c972ca200..f84bc7e06 100644 --- a/interface/modules/zend_modules/public/css/sendTo.css +++ b/interface/modules/zend_modules/public/css/sendTo.css @@ -173,4 +173,13 @@ padding: 10px; background: none repeat scroll 0 0 #F0F8FF; font-size: 12px; +} +#advance-opt { + height: 12px; + width: 5%; + background: url("") no-repeat right center; + margin-left: 18%; +} +.showcomponentsForCCDA-div { + cursor:pointer; } \ No newline at end of file diff --git a/interface/modules/zend_modules/public/js/application/sendTo.js b/interface/modules/zend_modules/public/js/application/sendTo.js index 98d9ddc80..5851bbb20 100644 --- a/interface/modules/zend_modules/public/js/application/sendTo.js +++ b/interface/modules/zend_modules/public/js/application/sendTo.js @@ -184,7 +184,45 @@ $(document).ready(function(){ } return false; }); - + + $(".showcomponentsForCCDA-div").click(function(){ + $("#componentsForCCDA").slideToggle('slow'); + }); + + //check all for component + $('#chkall_cmp1').click(function(event) { + if(this.checked) { + $("#chkall_cmp_div1").removeClass("selected_check"); + $('.chkbxcmp_click1').each(function() { + this.checked = true; + $(".selected_check").removeClass("selected_check"); + }); + } + else { + $("#chkall_cmp_div1").addClass("selected_check"); + $('.chkbxcmp_click1').each(function() { + this.checked = false; + $(".chkdivcmp1").addClass("selected_check"); + }); + } + }); + $(".chkbxcmp_click1").click(function(){ + chk_cmp_id = $(this).attr('id'); + if($(this).is(":checked")){ + $("#"+chk_cmp_id).removeClass("selected_check"); + }else{ + $("#"+chk_cmp_id).addClass("selected_check"); + } + chkbx_click_len = $(".chkbxcmp_click1").length; + chkbx_click_checked_len = $(".chkbxcmp_click1:checked").length; + if(chkbx_click_checked_len == chkbx_click_len){ + $("#chkall_cmp1").attr("checked",true); + $("#chkall_cmp_div1").removeClass("selected_check"); + }else{ + $("#chkall_cmp1").attr("checked",false); + $("#chkall_cmp_div1").addClass("selected_check"); + } + }); }); function getComponents(val){ $.ajax({ @@ -228,6 +266,14 @@ function send(){ $("#downloadccda").val(''); $("#downloadccr").val(''); $("#downloadccd").val(''); + var comp = ''; + $(".check_component1").each(function(){ + if($(this).is(":checked")){ + i++; + if(comp) comp +="|"; + comp += $(this).val(); + } + }); if(send_to == "printer" || send_to == "fax"){ formnames = ""; formnames_title = ""; @@ -311,7 +357,7 @@ function send(){ $.ajax({ type: "POST", - url : APP_URL+"/encounterccdadispatch/index?combination="+combination+"§ions="+str+"&send=1&recipient=hie", + url : APP_URL+"/encounterccdadispatch/index?combination="+combination+"§ions="+str+"&send=1&recipient=hie&components="+comp, dataType: "html", data: { }, @@ -380,7 +426,7 @@ function send(){ if(recipients != '') { $.ajax({ type: "POST", - url : APP_URL+"/encounterccdadispatch/index?combination="+combination+"§ions="+components+"&view=1&emr_transfer=1&recipient=emr_direct¶m="+recipients+"&referral_reason="+referral_reason, + url : APP_URL+"/encounterccdadispatch/index?combination="+combination+"§ions="+components+"&view=1&emr_transfer=1&recipient=emr_direct¶m="+recipients+"&referral_reason="+referral_reason+"&components="+comp, dataType: "html", data: { }, @@ -439,9 +485,10 @@ function send(){ var download_format = $('input:radio[name="downloadformat"]:checked').val(); if(download_format == 'ccda') { if($('#ccda_pid').val()) { - window.location.assign(WEB_ROOT+"/interface/modules/zend_modules/public/encountermanager/index?pid_ccda="+pid+"&downloadccda=download_ccda"); + window.location.assign(WEB_ROOT+"/interface/modules/zend_modules/public/encountermanager/index?pid_ccda="+pid+"&downloadccda=download_ccda&components="+comp); } else { + $('#components').val(comp); $('#download_ccda').trigger("click"); $(".check_pid").prop("checked",false); } diff --git a/interface/modules/zend_modules/public/js/carecoordination/encounterManager.js b/interface/modules/zend_modules/public/js/carecoordination/encounterManager.js index 0c63d4cf8..48c85bd54 100644 --- a/interface/modules/zend_modules/public/js/carecoordination/encounterManager.js +++ b/interface/modules/zend_modules/public/js/carecoordination/encounterManager.js @@ -1,5 +1,14 @@ function validate_search() { + if($('#downloadccda').val()) { + $('#downloadccda').val(''); + } + if($('#downloadccr').val()) { + $('#downloadccr').val(''); + } + if($('#downloadccd').val()) { + $('#downloadccd').val(''); + } var from_date = document.getElementsByName('form_date_from')[0].value; var to_date = document.getElementsByName('form_date_to')[0].value; var from_date_arr = from_date.split('/'); diff --git a/interface/modules/zend_modules/public/xsl/ccd.xsl b/interface/modules/zend_modules/public/xsl/ccd.xsl new file mode 100644 index 000000000..79f5e1d3d --- /dev/null +++ b/interface/modules/zend_modules/public/xsl/ccd.xsl @@ -0,0 +1 @@ + Clinical Document Do NOT edit this HTML directly: it was generated via an XSLT transformation from a CDA Release 2 XML document. <xsl:value-of select="$title"/>




Table of Contents

  # listenerObject->z_xlt('Date'); ?> listenerObject->z_xlt('Owner'); ?>
escapeHtml($row['fname']." ".$row['lname']); ?>
Document Id
Document Created:
Confidentiality Normal Restricted Very restricted
Author ,
Contact info
Signed at
Contact info
Legal authenticator at
Contact info
Entered by
Contact info
Encounter Id Encounter Type Encounter Id
Encounter Date  at   From  to
Encounter Location of id:
Responsible party
Contact info
Document maintained by
Contact info
 at   from  to
In fulfillment of    
Informant
Contact info
Contact info
Information recipient:


Contact info
Participant from to
Contact info
Patient Date of birth
Sex Language
Race Information not available Ethnicity Information not available
Contact info Patient IDs
Related document
Consent
SetId and Version SetId: Version: