/** * Fill body data * * @param \AnimeDb\Bundle\CatalogBundle\Entity\Item $item * @param \DOMXPath $xpath * @param \DOMElement $body * @param integer $id * @param boolean $frames * @param string $type * * @return \AnimeDb\Bundle\CatalogBundle\Entity\Item */ private function fillBodyData(Item $item, \DOMXPath $xpath, \DOMElement $body, $id, $frames, $type) { for ($i = 0; $i < $body->childNodes->length; $i++) { if ($value = trim($body->childNodes->item($i)->nodeValue)) { switch ($value) { // get summary case 'Краткое содержание:': $summary = $xpath->query('tr/td/p[1]', $body->childNodes->item($i + 2)); if ($summary->length) { $item->setSummary($this->getNodeValueAsText($summary->item(0))); } $i += 2; break; // get episodes // get episodes case 'Эпизоды:': if (!trim($body->childNodes->item($i + 1)->nodeValue)) { // simple list $item->setEpisodes($this->getNodeValueAsText($body->childNodes->item($i + 2))); $i += 2; } else { // episodes in table $rows = $xpath->query('tr/td[2]', $body->childNodes->item($i + 1)); $episodes = ''; for ($j = 1; $j < $rows->length; $j++) { $episode = $xpath->query('font', $rows->item($j)); $episodes .= $j . '. ' . $episode->item(0)->nodeValue; if ($rows->length > 1) { $episodes .= ' (' . $episode->item(1)->nodeValue . ')'; } $episodes .= "\n"; } $item->setEpisodes($episodes); $i++; } break; // get date premiere // get date premiere case 'Даты премьер и релизов': $rows = $xpath->query('tr/td/table/tr/td[3]', $body->childNodes->item($i + 1)); foreach ($rows as $row) { if (preg_match('/\\d{4}\\.\\d{2}\\.\\d{2}/', $row->nodeValue, $match)) { $date = new \DateTime(str_replace('.', '-', $match[0])); if (!$item->getDatePremiere() || $item->getDatePremiere() > $date) { $item->setDatePremiere($date); } } } break; default: // get frames if ((strpos($value, 'кадры из аниме') !== false || strpos($value, 'Кадры из фильма') !== false) && $id && $frames) { foreach ($this->getFrames($id, $type) as $frame) { $item->addImage($frame); } } } } } }
/** * @param Item $item * @param Crawler $body * * @return Item */ public function setEpisodes(Item $item, Crawler $body) { $episodes = ''; foreach ($body->filter('episodes > episode') as $episode) { $episode = new Crawler($episode); $episodes .= $episode->filter('epno')->text() . '. ' . $this->getEpisodeTitle($episode) . "\n"; } $item->setEpisodes(trim($episodes)); return $item; }
/** * Fill item * * @param \AnimeDb\Bundle\CatalogBundle\Entity\Item $item * @param \AnimeDb\Bundle\CatalogBundle\Entity\Item $new_item * @param string $field * * @return \AnimeDb\Bundle\CatalogBundle\Entity\Item */ protected function fillItem(Item $item, Item $new_item, $field) { switch ($field) { case self::FIELD_COUNTRY: $item->setCountry($new_item->getCountry()); break; case self::FIELD_DATE_END: $item->setDateEnd($new_item->getDateEnd()); break; case self::FIELD_DATE_PREMIERE: $item->setDatePremiere($new_item->getDatePremiere()); break; case self::FIELD_DURATION: $item->setDuration($new_item->getDuration()); break; case self::FIELD_EPISODES: $item->setEpisodes($new_item->getEpisodes()); break; case self::FIELD_EPISODES_NUMBER: $item->setEpisodesNumber($new_item->getEpisodesNumber()); break; case self::FIELD_FILE_INFO: $item->setFileInfo($new_item->getFileInfo()); break; case self::FIELD_GENRES: /* @var $new_genre \AnimeDb\Bundle\CatalogBundle\Entity\Genre */ foreach ($new_item->getGenres() as $new_genre) { $item->addGenre($new_genre); } break; case self::FIELD_NAMES: // set main name in top of names list $new_names = $new_item->getNames()->toArray(); array_unshift($new_names, (new Name())->setName($new_item->getName())); foreach ($new_names as $new_name) { $item->addName($new_name); } break; case self::FIELD_SOURCES: foreach ($new_item->getSources() as $new_source) { $item->addSource($new_source); } break; case self::FIELD_STUDIO: $item->setStudio($new_item->getStudio()); break; case self::FIELD_SUMMARY: $item->setSummary($new_item->getSummary()); break; } return $item; }