getTranslationLanguages()) as $langcode) { $translation = $this->getTranslation($langcode); // If no owner has been set explicitly, make the anonymous user the owner. if (!$translation->getOwner()) { $translation->setOwnerId(0); } } // If no revision author has been set explicitly, make the heartbeat owner the // revision author. if (!$this->getRevisionUser()) { $this->setRevisionUserId($this->getOwnerId()); } } /** * {@inheritdoc} */ public function getType() { return $this->bundle(); } /** * {@inheritdoc} */ public function getName() { return $this->get('name')->value; } /** * {@inheritdoc} */ public function setName($name) { $this->set('name', $name); return $this; } /** * Gets the Heartbeat message. * * @return string * Message of the Heartbeat. */ public function getMessage() { return $this->get('message'); } /** * Sets the Heartbeat Message. * * @param $name * @return * @internal param string $message The Heartbeat Message */ public function setMessage($message) { $this->set('message', $message); } /** * {@inheritdoc} */ public function getCreatedTime() { return $this->get('created')->value; } /** * {@inheritdoc} */ public function setCreatedTime($timestamp) { $this->set('created', $timestamp); return $this; } /** * {@inheritdoc} */ public function getOwner() { return $this->get('uid')->entity; } /** * {@inheritdoc} */ public function getOwnerId() { return $this->get('uid')->target_id; } /** * {@inheritdoc} */ public function setOwnerId($uid) { $this->set('uid', $uid); return $this; } /** * {@inheritdoc} */ public function setOwner(UserInterface $account) { $this->set('uid', $account->id()); return $this; } /** * {@inheritdoc} */ public function isPublished() { return (bool) $this->getEntityKey('status'); } /** * {@inheritdoc} */ public function setPublished($published) { $this->set('status', $published ? TRUE : FALSE); return $this; } /** * {@inheritdoc} */ public function getRevisionCreationTime() { return $this->get('revision_timestamp')->value; } /** * {@inheritdoc} */ public function setRevisionCreationTime($timestamp) { $this->set('revision_timestamp', $timestamp); return $this; } /** * {@inheritdoc} */ public function getRevisionUser() { return $this->get('revision_uid')->entity; } /** * {@inheritdoc} */ public function setRevisionUserId($uid) { $this->set('revision_uid', $uid); return $this; } /** * {@inheritdoc} */ public static function baseFieldDefinitions(EntityTypeInterface $entity_type) { $fields = parent::baseFieldDefinitions($entity_type); $fields['uid'] = BaseFieldDefinition::create('entity_reference') ->setLabel(t('Authored by')) ->setDescription(t('The user ID of author of the Heartbeat entity.')) ->setRevisionable(TRUE) ->setSetting('target_type', 'user') ->setSetting('handler', 'default') ->setTranslatable(TRUE) ->setDisplayOptions('view', array( 'label' => 'hidden', 'type' => 'author', 'weight' => 0, )) ->setDisplayOptions('form', array( 'type' => 'entity_reference_autocomplete', 'weight' => 5, 'settings' => array( 'match_operator' => 'CONTAINS', 'size' => '60', 'autocomplete_type' => 'tags', 'placeholder' => '', ), )) ->setDisplayConfigurable('form', TRUE) ->setDisplayConfigurable('view', TRUE); $fields['nid'] = BaseFieldDefinition::create('entity_reference') ->setLabel(t('Node')) ->setDescription(t('The content associated with this Heartbeat')) ->setSetting('target_type', 'node') ->setSetting('handler', 'default') ->setDisplayOptions('view', array( 'label' => 'hidden', 'type' => 'content', 'weight' => 0, )) ->setDisplayConfigurable('view', TRUE) ->setRevisionable(TRUE); $fields['name'] = BaseFieldDefinition::create('string') ->setLabel(t('Name')) ->setDescription(t('The name of the Heartbeat entity.')) ->setRevisionable(TRUE) ->setSettings(array( 'max_length' => 50, 'text_processing' => 0, )) ->setDefaultValue('') ->setDisplayOptions('view', array( 'label' => 'above', 'type' => 'string', 'weight' => -4, )) ->setDisplayOptions('form', array( 'type' => 'string_textfield', 'weight' => -4, )) ->setDisplayConfigurable('form', TRUE) ->setDisplayConfigurable('view', TRUE); $fields['message'] = BaseFieldDefinition::create('string_long') ->setLabel(t('Message')) ->setDescription(t('The message of the Heartbeat entity.')) ->setRevisionable(TRUE) ->setDisplayOptions('view', array( 'label' => 'above', 'type' => 'full_html', 'weight' => -4, )) ->setDisplayConfigurable('view', TRUE); $fields['comments'] = BaseFieldDefinition::create('comment') ->setLabel(t('Kommentare')) ->setDescription(t('Kommentare.')) ->setCardinality(BaseFieldDefinition::CARDINALITY_UNLIMITED) ->setSettings( array( 'default_mode'=> 1, 'per_page'=>50, 'anonymous'=> 0, 'form_location'=>1, 'preview'=> 1, 'comment_type'=>'heartbeat_comment', 'locked'=>false, )) ->setDefaultValue( array( 'status'=>2, 'cid'=>0, 'last_comment_timestamp'=> 0, 'last_comment_name'=> null, 'last_comment_uid'=> 0, 'comment_count'=> 0, ) ) ->setDisplayOptions('form', array( 'type' => 'comment_default', 'settings' => array( 'form_location' => 1, 'default_mode'=> 1, 'per_page'=>50, 'anonymous'=> 0, 'preview'=> 1, 'comment_type'=>'heartbeat_comment', 'locked'=>false, ), 'weight' => 1, )) ->setDisplayConfigurable('form', TRUE) ->setDisplayConfigurable('view', TRUE); $fields['status'] = BaseFieldDefinition::create('boolean') ->setLabel(t('Publishing status')) ->setDescription(t('A boolean indicating whether the Heartbeat is published.')) ->setRevisionable(TRUE) ->setDefaultValue(TRUE); $fields['created'] = BaseFieldDefinition::create('created') ->setLabel(t('Created')) ->setDescription(t('The time that the entity was created.')); $fields['changed'] = BaseFieldDefinition::create('changed') ->setLabel(t('Changed')) ->setDescription(t('The time that the entity was last edited.')); $fields['revision_timestamp'] = BaseFieldDefinition::create('created') ->setLabel(t('Revision timestamp')) ->setDescription(t('The time that the current revision was created.')) ->setQueryable(FALSE) ->setRevisionable(TRUE); $fields['revision_uid'] = BaseFieldDefinition::create('entity_reference') ->setLabel(t('Revision user ID')) ->setDescription(t('The user ID of the author of the current revision.')) ->setSetting('target_type', 'user') ->setQueryable(FALSE) ->setRevisionable(TRUE); $fields['revision_translation_affected'] = BaseFieldDefinition::create('boolean') ->setLabel(t('Revision translation affected')) ->setDescription(t('Indicates if the last edit of a translation belongs to current revision.')) ->setReadOnly(TRUE) ->setRevisionable(TRUE) ->setTranslatable(TRUE); return $fields; } /** * Returns the node type label for the passed node. * * @param \Drupal\heartbeat\Entity\HeartbeatInterface $heartbeat * A heartbeat entity to return the heartbeat type's label for. * * @return string|false * The heartbeat type label or FALSE if the heartbeat type is not found. * * @todo Add this as generic helper method for config entities representing * entity bundles. */ public function heartbeat_get_type(HeartbeatInterface $heartbeat) { $type = HeartbeatType::load($heartbeat->bundle()); return $type ? $type->label() : FALSE; } /** * Updates all heartbeat activities of one type to be of another type. * * @param string $old_id * The current heartbeat type of the activities. * @param string $new_id * The new heartbeat type of the activities. * * @return * The number of activities whose heartbeat type field was modified. */ public function heartbeat_type_update_nodes($old_id, $new_id) { return \Drupal::entityManager()->getStorage('heartbeat')->updateType($old_id, $new_id); } /** * Builds a message template for a given HeartbeatType * * @param HeartbeatType $heartbeatType * @param null $mediaData * @return null|string */ public static function buildMessage(Token $tokenService, $preparsedMessage, $entities = NULL, $entityType, $mediaData = NULL) { $arbitrarious = 'nothing at all'; $naul = 'nullll'; $preparsedMessage = self::wrapOwner($preparsedMessage, $entities); switch (true) { case $entityType === 'node': // $parsedMessage = $tokenService->replace($preparsedMessage . '', $entities); $parsedMessage = $tokenService->replace($preparsedMessage, $entities); if (strpos($parsedMessage, '#')) { self::parseHashtags($parsedMessage); } if (strpos($parsedMessage, '@')) { self::parseUsernames($parsedMessage); } /** @noinspection NestedTernaryOperatorInspection */ $message = $parsedMessage; $message .= $mediaData ? self::buildMediaMarkup($mediaData) : ''; // $message .= ''; return $message; break; case $entityType === 'status': $parsedMessage = $tokenService->replace($preparsedMessage . '', $entities); /** @noinspection NestedTernaryOperatorInspection */ $message = $parsedMessage; $message .= $mediaData ? self::buildMediaMarkup($mediaData) : 'Post'; $message .= ''; return $message; break; case $entityType === 'user': break; case $entityType === 'flag': $returnMessage = self::handleMultipleEntities($tokenService, $preparsedMessage, $entities); return strlen($returnMessage) > 0 ? $returnMessage : "Error creating message"; break; } } private static function buildMediaMarkup($mediaData) { $markup = ''; foreach ($mediaData as $media) { $markup .= self::mediaTag($media->type, $media->path); } return $markup; } private static function mediaTag($type, $filePath) { //TODO put this into new method if ($type == 'image') { $type = 'img'; return '<' . $type . ' src="' . str_replace('public://', '/sites/default/files/', $filePath) . '" class="heartbeat-image" / >'; } else if ($type == 'youtube') { $filePath = str_replace('youtube://', 'https://www.youtube.com/embed/', $filePath); return ''; } else if ($type == 'video') { return '<' . $type . ' controls src="' . str_replace('public://', '/sites/default/files/', $filePath) . '" class="heartbeat-video">' . $type . '>'; } } protected static function handleMultipleEntities(Token $tokenService, $message, $entities) { $tokens = $tokenService->scan($message); foreach($tokens as $key => $token) { foreach ($token as $type) { if (substr_count($message, $type) > 1) { foreach ($entities as $entityKey => $entityValue) { if ($entityValue instanceof \stdClass && count($entityValue->entities) > 1) { if ($key == $entityValue->type) { $messageArray = explode($type, $message); $stringRebuild = array(); $replacements = array(); $i = 0; foreach ($entityValue->entities as $entity) { $stringRebuild[] = $tokenService->replace($message, array($key => $entity)); foreach (self::getWordRepeats($stringRebuild[$i]) as $word => $num) { if ($num > 1 && !strpos($messageArray[1], $word)) { $replacements[] = $word; } } $i++; } if (count($replacements) == 2) { $uid = $entityValue->entities[0]->id(); $uid_target = $entityValue->entities[1]->id(); $query = Database::getConnection()->query(' SELECT status FROM heartbeat_friendship WHERE uid = :uid AND uid_target = :uid_target', array( ':uid' => $uid, ':uid_target' => $uid_target ) ); if ($query->fetchCol()[0] < 1) { $messageArray[1] = ' has requested friendship with '; } $user1Link = Link::fromTextAndUrl($replacements[0], $entityValue->entities[0]->toUrl()); $user2Link = Link::fromTextAndUrl($replacements[1], $entityValue->entities[1]->toUrl()); $rebuiltMessage = $user1Link->toString() . $messageArray[1] . $user2Link->toString(); return $rebuiltMessage; } } } } } } } return null; } public static function parseHashtags(&$message) { $lastRow = false; $tagsArray = explode('#', $message); $i = 0; $num = count($tagsArray); foreach ($tagsArray as $hashtag) { if ($i === $num - 1) { $lastTagArray = explode(' ', $hashtag); if (strlen($lastTagArray[1]) > 1) { $hashtag = trim($lastTagArray[0]); $lastRow = true; $remainder = ''; $lastRowArgCount = count($lastTagArray); for ($x = 1; $x < $lastRowArgCount; $x++) { $remainder .= ' ' . $lastTagArray[$x]; } } } $tid = \Drupal::entityQuery("taxonomy_term") ->condition("name", trim($hashtag)) ->condition('vid', [ 'twitter', 'tags', 'kekistan' ], 'IN') ->execute(); if (count($tid) > 0) { $term = Term::load(array_values($tid)[0]); $link = Link::fromTextAndUrl('#' . $hashtag, $term->toUrl()); $tagsArray[$i] = '