var ref = firebase.database().ref("books/" + bookId + "/status");
ref.once('value').then(function(snapshot) {
var status = snapshot.val();
console.log(status.name);
});
var bookRef = firebase.database().ref("books/" + bookId);
bookRef.once('value').then(function(snapshot) {
var book = snapshot.val();
var statusRef = bookRef.child("status");
statusRef.once('value').then(function(snapshot) {
var status = snapshot.val();
console.log(status.name);
});
});
$res = \CIBlockElement::GetList(null, Array('IBLOCK_ID' => '26', 'ID' => $productId), false , false,array('ID','XML_ID','IBLOCK_EXTERNAL_ID'));
...
$arParamsProp=[...];
...
$item->getPropertyCollection()->setProperty($arParamsProp);
$item->setFields(array(
'QUANTITY' => 1,
'CURRENCY' => Bitrix\Currency\CurrencyManager::getBaseCurrency(),
'LID' => Bitrix\Main\Context::getCurrent()->getSite(),
'PRODUCT_PROVIDER_CLASS' => 'CCatalogProductProvider',
"CATALOG_XML_ID" => $arParamsProp['CATALOG_XML_ID'],
"PRODUCT_XML_ID" => $arParamsProp['PRODUCT_XML_ID'],
));
$isNotOverlapped = $range2start > $range1end || $range1start > $range2end;
$isOverlapped = !($range2start > $range1end || $range1start > $range2end);
$isOverlapped = $range2start <= $range1end && $range1start <= $range2end;
strtotime()затем сравнить два диапазона с помощью цикла
public function getEntitiesByBatch(int $limit): \Generator
{
$expr = $this->createQueryBuilder('s');
$predicates = $expr->expr()->andX();
$predicates->add($expr->expr()->isNotNull('s.field1'));
$predicates->add($expr->expr()->isNotNull('s.field2'));
$accountState = $expr->expr()->eq('a.field3', 'true');
$qb = $this->createQueryBuilder('s')
->where($predicates)
->join('s.account', 'a')
->where($accountState)
;
$batches = ceil($qb->select('count(s.id)')->getQuery()->getSingleScalarResult() / $limit);
for ($batch = 1; $batch <= $batches; ++$batch) {
yield $this->createQueryBuilder('s')
->where($predicates)
->join('s.account', 'a')
->where($accountState)
->setFirstResult($batch * $limit - $limit)
->setMaxResults($limit)
->getQuery()
->toIterable() // тут можно возращать просто массив, но мне нужен итерируемый объект
;
}
}
&customPackages=`quipComment:body:quip:{core_path}components/quip/model/:quipComment.resource = modResource.id`
Let's break down each part:
className - The class name of the table you want to search. Here, it's QuipComment.
fieldName(s) - A comma-separated list of column names to search. We did 'body', you could also have done 'body,email' or whatever.
packageName - The name of the schema Package to add. This one is called quip.
packagePath - The path to the model/ directory where the package is located.
joinCriteria - The SQL to join the table you want to search and the modResource table. Your table must have some connection to the Resource it's on (otherwise SimpleSearch won't know how to load a URL for it!)
EWreview.combo.Rate = function(config) {
config = config || {};
Ext.applyIf(config,{
name: 'name'
,hiddenName: 'product_id'
,displayField: 'name'
,valueField: 'product_id'
,fields: ['product_id','name']
,pageSize: 20
,url: EWreview.config.connector_url
,baseParams: {
action: 'ew/getlist'
}
,typeAhead: true
,editable: true
});
EWreview.combo.Rate.superclass.constructor.call(this,config);
};
Ext.extend(EWreview.combo.Rate,MODx.combo.ComboBox);
Ext.reg('ewreview-combo-rate',EWreview.combo.Rate);