new importfiles

This commit is contained in:
Marko
2023-02-28 11:27:27 +01:00
parent 9bf0994b25
commit 48230c73a6
6 changed files with 41 additions and 24 deletions

View File

@@ -113,10 +113,10 @@ class HiltesImport
// Header überspringen
$c++;
#*** Convertiert die Zeile in UTF8
//$str = iconv('ISO-8859-1','UTF-8',$file->fgets());
$data = iconv('ISO-8859-1','UTF-8',$file->fgets());
#*** Zerlegt die Zeile **********
$data = $file->fgets();
//$data = $file->fgets();
if($c <= 1){ continue; }
$this->switchSaveData($this->splitLine($data));
@@ -212,29 +212,44 @@ class HiltesImport
}
/**
* @param string $wareHouseName
* @return Warehouse|false|int|mixed|null
*/
private function checkWareHouseName(string $wareHouseName){
#*** WEnn keine geCached Id Vorhanden
$warehouse2 = false;
if(empty($this->cachedWarehouseIds[$wareHouseName])){
#*** Check
$warehouse2 = $this->warehouseRepository->findOneBy(['id'=> (int)$wareHouseName]);
#dump($warehouse2);
//dump($warehouse2);
if(empty($warehouse2)){
$warehouse = new Warehouse();
$warehouse->setId((int)$wareHouseName);
$warehouse->setName($wareHouseName);
#
$this->warehouseRepository->save($warehouse,true);
$this->warehouseRepository->save($warehouse,true);
$this->cachedWarehouseIds[$wareHouseName] = $warehouse;
#*****************
$warehouse2 = $this->warehouseRepository->findOneBy(['id'=> (int)$wareHouseName]);
#$warehouse2 = $this->warehouseRepository->findOneBy(['id'=> (int)$wareHouseName]);
#dump($warehouse2);
}
$this->cachedWarehouseIds[$wareHouseName] = $warehouse2;
}else{
$this->cachedWarehouseIds[$wareHouseName] = $warehouse2;
}
}
if(!empty($this->cachedWarehouseIds[$wareHouseName]))
return $this->cachedWarehouseIds[$wareHouseName];
return false;
}
/**
* @param string $gtin
* @param string $modellNr
* @param string $modellBez
* @return false|int|mixed|null
*/
private function checkProduct(string $gtin,string $modellNr,string $modellBez){
#*** WEnn keine geCached Id Vorhanden
if(empty($this->cachedProdIds[$gtin])){
@@ -244,16 +259,18 @@ class HiltesImport
if(empty($prod2)){
$prod = new Product();
$prod->setGtin($gtin);
$prod->setModellNr($modellNr);
$prod->setModellBez($modellBez);
$prod->setModellNr(trim($modellNr));
$prod->setModellBez(trim($modellBez));
$prod->setShopwareId("");
#
$this->productRepository->save($prod,true);
$this->cachedProdIds[$gtin] = $this->productRepository->save($prod,true);
#*****************
$prod2 = $this->productRepository->findOneBy(['gtin'=> $gtin]);
//$prod2 = $this->productRepository->findOneBy(['gtin'=> $gtin]);
#dump($warehouse2);
}
$this->cachedProdIds[$gtin] = $prod2->getId();
}else{
$this->cachedProdIds[$gtin] = $prod2->getId();
}
}
if(!empty($this->cachedProdIds[$gtin]))
return $this->cachedProdIds[$gtin];