DecRole.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <?php
  2. namespace common\models;
  3. use common\helpers\Cache;
  4. use common\helpers\Tool;
  5. use Yii;
  6. /**
  7. * This is the model class for table "{{%DEC_ROLE}}".
  8. *
  9. * @property string $ID
  10. * @property string $ROLE_NAME 名称
  11. * @property string $FW_BONUS_PERCENT 店补比例
  12. * @property string $SORT 排序
  13. * @property int $CREATED_AT 创建时间
  14. * @property int $UPDATED_AT 更新时间
  15. * @property string $UPDATER 更新人
  16. * @property string $ADM_NAME 操作人
  17. */
  18. class DecRole extends \common\components\ActiveRecord
  19. {
  20. /**
  21. * @inheritdoc
  22. */
  23. public static function tableName()
  24. {
  25. return '{{%DEC_ROLE}}';
  26. }
  27. /**
  28. * @inheritdoc
  29. */
  30. public function rules()
  31. {
  32. return [
  33. [['ROLE_NAME', 'ADM_NAME'], 'required'],
  34. [['FW_BONUS_PERCENT'], 'number'],
  35. [['SORT', 'CREATED_AT', 'UPDATED_AT'], 'integer'],
  36. [['ID'], 'string', 'max' => 32],
  37. [['ROLE_NAME'], 'string', 'max' => 255],
  38. [['UPDATER', 'ADM_NAME'], 'string', 'max' => 16],
  39. [['ID'], 'unique'],
  40. ];
  41. }
  42. /**
  43. * @inheritdoc
  44. */
  45. public function attributeLabels()
  46. {
  47. return [
  48. 'ID' => 'ID',
  49. 'ROLE_NAME' => '名称',
  50. 'FW_BONUS_PERCENT' => '推荐奖比例',
  51. 'SORT' => '排序',
  52. 'CREATED_AT' => '创建时间',
  53. 'UPDATED_AT' => '更新时间',
  54. 'UPDATER' => '更新人',
  55. 'ADM_NAME' => '操作人',
  56. ];
  57. }
  58. /**
  59. * 获取所有数据
  60. * @return array|\yii\db\ActiveRecord[]
  61. */
  62. public static function getAllData(){
  63. return static::find()->where('1=1')->indexBy('ID')->asArray()->all();
  64. }
  65. /**
  66. * 通过会员ID获取报单中心级别ID
  67. * @param $userId
  68. * @return mixed
  69. */
  70. public static function getRoleIdFromUserId($userId){
  71. $data = User::findOneAsArray('ID=:ID', [':ID'=>$userId], 'DEC_ROLE_ID');
  72. return $data['DEC_ROLE_ID'];
  73. }
  74. /**
  75. * 通过会员ID获得报单中心级别名称
  76. * @param $userId
  77. * @return string
  78. */
  79. public static function getRoleNameFromUserId($userId){
  80. $roleId = self::getRoleIdFromUserId($userId);
  81. if($roleId){
  82. $role = self::findOneAsArray('ID=:ID', [':ID'=>$roleId]);
  83. return $role ? $role['ROLE_NAME'] : '';
  84. } else {
  85. return null;
  86. }
  87. }
  88. /**
  89. * 报单级别名称
  90. * @param $roleId
  91. * @return string
  92. */
  93. public static function getRoleNameId($roleId){
  94. $role = self::findOneAsArray('ID=:ID', [':ID'=>$roleId]);
  95. return $role ? $role['ROLE_NAME'] : '';
  96. }
  97. /**
  98. * 更新缓存
  99. * @return array|\yii\db\ActiveRecord[]
  100. */
  101. public static function updateToCache(){
  102. // 获取配置
  103. $data = static::find()->where('1=1')->orderBy('SORT ASC')->asArray()->indexBy('ID')->all();
  104. Yii::$app->cache->set(Cache::DEC_ROLE_CONFIG_KEY, $data);
  105. return $data;
  106. }
  107. // 全部报单中心角色
  108. public static function getAllDecRole() {
  109. $data = DecRole::find()->where('1=1')->select('ID,ROLE_NAME,LANGUAGE_KEY')->indexBy('ID')->asArray()->all();
  110. $data = Tool::convertLanguage($data, 'ROLE_NAME');
  111. return $data;
  112. }
  113. }