display batch export date on contribution forms
This commit is contained in:
		@@ -1,7 +1,7 @@
 | 
				
			|||||||
<?php
 | 
					<?php
 | 
				
			||||||
 | 
					
 | 
				
			||||||
require_once 'batchexportperm.civix.php';
 | 
					require_once 'batchexportperm.civix.php';
 | 
				
			||||||
use CRM_Batchexportperm_ExtensionUtil as E;
 | 
					// use CRM_Batchexportperm_ExtensionUtil as E;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Implements hook_civicrm_config().
 | 
					 * Implements hook_civicrm_config().
 | 
				
			||||||
@@ -240,9 +240,27 @@ function _batchexportperm_civicrm_check_permission($contributionId, $errorType =
 | 
				
			|||||||
 * @param int $contributionId
 | 
					 * @param int $contributionId
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
function _batchexportperm_civicrm_allow_contribution_to_edit($contributionId) {
 | 
					function _batchexportperm_civicrm_allow_contribution_to_edit($contributionId) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  $exportDate = _getExportData($contributionId);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (!$exportDate || CRM_Core_Permission::check('edit exported contributions')) {
 | 
				
			||||||
 | 
					    return TRUE;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return FALSE;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * Given a contribution ID, return its batch export date.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @param int $contributionId
 | 
				
			||||||
 | 
					 * @return string|null This contribution's batch export date if it exists.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_post
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					function _getExportData($contributionId) {
 | 
				
			||||||
  // See if the contribution has been exported.
 | 
					  // See if the contribution has been exported.
 | 
				
			||||||
  // Man, I wish API4 actually worked.
 | 
					  // Man, I wish API4 actually worked.
 | 
				
			||||||
  $query = "SELECT ceft.entity_id "
 | 
					  $query = "SELECT cb.modified_date "
 | 
				
			||||||
  . "FROM civicrm_entity_batch ceb "
 | 
					  . "FROM civicrm_entity_batch ceb "
 | 
				
			||||||
  . "JOIN civicrm_batch cb on ceb.batch_id = cb.id AND ceb.entity_table = 'civicrm_financial_trxn' "
 | 
					  . "JOIN civicrm_batch cb on ceb.batch_id = cb.id AND ceb.entity_table = 'civicrm_financial_trxn' "
 | 
				
			||||||
  . "JOIN civicrm_entity_financial_trxn ceft ON ceft.entity_table = 'civicrm_contribution' AND ceb.entity_id = ceft.financial_trxn_id "
 | 
					  . "JOIN civicrm_entity_financial_trxn ceft ON ceft.entity_table = 'civicrm_contribution' AND ceb.entity_id = ceft.financial_trxn_id "
 | 
				
			||||||
@@ -250,12 +268,8 @@ function _batchexportperm_civicrm_allow_contribution_to_edit($contributionId) {
 | 
				
			|||||||
  . "JOIN civicrm_option_group cog ON cov.option_group_id = cog.id AND cog.name = 'batch_status' "
 | 
					  . "JOIN civicrm_option_group cog ON cov.option_group_id = cog.id AND cog.name = 'batch_status' "
 | 
				
			||||||
  . "WHERE ceft.entity_id = %1";
 | 
					  . "WHERE ceft.entity_id = %1";
 | 
				
			||||||
  $params = [1 => [$contributionId, 'Integer']];
 | 
					  $params = [1 => [$contributionId, 'Integer']];
 | 
				
			||||||
  $dao = CRM_Core_DAO::executeQuery($query, $params);
 | 
					  $date = CRM_Core_DAO::singleValueQuery($query, $params);
 | 
				
			||||||
 | 
					  return CRM_Utils_Date::customFormat($date);
 | 
				
			||||||
  if ($dao->N === 0 || CRM_Core_Permission::check('edit exported contributions')) {
 | 
					 | 
				
			||||||
    return TRUE;
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
  return FALSE;
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
@@ -278,8 +292,13 @@ function batchexportperm_civicrm_post($op, $objectName, $objectId, &$objectRef)
 | 
				
			|||||||
 * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_buildForm
 | 
					 * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_buildForm
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
function batchexportperm_civicrm_buildForm($formName, $form) {
 | 
					function batchexportperm_civicrm_buildForm($formName, $form) {
 | 
				
			||||||
  if (in_array($formName, ['CRM_Contribute_Form_ContributionView', 'CRM_Contribute_Form_Contribution']) &&
 | 
					  if ($formName == 'CRM_Contribute_Form_ContributionView' ||
 | 
				
			||||||
  !empty($form->_id)) {
 | 
					  $formName == 'CRM_Contribute_Form_Contribution' && !empty($form->_id)) {
 | 
				
			||||||
    $temp = $form->_id;
 | 
					    // ContributionView doesn't pass the ID in the form object?  Really?
 | 
				
			||||||
    $temp2 =  }
 | 
					    $contributionId = $form->_id ?? CRM_Utils_Request::retrieve('id', 'Positive');
 | 
				
			||||||
 | 
					    $exportDate = _getExportData($contributionId);
 | 
				
			||||||
 | 
					    $form->assign('exportDate', $exportDate);
 | 
				
			||||||
 | 
					    CRM_Core_Region::instance('page-body')->add(['template' => "CRM/Batchexportperm/Form/BatchDetails.tpl"]);
 | 
				
			||||||
 | 
					    CRM_Core_Resources::singleton()->addScriptFile('org.agbu.batchexportperm', 'js/exportDate.js');
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										3
									
								
								js/exportDate.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								js/exportDate.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,3 @@
 | 
				
			|||||||
 | 
					CRM.$(function ($) {
 | 
				
			||||||
 | 
					  $('#export-details-accordion').insertBefore('.crm-submit-buttons:last');
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
							
								
								
									
										16
									
								
								templates/CRM/Batchexportperm/Form/BatchDetails.tpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								templates/CRM/Batchexportperm/Form/BatchDetails.tpl
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,16 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					<div id="export-details-accordion" class="crm-accordion-wrapper">
 | 
				
			||||||
 | 
					  <div class="crm-accordion-header">
 | 
				
			||||||
 | 
					    {ts}Export Details{/ts}
 | 
				
			||||||
 | 
					    </div><!-- /.crm-accordion-header -->
 | 
				
			||||||
 | 
					    <div class="crm-accordion-body">
 | 
				
			||||||
 | 
					      <table>
 | 
				
			||||||
 | 
					        <tr class="export-details">
 | 
				
			||||||
 | 
					          <td class="label">Export Date</td>
 | 
				
			||||||
 | 
					          <td>{$exportDate}</td>
 | 
				
			||||||
 | 
					        </tr>
 | 
				
			||||||
 | 
					      </table>
 | 
				
			||||||
 | 
					    </div><!-- /.crm-accordion-body -->
 | 
				
			||||||
 | 
					  </div><!-- /.crm-accordion-wrapper -->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		Reference in New Issue
	
	Block a user