MMCT TEAM
Server IP : 192.185.129.71  /  Your IP : 13.59.203.127
Web Server : Apache
System : Linux bh-ht-3.webhostbox.net 4.19.286-203.ELK.el7.x86_64 #1 SMP Wed Jun 14 04:33:55 CDT 2023 x86_64
User : svymadmin ( 4072)
PHP Version : 7.4.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON
Directory (0755) :  /home4/svymadmin/public_html/vivekaexcel.edu.in/bkp/modules/exports/services/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : /home4/svymadmin/public_html/vivekaexcel.edu.in/bkp/modules/exports/services/ContactCSVExport.php
<?php

namespace app\modules\exports\services;

use CI_DB_mysqli_driver;

class ContactCSVExport extends CSVExport
{
    private string $defaultDirection;

    public function __construct(?string $fromDate, ?string $toDate)
    {
        parent::__construct($fromDate, $toDate, 'contacts');
        $this->defaultDirection = get_option('rtl_support_client') == 1 ? 'rtl' : 'ltr';
    }

    private array $excludedFields = [
        'new_pass_key',
        'new_pass_key_requested',
        'email_verification_key',
        'email_verification_sent_at',
        'password',
        'last_password_change',
        'last_ip',
        'userid',
    ];

    public function queryData(): CI_DB_mysqli_driver
    {
        $this->ci->db->select(prefixed_table_fields_array(db_prefix() . 'contacts', true, $this->excludedFields) . ',' . get_sql_select_client_company());
        $this->selectCustomFields(db_prefix() . 'contacts.id');
        $this->ci->db->join(db_prefix() . 'clients', db_prefix() . 'clients.userid = ' . db_prefix() . 'contacts.userid', 'left');
        $this->applyDateFilter(db_prefix() . 'contacts.datecreated');

        return $this->ci->db->from(db_prefix() . 'contacts');
    }

    protected function formatRow(string $name, $value, array $row)
    {
        switch ($name) {
            case 'profile_image':
                return $this->getProfileImageUrl($row['id'], $value);
            case 'direction':
                return $value ?: $this->defaultDirection;
            default:
                return parent::formatRow($name, $value, $row);
        }
    }

    private function getProfileImageUrl(int $contactId, ?string $profileImage): ?string
    {
        if (!empty($profileImage)) {
            $path = 'uploads/client_profile_images/' . $contactId . '/small_' . $profileImage;

            if (file_exists($path)) {
                return base_url($path);
            }
        }

        return '';
    }
}

MMCT - 2023