You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
861 lines
30 KiB
861 lines
30 KiB
<?php
|
|
/**
|
|
*
|
|
*/
|
|
include_once(SERVER_ROOT . "/model/mBase.php");
|
|
|
|
|
|
class mFormula extends mBase {
|
|
private $obj;
|
|
private $tbl;
|
|
private $formula_herb_tbl;
|
|
private $herb_tbl;
|
|
private $collect_log_tbl;
|
|
private $formula_use_log_tbl;
|
|
private $unit_conv;
|
|
private $user_conv;
|
|
|
|
public function __construct() {
|
|
$this->obj = new dFormula();
|
|
$this->tbl = 'tcm_formula';
|
|
$this->formula_herb_tbl = 'tcm_formula_herb';
|
|
$this->herb_tbl = 'tcm_herb';
|
|
$this->collect_log_tbl = 'tcm_collect_log';
|
|
$this->formula_use_log_tbl = 'tcm_formula_use_log';
|
|
$this->unit_conv = 'tcm_unit_conv';
|
|
$this->user_conv = 'tcm_user_conv';
|
|
}
|
|
|
|
public function searchFormulaList($condition, $page_num, $page_size) {
|
|
$offset = ($page_num - 1) * $page_size;
|
|
|
|
$uid = 0;
|
|
$where = "1=1";
|
|
if (!empty($condition)) {
|
|
foreach ($condition as $key => $val) {
|
|
if ($key == 'name') {
|
|
$where .= " and s.{$key} like '%{$val}%'";
|
|
} elseif ($key == 'uid') {
|
|
$uid = $val;
|
|
$where .= " and s.{$key} in (0,{$val})";
|
|
} elseif (is_array($val)) {
|
|
$val = implode(',', $val);
|
|
$where .= " and s.{$key} in ({$val})";
|
|
} else {
|
|
$where .= " and s.{$key}={$val}";
|
|
}
|
|
}
|
|
}
|
|
|
|
$sql = "select s.*,COALESCE(u.use_num, 0) AS use_num from {$this->tbl} as s left join {$this->formula_use_log_tbl} as u on s.id=u.formula_id and u.uid={$uid} where {$where} group by s.id order by use_num desc,s.sort desc,s.id asc limit {$offset},{$page_size}";
|
|
$data = $this->obj->execute($sql, true, true);
|
|
|
|
$formula_ids = array_column($data, 'id');
|
|
$formula_arr = $this->getFormulaHerbData($formula_ids);
|
|
|
|
$unit_conv = array();
|
|
$user_conv = $this->getUserConvList($uid);
|
|
if ($user_conv) {
|
|
$conv_ids = array_column($user_conv, 'conv_id');
|
|
if ($conv_ids) {
|
|
$unit_conv = $this->getUnitConvByIds($conv_ids);
|
|
$unit_conv = array_column($unit_conv, null, 'unit_type');
|
|
}
|
|
}
|
|
|
|
foreach ($data as &$da) {
|
|
if (isset($formula_arr[$da['id']])) $da['formula'] = $formula_arr[$da['id']];
|
|
|
|
//原方信息
|
|
if (!empty($da['original'])) {
|
|
$original = json_decode($da['original'], true);
|
|
$original = array_column($original, null, 'name');
|
|
|
|
foreach ($da['formula'] as &$v) {
|
|
if (isset($original[$v['name']])) {
|
|
$num = $this->convByUserChoice($original[$v['name']]['num'], $unit_conv);
|
|
if ($num) $v['num'] = $num;
|
|
|
|
$v['num_str'] = $original[$v['name']]['num'];
|
|
$v['desc'] = $original[$v['name']]['desc'];
|
|
}
|
|
}
|
|
}
|
|
unset($da['original']);
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function convByUserChoice($num_str, $unit_conv) {
|
|
if (!$unit_conv) return false;
|
|
|
|
$unit_name = preg_replace('/\d/', '', $num_str);
|
|
|
|
$unit_type = array_search($unit_name, $GLOBALS['weight_convert_list']);
|
|
if (!$unit_type) return false;
|
|
if (!isset($unit_conv[$unit_type])) return false;
|
|
|
|
$unit_num = filter_var($num_str, FILTER_SANITIZE_NUMBER_INT);
|
|
$conv_num = $unit_conv[$unit_type]['num'];
|
|
|
|
$num = $unit_num * $conv_num;
|
|
if (!$num) return false;
|
|
|
|
return $num;
|
|
}
|
|
|
|
public function searchFormulaTotal($condition) {
|
|
$where = "1=1";
|
|
if (!empty($condition)) {
|
|
foreach ($condition as $key => $val) {
|
|
if ($key == 'name') {
|
|
$where .= " and {$key} like '%{$val}%'";
|
|
} elseif ($key == 'uid') {
|
|
$where .= " and {$key} in (0,{$val})";
|
|
} elseif (is_array($val)) {
|
|
$val = implode(',', $val);
|
|
$where .= " and {$key} in ({$val})";
|
|
} else {
|
|
$where .= " and {$key}={$val}";
|
|
}
|
|
}
|
|
}
|
|
|
|
$sql = "select count(*) as count from $this->tbl where {$where}";
|
|
$res = $this->obj->execute($sql, true, true);
|
|
$num = $res[0]['count'];
|
|
|
|
return $num;
|
|
}
|
|
|
|
public function getUserFormulaList($condition, $page_num, $page_size) {
|
|
$offset = ($page_num - 1) * $page_size;
|
|
|
|
$uid = 0;
|
|
$where = "1=1";
|
|
if (!empty($condition)) {
|
|
foreach ($condition as $key => $val) {
|
|
if ($key == 'uid') $uid = $val;
|
|
|
|
if ($key == 'name') {
|
|
$where .= " and s.{$key} like '%{$val}%'";
|
|
} elseif (is_array($val)) {
|
|
$val = implode(',', $val);
|
|
$where .= " and s.{$key} in ({$val})";
|
|
} else {
|
|
$where .= " and s.{$key}={$val}";
|
|
}
|
|
}
|
|
}
|
|
|
|
$sql = "select s.*,COALESCE(u.use_num, 0) AS use_num from {$this->tbl} as s left join {$this->formula_use_log_tbl} as u on s.id=u.formula_id and u.uid={$uid} where {$where} group by s.id order by use_num desc,s.sort desc,s.id desc limit {$offset},{$page_size}";
|
|
return $this->obj->execute($sql, true, true);
|
|
}
|
|
|
|
public function getUserFormulaTotal($condition) {
|
|
$where = "1=1";
|
|
if (!empty($condition)) {
|
|
foreach ($condition as $key => $val) {
|
|
if ($key == 'name') {
|
|
$where .= " and {$key} like '%{$val}%'";
|
|
} elseif (is_array($val)) {
|
|
$val = implode(',', $val);
|
|
$where .= " and {$key} in ({$val})";
|
|
} else {
|
|
$where .= " and {$key}={$val}";
|
|
}
|
|
}
|
|
}
|
|
|
|
$sql = "select count(*) as count from $this->tbl where {$where}";
|
|
$res = $this->obj->execute($sql, true, true);
|
|
$num = $res[0]['count'];
|
|
|
|
return $num;
|
|
}
|
|
|
|
public function getFormulaList($condition, $page_num, $page_size) {
|
|
$offset = ($page_num - 1) * $page_size;
|
|
|
|
$where = "1=1 ";
|
|
if (!empty($condition)) {
|
|
foreach ($condition as $key => $val) {
|
|
if ($key == 'name') {
|
|
$where .= " and {$key} like '%{$val}%'";
|
|
} elseif (is_array($val)) {
|
|
$val = implode(',', $val);
|
|
$where .= " and {$key} in ({$val})";
|
|
} else {
|
|
$where .= " and {$key}={$val}";
|
|
}
|
|
}
|
|
}
|
|
|
|
$data = $this->obj->selectAll($this->tbl, array('sql' => $where, 'vals' => array()), 'id desc ', array($offset, $page_size));
|
|
|
|
$formula_ids = array_column($data, 'id');
|
|
$formula_arr = $this->getFormulaHerbData($formula_ids);
|
|
|
|
foreach ($data as &$da) {
|
|
if (isset($formula_arr[$da['id']])) $da['formula'] = $formula_arr[$da['id']];
|
|
|
|
//原方信息
|
|
if (!empty($da['original'])) {
|
|
$original = json_decode($da['original'], true);
|
|
$original = array_column($original, null, 'name');
|
|
|
|
foreach ($da['formula'] as &$v) {
|
|
if (isset($original[$v['name']])) {
|
|
$v['num_str'] = $original[$v['name']]['num'];
|
|
$v['desc'] = $original[$v['name']]['desc'];
|
|
}
|
|
}
|
|
}
|
|
unset($da['original']);
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function getFormulaTotal($condition) {
|
|
$where = "1=1 ";
|
|
if (!empty($condition)) {
|
|
foreach ($condition as $key => $val) {
|
|
if ($key == 'name') {
|
|
$where .= " and {$key} like '%{$val}%'";
|
|
} elseif (is_array($val)) {
|
|
$val = implode(',', $val);
|
|
$where .= " and {$key} in ({$val})";
|
|
} else {
|
|
$where .= " and {$key}={$val}";
|
|
}
|
|
}
|
|
}
|
|
|
|
return $this->obj->count($this->tbl, array('sql' => $where, 'vals' => array()));
|
|
}
|
|
|
|
public function getFormulaById($id) {
|
|
return $this->obj->select($this->tbl, array('sql' => '`id`=?', 'vals' => array($id)));
|
|
}
|
|
|
|
public function getHerbs($ids) {
|
|
return $this->obj->selectIn($this->herb_tbl, array('id' => $ids));
|
|
}
|
|
|
|
public function getFormulasHerb($formula_ids) {
|
|
$data = $this->obj->selectIn($this->formula_herb_tbl, array('formula_id' => $formula_ids));
|
|
if (empty($data)) return array();
|
|
return array_column($data, null, 'id');
|
|
}
|
|
|
|
public function getFormulaHerbData($formula_ids) {
|
|
$formula_herbs = $this->getFormulasHerb($formula_ids);
|
|
|
|
$herb_ids = array_column($formula_herbs, 'herb_id');
|
|
$herbs = $this->getHerbs($herb_ids);
|
|
$herb_arr = array_column($herbs, null, 'id');
|
|
|
|
$formula_arr = array();
|
|
foreach ($formula_herbs as $formula_herb) {
|
|
$formula_arr[$formula_herb['formula_id']][] = array(
|
|
'id' => $formula_herb['herb_id'],
|
|
'name' => $herb_arr[$formula_herb['herb_id']]['name'],
|
|
'num' => $formula_herb['num'],
|
|
//'desc' => $formula_herb['desc'],
|
|
'num_str' => $formula_herb['num'] . 'g',
|
|
);
|
|
}
|
|
return $formula_arr;
|
|
}
|
|
|
|
public function getFormulaInfo($id, $uid) {
|
|
//药方信息
|
|
$formula = $this->getFormulaById($id);
|
|
if (empty($formula)) {
|
|
$this->setError('抱歉,未找到匹配的药方');
|
|
return false;
|
|
}
|
|
|
|
//自拟药方 判断药方归属
|
|
if ($uid > 0 && $formula['uid'] > 0 && $formula['uid'] != $uid) {
|
|
$this->setError('抱歉,这不是你的药方');
|
|
return false;
|
|
}
|
|
|
|
//获取药方药材信息
|
|
$formula_arr = $this->getFormulaHerbData(array($formula['id']));
|
|
$formulaHerb = $formula_arr[$formula['id']];
|
|
|
|
$original = $formula['original'];
|
|
unset($formula['original']);
|
|
|
|
if (empty($original)) {
|
|
$formula['formula'] = $formulaHerb;
|
|
return $formula;
|
|
}
|
|
|
|
$unit_conv = array();
|
|
$user_conv = $this->getUserConvList($uid);
|
|
if ($user_conv) {
|
|
$conv_ids = array_column($user_conv, 'conv_id');
|
|
if ($conv_ids) {
|
|
$unit_conv = $this->getUnitConvByIds($conv_ids);
|
|
$unit_conv = array_column($unit_conv, null, 'unit_type');
|
|
}
|
|
}
|
|
|
|
//原方信息
|
|
$original = json_decode($original, true);
|
|
$original = array_column($original, null, 'name');
|
|
foreach ($formulaHerb as &$v) {
|
|
if (isset($original[$v['name']])) {
|
|
$num = $this->convByUserChoice($original[$v['name']]['num'], $unit_conv);
|
|
if ($num) $v['num'] = $num;
|
|
|
|
$v['num_str'] = $original[$v['name']]['num'];
|
|
$v['desc'] = $original[$v['name']]['desc'];
|
|
}
|
|
}
|
|
|
|
$formula['formula'] = $formulaHerb;
|
|
return $formula;
|
|
}
|
|
|
|
public function convOriginal($original) {
|
|
$herbString_arr = explode(' ', $original);
|
|
|
|
$num_map = $GLOBALS['num_list'];
|
|
$num_list = implode('', array_keys($num_map));
|
|
|
|
$herb_arr = array();
|
|
foreach ($herbString_arr as $herbString) {
|
|
$pattern = '/^(.)(.*?)([' . $num_list . ']+)([^(]*)?((.*?))?/u';
|
|
preg_match($pattern, $herbString, $matches);
|
|
|
|
if ($matches) {
|
|
$herb_name = str_replace(array('(', ')'), '', trim($matches[1] . $matches[2]));
|
|
$herb_num = str_replace(array('(', ')'), '', trim($matches[3] . $matches[4]));
|
|
$herb_desc = isset($matches[5]) ? str_replace(array('(', ')'), '', trim($matches[5])) : "";
|
|
|
|
$herb_arr[] = array(
|
|
'herb_name' => $herb_name,
|
|
'herb_num' => $herb_num,
|
|
'herb_desc' => $herb_desc,
|
|
);
|
|
} else {
|
|
$herb_arr[] = array(
|
|
'herb_name' => $herbString,
|
|
'herb_num' => "",
|
|
'herb_desc' => "",
|
|
);
|
|
}
|
|
}
|
|
|
|
return $herb_arr;
|
|
}
|
|
|
|
public function convToNumber($str) {
|
|
$num_map = $GLOBALS['num_list'];
|
|
$num_list = implode('', array_keys($num_map));
|
|
preg_match_all('/[' . $num_list . ']+/u', $str, $matches);
|
|
|
|
foreach ($matches[0] as $chinese) {
|
|
$result = 0;
|
|
$current = 0; // 当前的数字
|
|
|
|
for ($i = 0; $i < mb_strlen($chinese); $i++) {
|
|
$char = mb_substr($chinese, $i, 1);
|
|
|
|
if (isset($num_map[$char])) {
|
|
$num = $num_map[$char];
|
|
if ($num == 10) {
|
|
// 如果是“十”
|
|
if ($current == 0) {
|
|
$current = 1; // 处理“十”前没有数字的情况
|
|
}
|
|
$result += $current * 10; // 将当前数字乘以十
|
|
$current = 0; // 重置当前数字
|
|
} else {
|
|
$current += $num; // 累加当前数字
|
|
}
|
|
}
|
|
}
|
|
$result = $result + $current;
|
|
|
|
$str = str_replace($chinese, $result, $str);
|
|
}
|
|
return $str;
|
|
}
|
|
|
|
public function convertToNum($herb_name, $str, $onlyconertNum = true, $from = '汉') {
|
|
$num_list = $GLOBALS['num_list'];
|
|
$num_list_arr = array_merge(array_keys($GLOBALS['num_list']['num']), array_keys($GLOBALS['num_list']['unit']));
|
|
|
|
$weight_list = $GLOBALS['weight_list'][$from];
|
|
$weight_list_arr = array_keys($GLOBALS['weight_list'][$from]);
|
|
|
|
//计量数字
|
|
$num_str = str_replace($weight_list_arr, '', $str);
|
|
|
|
//计量单位
|
|
$unit = str_replace($num_list_arr, '', $str);
|
|
//计量单位
|
|
$unit = str_replace($num_str, '', $unit);
|
|
|
|
//非数字转换
|
|
$num = $num_str;
|
|
if (!is_numeric($num) && $num) {
|
|
$num = 0;
|
|
$temp = 0;
|
|
|
|
$length = mb_strlen($num_str);
|
|
for ($i = 0; $i < $length; $i++) {
|
|
$char = mb_substr($num_str, $i, 1);
|
|
if (isset($num_list['num'][$char])) {
|
|
$temp += $num_list['num'][$char];
|
|
} elseif (isset($num_list['unit'][$char])) {
|
|
$temp = ($temp == 0 ? 1 : $temp) * $num_list['unit'][$char];
|
|
$num += $temp; // 将临时结果累加到最终结果中
|
|
$temp = 0; // 重置临时结果
|
|
}
|
|
}
|
|
|
|
$num += $temp;
|
|
}
|
|
|
|
//只将汉字数字转换成number
|
|
if ($onlyconertNum) {
|
|
return $num . $unit;
|
|
}
|
|
|
|
//单位换算 直接换算成克数
|
|
$weight = isset($weight_list[$unit]) ? $weight_list[$unit] : 0;
|
|
if (isset($weight[$herb_name])) $weight = $weight[$herb_name];
|
|
if (!is_numeric($weight)) $weight = 0;
|
|
|
|
return $num * $weight;
|
|
}
|
|
|
|
public function getHerb($name) {
|
|
return $this->obj->select($this->herb_tbl, array('sql' => '`name`=?', 'vals' => array($name)));
|
|
}
|
|
|
|
public function insertHerb($info) {
|
|
$herb_id = $this->obj->insert($this->herb_tbl, $info);
|
|
if (!$herb_id) {
|
|
$this->writeLog('formula', 'save_error_log', '添加药材失败|' . json_encode($info));
|
|
return false;
|
|
}
|
|
|
|
return $herb_id;
|
|
}
|
|
|
|
public function dealForulaHerb($uid, $herbs) {
|
|
$formula_herb = array();
|
|
|
|
$herb_ids = array();
|
|
foreach ($herbs as $key => $item) {
|
|
$name = trim($item['name']);
|
|
$num = trim($item['num']);
|
|
$desc = trim($item['desc']);
|
|
|
|
//自拟药方 克重不能为0
|
|
if ($uid > 0 && $num == 0) {
|
|
$this->setError("抱歉,药材{$name}重量不能为零");
|
|
return false;
|
|
}
|
|
|
|
$temp = array();
|
|
|
|
//格式化药材id
|
|
$herb = $this->getHerb($name);
|
|
if ($herb) {
|
|
$temp['herb_id'] = $herb['id'];
|
|
} else {
|
|
$temp['herb_id'] = $this->insertHerb(array('uid' => $uid, 'name' => $name, 'desc' => $desc));
|
|
if (!$temp['herb_id']) {
|
|
$this->setError('添加药材失败');
|
|
return false;
|
|
}
|
|
}
|
|
|
|
if (isset($herb_ids[$temp['herb_id']])) {
|
|
$this->setError("抱歉,药方中存在重复的药材");
|
|
return false;
|
|
}
|
|
$herb_ids[$temp['herb_id']] = $temp['herb_id'];
|
|
|
|
//录药方上传的原方需要 单位换算
|
|
$temp['num'] = $num;
|
|
if ($uid == 0) {
|
|
//目前先不换算 默认为0 使用原方用量
|
|
$temp['num'] = 0;
|
|
//$temp['num'] = $this->convertToNum($name, $num, false);
|
|
}
|
|
$temp['sort'] = $key;
|
|
|
|
$formula_herb[] = $temp;
|
|
}
|
|
|
|
return $formula_herb;
|
|
}
|
|
|
|
public function insertFormula($info) {
|
|
$id = $this->obj->insert($this->tbl, $info);
|
|
if (empty($id)) {
|
|
$this->writeLog('formula', 'save_error_log', '添加药方失败|' . json_encode($info, JSON_UNESCAPED_UNICODE));
|
|
return false;
|
|
}
|
|
|
|
return $id;
|
|
}
|
|
|
|
public function insertFormulaHerb($info) {
|
|
$res = $this->obj->mutiInsert($this->formula_herb_tbl, $info);
|
|
if (!$res) {
|
|
$this->writeLog('formula', 'save_error_log', '批量添加药方药材关联失败|' . json_encode($info, JSON_UNESCAPED_UNICODE));
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public function updateFormula($id, $info) {
|
|
$res = $this->obj->update($this->tbl, $info, array('sql' => '`id`=?', 'vals' => array($id)));
|
|
if (!$res) {
|
|
$this->writeLog('formula', 'save_error_log', '更新药方失败|' . $id . '|' . json_encode($info, JSON_UNESCAPED_UNICODE));
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public function getFormulaHerb($formula_id) {
|
|
return $this->obj->selectAll($this->formula_herb_tbl, array('sql' => '`formula_id`=?', 'vals' => array($formula_id)), 'sort asc ');
|
|
}
|
|
|
|
public function mutiUpdateFormulaHerb($id, $new_data) {
|
|
$old_data = $this->getFormulaHerb($id);
|
|
|
|
$old_num = count($old_data);
|
|
$new_num = count($new_data);
|
|
|
|
if ($old_num >= $new_num) {
|
|
//需要删除药方对应的药材
|
|
foreach ($old_data as $key => $value) {
|
|
if (!isset($new_data[$key])) {
|
|
$res = $this->obj->delete($this->formula_herb_tbl, array('sql' => '`id`=?', 'vals' => array($value['id'])));
|
|
if (!$res) {
|
|
$this->writeLog('formula', 'save_error_log', '删除药方药材关联失败|' . $value['id']);
|
|
return false;
|
|
}
|
|
continue;
|
|
}
|
|
$res = $this->obj->update($this->formula_herb_tbl, $new_data[$key], array('sql' => '`id`=?', 'vals' => array($value['id'])));
|
|
if (!$res) {
|
|
$this->writeLog('formula', 'save_error_log', '更新药方药材关联失败1|' . $value['id'] . '|' . json_encode($new_data[$key], JSON_UNESCAPED_UNICODE));
|
|
return false;
|
|
}
|
|
}
|
|
} else {
|
|
//需要增加药方对应的药材
|
|
foreach ($new_data as $key => $value) {
|
|
if (!isset($old_data[$key])) {
|
|
$res = $this->obj->insert($this->formula_herb_tbl, $value);
|
|
if (!$res) {
|
|
$this->writeLog('formula', 'save_error_log', '添加药方药材关联失败|' . $value['id']);
|
|
return false;
|
|
}
|
|
continue;
|
|
}
|
|
$res = $this->obj->update($this->formula_herb_tbl, $value, array('sql' => '`id`=?', 'vals' => array($old_data[$key]['id'])));
|
|
if (!$res) {
|
|
$this->writeLog('formula', 'save_error_log', '更新药方药材关联失败2|' . $value['id'] . '|' . json_encode($new_data[$key], JSON_UNESCAPED_UNICODE));
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public function saveFormula($uid, $id, $name, $source, $method, $herbs, $remark = "", $admin_user = 0) {
|
|
if (empty($name)) {
|
|
$this->setError('请填写药方名称');
|
|
return false;
|
|
}
|
|
|
|
$herbs = json_decode($herbs, true);
|
|
if (empty($herbs)) {
|
|
$this->setError('请填写药方详情');
|
|
return false;
|
|
}
|
|
|
|
if ($id) {
|
|
$formula = $this->getFormulaById($id);
|
|
if (empty($formula)) {
|
|
$this->setError('抱歉,未找到匹配的药方');
|
|
return false;
|
|
}
|
|
if ($formula['uid'] != $uid) {
|
|
$this->setError('抱歉,这不是你的药方');
|
|
return false;
|
|
}
|
|
}
|
|
|
|
$data = array(
|
|
'uid' => $uid,
|
|
'name' => $name,
|
|
'source' => $source,
|
|
);
|
|
|
|
//$uid为0 即为后台录入药方 需处理原方数据
|
|
if ($uid == 0) {
|
|
$org_herb = array();
|
|
foreach ($herbs as $key => $herb) {
|
|
$org_herb[$key] = array(
|
|
'name' => trim($herb['name']),
|
|
'num' => trim($herb['num']),
|
|
'desc' => trim($herb['desc']),
|
|
);
|
|
|
|
//如果转义成功 则保存转义后的数据
|
|
$num = $this->convToNumber(trim($herb['num']));
|
|
if ($num != 0) $org_herb[$key]['num'] = $num;
|
|
}
|
|
|
|
//更新原方和用法
|
|
$data['original'] = json_encode($org_herb, JSON_UNESCAPED_UNICODE);
|
|
$data['method'] = $method;
|
|
$data['remark'] = $remark;
|
|
$data['is_delete'] = 2;
|
|
$data['user_id'] = $admin_user;
|
|
}
|
|
|
|
//格式化药方对应的药材数据
|
|
$formula_herb = $this->dealForulaHerb($uid, $herbs);
|
|
if (!$formula_herb) {
|
|
$this->writeLog('formula', 'save_error_log', '药方药材初始化失败|' . $uid . '|' . json_encode($herbs, JSON_UNESCAPED_UNICODE));
|
|
return false;
|
|
}
|
|
|
|
if (!$id) {
|
|
//添加药方 并添加药方药材关联关系
|
|
$id = $this->insertFormula($data);
|
|
if (!$id) {
|
|
$this->setError('添加药材失败');
|
|
return false;
|
|
}
|
|
|
|
//创建药方对应的药材
|
|
foreach ($formula_herb as &$item) {
|
|
$item['formula_id'] = $id;
|
|
}
|
|
$res = $this->insertFormulaHerb($formula_herb);
|
|
if (!$res) {
|
|
$this->setError('添加药方详情失败');
|
|
return false;
|
|
}
|
|
} else {
|
|
//更新药方 并更新药方药材关联关系
|
|
$res = $this->updateFormula($id, $data);
|
|
if (!$res) {
|
|
$this->setError('更新药方失败');
|
|
return false;
|
|
}
|
|
|
|
//批量更新药方药材关联关系
|
|
foreach ($formula_herb as &$item) {
|
|
$item['formula_id'] = $id;
|
|
}
|
|
$res = $this->mutiUpdateFormulaHerb($id, $formula_herb);
|
|
if (!$res) {
|
|
$this->setError('更新药方详情失败');
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return $id;
|
|
}
|
|
|
|
public function deleteFormula($uid, $id, $is_delete) {
|
|
$formula = $this->getFormulaById($id);
|
|
if (empty($formula)) {
|
|
$this->setError('抱歉,未找到匹配的药方');
|
|
return false;
|
|
}
|
|
if ($formula['uid'] != $uid) {
|
|
$this->setError('抱歉,这不是你的药方');
|
|
return false;
|
|
}
|
|
|
|
$res = $this->updateFormula($id, array('is_delete' => $is_delete));
|
|
if (!$res) {
|
|
$this->setError('删除药方失败');
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public function getHerbById($id) {
|
|
return $this->obj->select($this->herb_tbl, array('sql' => '`id`=?', 'vals' => array($id)));
|
|
}
|
|
|
|
public function getFormulaByIds($ids) {
|
|
return $this->obj->selectIn($this->tbl, array('id' => $ids));
|
|
}
|
|
|
|
public function updateFormulaUseLog($uid, $formula_id) {
|
|
$res = $this->obj->increase($this->formula_use_log_tbl, array('sql' => '`uid`=? and `formula_id`=?', 'vals' => array($uid, $formula_id)), 'use_num');
|
|
if (!$res) {
|
|
$this->writeLog('formula', 'update_error_log', '药方使用次数更新失败|' . $uid . '|' . $formula_id);
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public function getCollectLog($page_num, $page_size) {
|
|
$offset = ($page_num - 1) * $page_size;
|
|
return $this->obj->selectAll($this->collect_log_tbl, array(), 'collect_time desc ', array($offset, $page_size));
|
|
}
|
|
|
|
public function getCollectLogTotal() {
|
|
return $this->obj->count($this->collect_log_tbl);
|
|
}
|
|
|
|
public function getUnitConvByIds($ids) {
|
|
return $this->obj->selectIn($this->unit_conv, array('id' => $ids), array('sql' => '`status`=?', 'vals' => array(0)));
|
|
}
|
|
|
|
public function getUnitConvById($id) {
|
|
return $this->obj->select($this->unit_conv, array('sql' => '`id`=?', 'vals' => array($id)));
|
|
}
|
|
|
|
public function getUnitTypeConv($unit_type) {
|
|
return $this->obj->selectAll($this->unit_conv, array('sql' => '`unit_type`=? and `status`=?', 'vals' => array($unit_type, 0)));
|
|
}
|
|
|
|
public function getUnitConvList($condition, $page_num = 1, $page_size = 500) {
|
|
$offset = ($page_num - 1) * $page_size;
|
|
|
|
$where = "1=1 ";
|
|
if (!empty($condition)) {
|
|
foreach ($condition as $key => $val) {
|
|
$where .= " and {$key}={$val}";
|
|
}
|
|
}
|
|
|
|
return $this->obj->selectAll($this->unit_conv, array('sql' => $where, 'vals' => array()), 'id desc ', array($offset, $page_size));
|
|
}
|
|
|
|
public function updateUnitConv($id, $info) {
|
|
return $this->obj->update($this->unit_conv, $info, array('sql' => '`id`=?', 'vals' => array($id)));
|
|
}
|
|
|
|
public function insertUnitConv($info) {
|
|
$id = $this->obj->insert($this->unit_conv, $info);
|
|
if (empty($id)) {
|
|
$this->writeLog('formula', 'save_error_log', '添加计量单位转换失败|' . json_encode($info, JSON_UNESCAPED_UNICODE));
|
|
return false;
|
|
}
|
|
|
|
return $id;
|
|
}
|
|
|
|
public function saveUnitConv($id, $unit_type, $num, $from) {
|
|
if (!$unit_type) {
|
|
$this->setError('请选择计量单位');
|
|
return false;
|
|
}
|
|
if (!$num) {
|
|
$this->setError('请填写转换克重');
|
|
return false;
|
|
}
|
|
if (empty($from)) {
|
|
$this->setError('请填写转换根据');
|
|
return false;
|
|
}
|
|
|
|
$data = array(
|
|
'unit_type' => $unit_type,
|
|
'num' => $num,
|
|
'from' => $from,
|
|
'status' => 1,
|
|
);
|
|
|
|
if (!$id) {
|
|
//添加药方 并添加药方药材关联关系
|
|
$id = $this->insertUnitConv($data);
|
|
if (!$id) {
|
|
$this->setError('添加失败');
|
|
return false;
|
|
}
|
|
|
|
} else {
|
|
//更新药方 并更新药方药材关联关系
|
|
$res = $this->updateUnitConv($id, $data);
|
|
if (!$res) {
|
|
$this->setError('更新失败');
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return $id;
|
|
}
|
|
|
|
public function getUserConvList($uid) {
|
|
return $this->obj->selectAll($this->user_conv, array('sql' => '`uid`=?', 'vals' => array($uid)));
|
|
}
|
|
|
|
public function getUserConv($uid, $unit_type) {
|
|
return $this->obj->select($this->user_conv, array('sql' => '`uid`=? and `unit_type`=?', 'vals' => array($uid, $unit_type)));
|
|
}
|
|
|
|
public function saveUserConv($uid, $unit_type, $conv_id) {
|
|
if (!$unit_type || !$conv_id) {
|
|
$this->setError('参数错误');
|
|
return false;
|
|
}
|
|
|
|
$user_conv = $this->getUserConv($uid, $unit_type);
|
|
if ($user_conv) {
|
|
$res = $this->updateUserConv($user_conv['id'], array('conv_id' => $conv_id));
|
|
if (!$res) {
|
|
$this->setError('更新失败');
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
$res = $this->insertUserConv(array('uid' => $uid, 'unit_type' => $unit_type, 'conv_id' => $conv_id));
|
|
if (!$res) {
|
|
$this->setError('设置失败');
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
public function updateUserConv($id, $info) {
|
|
$res = $this->obj->update($this->user_conv, $info, array('sql' => '`id`=?', 'vals' => array($id)));
|
|
if (!$res) {
|
|
$this->writeLog('formula', 'save_error_log', '更新用户计量单位转换设置失败|' . $id . '|' . json_encode($info, JSON_UNESCAPED_UNICODE));
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public function insertUserConv($info) {
|
|
$res = $this->obj->insert($this->user_conv, $info);
|
|
if (!$res) {
|
|
$this->writeLog('formula', 'save_error_log', '添加用户计量单位转换设置失败|' . json_encode($info));
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|