晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
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/Documents/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 Documents_Folder_Model extends Vtiger_Base_Model {
/**
* Function returns duplicate record status of the module
* @return true if duplicate records exists else false
*/
public function checkDuplicate() {
$db = PearDatabase::getInstance();
$folderName = $this->getName();
$folderId = $this->getId();
//added folder id check to support folder edit feature
$result = $db->pquery("SELECT 1 FROM vtiger_attachmentsfolder WHERE foldername = ? AND folderid != ?", array($folderName, $folderId));
$num_rows = $db->num_rows($result);
if ($num_rows > 0) {
return true;
}
return false;
}
/**
* Function returns whether documents are exist or not in that folder
* @return true if exists else false
*/
public function hasDocuments() {
$db = PearDatabase::getInstance();
$folderId = $this->getId();
$result = $db->pquery("SELECT 1 FROM vtiger_notes
INNER JOIN vtiger_attachmentsfolder ON vtiger_attachmentsfolder.folderid = vtiger_notes.folderid
INNER JOIN vtiger_crmentity ON vtiger_crmentity.crmid = vtiger_notes.notesid
WHERE vtiger_attachmentsfolder.folderid = ?
AND vtiger_attachmentsfolder.foldername != 'Default'
AND vtiger_crmentity.deleted = 0", array($folderId));
$num_rows = $db->num_rows($result);
if ($num_rows>0) {
return true;
}
return false;
}
/**
* Function to add the new folder
* @return Documents_Folder_Model
*/
public function save() {
$db = PearDatabase::getInstance();
$folderName = $this->getName();
$folderDesc = $this->get('description');
$currentUserModel = Users_Record_Model::getCurrentUserModel();
$currentUserId = $currentUserModel->getId();
if($this->get('mode') != 'edit') {
$result = $db->pquery("SELECT max(sequence) AS max, max(folderid) AS max_folderid FROM vtiger_attachmentsfolder", array());
$sequence = $db->query_result($result, 0, 'max') + 1;
$folderId = $db->query_result($result,0,'max_folderid') + 1;
$params = array($folderId,$folderName, $folderDesc, $currentUserId, $sequence);
$db->pquery("INSERT INTO vtiger_attachmentsfolder(folderid,foldername, description, createdby, sequence) VALUES(?, ?, ?, ?, ?)", $params);
$this->set('sequence', $sequence);
$this->set('createdby', $currentUserId);
$this->set('folderid',$folderId);
} else {
$db->pquery('UPDATE vtiger_attachmentsfolder SET foldername=?, description=? WHERE folderid=?', array($folderName, $folderDesc, $this->getId()));
}
return $this;
}
/**
* Function to delete existing folder
* @return Documents_Folder_Model
*/
public function delete() {
$db = PearDatabase::getInstance();
$folderId = $this->getId();
$result = $db->pquery("DELETE FROM vtiger_attachmentsfolder WHERE folderid = ? AND foldername != 'Default'", array($folderId));
return $this;
}
/**
* Function return an instance of Folder Model
* @return Documents_Folder_Model
*/
public static function getInstance() {
return new self();
}
/**
* Function returns an instance of Folder Model
* @param foldername
* @return Documents_Folder_Model
*/
public static function getInstanceById($folderId) {
$db = PearDatabase::getInstance();
$folderModel = Documents_Folder_Model::getInstance();
$result = $db->pquery("SELECT * FROM vtiger_attachmentsfolder WHERE folderid = ?", array($folderId));
$num_rows = $db->num_rows($result);
if ($num_rows > 0) {
$values = $db->query_result_rowdata($result, 0);
$folderModel->setData($values);
}
return $folderModel;
}
/**
* Function returns an instance of Folder Model
* @param <Array> row
* @return Documents_Folder_Model
*/
public static function getInstanceByArray($row) {
$folderModel = Documents_Folder_Model::getInstance();
return $folderModel->setData($row);
}
/**
* Function returns Folder's Delete url
* @return <String> - Delete Url
*/
public function getDeleteUrl() {
$folderName = $this->getName();
return "index.php?module=Documents&action=Folder&mode=delete&foldername=$folderName";
}
/**
* Function to get the id of the folder
* @return <Number>
*/
public function getId() {
return $this->get('folderid');
}
/**
* Function to get the name of the folder
* @return <String>
*/
public function getName() {
return $this->get('foldername');
}
/**
* Function to get the description of the folder
* @return <String>
*/
function getDescription() {
return $this->get('description');
}
/**
* Function to get info array while saving a folder
* @return Array info array
*/
public function getInfoArray() {
return array(
'folderName'=> $this->getName(),
'folderid' => $this->getId(),
'folderDesc'=> $this->getDescription()
);
}
}
?>