- Модуль: crm
- Путь к файлу: ~/bitrix/modules/crm/lib/statistics/entity/activitystatistics.php
- Класс: Bitrix\Crm\Statistics\Entity\ActivityStatisticsTable
- Вызов: ActivityStatisticsTable::upsert
static function upsert(array $data)
{
$fields = array(
'OWNER_TYPE_ID' => isset($data['OWNER_TYPE_ID']) ? (int)$data['OWNER_TYPE_ID'] : 0,
'RESPONSIBLE_ID' => isset($data['RESPONSIBLE_ID']) ? (int)$data['RESPONSIBLE_ID'] : 0,
'COMPLETED' => isset($data['COMPLETED']) && $data['COMPLETED'] === 'Y' ? 'Y' : 'N',
'STATUS_ID' => isset($data['STATUS_ID']) ? (int)$data['STATUS_ID'] : 0,
'MARK_ID' => isset($data['MARK_ID']) ? (int)$data['MARK_ID'] : 0,
'SOURCE_ID' => isset($data['SOURCE_ID']) ? $data['SOURCE_ID'] : '',
'STREAM_ID' => isset($data['STREAM_ID']) ? (int)$data['STREAM_ID'] : 0,
'CURRENCY_ID' => isset($data['CURRENCY_ID']) ? $data['CURRENCY_ID'] : '',
'SUM_TOTAL' => isset($data['SUM_TOTAL']) ? (float)$data['SUM_TOTAL'] : 0.0
);
$connection = Main\Application::getConnection();
$queries = $connection->getSqlHelper()->prepareMerge(
'b_crm_act_stat',
array('OWNER_ID', 'DEADLINE_DATE', 'PROVIDER_ID', 'PROVIDER_TYPE_ID'),
array_merge(
$fields,
array(
'OWNER_ID' => isset($data['OWNER_ID']) ? $data['OWNER_ID'] : 0,
'DEADLINE_DATE' => isset($data['DEADLINE_DATE']) ? $data['DEADLINE_DATE'] : null,
'PROVIDER_ID' => isset($data['PROVIDER_ID']) ? $data['PROVIDER_ID'] : null,
'PROVIDER_TYPE_ID' => isset($data['PROVIDER_TYPE_ID']) ? $data['PROVIDER_TYPE_ID'] : null,
)
),
$fields
);
foreach($queries as $query)
{
$connection->queryExecute($query);
}
}