/**
  * 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);
                         }
                     }
             }
         }
     }
 }
Example #2
0
 /**
  * @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;
 }