185 lines
6.3 KiB
PHP
185 lines
6.3 KiB
PHP
<?
|
|
namespace soft\user;
|
|
|
|
use core\columns\structure\eFilterType;
|
|
use core\db\structure\Column as C;
|
|
use core\db\structure\eColumnType;
|
|
use soft\project\Group;
|
|
use soft\Soft;
|
|
use soft\Subscribe;
|
|
use soft\Subscribe\group as SubscribeGroup;
|
|
use soft\User;
|
|
use ui\form\structure\eInputType;
|
|
use ui\Form;
|
|
use ui\input\Input;
|
|
use core\lang\structure\LangVariable as V;
|
|
use ms\ms\structure\msModuleTable;
|
|
use soft\user\payment\structure\softUserPaymentLang as Vars;
|
|
|
|
|
|
|
|
|
|
class Payment extends msModuleTable {
|
|
static $self;
|
|
static $table_name = 'softUserPayment';
|
|
static $controller = 'soft.user.payment';
|
|
|
|
static $ID = 'id';
|
|
|
|
static $PROFILE = 'profile';
|
|
static $CHECK = 'check';
|
|
static $VALUE = 'value';
|
|
static $SUBSCRIBE = 'subscribe';
|
|
static $SOFT = 'soft';
|
|
static $DATE = 'date';
|
|
|
|
static $PORTAL = 'account';
|
|
static $ACCOUNT = 'account';
|
|
static $CREATED = 'created';
|
|
|
|
|
|
static function getTitle(){return V::get(Vars::$MODULE_NAME);}
|
|
static function getSystemLangValues():array{ return Vars::getArray(); }
|
|
|
|
public function _insert(array $values, array $options = array()) {
|
|
$res = parent::_insert($values, $options);
|
|
User::mathBalance($values[self::$PROFILE]);
|
|
return $res;
|
|
}
|
|
|
|
|
|
static public function add($values){
|
|
$soft_id = $values[self::$SOFT];
|
|
$profile_id = $values[self::$PROFILE];
|
|
$date = date('Y-m-d');
|
|
|
|
if($soft_id) {
|
|
$r = self::select([
|
|
\Query::WHERE => new \Where(\Where::_and([
|
|
\Where::_operator(self::$SOFT, '=', $soft_id),
|
|
\Where::_operator(self::$PROFILE, '=', $profile_id),
|
|
\Where::_operator(self::$DATE, '=', $date),
|
|
])),
|
|
\Query::COUNT => 1,
|
|
]);
|
|
if(!\DB::numRows($r)){
|
|
self::insert($values);
|
|
}
|
|
} else {
|
|
self::insert($values);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
public static function installUniques() {
|
|
\DB::addIndex(self::$table_name,self::$PROFILE);
|
|
\DB::addIndexManyColumns(self::$table_name,[self::$SOFT,self::$PROFILE,self::$DATE]);
|
|
}
|
|
|
|
|
|
static function columnInfo() : array {
|
|
return [
|
|
new C([
|
|
C::VAR_NAME =>&self::$ID,
|
|
C::TYPE =>eColumnType::INT,
|
|
C::AUTO_INCREMENT =>true,
|
|
C::PRIMARY =>true,
|
|
C::DEFAULT =>0,
|
|
//C::HIDDEN =>true,
|
|
C::TH =>V::get(Vars::$ID),
|
|
]),
|
|
|
|
|
|
new C([
|
|
C::VAR_NAME => &self::$PROFILE,
|
|
C::TYPE => eColumnType::INT,
|
|
C::TH => V::get(Vars::$PROFILE),
|
|
//C::HIDDEN => true,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$SOFT,
|
|
C::TYPE => eColumnType::INT,
|
|
C::TH => V::get(Vars::$SOFT),
|
|
C::FUNC_VALUE_DATA => function($v){
|
|
if($v[self::$VALUE]>0){
|
|
return "Пополнение баланса";
|
|
} else {
|
|
if ($id = intval($v[self::$SOFT])) {
|
|
return Soft::getName(Soft::getByID($id));
|
|
} else {
|
|
$s = Subscribe::getByID(intval($v[self::$SUBSCRIBE]));
|
|
$group = SubscribeGroup::getByID(intval($s[Subscribe::$GROUP]));
|
|
return SubscribeGroup::getName($group);
|
|
}
|
|
}
|
|
},
|
|
C::FILTER_TYPE => eFilterType::SELECT,
|
|
C::FUNC_FILTER_SELECT_OPTIONS => function(){
|
|
return Soft::getNameList([
|
|
\Query::WHERE => new \Where(\Where::_and([
|
|
\Where::_operator(Soft::$PORTAL,'=',\Site::$portal_id),
|
|
\Where::_operator(Soft::$VIS,'=',1),
|
|
]))
|
|
]);
|
|
}
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$CHECK,
|
|
C::TYPE => eColumnType::INT,
|
|
C::TH => V::get(Vars::$CHECK),
|
|
C::HIDDEN => true,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$VALUE,
|
|
C::TD_CLASS => 'tar',
|
|
C::TYPE => eColumnType::DOUBLE,
|
|
C::LENGTH => '10,2',
|
|
C::TH => V::get(Vars::$VALUE),
|
|
C::FILTER_TYPE => eFilterType::NUMBER,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$DATE,
|
|
C::TYPE => eColumnType::DATE,
|
|
C::DEFAULT => date('Y-m-d'),
|
|
C::TH => V::get(Vars::$DATE),
|
|
C::FILTER_TYPE => eFilterType::DATE,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$SUBSCRIBE,
|
|
C::TYPE => eColumnType::INT,
|
|
C::TH => V::get(Vars::$SUBSCRIBE),
|
|
]),
|
|
|
|
|
|
new C([
|
|
C::VAR_NAME => &self::$PORTAL,
|
|
C::TYPE => eColumnType::INT,
|
|
C::DEFAULT => intval(\Site::$portal_id),
|
|
c::HIDDEN=>true,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$ACCOUNT,
|
|
C::TYPE => eColumnType::INT,
|
|
C::LENGTH => 11,
|
|
C::TH => V::get(Vars::$ACCOUNT),
|
|
C::DEFAULT => intval(\Site::$owner_id),
|
|
c::HIDDEN=>true,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$CREATED,
|
|
C::TYPE => eColumnType::INT,
|
|
C::LENGTH => 11,
|
|
C::TH => V::get(Vars::$CREATED),
|
|
C::DEFAULT => time(),
|
|
c::FUNC_VALUE => function($v){return self::formatDate($v[self::$CREATED]);},
|
|
c::HIDDEN=>true,
|
|
]),
|
|
];
|
|
}
|
|
|
|
}
|
|
new Payment();
|
|
|
|
|