HEX
Server: Apache
System: Linux server1.royalgt4.com 4.18.0-553.89.1.lve.el8.x86_64 #1 SMP Wed Dec 10 13:58:50 UTC 2025 x86_64
User: mostafedeg (1125)
PHP: 5.6.40
Disabled: mail,passthru,parse_ini_file,show_source,eval,assert,pcntl_exec,dl,putenv,proc_open,popen
Upload Files
File: /home/mostafedeg/public_html/erp/controllers/monthlytrialbalance.php
<?php

//the global file operation
include("../public/impOpreation.php");

//global varable
global $showoutside;

//to check if the page from .htacess
//$showoutside = $_GET['sn'];
// get the config file
include_once("../public/config.php");
//Transaction
include_once("../models/sql/Transaction.class.php");
include_once("dailyentryfun.php");

//here the db files that include in the file
include("../public/include_dao.php");

//Accountstree
require_once('../models/dao/AccountstreeDAO.class.php');
require_once('../models/dto/Accountstree.class.php');
require_once('../models/mysql/AccountstreeMySqlDAO.class.php');
require_once('../models/mysql/ext/AccountstreeMySqlExtDAO.class.php');
//Accountstreesetting
require_once('../models/dao/AccountstreesettingDAO.class.php');
require_once('../models/dto/Accountstreesetting.class.php');
require_once('../models/mysql/AccountstreesettingMySqlDAO.class.php');
require_once('../models/mysql/ext/AccountstreesettingMySqlExtDAO.class.php');

require_once('../models/dao/YoutubeLinkDAO.class.php');
require_once('../models/dto/YoutubeLink.class.php');
require_once('../models/mysql/YoutubeLinkMySqlDAO.class.php');
require_once('../models/mysql/ext/YoutubeLinkMySqlExtDAO.class.php');

//get the do the action
$do = $_GET['do'];
$langs = $_SESSION['erp_lang'];
include_once("../views/languages/$langs/success.php");
include_once("../views/languages/$langs/error.php");
/* ======================

  Controller Name :- accountstree

  OPERTATION in Controller

  1- display add form, add
  2- add in tbl
  3- display show and tempdelete
  4- edit
  5- update

  ======================== */

//here the global templates
$smarty->display("header.html");

//here goes the instances and general variables
//Transaction
$transactions = new Transaction();

//Accountstree
$accountsTree = new Accountstree();
$accountsTreeDAO = new AccountstreeMySqlDAO();
$accountsTreeEX = new AccountstreeMySqlExtDAO();
//Accountstreesetting
$accountsTreeSetting = new Accountstreesetting();
$accountsTreeSettingDAO = new AccountstreesettingMySqlDAO();
$accountsTreeSettingEX = new AccountstreesettingMySqlExtDAO();

$youtubeLink = new YoutubeLink();
$youtubeLinkDAO = new YoutubeLinkMySqlDAO();
$youtubeLinkEX = new YoutubeLinkMySqlExtDAO();

$today = date("Y-m-d");


//check and use the condition that suite this action
if (empty($do)) {
    //here the permssion check
    include_once("../public/authentication.php");

    $from = filter_input(INPUT_POST, 'from');
    $to = filter_input(INPUT_POST, 'to');
    $msg = '';
    if (!isset($from) || empty($from)) {
        $from = date('Y-m-01');
    }
    if (!isset($to) || empty($to)) {
        $to = date('Y-m-t');
    }
    $msg .= "<b>من تاريخ:</b>  " . $from . " ";
    $msg .= " <b>الى تاريخ:</b>  " . $to . " ";
    $smarty->assign("msg", $msg);

    $months = getMonthsBetweenTwoDates($from, $to, 'asc');
    $smarty->assign("months", $months);
    $monthsKV = array();
    foreach ($months as $month) {
        $monthsKV[$month]['debt'] = 0;
        $monthsKV[$month]['credit'] = 0;
    }
    ##
    // here the function that do the action
    $totalDebtor = 0;
    $totalCreditor = 0;
    $balanceArray = array();
    $sum = $totalsArr = $monthsKV; //array();
    $firstPeriodDebt = $firstPeriodCredit = 0;
    //    $maxNoOfLevels = 1;
//    getMaxNoOfLevels(0, 1);
//    $levelSetting = array();
    ##make no of levels fixed =6 "now we dont count tree levels"
    $maxNoOfLevels = 6;
    for ($i = 1; $i <= $maxNoOfLevels; $i++) {
        $level = $accountsTreeSettingDAO->queryByLevelno($i);
        if (count($level) < 1) {
            $accountsTreeSetting->levelno = $i;
            $accountsTreeSetting->nooffields = 1;
            $id = $accountsTreeSettingDAO->insert($accountsTreeSetting);
            $level = $accountsTreeSettingDAO->load($id);
        } else {
            $level = $level[0];
        }
        //array_push($levelSetting, $level);
        $levelSetting[$i] = $level;
    }

    display_children(0, 0, 0, 0);  //display the tree
    $smarty->assign("totalDebtor", $totalDebtor);
    $smarty->assign("totalCreditor", $totalCreditor);
    $smarty->assign("balanceArray", $balanceArray);
    $smarty->assign("totalsArr", $totalsArr);

    $smarty->assign("showClientsAtTree", $_COOKIE['showClientsAtTree']);
    $smarty->assign("showSuppliersAtTree", $_COOKIE['showSuppliersAtTree']);

    $youtubes = $youtubeLinkDAO->queryAll();
    $smarty->assign("youtubes", $youtubes);
    //here the smarty templates
    $smarty->display("monthlytrialbalanceview/add.html");
} elseif ($do == "monitor") {
    $from = filter_input(INPUT_POST, 'from');
    $to = filter_input(INPUT_POST, 'to');
    $msg = '';
    if (!isset($from) || empty($from)) {
        $from = date('Y-m-01');
    }
    if (!isset($to) || empty($to)) {
        $to = date('Y-m-t');
    }
    $msg .= "<b>من تاريخ:</b>  " . $from . " ";
    $msg .= " <b>الى تاريخ:</b>  " . $to . " ";
    $smarty->assign("msg", $msg);

    $months = getMonthsBetweenTwoDates($from, $to, 'asc');
    $smarty->assign("months", $months);
    $monthsKV = array();
    foreach ($months as $month) {
        $monthsKV[$month]['debt'] = 0;
        $monthsKV[$month]['credit'] = 0;
    }
    ##
    // here the function that do the action
    $totalDebtor = 0;
    $totalCreditor = 0;
    $balanceArray = array();
    $sum = $totalsArr = $monthsKV; //array();
    $sumTree = 0;
    $firstPeriodDebt = $firstPeriodCredit = 0;
    //    $maxNoOfLevels = 1;
//    getMaxNoOfLevels(0, 1);
//    $levelSetting = array();
    ##make no of levels fixed =6 "now we dont count tree levels"
    $maxNoOfLevels = 6;
    for ($i = 1; $i <= $maxNoOfLevels; $i++) {
        $level = $accountsTreeSettingDAO->queryByLevelno($i);
        if (count($level) < 1) {
            $accountsTreeSetting->levelno = $i;
            $accountsTreeSetting->nooffields = 1;
            $id = $accountsTreeSettingDAO->insert($accountsTreeSetting);
            $level = $accountsTreeSettingDAO->load($id);
        } else {
            $level = $level[0];
        }
        //array_push($levelSetting, $level);
        $levelSetting[$i] = $level;
    }

    display_children(0, 0, 0, 0);  //display the tree
    $smarty->assign("totalDebtor", $totalDebtor);
    $smarty->assign("totalCreditor", $totalCreditor);
    $smarty->assign("balanceArray", $balanceArray);
    $smarty->assign("totalsArr", $totalsArr);

    $smarty->assign("showClientsAtTree", $_COOKIE['showClientsAtTree']);
    $smarty->assign("showSuppliersAtTree", $_COOKIE['showSuppliersAtTree']);

    $youtubes = $youtubeLinkDAO->queryAll();
    $smarty->assign("youtubes", $youtubes);
    //here the smarty templates
    $smarty->display("monthlytrialbalanceview/monitor.html");
} elseif ($do == "sucess") {
    //here the smarty templates
    $smarty->display("succes.html");
} elseif ($do == "error") {
    //here the smarty templates
    $smarty->display("error.html");
}
//here the global templates
$smarty->display("footer.html");

/* ===============================
  function in this CONTROLLER
  ================================ */

function display_children($parent, $level, $itr, $itr2) {//$itr is itr without zeros  , $itr2 wit zeros
    global $accountsTreeDAO;
    global $accountsTreeEX;
    global $accountsTreeSettingDAO;
    global $outputString;
    global $sum;
    global $sumTree;
    global $levelSetting;
    global $maxNoOfLevels;

    global $balanceArray;
    global $totalDebtor;
    global $totalCreditor;
    global $monthsKV, $totalsArr;
    global $firstPeriodDebt, $firstPeriodCredit;

    //note: url of tree ##http://jsfiddle.net/jhfrench/GpdgF/
    // retrieve all children of $parent
    $result = $accountsTreeEX->queryByParentExt($parent);
    if (count($result) > 0) {
        // display each child
        $i = 1;
        foreach ($result as $type) {
            //generte laying order  "use a method from the two coming"
            $preDigits = '';
            if (strlen($i) != $levelSetting[($level + 1)]->nooffields) {
                $noDigitsLeft = $levelSetting[($level + 1)]->nooffields - strlen($i);
                for ($j = 0; $j < $noDigitsLeft; $j++) {
                    $preDigits .= '0';
                }
            }

            if ($itr == 0) {
                $nodeName = $preDigits . $i; //. $type->id;
            } else {
                $nodeName = $itr . $preDigits . $i; //. $type->id;
            }
            //fill remaining with zeros to the right // optional
            $nodeNameWithZeros = $nodeName;
//            for ($ii = ($level + 2); $ii <= $maxNoOfLevels; $ii++) {
//                for ($j = 0; $j < $levelSetting[$ii]->nooffields; $j++) {
//                    $nodeNameWithZeros .= '0';
//                }
//            }
            //----------------------------------------------------------------
            //make sure node name is saved in db for searching purpose
            if ($nodeNameWithZeros !== $type->layingOrder) {
                R::exec('update accountstree set layingOrder =' . $nodeNameWithZeros . ' where id= ' . $type->id);
//                $type->layingOrder = $nodeNameWithZeros;
//                $accountsTreeDAO->update($type);
            }
            //
//            exportToExcel($type, $level);
            //
            $preString = '';
            for ($index = 0; $index < $level; $index++) {
                $preString .= '&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;';
            }
            $type->customName = $preString . '<strong>' . $nodeName . '</strong> ' . $type->customName;

//            if ($type->theValue > 0) {
//                $totalDebtor += $type->theValue;
//            }
//            if ($type->theValue < 0) {
//                $totalCreditor += $type->theValue;
//            }
            //check for expenses for this category
            $childDataCount = R::getCell('select count(*) as c from accountstree where parent = ' . $type->id);
            if ($childDataCount > 0) {
                $sum = $monthsKV; //array();
                getTheTrueValue($type->id, $sum);
                $type->theValue = (float) $type->theValue;
                $type->theValue2 = $sum;
                $type->theValue3 = getTheTrueValueProgram($type->id);
                $type->islastLeaf = 0;

                ##
                $firstPeriodDebt = $firstPeriodCredit = 0;
                getFirstPeriodValOfParent($type->id);

                $type->firstPeriodDebtor = $firstPeriodDebt;
                $type->firstPeriodCreditor = $firstPeriodCredit;
            } else {
                $sum = $monthsKV; //array();
                getTheTrueValueLastLeaf($type->id, $sum);
                list($type->firstPeriodDebtor, $type->firstPeriodCreditor) = getFirstPeriodValLastLeaf($type->id);
                $type->theValue = (float) $type->theValue;
                $type->theValue2 = $sum;
                $type->theValue3 = getTheTrueValueProgram($type->id);
                $type->islastLeaf = 1;
                foreach ($totalsArr as $month => $arr) {
                    $totalsArr[$month]['debt'] += (float) $sum[$month]['debt'];
                    $totalsArr[$month]['credit'] += (float) $sum[$month]['credit'];
                }
                $totalsArr['firstPeriodDebtor'] += $type->firstPeriodDebtor;
                $totalsArr['firstPeriodCreditor'] += $type->firstPeriodCreditor;
            }
            //get debt,credit val of sum as they are hidden
            if (($_COOKIE['showClientsAtTree'] == 0 && ($type->id == 58 || $type->id == 60)) || ($_COOKIE['showSuppliersAtTree'] == 0 && ($type->id == 81 || $type->id == 87))) {
                ##
                $firstPeriodDebt = $firstPeriodCredit = 0;
                getFirstPeriodValOfParent($type->id);
                $type->firstPeriodDebtor = $firstPeriodDebt;
                $type->firstPeriodCreditor = $firstPeriodCredit;
                //as they are hidden , not added as leaf as it has children , add it now
                foreach ($totalsArr as $month => $arr) {
                    $totalsArr[$month]['debt'] += (float) $sum[$month]['debt'];
                    $totalsArr[$month]['credit'] += (float) $sum[$month]['credit'];
                }
                $totalsArr['firstPeriodDebtor'] += $type->firstPeriodDebtor;
                $totalsArr['firstPeriodCreditor'] += $type->firstPeriodCreditor;

                $sumTree = 0;
                getTheTrueValueTree($type->id, $sumTree);
                $type->theValue = $sumTree;
            }

            $i++;
//            var_dump($type);
            array_push($balanceArray, $type);

            if (($_COOKIE['showClientsAtTree'] == 0 && ($type->id == 58 || $type->id == 60)) || ($_COOKIE['showSuppliersAtTree'] == 0 && ($type->id == 81 || $type->id == 87))) {
                //do noting.
            } else if ($childDataCount > 0) {
                display_children($type->id, $level + 1, $nodeName, $nodeNameWithZeros);
            }
        }
    }


    return $outputString;
}

function getTheTrueValue($parent, $sum) {
    global $accountsTreeEX;
    global $sum;
    global $from, $to;

    if (($_COOKIE['showClientsAtTree'] == 0 && ($parent == 58 || $parent == 60)) || ($_COOKIE['showSuppliersAtTree'] == 0 && ($parent == 81 || $parent == 87))) {

        list($debtor, $creditor) = getDailyEntrySumByParentAndDate($parent, $from, $to);
        foreach ($sum as $month => $arr) {
            $sum[$month]['debt'] += (float) $debtor[$month]['debtorVal'];
            $sum[$month]['credit'] += (float) $creditor[$month]['creditorVal'];
        }
//        $lastNodeSum = (float) $accountsTreeEX->getLastNodeSumById($parent);
//        $sum += $lastNodeSum;
//    } else if ($_COOKIE['calTreeNodes'] == 1) {
    } else {
        $result = R::getAll('select id,theValue from accountstree where parent = ' . $parent);
        foreach ($result as $type) {
            list($debtor, $creditor) = getDailyEntrySumByAccountIdAndDate($type['id'], $from, $to);
            foreach ($sum as $month => $arr) {
                $sum[$month]['debt'] += (float) $debtor[$month]['debtorVal'];
                $sum[$month]['credit'] += (float) $creditor[$month]['creditorVal'];
            }
            //$sum += $type['theValue'];
            getTheTrueValue($type['id'], $sum);
        }
    }
}

function getTheTrueValueLastLeaf($accountId, $sum) {
    global $sum;
    global $from, $to;

    list($debtor, $creditor) = getDailyEntrySumByAccountIdAndDate($accountId, $from, $to);
    foreach ($sum as $month => $arr) {
        $sum[$month]['debt'] += (float) $debtor[$month]['debtorVal'];
        $sum[$month]['credit'] += (float) $creditor[$month]['creditorVal'];
    }
}

function getFirstPeriodValLastLeaf($accountId) {
    global $from;

    list($debtor, $creditor) = getFirstPeriodValUsingDailyEntry($accountId, $from);
    return array($debtor, $creditor);
}

function getFirstPeriodValLastLeafByParent($accountId) {
    global $from;

    list($debtor, $creditor) = getFirstPeriodValUsingDailyEntryByParent($accountId, $from);
    return array($debtor, $creditor);
}

function getFirstPeriodValOfParent($accountId) {
    global $from, $firstPeriodDebt, $firstPeriodCredit;

    $parent = $accountId;
    if (($_COOKIE['showClientsAtTree'] == 0 && ($parent == 58 || $parent == 60)) || ($_COOKIE['showSuppliersAtTree'] == 0 && ($parent == 81 || $parent == 87))) {
        list($debtor, $creditor) = getFirstPeriodValLastLeafByParent($parent, $from);
        $firstPeriodDebt += $debtor;
        $firstPeriodCredit += $creditor;
    } else {
        $result = R::getAll('select id,theValue from accountstree where parent = ' . $parent);
        foreach ($result as $type) {
            list($debtor, $creditor) = getFirstPeriodValUsingDailyEntry($type['id'], $from);
            $firstPeriodDebt += $debtor;
            $firstPeriodCredit += $creditor;
            getFirstPeriodValOfParent($type['id']);
        }
    }
}

function getMonthsBetweenTwoDates($from, $to, $order = 'asc') {
    $ret = array();
    if ($from < $to) {
        $current = $from;
        $ret[] = date("Y-m", strtotime($current));
        while ($current < $to) {
            $next = date("Y-m-d", strtotime("+1 month", strtotime($current)));
            if ($next < $to) {
                $ret[] = date("Y-m", strtotime($next));
            }
            $current = $next;
        }
    }

    ##ret
    if ($order == 'asc') {
        return $ret;
    } else {
        return array_reverse($ret);
    }
}

function getDailyEntrySumByParentAndDate($parent, $from, $to) {
    $debtor = R::getAll('select DATE_FORMAT(thedate, "%Y-%m") AS thedate,sum(value) as debtorVal
                        from dailyentry
                        join dailyentrydebtor on dailyentrydebtor.dailyentryid = dailyentry.id
                        join accountstree on accountstree.id=dailyentrydebtor.accountstreeid
                        where `condition`=0 and parent=' . $parent . ' and thedate >= "' . $from . '" and thedate <= "' . $to . '"
                        group by MONTH(thedate),YEAR(thedate)'); // order by thedate desc

    $creditor = R::getAll('select DATE_FORMAT(thedate, "%Y-%m") AS thedate,sum(value) as creditorVal
                        from dailyentry
                        join dailyentrycreditor on dailyentrycreditor.dailyentryid = dailyentry.id
                        join accountstree on accountstree.id=dailyentrycreditor.accountstreeid
                        where `condition`=0 and parent=' . $parent . ' and thedate >= "' . $from . '" and thedate <= "' . $to . '"
                        group by MONTH(thedate),YEAR(thedate)'); // order by thedate desc

    $debtorArr = customArrayIndexOne($debtor, 'thedate');
    $creditorArr = customArrayIndexOne($creditor, 'thedate');
    return array($debtorArr, $creditorArr);
}

function getDailyEntrySumByAccountIdAndDate($accountId, $from, $to) {
    $debtor = R::getAll('select DATE_FORMAT(thedate, "%Y-%m") AS thedate,sum(value) as debtorVal
                        from dailyentry
                        join dailyentrydebtor on dailyentrydebtor.dailyentryid = dailyentry.id
                        where `condition`=0 and accountstreeid=' . $accountId . ' and thedate >= "' . $from . '" and thedate <= "' . $to . '"
                        group by MONTH(thedate),YEAR(thedate)'); // order by thedate desc

    $creditor = R::getAll('select DATE_FORMAT(thedate, "%Y-%m") AS thedate,sum(value) as creditorVal
                        from dailyentry
                        join dailyentrycreditor on dailyentrycreditor.dailyentryid = dailyentry.id
                        where `condition`=0 and accountstreeid=' . $accountId . ' and thedate >= "' . $from . '" and thedate <= "' . $to . '"
                        group by MONTH(thedate),YEAR(thedate)'); // order by thedate desc

    $debtorArr = customArrayIndexOne($debtor, 'thedate');
    $creditorArr = customArrayIndexOne($creditor, 'thedate');
    return array($debtorArr, $creditorArr);
}

function getFirstPeriodValUsingDailyEntry($accountId, $from) {
    $debtor = R::getCell('select sum(value) as debtorVal
                        from dailyentry
                        join dailyentrydebtor on dailyentrydebtor.dailyentryid = dailyentry.id
                        where `condition`=0 and accountstreeid=' . $accountId . ' and thedate < "' . $from . '" ');

    $creditor = R::getCell('select sum(value) as creditorVal
                        from dailyentry
                        join dailyentrycreditor on dailyentrycreditor.dailyentryid = dailyentry.id
                        where `condition`=0 and accountstreeid=' . $accountId . ' and thedate < "' . $from . '" ');

    return array($debtor, $creditor);
}

function getFirstPeriodValUsingDailyEntryByParent($accountId, $from) {
    $debtor = R::getCell('select sum(value) as debtorVal
                        from dailyentry
                        join dailyentrydebtor on dailyentrydebtor.dailyentryid = dailyentry.id
                        join accountstree on accountstree.id=dailyentrydebtor.accountstreeid
                        where `condition`=0 and parent=' . $accountId . ' and thedate < "' . $from . '" ');

    $creditor = R::getCell('select sum(value) as creditorVal
                        from dailyentry
                        join dailyentrycreditor on dailyentrycreditor.dailyentryid = dailyentry.id
                        join accountstree on accountstree.id=dailyentrycreditor.accountstreeid
                        where `condition`=0 and parent=' . $accountId . ' and thedate < "' . $from . '" ');

    return array($debtor, $creditor);
}

//-- --------------------------------------------
function getTheTrueValueTree($parent, $sumTree) {
    global $accountsTreeDAO;
    global $accountsTreeEX;
    global $sumTree;

    if (($_COOKIE['showClientsAtTree'] == 0 && ($parent == 58 || $parent == 60)) || ($_COOKIE['showSuppliersAtTree'] == 0 && ($parent == 81 || $parent == 87))) {
        $lastNodeSum = (float) $accountsTreeEX->getLastNodeSumById($parent);
        $sumTree += $lastNodeSum;
        //    } else if ($_COOKIE['calTreeNodes'] == 1) {
    } else {
        $result = R::getAll('select id,theValue from accountstree where parent = ' . $parent);
        foreach ($result as $type) {
            $sumTree += $type['theValue'];
            getTheTrueValueTree($type['id'], $sumTree);
        }
    }
}

function getTheTrueValueProgram($treeId) {
    global $do;
    global $pluginMapArr;

    $val = '';
    if ($do == "monitor") {
        $whatIsIt = whatIsIt($treeId);
        switch ($whatIsIt) {
            case 'save'://save
            case '3ohad'://3ohad
                if ($treeId == $pluginMapArr['save']) {
                    $val = (float) R::getCell('select sum(savecurrentvalue) from save where conditions=0 and saveTreeParentType=0');
                } elseif ($treeId == $pluginMapArr['3ohad']) {
                    $val = (float) R::getCell('select sum(savecurrentvalue) from save where conditions=0 and saveTreeParentType=1');
                } else {
                    $val = (float) R::getCell('select savecurrentvalue from save where treeId=' . $treeId);
                }
                break;
            case 'bank'://bank
                if ($treeId == $pluginMapArr['bank']) {
                    $val = (float) R::getCell('select sum(accountbeginingbalance) from bankaccount where conditions=0');
                } else {
                    $val = (float) R::getCell('select accountbeginingbalance from bankaccount where treeId=' . $treeId);
                }

                break;
            case 'client'://client
                if ($treeId == $pluginMapArr['client'] || $treeId == 58 || $treeId == 60) {
                    $val = (float) R::getCell('select sum(clientdebt) from client where conditions=0');
                } else {
                    $val = (float) R::getCell('select clientdebt from client where treeId=' . $treeId);
                }
                break;
            case 'supplier'://spplier
                if ($treeId == $pluginMapArr['supplier'] || $treeId == 81 || $treeId == 87) {
                    $val = (float) R::getCell('select sum(suppliercurrentDebt) from supplier where conditions=0');
                } else {
                    $val = (float) R::getCell('select suppliercurrentDebt from supplier where treeId=' . $treeId);
                }
                break;
            case 'expenses'://expenses//مصروفات
                $id = R::getCell('select expensestypeid from expensestype where  treeId=' . $treeId);
                if ($id > 0) {
                    $val = (float) R::getCell('select sum(expensesValue) from expenses where expensestypeid=(select expensestypeid from expensestype where treeId=' . $treeId . ')');
                }
                break;
            case 'income'://income//ايرادات
                if ($treeId == $pluginMapArr['income']) {
                    $val = (float) R::getCell('select sum(incomeValue) from income where conditions=0');
                } else {
                    $val = (float) R::getCell('select sum(incomeValue) from income where incomeTypeId=(select incomeTypeId from incometype where treeId=' . $treeId . ')');
                }
                break;
            case 'asset'://asset    osool//اصول
                $id = R::getCell('select assetId from assets where  treeId=' . $treeId);
                if ($id > 0) {
                    $val = (float) R::getCell('select sum(assetsValue) from assets where treeId=' . $treeId);
                } else {
                    if ($treeId == $pluginMapArr['asset']) {
                        $val = (float) R::getCell('select sum(assetsValue) from assets where conditions=0');
                    } else {
                        $val = (float) R::getCell('select sum(assetsValue) from assets where assetscatid=(select assetscatid from assetscat where treeId=' . $treeId . ')');
                    }
                }
                break;
            case 'capital'://ras elmal    راس المال
                $val = (float) R::getCell('select capitalamount from capital');
                break;
            case 'partner'://partner  الشركاء
                if ($treeId == $pluginMapArr['partner']) {
                    $val = (float) R::getCell('select sum(partnermoney) from partner where conditions=0');
                } else {
                    $val = (float) R::getCell('select partnermoney from partner where treeId=' . $treeId);
                }
                break;
            default:
                break;
        }
    }
    return $val;
}

?>