DecRole.php 3.0 KB

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