SysPrinter.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | Niucloud-admin 企业快速开发的多应用管理平台
  4. // +----------------------------------------------------------------------
  5. // | 官方网址:https://www.niucloud.com
  6. // +----------------------------------------------------------------------
  7. // | niucloud团队 版权所有 开源版本可自由商用
  8. // +----------------------------------------------------------------------
  9. // | Author: Niucloud Team
  10. // +----------------------------------------------------------------------
  11. namespace app\model\sys;
  12. use app\dict\sys\PrinterDict;
  13. use core\base\BaseModel;
  14. /**
  15. * 小票打印机模型
  16. * Class SysPrinter
  17. * @package app\model\sys
  18. */
  19. class SysPrinter extends BaseModel
  20. {
  21. /**
  22. * 数据表主键
  23. * @var string
  24. */
  25. protected $pk = 'printer_id';
  26. /**
  27. * 模型名称
  28. * @var string
  29. */
  30. protected $name = 'sys_printer';
  31. // 设置json类型字段
  32. protected $json = [ 'template_type', 'trigger', 'value' ];
  33. // 设置JSON数据返回数组
  34. protected $jsonAssoc = true;
  35. /**
  36. * 状态字段转化
  37. * @param $value
  38. * @param $data
  39. * @return mixed
  40. */
  41. public function getBrandNameAttr($value, $data)
  42. {
  43. if (!empty($data[ 'brand' ])) {
  44. return PrinterDict::getBrandName($data[ 'brand' ]) ?? '';
  45. }
  46. return '';
  47. }
  48. /**
  49. * 搜索器:小票打印机
  50. * @param $value
  51. * @param $data
  52. */
  53. public function searchPrinterIdAttr($query, $value, $data)
  54. {
  55. if ($value) {
  56. $query->where("printer_id", $value);
  57. }
  58. }
  59. /**
  60. * 搜索器:小票打印机设备品牌(易联云,365,飞鹅)
  61. * @param $value
  62. * @param $data
  63. */
  64. public function searchBrandAttr($query, $value, $data)
  65. {
  66. if ($value) {
  67. $query->where("brand", $value);
  68. }
  69. }
  70. /**
  71. * 搜索器:小票打印机打印机名称
  72. * @param $value
  73. * @param $data
  74. */
  75. public function searchPrinterNameAttr($query, $value, $data)
  76. {
  77. if ($value != '') {
  78. $query->where("printer_name", 'like', '%' . $value . '%');
  79. }
  80. }
  81. /**
  82. * 搜索器:小票打印机状态(0,关闭,1:开启)
  83. * @param $value
  84. * @param $data
  85. */
  86. public function searchStatusAttr($query, $value, $data)
  87. {
  88. if ($value !== '') {
  89. $query->where("status", $value);
  90. }
  91. }
  92. }