может у битрикса есть какие стандартные инструменты по импорту или может вы знаете адекватные бесплатные модули.
Либо писать свой парсер, тогда какой - csv или xml?
Подскажите, как лучше поступить?
// Для элемента
array(
"CONDITION" => "#^/podobrat-dver/([a-z0-9\-]+)/([^/\?]*)(.*)$#",
"RULE" => "SECION_CODE=\$1&ELEMENT_CODE=\$2&$3",
"PATH" => "/podobrat-dver/detail.php",
)
// Для раздела
array(
"CONDITION" => "#^/podobrat-dver/([a-z0-9\-]+)/(.*)$#",
"RULE" => "SECION_CODE=$1&$2",
"PATH" => "/podobrat-dver/section.php",
)
<?$APPLICATION->IncludeComponent(
"bitrix:catalog.element",
"detail",
array(
.....
"IBLOCK_ID" => "30",
"ELEMENT_ID" => "",
"ELEMENT_CODE" => $_REQUEST["ELEMENT_CODE"],
"SECTION_ID" => "",
"SECTION_CODE" => $_REQUEST["SECION_CODE"],
"SECTION_URL" => "",
"DETAIL_URL" => "/podobrat-dver/#ELEMENT_CODE#/",
"SECTION_ID_VARIABLE" => "ELEMENT_CODE",
"SECTION_CODE_PATH" => ""
.....
),
false
);?>
<?$APPLICATION->IncludeComponent(
"bitrix:catalog.section",
"catalog_list",
array(
....
"DETAIL_URL" => "/podobrat-dver/#ELEMENT_CODE#/",
"SECTION_CODE" => $_REQUEST["SECTION_CODE"],
"SECTION_ID" => "",
"SECTION_URL" => "",
"SHOW_ALL_WO_SECTION" => "Y",
....
),
false
);?>
//region Try to extract user action data
// We have to extract them before call of CGridOptions::GetFilter() or the custom filter will be corrupted.
$actionData = array(
'METHOD' => $_SERVER['REQUEST_METHOD'],
'ACTIVE' => false
);
if(check_bitrix_sessid())
{
$postAction = 'action_button_'.$arResult['GRID_ID'];
$getAction = 'action_'.$arResult['GRID_ID'];
//We need to check grid 'controls'
$controls = isset($_POST['controls']) && is_array($_POST['controls']) ? $_POST['controls'] : array();
if ($actionData['METHOD'] == 'POST' && (isset($controls[$postAction]) || isset($_POST[$postAction])))
{
CUtil::JSPostUnescape();
$actionData['ACTIVE'] = true;
if(isset($controls[$postAction]))
{
$actionData['NAME'] = $controls[$postAction];
}
else
{
$actionData['NAME'] = $_POST[$postAction];
unset($_POST[$postAction], $_REQUEST[$postAction]);
}
...
...
...
$actionData['AJAX_CALL'] = $arResult['IS_AJAX_CALL'];
}
}
//endregion
// POST & GET actions processing -->
if($actionData['ACTIVE'])
{
if ($actionData['METHOD'] == 'POST')
{
if($actionData['NAME'] == 'delete')
{
...
elseif($actionData['NAME'] == 'assign_to')
{
if(isset($actionData['ASSIGNED_BY_ID']))
{
$arIDs = array();
if ($actionData['ALL_ROWS'])
{
$arActionFilter = $arFilter;
$arActionFilter['CHECK_PERMISSIONS'] = 'N'; // Ignore 'WRITE' permission - we will check it before update.
$dbRes = CCrmDeal::GetListEx(array(), $arActionFilter, false, false, array('ID'));
while($arDeal = $dbRes->Fetch())
{
$arIDs[] = $arDeal['ID'];
}
}
elseif (isset($actionData['ID']) && is_array($actionData['ID']))
{
$arIDs = $actionData['ID'];
}
foreach($arIDs as $ID)
{
if (!CCrmDeal::CheckUpdatePermission($ID, $userPermissions))
{
continue;
}
$DB->StartTransaction();
$arUpdateData = array(
'ASSIGNED_BY_ID' => $actionData['ASSIGNED_BY_ID']
);
if($CCrmDeal->Update($ID, $arUpdateData, true, true, array('DISABLE_USER_FIELD_CHECK' => true)))
{
$DB->Commit();
$arErrors = array();
CCrmBizProcHelper::AutoStartWorkflows(
CCrmOwnerType::Deal,
$ID,
CCrmBizProcEventType::Edit,
$arErrors
);
}
else
{
$DB->Rollback();
}
}
}
}
...
}
}
// <-- POST & GET actions processing
use Bitrix\TestPartner\TestPartnerModule\TestPartnerModuleListTable;
use TestPartner\TestPartnerModule\TestPartnerModuleListTable;
Можно ли это сделать встроенными средствами битрикса?
Может есть готовые дополнения?
/* @var array Список контактов */
$arContacts = array();
if ( \Bitrix\Main\Loader::IncludeModule('crm') )
{
/* @var array Сортировка полученного списка контактов */
$arOrder = array('ID' => 'DESC');
/* @var array Условия получаемого списка контактов */
$arFilter = array(
"NAME" => "Имя",
"LAST_NAME" => "Фамилия",
'CHECK_PERMISSIONS' => 'N' // Данный ключ необходим для того чтобы получить всех пользоватей,
// иначе, будет найден только если ответственным за него является тот,
// под кем запускается скрипт в битриксе
);
/* @var array Получаемые поля для списка контактов */
$arSelect = array(
'ID'
);
// NOTE: Запрашивайте только необходимые поля
$res = CCrmContact::GetList( $arOrder, $arFilter, $arSelect );
while( $arContact = $res->fetch() )
{
$arContacts[ $arContact['ID'] ] = $arContact['ID'];
}
}
// Тут в $arContacts либо пустой массив, либо массив с ID контактами, которые соответствуют условию поиска
use \Bitrix\Main\Loader;
use \Bitrix\Crm;
/* @var array Список контактов */
$arContacts = array();
if ( Loader::IncludeModule('crm') )
{
$resContacts = Crm\ContactTable::getList(array(
'select' => array('ID'),
'filter' => array(
"NAME" => "Имя",
"LAST_NAME" => "Фамилия",
),
'order' => array('ID' => 'DESC')
));
while( $arContact = $resContacts->fetch() )
{
$arContacts[ $arContact['ID'] ] = $arContact['ID'];
}
/*
Начиная с 17 версии (вроде бы), можно делать так:
foreach( $resContacts as $arContact)
{
$arContacts[ $arContact['ID'] ] = $arContact['ID'];
}
вместо while цикла
*/
}