晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/akaindir/public_html/crm/modules/Project/models/ |
Upload File : |
<?php
/*+***********************************************************************************
* The contents of this file are subject to the vtiger CRM Public License Version 1.0
* ("License"); You may not use this file except in compliance with the License
* The Original Code is: vtiger CRM Open Source
* The Initial Developer of the Original Code is vtiger.
* Portions created by vtiger are Copyright (C) vtiger.
* All Rights Reserved.
*************************************************************************************/
Class Project_Record_Model extends Vtiger_Record_Model {
/**
* Function to get the summary information for module
* @return <array> - values which need to be shown as summary
*/
public function getSummaryInfo() {
$userPrivilegesModel = Users_Privileges_Model::getCurrentUserPrivilegesModel();
$projectTaskInstance = Vtiger_Module_Model::getInstance('ProjectTask');
if($userPrivilegesModel->hasModulePermission($projectTaskInstance->getId())) {
$adb = PearDatabase::getInstance();
$query ='SELECT smownerid,enddate,projecttaskstatus,projecttaskpriority
FROM vtiger_projecttask
INNER JOIN vtiger_crmentity ON vtiger_crmentity.crmid=vtiger_projecttask.projecttaskid
AND vtiger_crmentity.deleted=0
WHERE vtiger_projecttask.projectid = ? ';
$result = $adb->pquery($query, array($this->getId()));
$tasksOpen = $taskCompleted = $taskDue = $taskDeferred = $numOfPeople = 0;
$highTasks = $lowTasks = $normalTasks = $otherTasks = 0;
$currentDate = date('Y-m-d');
$inProgressStatus = array('Open', 'In Progress');
$usersList = array();
while($row = $adb->fetchByAssoc($result)) {
$projectTaskStatus = $row['projecttaskstatus'];
switch($projectTaskStatus){
case 'Open' : $tasksOpen++; break;
case 'Deferred' : $taskDeferred++; break;
case 'Completed': $taskCompleted++; break;
}
$projectTaskPriority = $row['projecttaskpriority'];
switch($projectTaskPriority){
case 'high' : $highTasks++;break;
case 'low' : $lowTasks++;break;
case 'normal' : $normalTasks++;break;
default : $otherTasks++;break;
}
if(!empty($row['enddate']) && (strtotime($row['enddate']) < strtotime($currentDate)) &&
(in_array($row['projecttaskstatus'], $inProgressStatus))) {
$taskDue++;
}
$usersList[] = $row['smownerid'];
}
$usersList = array_unique($usersList);
$numOfPeople = count($usersList);
$summaryInfo['projecttaskstatus'] = array(
'LBL_TASKS_OPEN' => $tasksOpen,
'Progress' => $this->get('progress'),
'LBL_TASKS_DUE' => $taskDue,
'LBL_TASKS_COMPLETED'=> $taskCompleted,
);
$summaryInfo['projecttaskpriority'] = array(
'LBL_TASKS_HIGH' => $highTasks,
'LBL_TASKS_NORMAL' => $normalTasks,
'LBL_TASKS_LOW' => $lowTasks,
'LBL_TASKS_OTHER' => $otherTasks,
);
}
return $summaryInfo;
}
/**
* Function to get the project task for a project
* @return <Array> - $projectTasks
*/
public function getProjectTasks() {
$recordId = $this->getId();
$db = PearDatabase::getInstance();
$sql = "SELECT projecttaskid as recordid,projecttaskname as name,startdate,enddate,projecttaskstatus FROM vtiger_projecttask
INNER JOIN vtiger_crmentity ON vtiger_projecttask.projecttaskid = vtiger_crmentity.crmid
WHERE projectid=? AND vtiger_crmentity.deleted=0 AND vtiger_projecttask.startdate IS NOT NULL AND vtiger_projecttask.enddate IS NOT NULL";
$result = $db->pquery($sql, array($recordId));
$i = -1;
while($record = $db->fetchByAssoc($result)){
$record['id'] = $i;
$record['name'] = decode_html(textlength_check($record['name']));
$record['status'] = self::getGanttStatus($record['projecttaskstatus']);
$record['start'] = strtotime($record['startdate']) * 1000;
$record['duration'] = $this->getDuration($record['startdate'], $record['enddate']);
$record['end'] = strtotime($record['enddate']) * 1000;
$projectTasks[] = $record;
$i--;
}
return $projectTasks;
}
/**
* Function to get the duration
* @param <string> $startDate,$endDate
* @return $duration
*/
public function getDuration($startDate,$endDate) {
$difference = strtotime($endDate) - strtotime($startDate);
$duration = floor($difference/(3600*24)+1);
// if the start date and end date are same
if($duration == 0) {
return $duration+0.1;
} else if($duration < 0) { // if end date is null or less than start date
return 0;
}
return $duration;
}
static public function getGanttStatus($status) {
switch($status) {
case 'Open' : return 'STATUS_UNDEFINED';
case 'In Progress' : return 'STATUS_ACTIVE';
case 'Completed' : return 'STATUS_DONE';
case 'Deferred' : return 'STATUS_SUSPENDED';
case 'Canceled' : return 'STATUS_FAILED';
default : return $status;
}
}
function getStatusColors() {
$statusColorMap = array();
$db = PearDatabase::getInstance();
$result = $db->pquery('SELECT *FROM vtiger_projecttask_status_color');
if ($db->num_rows($result) > 0) {
for ($i = 0; $i < $db->num_rows($result); $i++) {
$status = decode_html($db->query_result($result, $i, 'status'));
$color = $db->query_result($result, $i, 'color');
if (empty($color)) {
$color = $db->query_result($result, $i, 'defaultcolor');
}
$statusColorMap[$status] = $color;
}
}
return $statusColorMap;
}
static function getGanttStatusCss($status, $color) {
return '.taskStatus[status="'.self::getGanttStatus($status).'"]{
background-color: '.$color.';
}';
}
static function getGanttSvgStatusCss($status, $color) {
return '.taskStatusSVG[status="'.self::getGanttStatus($status).'"]{
fill: '.$color.';
}';
}
}
?>