Config.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. <?php
  2. namespace common\models;
  3. use common\helpers\Cache;
  4. use Yii;
  5. use common\libs\logging\operate\valueType\Config as ValueTypeConfig;
  6. /**
  7. * This is the model class for table "{{%CONFIG}}".
  8. *
  9. * @property string $CONFIG_NAME 配置参数名
  10. * @property string $TITLE 标题
  11. * @property string $UNIT 单位
  12. * @property int $INPUT_TYPE 表单类型
  13. * @property string $OPTIONS 参数配置的选项
  14. * @property string $VALUE 配置值
  15. * @property string $TYPE 类型
  16. * @property int $SORT 排序
  17. * @property int $CREATED_AT 创建时间
  18. * @property int $UPDATED_AT 更新时间
  19. */
  20. class Config extends \common\components\ActiveRecord
  21. {
  22. const OTHER_EMP_LEVEL_WEEK = 1; // 计算聘级间隔一结算周
  23. CONST OTHER_EMP_LEVEL_MONTH = 2; // 计算聘级间隔一结算月
  24. const INPUT_TYPE_TEXT = 1; // 文本框
  25. const INPUT_TYPE_SELECT = 2; // 下拉选框
  26. const INPUT_TYPE_SELECT_MULTIPLE = 3; // 下拉多选
  27. const INPUT_TYPE_CHECKBOX = 3; // 复选框
  28. const INPUT_TYPE_YEAR_PICKER = 4; // 年选择器
  29. const INPUT_TYPE_DATE_TIME_PICKER = 5; // 日期时间选择器
  30. const INPUT_TYPE_DATE_PICKER = 6; // 日期选择器
  31. const INPUT_TYPE_TIME_PICKER = 7; // 时间选择器
  32. const INPUT_TYPE_SWITCH = 8; // 开关切换
  33. const INPUT_TYPE_TEXTAREA = 9; // 多行文本
  34. const INPUT_TYPE_TABLE = 10; // 表格
  35. CONST DEDUCT_MANAGE_TAX = [
  36. 'BONUS_BS', // 蓝星管理奖
  37. 'BONUS_QY', // 团队奖
  38. 'BONUS_QUARTER' // 季度奖
  39. ]; // 扣除管理费的奖金项
  40. CONST DEDUCT_RECONSUME_POINTS = [
  41. 'BONUS_BS', // 蓝星管理奖
  42. 'BONUS_QY', // 团队奖
  43. 'BONUS_QUARTER' // 季度奖
  44. ]; // 扣除复消积分的奖金项
  45. /**
  46. * @inheritdoc
  47. */
  48. public static function tableName()
  49. {
  50. return '{{%CONFIG}}';
  51. }
  52. /**
  53. * @inheritdoc
  54. */
  55. public function rules()
  56. {
  57. return [
  58. [['CONFIG_NAME', 'TITLE', 'TYPE', 'CREATED_AT'], 'required'],
  59. [['INPUT_TYPE', 'SORT', 'CREATED_AT', 'UPDATED_AT'], 'integer'],
  60. [['CONFIG_NAME', 'TITLE', 'UNIT', 'TYPE'], 'string', 'max' => 32],
  61. [['OPTIONS', 'VALUE'], 'string', 'max' => 4000],
  62. [['CONFIG_NAME'], 'unique'],
  63. ];
  64. }
  65. /**
  66. * @inheritdoc
  67. */
  68. public function attributeLabels()
  69. {
  70. return [
  71. 'CONFIG_NAME' => '配置参数名',
  72. 'TITLE' => '标题',
  73. 'UNIT' => '单位',
  74. 'INPUT_TYPE' => '表单类型',
  75. 'OPTIONS' => '参数配置的选项',
  76. 'VALUE' => '配置值',
  77. 'TYPE' => '类型',
  78. 'SORT' => '排序',
  79. 'CREATED_AT' => '创建时间',
  80. 'UPDATED_AT' => '更新时间',
  81. ];
  82. }
  83. /**
  84. * 从缓存获取配置信息
  85. * @return array|mixed|\yii\db\ActiveRecord[]
  86. */
  87. public static function getFromCache(){
  88. $config = Yii::$app->cache->get(Cache::SYSTEM_CONFIG_KEY);
  89. if(!$config){
  90. // 获取配置
  91. $config = Config::find()->where('1=1')->indexBy('CONFIG_NAME')->asArray()->all();
  92. Yii::$app->cache->set('sysConfig', $config);
  93. }
  94. return $config;
  95. }
  96. /**
  97. * 更新到缓存
  98. * @return array|\yii\db\ActiveRecord[]
  99. */
  100. public static function updateToCache(){
  101. // 获取配置
  102. $config = Config::find()->where('1=1')->indexBy('CONFIG_NAME')->asArray()->all();
  103. Yii::$app->cache->set(Cache::SYSTEM_CONFIG_KEY, $config);
  104. return $config;
  105. }
  106. /**
  107. * 操作日志记录条件
  108. * @return array
  109. */
  110. public function attrLabelsWithLogType(){
  111. return [
  112. 'TITLE' => '标题',
  113. 'VALUE' => '配置值',
  114. ];
  115. }
  116. /**
  117. * 按类型获取配置
  118. * @param $type
  119. * @return array
  120. */
  121. public static function getConfigByType($type) {
  122. $configs = Config::find()->where('TYPE=:TYPE', [':TYPE' => $type])->orderBy('SORT ASC')->indexBy('CONFIG_NAME')->asArray()->all();
  123. $data = [];
  124. foreach ($configs as $value) {
  125. $data[$value['CONFIG_NAME']]['label'] = $value['TITLE'];
  126. switch ($value['INPUT_TYPE']) {
  127. case 2:
  128. $options = json_decode($value['OPTIONS'],true);
  129. $arr = explode(",", $value['VALUE']);
  130. if($type=='other'){
  131. $colArr = array_column($options, 'value','label');
  132. $result=array_flip($colArr);
  133. $str = '';
  134. foreach ($arr as $v) {
  135. $str .= $result[$v] . ',';
  136. }
  137. }else {
  138. $str = '';
  139. foreach ($arr as $v) {
  140. $str .= $options[$v - 1]['label'] . ',';
  141. }
  142. }
  143. $data[$value['CONFIG_NAME']]['value'] = $str;
  144. break;
  145. case 3:
  146. $options = json_decode($value['OPTIONS'],true);
  147. if( $value["VALUE"] ) {
  148. $arr = explode(",", $value['VALUE']);
  149. $str = '';
  150. foreach ($arr as $v) {
  151. foreach ($options as $option) {
  152. if( $option['value'] === $v ) {
  153. $str .= $option['label'] . ',';
  154. break;
  155. }
  156. }
  157. }
  158. $data[$value['CONFIG_NAME']]['value'] = $str;
  159. }else {
  160. $data[$value['CONFIG_NAME']]['value'] = '';
  161. }
  162. break;
  163. case 8:
  164. $data[$value['CONFIG_NAME']]['value'] = $value['VALUE'] == 1 ? '是' : '否';
  165. break;
  166. case 10:
  167. $data[$value['CONFIG_NAME']]['value'] = $value['VALUE'];
  168. break;
  169. default:
  170. $data[$value['CONFIG_NAME']]['value'] = $value['VALUE'];
  171. }
  172. }
  173. return $data;
  174. }
  175. }