| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 |
- <?php
- namespace common\models;
- use common\helpers\Cache;
- use Yii;
- use common\libs\logging\operate\valueType\Config as ValueTypeConfig;
- /**
- * This is the model class for table "{{%CONFIG}}".
- *
- * @property string $CONFIG_NAME 配置参数名
- * @property string $TITLE 标题
- * @property string $UNIT 单位
- * @property int $INPUT_TYPE 表单类型
- * @property string $OPTIONS 参数配置的选项
- * @property string $VALUE 配置值
- * @property string $TYPE 类型
- * @property int $SORT 排序
- * @property int $CREATED_AT 创建时间
- * @property int $UPDATED_AT 更新时间
- */
- class Config extends \common\components\ActiveRecord
- {
- const OTHER_EMP_LEVEL_WEEK = 1; // 计算聘级间隔一结算周
- CONST OTHER_EMP_LEVEL_MONTH = 2; // 计算聘级间隔一结算月
- const INPUT_TYPE_TEXT = 1; // 文本框
- const INPUT_TYPE_SELECT = 2; // 下拉选框
- const INPUT_TYPE_SELECT_MULTIPLE = 3; // 下拉多选
- const INPUT_TYPE_CHECKBOX = 3; // 复选框
- const INPUT_TYPE_YEAR_PICKER = 4; // 年选择器
- const INPUT_TYPE_DATE_TIME_PICKER = 5; // 日期时间选择器
- const INPUT_TYPE_DATE_PICKER = 6; // 日期选择器
- const INPUT_TYPE_TIME_PICKER = 7; // 时间选择器
- const INPUT_TYPE_SWITCH = 8; // 开关切换
- const INPUT_TYPE_TEXTAREA = 9; // 多行文本
- const INPUT_TYPE_TABLE = 10; // 表格
- /**
- * @inheritdoc
- */
- public static function tableName()
- {
- return '{{%CONFIG}}';
- }
- /**
- * @inheritdoc
- */
- public function rules()
- {
- return [
- [['CONFIG_NAME', 'TITLE', 'TYPE', 'CREATED_AT'], 'required'],
- [['INPUT_TYPE', 'SORT', 'CREATED_AT', 'UPDATED_AT'], 'integer'],
- [['CONFIG_NAME', 'TITLE', 'UNIT', 'TYPE'], 'string', 'max' => 32],
- [['OPTIONS', 'VALUE'], 'string', 'max' => 4000],
- [['CONFIG_NAME'], 'unique'],
- ];
- }
- /**
- * @inheritdoc
- */
- public function attributeLabels()
- {
- return [
- 'CONFIG_NAME' => '配置参数名',
- 'TITLE' => '标题',
- 'UNIT' => '单位',
- 'INPUT_TYPE' => '表单类型',
- 'OPTIONS' => '参数配置的选项',
- 'VALUE' => '配置值',
- 'TYPE' => '类型',
- 'SORT' => '排序',
- 'CREATED_AT' => '创建时间',
- 'UPDATED_AT' => '更新时间',
- ];
- }
- /**
- * 从缓存获取配置信息
- * @return array|mixed|\yii\db\ActiveRecord[]
- */
- public static function getFromCache(){
- $config = Yii::$app->cache->get(Cache::SYSTEM_CONFIG_KEY);
- if(!$config){
- // 获取配置
- $config = Config::find()->where('1=1')->indexBy('CONFIG_NAME')->asArray()->all();
- Yii::$app->cache->set('sysConfig', $config);
- }
- return $config;
- }
- /**
- * 更新到缓存
- * @return array|\yii\db\ActiveRecord[]
- */
- public static function updateToCache(){
- // 获取配置
- $config = Config::find()->where('1=1')->indexBy('CONFIG_NAME')->asArray()->all();
- Yii::$app->cache->set(Cache::SYSTEM_CONFIG_KEY, $config);
- return $config;
- }
- /**
- * 操作日志记录条件
- * @return array
- */
- public function attrLabelsWithLogType(){
- return [
- 'TITLE' => '标题',
- 'VALUE' => '配置值',
- ];
- }
- /**
- * 按类型获取配置
- * @param $type
- * @return array
- */
- public static function getConfigByType($type) {
- $configs = Config::find()->where('TYPE=:TYPE', [':TYPE' => $type])->orderBy('SORT ASC')->indexBy('CONFIG_NAME')->asArray()->all();
- $data = [];
- foreach ($configs as $value) {
- $data[$value['CONFIG_NAME']]['label'] = $value['TITLE'];
- switch ($value['INPUT_TYPE']) {
- case 2:
- $options = json_decode($value['OPTIONS'],true);
- $arr = explode(",", $value['VALUE']);
- if($type=='other'){
- $colArr = array_column($options, 'value','label');
- $result=array_flip($colArr);
- $str = '';
- foreach ($arr as $v) {
- $str .= $result[$v] . ',';
- }
- }else {
- $str = '';
- foreach ($arr as $v) {
- $str .= $options[$v - 1]['label'] . ',';
- }
- }
- $data[$value['CONFIG_NAME']]['value'] = $str;
- break;
- case 3:
- $options = json_decode($value['OPTIONS'],true);
- if( $value["VALUE"] ) {
- $arr = explode(",", $value['VALUE']);
- $str = '';
- foreach ($arr as $v) {
- foreach ($options as $option) {
- if( $option['value'] === $v ) {
- $str .= $option['label'] . ',';
- break;
- }
- }
- }
- $data[$value['CONFIG_NAME']]['value'] = $str;
- }else {
- $data[$value['CONFIG_NAME']]['value'] = '';
- }
- break;
- case 8:
- $data[$value['CONFIG_NAME']]['value'] = $value['VALUE'] == 1 ? '是' : '否';
- break;
- case 10:
- $data[$value['CONFIG_NAME']]['value'] = $value['VALUE'];
- break;
- default:
- $data[$value['CONFIG_NAME']]['value'] = $value['VALUE'];
- }
- }
- return $data;
- }
- }
|