StarCrownLevel.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. <?php
  2. namespace common\models;
  3. use common\helpers\Cache;
  4. use common\helpers\LoggerTool;
  5. use Yii;
  6. /**
  7. * This is the model class for table "{{%CROWN_LEVEL}}".
  8. *
  9. * @property string $ID
  10. * @property string $LEVEL_NAME 级别名称
  11. * @property int $ICON_TYPE 图标类型
  12. * @property int $ICON_NUM 图标个数
  13. * @property int $RX_PERCENT 图标个数
  14. * @property string $MIN_LEVEL_ID 上级ID
  15. * @property string $LEVEL_SCORE 级别分数
  16. * @property string $UPGRADE_SCORE 升级分数
  17. * @property string $TOURISM_PERCENT 旅游奖比例
  18. * @property string $GARAGE_PERCENT 车房奖比例
  19. * @property int $SORT 排序
  20. * @property int $CREATED_AT 创建时间
  21. * @property int $UPDATED_AT 更新时间
  22. * @property string $CREATE_ADMIN 创建人
  23. * @property string $UPDATE_ADMIN 更新人
  24. */
  25. class StarCrownLevel extends \common\components\ActiveRecord
  26. {
  27. const NO_LEVEL_ID = 'DCBEDD8E0EAD3DF59D81CCC0C2ACAEFF';
  28. /**
  29. * @inheritdoc
  30. */
  31. public static function tableName()
  32. {
  33. return '{{%CROWN_LEVEL}}';
  34. }
  35. /**
  36. * @inheritdoc
  37. */
  38. public function rules()
  39. {
  40. return [
  41. [['LEVEL_NAME', 'CREATED_AT', 'CREATE_ADMIN'], 'required'],
  42. [['SORT', 'CREATED_AT', 'UPDATED_AT', 'ICON_TYPE', 'ICON_NUM'], 'integer'],
  43. [['LEVEL_SCORE', 'UPGRADE_SCORE', 'TOURISM_PERCENT', 'GARAGE_PERCENT'], 'number'],
  44. [['ID', 'MIN_LEVEL_ID', 'CREATE_ADMIN', 'UPDATE_ADMIN'], 'string', 'max' => 32],
  45. [['LEVEL_NAME'], 'string', 'max' => 20],
  46. [['LEVEL_NAME'], 'unique'],
  47. [['ID'], 'unique'],
  48. ];
  49. }
  50. /**
  51. * @inheritdoc
  52. */
  53. public function attributeLabels()
  54. {
  55. return [
  56. 'ID' => 'ID',
  57. 'LEVEL_NAME' => '级别名称',
  58. 'SORT' => '排序',
  59. 'CREATED_AT' => '创建时间',
  60. 'UPDATED_AT' => '更新时间',
  61. 'CREATE_ADMIN' => '创建人',
  62. 'UPDATE_ADMIN' => '更新人',
  63. 'ICON_TYPE' => '图标类型',
  64. 'ICON_NUM' => '图标个数',
  65. 'MIN_LEVEL_ID' => '上级ID',
  66. 'LEVEL_SCORE' => '级别分数',
  67. 'UPGRADE_SCORE' => '升级分数',
  68. 'TOURISM_PERCENT' => '旅游奖比例',
  69. 'GARAGE_PERCENT' => '车房奖比例',
  70. ];
  71. }
  72. /**
  73. * 获取全部级别以数字索引的方式展现
  74. * @return array|\yii\db\ActiveRecord[]
  75. */
  76. public static function getAllDataWithNumIndex()
  77. {
  78. return static::find()->where('1=1')->orderBy('SORT ASC, CREATED_AT ASC')->indexBy('SORT')->asArray()->all();
  79. }
  80. /**
  81. * 获取全部配置
  82. * @return array|\yii\db\ActiveRecord[]
  83. */
  84. public static function getAllData()
  85. {
  86. return static::find()->where('1=1')->orderBy('SORT ASC, CREATED_AT ASC')->indexBy('ID')->asArray()->all();
  87. }
  88. // 获取级别配置一维度数组,id为键,级别等级为值
  89. public static function getIdConvertLevelSort()
  90. {
  91. $ret = [];
  92. $allData = static::find()->where('1=1')->orderBy('SORT ASC, CREATED_AT ASC')->indexBy('ID')->asArray()->all();
  93. foreach($allData as $data) {
  94. $ret[$data['ID']] = $data['SORT'];
  95. }
  96. return $ret;
  97. }
  98. /**
  99. * 从缓存获取信息
  100. * @return array|mixed|\yii\db\ActiveRecord[]
  101. */
  102. public static function getIdConvertLevelSortCache()
  103. {
  104. $key = Cache::CROWN_LEVEL_CONFIG_KEY . ':idsort';
  105. $data = Yii::$app->cache->get($key);
  106. if(!$data){
  107. // 获取信息
  108. $data = self::getIdConvertLevelSort();
  109. Yii::$app->cache->set($key, $data);
  110. }
  111. return $data;
  112. }
  113. /**
  114. * 从缓存获取信息
  115. * @return array|mixed|\yii\db\ActiveRecord[]
  116. */
  117. public static function getFromCache()
  118. {
  119. $data = Yii::$app->cache->get(Cache::CROWN_LEVEL_CONFIG_KEY);
  120. if(!$data){
  121. // 获取信息
  122. $data = self::getAllData();
  123. Yii::$app->cache->set(Cache::CROWN_LEVEL_CONFIG_KEY, $data);
  124. }
  125. // i18n转换
  126. foreach ($data as &$item) {
  127. $item['LEVEL_NAME'] = Yii::t('ctx', $item['LANGUAGE_KEY']);
  128. }
  129. return $data;
  130. }
  131. /**
  132. * 更新缓存
  133. * @return array|\yii\db\ActiveRecord[]
  134. */
  135. public static function updateToCache()
  136. {
  137. // 获取配置
  138. $data = self::getAllData();
  139. Yii::$app->cache->set(Cache::CROWN_LEVEL_CONFIG_KEY, $data);
  140. return $data;
  141. }
  142. /**
  143. * 通过排序获取级别
  144. * @param int $sort
  145. * @return mixed
  146. */
  147. public static function getLevelFromSort(int $sort)
  148. {
  149. static $crownLevels;
  150. if(!$crownLevels){
  151. $crownLevels = self::getFromCache();
  152. $crownLevels = array_column($crownLevels, null, 'sort');
  153. }
  154. return $crownLevels[$sort];
  155. }
  156. /**
  157. * 通过排序获取ID
  158. * @param int $sort
  159. * @return mixed
  160. */
  161. public static function getIdFromSort(int $sort)
  162. {
  163. $level = self::getLevelFromSort($sort);
  164. return $level['ID'];
  165. }
  166. /**
  167. * 获取默认级别
  168. * @return mixed
  169. */
  170. public static function getDefaultLevelId()
  171. {
  172. return self::NO_LEVEL_ID;
  173. }
  174. /**
  175. * 获取星级的排序
  176. * @param $id
  177. * @return mixed
  178. */
  179. public static function getSortById($id)
  180. {
  181. $crownLevels = self::getFromCache();
  182. return $crownLevels[$id]['SORT'] ?? 0;
  183. }
  184. /**
  185. * 通过ID获取星级名称
  186. * @param $levelId
  187. * @return mixed'
  188. */
  189. public static function getNameById($levelId)
  190. {
  191. return self::findOneAsArray('ID = :ID', [':ID' => $levelId])['LEVEL_NAME'] ?? '';
  192. }
  193. /**
  194. * 奖金参数
  195. */
  196. public static function getBonusConfig(){
  197. $allData = self::getAllData();
  198. $data = [];
  199. foreach ($allData as $value) {
  200. $data[$value['ID']]['label'] = $value['LEVEL_NAME'];
  201. $data[$value['ID']]['value'] = '【旅游奖】拿奖比例' . $value['TOURISM_PERCENT'] . '%,' . '【车房奖】拿奖比例' . $value['GARAGE_PERCENT'] . '%';
  202. }
  203. return $data;
  204. }
  205. /**
  206. * 根据业绩计算星级
  207. * @param $payLeg
  208. * @return array|mixed|\yii\db\ActiveRecord
  209. */
  210. public static function getStarCrown($payLeg)
  211. {
  212. $starCrown = [];
  213. $allData = self::getAllData();
  214. // 最大边界值
  215. $maxData = end($allData);
  216. if ($payLeg >= $maxData) {
  217. return $maxData;
  218. }
  219. foreach ($allData as $item) {
  220. if (($payLeg >= $item['LEVEL_SCORE']) && ($payLeg < $item['UPGRADE_SCORE'])) {
  221. $starCrown = $item;
  222. break;
  223. }
  224. }
  225. return $starCrown ?: $allData[self::NO_LEVEL_ID];
  226. }
  227. }