Browse Source

Starting clean

logicp 8 years ago
parent
commit
a708e0b8e0
55 changed files with 0 additions and 3821 deletions
  1. 0 1
      README.md
  2. 0 14
      composer.json
  3. 0 1
      config/install/heartbeat8.templatelist.yml
  4. 0 11
      config/install/system.action.heartbeat.yml
  5. 0 12
      config/schema/heartbeat.schema.yml
  6. 0 34
      config/schema/heartbeat_stream_entity.schema.yml
  7. 0 12
      config/schema/heartbeat_type.schema.yml
  8. 0 30
      heartbeat.page.inc
  9. 0 97
      heartbeat.streams.inc
  10. 0 5
      heartbeat8.info.yml
  11. 0 353
      heartbeat8.install
  12. 0 8
      heartbeat8.libraries.yml
  13. 0 23
      heartbeat8.links.action.yml
  14. 0 41
      heartbeat8.links.menu.yml
  15. 0 23
      heartbeat8.links.task.yml
  16. 0 70
      heartbeat8.module
  17. 0 32
      heartbeat8.module.php
  18. 0 33
      heartbeat8.permissions.yml
  19. 0 23
      heartbeat8.routing.yml
  20. 0 149
      heartbeatstream.inc
  21. 0 106
      includes/heartbeatstreamconfig.inc
  22. 0 73
      src/Controller/HeartbeatController.php
  23. 0 309
      src/Entity/Heartbeat.php
  24. 0 126
      src/Entity/HeartbeatInterface.php
  25. 0 254
      src/Entity/HeartbeatStreamEntity.php
  26. 0 193
      src/Entity/HeartbeatStreamEntityInterface.php
  27. 0 62
      src/Entity/HeartbeatType.php
  28. 0 13
      src/Entity/HeartbeatTypeInterface.php
  29. 0 24
      src/Entity/HeartbeatViewsData.php
  30. 0 15
      src/Form/HeartbeatDeleteForm.php
  31. 0 82
      src/Form/HeartbeatForm.php
  32. 0 123
      src/Form/HeartbeatRevisionDeleteForm.php
  33. 0 149
      src/Form/HeartbeatRevisionRevertForm.php
  34. 0 115
      src/Form/HeartbeatRevisionRevertTranslationForm.php
  35. 0 55
      src/Form/HeartbeatSettingsForm.php
  36. 0 52
      src/Form/HeartbeatStreamEntityDeleteForm.php
  37. 0 83
      src/Form/HeartbeatStreamEntityForm.php
  38. 0 53
      src/Form/HeartbeatTypeDeleteForm.php
  39. 0 67
      src/Form/HeartbeatTypeForm.php
  40. 0 99
      src/Form/TemplateList.php
  41. 0 47
      src/HeartbeatAccessControlHandler.php
  42. 0 225
      src/HeartbeatHtmlRouteProvider.php
  43. 0 45
      src/HeartbeatListBuilder.php
  44. 0 58
      src/HeartbeatStorage.php
  45. 0 61
      src/HeartbeatStorageInterface.php
  46. 0 95
      src/HeartbeatStreamEntityHtmlRouteProvider.php
  47. 0 31
      src/HeartbeatStreamEntityListBuilder.php
  48. 0 14
      src/HeartbeatTranslationHandler.php
  49. 0 59
      src/HeartbeatTypeHtmlRouteProvider.php
  50. 0 32
      src/HeartbeatTypeListBuilder.php
  51. 0 37
      src/Plugin/Action/Heartbeat.php
  52. 0 46
      src/Tests/LoadTest.php
  53. 0 23
      templates/heartbeat-content-add-list.html.twig
  54. 0 22
      templates/heartbeat.html.twig
  55. 0 1
      templates/heartbeat8.html.twig

+ 0 - 1
README.md

@@ -1 +0,0 @@
-README

+ 0 - 14
composer.json

@@ -1,14 +0,0 @@
-{
-  "name": "drupal/heartbeat8",
-  "type": "drupal-module",
-  "description": "Heartbeat for Drupal 8",
-  "keywords": ["Drupal"],
-  "license": "GPL-2.0+",
-  "homepage": "https://www.drupal.org/project/heartbeat8",
-  "minimum-stability": "dev",
-  "support": {
-    "issues": "https://www.drupal.org/project/issues/heartbeat8",
-    "source": "http://cgit.drupalcode.org/heartbeat8"
-  },
-  "require": { }
-}

+ 0 - 1
config/install/heartbeat8.templatelist.yml

@@ -1 +0,0 @@
-heartbeat8:

+ 0 - 11
config/install/system.action.heartbeat.yml

@@ -1,11 +0,0 @@
-id: heartbeat
-label: 'Heartbeat'
-status: true
-langcode: en
-type: user
-plugin: heartbeat
-dependencies:
-  module:
-    - user
-    - heartbeat8
-

+ 0 - 12
config/schema/heartbeat.schema.yml

@@ -1,12 +0,0 @@
-heartbeat8.heartbeat.*:
-  type: config_entity
-  label: 'Heartbeat config'
-  mapping:
-    id:
-      type: string
-      label: 'ID'
-    label:
-      type: label
-      label: 'Label'
-    uuid:
-      type: string

+ 0 - 34
config/schema/heartbeat_stream_entity.schema.yml

@@ -1,34 +0,0 @@
-heartbeat8.heartbeat_stream_entity.*:
-  type: config_entity
-  label: 'Heartbeat stream entity config'
-  mapping:
-    hid:
-      type: serial
-      label: 'hid'
-    message_id:
-      type: string
-      label: 'message_id'
-    description:
-      type: string
-      label: 'description'
-    message:
-      type: string
-      label: 'message'
-    message_concat:
-      type: string
-      label: 'message_concat'
-    perms:
-      type: integer
-      label: 'perms'
-    group_type:
-      type: string
-      label: 'group_type'
-    concat_args:
-      type: blob
-      label: 'concat_args'
-    variables:
-      type: blob
-      label: 'variables'
-    attachments:
-      type: blob
-      label: 'attachments'

+ 0 - 12
config/schema/heartbeat_type.schema.yml

@@ -1,12 +0,0 @@
-heartbeat8.heartbeat_type.*:
-  type: config_entity
-  label: 'Heartbeat type config'
-  mapping:
-    id:
-      type: string
-      label: 'ID'
-    label:
-      type: label
-      label: 'Label'
-    uuid:
-      type: string

+ 0 - 30
heartbeat.page.inc

@@ -1,30 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains heartbeat.page.inc.
- *
- * Page callback for Heartbeat entities.
- */
-
-use Drupal\Core\Render\Element;
-
-/**
- * Prepares variables for Heartbeat templates.
- *
- * Default template: heartbeat.html.twig.
- *
- * @param array $variables
- *   An associative array containing:
- *   - elements: An associative array containing the user information and any
- *   - attributes: HTML attributes for the containing element.
- */
-function template_preprocess_heartbeat(array &$variables) {
-  // Fetch Heartbeat Entity Object.
-  $heartbeat = $variables['elements']['#heartbeat'];
-
-  // Helpful $content variable for templates.
-  foreach (Element::children($variables['elements']) as $key) {
-    $variables['content'][$key] = $variables['elements'][$key];
-  }
-}

+ 0 - 97
heartbeat.streams.inc

@@ -1,97 +0,0 @@
-<?php
-
-use \Drupal\Core\Extension\ModuleHandler;
-
-/**
- * Prepares a heartbeat stream
- * @param $stream_name the name of the stream
- */
-
-function heartbeat_stream($stream_name, $page = 0, $account = NULL) {
-  static $streams;
-
-  try {
-
-    if (!isset($streams[$stream_name])) {
-      //Load configuration object for the stream
-      $streamConfig = heartbeat_stream_config_load($stream_name);
-
-      //Load the stream if access is permitted
-      if (_heartbeat_stream_has_access($streamConfig)) {
-
-        $heartbeatStream = HeartbeatStreamFactory::getStream($streamConfig, $page, $account);
-
-        //Add settings that need to be set for each stream
-        //TODO equivalent drupal_add_js to attach streamconfig messages to the drupalSettings object
-        /*
-         * drupal_add_js(array('heartbeatPollNewerMessages' => array($streamConfig->class => $streamConfig->poll_messages)), 'setting');
-         * drupal_add_js(array('heartbeatPollTypes' => array($streamConfig->class => $streamConfig->poll_messages_type)), 'setting');
-         *
-         *
-         */
-
-        //Give other modules a chance to take action when stream is loaded
-
-        ModuleHandler::invokeAll('heartbeat_stream_load', $heartbeatStream);
-
-        if ($heartbeatStream instanceof HeartbeatStream && !$heartbeatStream->hasErrors()) {
-          $streams[$stream_name] = $heartbeatStream;
-        } else {
-          $streams[$stream_name] = FALSE;
-        }
-      } else {
-        $streams[$stream_name] = FALSE;
-      }
-    }
-  } catch (HeartbeatInvalidStreamException $he) {
-    $errorMessage = $he->getMessage();
-    drupal_set_message($errorMessage);
-    \Drupal::logger('HeartbeatDEBUG')->error('Error message: %errMsg', array(
-      '%errMsg' => $errorMessage
-    ));
-  }
-
-  return $streams[$stream_name];
-}
-
-/*
- * Builds a heartbeat stream in the StreamObject
- */
-
-function heartbeat_stream_build(HeartbeatStream &$heartbeatStream) {
-  //Load messages
-  $messages = $heartbeatStream->execute();
-}
-
-/*
- * Builds a stream from Views Results
- */
-
-function heartbeat_stream_views_build(HeartbeatStream &$heartbeatStream, $view_mode = NULL) {
-
-  if (isset($view_mode)) {
-    $heartbeatStream->setViewMode($view_mode);
-  }
-
-  $build = $heartbeatStream->render();
-
-  return $build;
-}
-
-
-/**
- * Load all the stream configuration objects
- * @param bool $reset
- *  Indicates whether the stream data needs to be rebuilt
- */
-
-function heartbeat_stream_config_load_all($reset = FALSE) {
-  $streams = &drupal_static('heartbeat_streams');
-
-  if (!$reset && $object = cache_get('heartbeat_streams')) {
-    $streams = $object->data;
-  } else {
-    //TODO fetch streams with alternative to ctools export
-  }
-}
-

+ 0 - 5
heartbeat8.info.yml

@@ -1,5 +0,0 @@
-name: heartbeat8
-type: module
-description: Heartbeat for Drupal 8
-core: 8.x
-package: Heartbeat

+ 0 - 353
heartbeat8.install

@@ -1,353 +0,0 @@
-<?php
-
-/**
- * @file
- * Install, update and uninstall functions for the node module.
- */
-
-use Drupal\Core\Field\BaseFieldDefinition;
-use Drupal\user\RoleInterface;
-
-/**
- * Implements hook_requirements().
- */
-function heartbeat8_requirements($phase) {
-  $requirements = array();
-  if ($phase === 'runtime') {
-    // Only show rebuild button if there are either 0, or 2 or more, rows
-    // in the {node_access} table, or if there are modules that
-    // implement hook_node_grants().
-    $grant_count = \Drupal::entityManager()->getAccessControlHandler('node')->countGrants();
-    if ($grant_count != 1 || count(\Drupal::moduleHandler()->getImplementations('node_grants')) > 0) {
-      $value = \Drupal::translation()->formatPlural($grant_count, 'One permission in use', '@count permissions in use', array('@count' => $grant_count));
-    }
-    else {
-      $value = t('Disabled');
-    }
-
-    $requirements['node_access'] = array(
-      'title' => t('Node Access Permissions'),
-      'value' => $value,
-      'description' => t('If the site is experiencing problems with permissions to content, you may have to rebuild the permissions cache. Rebuilding will remove all privileges to content and replace them with permissions based on the current modules and settings. Rebuilding may take some time if there is a lot of content or complex permission settings. After rebuilding has completed, content will automatically use the new permissions. <a href=":rebuild">Rebuild permissions</a>', array(
-        ':rebuild' => \Drupal::url('node.configure_rebuild_confirm'),
-      )),
-    );
-  }
-  return $requirements;
-}
-
-/**
- * Implements hook_schema().
- * ** //TODO Have not yet set export schema for CTOOLS as CTOOLS is not yet a part of Drupal 8
- */
-function heartbeat8_schema() {
-  $schema['heartbeat_messages'] = array(
-    'description' => 'Table that contains predefined messages that can be used in heartbeat views.',
-    'fields' => array(
-      'hid' => array(
-        'description' => 'Primary Key: Unique heartbeat_messages event ID.',
-        'type' => 'serial',
-        'not null' => TRUE,
-      ),
-      'message_id' => array(
-        'description' => 'The message id which is unique to identify activity.',
-        'type' => 'varchar',
-        'length' => 255,
-        'not null' => FALSE,
-        'default' => '',
-      ),
-      'description' => array(
-        'description' => 'Description and help text',
-        'type' => 'text',
-        'not null' => FALSE,
-        'size' => 'big'
-      ),
-      'message' => array(
-        'type' => 'text',
-        'not null' => TRUE,
-        'size' => 'big',
-        'description' => 'Text of log message to be passed into the ) function.',
-        //'alias' => 'message_orig', // Internal heartbeat field/property
-      ),
-      'message_concat' => array(
-        'type' => 'text',
-        'not null' => TRUE,
-        'size' => 'big',
-        'description' => 'Text of translatable log message for in concatenated form.',
-        //'alias' => 'message_concat_orig', // Internal heartbeat field/property
-      ),
-      'perms' => array(
-        'type' => 'int',
-        'unsigned' => TRUE,
-        'not null' => FALSE,
-        'default' => 4,
-        'description' => 'Permissions for this message.',
-      ),
-      'group_type' => array(
-        'type' => 'varchar',
-        'length' => 20,
-        'not null' => TRUE,
-        'default' => 'single',
-        'description' => 'The group type of the template',
-      ),
-      'concat_args' => array(
-        'description' => 'Arguments for concatenation message.',
-        'type' => 'blob',
-        'serialize' => TRUE,
-        'not null' => FALSE,
-      ),
-      'variables' => array(
-        'description' => 'Variables to parse into the message (used in message).',
-        'type' => 'blob',
-        'serialize' => TRUE,
-        'not null' => FALSE,
-      ),
-      'attachments' => array(
-        'description' => 'Attachments on messages.',
-        'type' => 'blob',
-        'serialize' => TRUE,
-        'not null' => FALSE,
-      ),
-    ),
-    'primary key' => array('hid'),
-    'indexes' => array(
-      'message_id' => array('message_id'),
-    ),
-  );
-
-
-
-  $schema['heartbeat_activity'] = array(
-    'description' => 'Table that contains logs of all user triggerable actions.',
-    'fields' => array(
-      'uaid' => array(
-        'type' => 'serial',
-        'not null' => TRUE,
-        'description' => 'Primary Key: Unique heartbeat_activity event ID.',
-      ),
-      'uid' => array(
-        'type' => 'int',
-        'unsigned' => TRUE,
-        'not null' => TRUE,
-        'default' => 0,
-        'description' => 'The {users}.uid of the user who triggered the event (requester).',
-      ),
-      'uid_target' => array(
-        'type' => 'int',
-        'unsigned' => TRUE,
-        'not null' => FALSE,
-        'default' => 0,
-        'description' => 'The target User ID',
-      ),
-      'nid' => array(
-        'description' => 'The Node ID.',
-        'type' => 'int',
-        'unsigned' => TRUE,
-        'not null' => FALSE,
-      ),
-      'nid_target' => array(
-        'description' => 'The target Node ID (E.g. Group id, node reference, ...).',
-        'type' => 'int',
-        'unsigned' => TRUE,
-        'not null' => FALSE,
-      ),
-      'cid' => array(
-        'description' => 'The target comment ID (optional).',
-        'type' => 'int',
-        'unsigned' => TRUE,
-        'not null' => FALSE,
-      ),
-      'access' => array(
-        'type' => 'int',
-        'not null' => TRUE,
-        'size' => 'tiny',
-        'description' => 'Access for this message to others.',
-        'default' => 0,
-      ),
-      'message_id' => array(
-        'type' => 'varchar',
-        'length' => 255,
-        'not null' => FALSE,
-        'default' => '',
-        'description' => 'The message id which links to the heartbeat message.',
-      ),
-      'timestamp' => array(
-        'description' => 'The activity\'s unix timestamp when action occurred',
-        'type' => 'int',
-        'unsigned' => TRUE,
-        'not null' => TRUE,
-        'default' => 0,
-      ),
-      'language' => array(
-        'type' => 'varchar',
-        'length' => 12,
-        'not null' => FALSE,
-        'default' => 'en',
-        'description' => 'language for a log".',
-      ),
-      'variables' => array(
-        'type' => 'text',
-        'not null' => FALSE,
-        'size' => 'big',
-        'description' => 'Serialized array of variables that match the message string and that is passed into the ) function.',
-      ),
-      'in_group' => array(
-        'type' => 'int',
-        'not null' => TRUE,
-        'size' => 'big',
-        'description' => 'Indicates whether the activity is related to a group',
-        'default' => 0,
-      ),
-    ),
-    'primary key' => array('uaid'),
-    'indexes' => array(
-      'timestamp' => array('timestamp'),
-      'uid' => array('uid'),
-      'message_id' => array('message_id'),
-      'uid_target' => array('uid_target'),
-      'nid' => array('nid'),
-      'nid_target' => array('nid_target'),
-      'cid' => array('cid'),
-      'language' => array('language'),
-      ),
-
-  );
-
-  $schema['heartbeat_activity']['fields']['in_group'] = array(
-    'type' => 'int',
-    'not null' => TRUE,
-    'size' => 'big',
-    'description' => 'Indicates whether the activity is related to a group.',
-    'default' => 0,
-  );
-  $schema['heartbeat_activity']['indexes']['in_group'] = array('in_group');
-  $schema['heartbeat_user_templates'] = heartbeat_install_table_user_templates();
-
-
-  $schema['heartbeat_streams'] = array(
-    'description' => 'Table that contains heartbeat streams.',
-    // CTools export definitions.
-//    'export' => array(
-//      'key' => 'class',
-//      'key name' => 'name',
-//      'primary key' => 'class',
-//      'bulk export' => TRUE,
-//      'identifier' => 'heartbeatstream',
-//      'object' => 'HeartbeatStreamConfig',
-//      'default hook' => 'heartbeat_stream_info',
-//      'load callback' => '_heartbeat_stream_config_load',
-//      'load all callback' => '_heartbeat_stream_config_load_all',
-//      'can disable' => TRUE,
-//      'api' => array(
-//        'owner' => 'heartbeat',
-//        'api' => 'heartbeat',
-//        'minimum_version' => 1,
-//        'current_version' => 1,
-//      ),
-//    ),
-    'fields' => array(
-      'class' => array(
-        'type' => 'varchar',
-        'length' => 100,
-        'not null' => TRUE,
-        'default' => '',
-        'description' => 'Class of the stream to load.',
-      ),
-      'real_class' => array(
-        'type' => 'varchar',
-        'length' => 100,
-        'not null' => TRUE,
-        'default' => '',
-        'description' => 'Real Class of the stream to load.',
-      ),
-      'name' => array(
-        'type' => 'varchar',
-        'length' => 100,
-        'not null' => TRUE,
-        'default' => '',
-        'description' => 'Name of the stream. Cloned streams will have the same object but same cla
-ss.',
-      ),
-      'module' => array(
-        'type' => 'varchar',
-        'length' => 100,
-        'not null' => TRUE,
-        'default' => '',
-        'description' => 'The module that defines the class and where the query builder is located.
-',
-      ),
-      'title' => array(
-        'type' => 'varchar',
-        'length' => 100,
-        'not null' => TRUE,
-        'default' => '',
-        'description' => 'Human readable name of the stream.',
-      ),
-      'path' => array(
-        'type' => 'varchar',
-        'length' => 250,
-        'not null' => TRUE,
-        'default' => '',
-        'description' => 'Path to the stream object.',
-      ),
-      'settings' => array(
-        'description' => 'Serialized settings for this stream.',
-        'type' => 'blob',
-        'serialize' => TRUE,
-        'not null' => FALSE,
-      ),
-      'variables' => array(
-        'description' => 'Variables to parse into the message (used in message).',
-        'type' => 'blob',
-        'serialize' => TRUE,
-        'not null' => FALSE,
-      ),
-      'real_class' => array(
-        'type' => 'varchar',
-        'length' => 100,
-        'not null' => TRUE,
-        'default' => '',
-          'description' => 'Real Class of the stream to load',
-      )
-    ),
-    'primary key' => array('class'),
-    'indexes' => array(
-      'name' => array('name'),
-    ),
-  );
-
-  //TODO determine if these foreign keys are to be added
-//  db_add_unique_key('heartbeat_activity', 'uaid', array('uaid'));
-//  db_add_unique_key('heartbeat_activity', 'uaid_uid', array('uaid', 'uid'));
-//  db_add_unique_key('heartbeat_activity', 'uaid_nid', array('uaid', 'nid'));
-//  db_add_unique_key('heartbeat_activity', 'uaid_uid_nid', array('uaid', 'uid', 'nid'))
-
-
-  return $schema;
-
-}
-
-function heartbeat_install_table_user_templates() {
-  return array(
-    'description' => 'Table that connects translations of the same activity.',
-    'fields' => array(
-      'uid' => array(
-        'type' => 'int',
-        'not null' => TRUE,
-        'description' => 'The referenced user ID.',
-      ),
-      'message_id' => array(
-        'type' => 'varchar',
-        'length' => 250,
-        'not null' => FALSE,
-        'default' => '',
-        'description' => 'The template message ID.',
-      ),
-      'status' => array(
-        'type' => 'int',
-        'not null' => TRUE,
-        'description' => 'The status of the template.',
-      ),
-    ),
-  );
-}

+ 0 - 8
heartbeat8.libraries.yml

@@ -1,8 +0,0 @@
-heartbeatAdditions:
-  version: 1.x
-
-  dependencies:
-    - core/jquery
-    - core/jquery.once
-    - core/drupal
-    - core/drupalSettings

+ 0 - 23
heartbeat8.links.action.yml

@@ -1,23 +0,0 @@
-entity.heartbeat.add_form:
-  route_name: 'entity.heartbeat.add_form'
-  title: 'Add Heartbeat'
-  appears_on:
-    - entity.heartbeat.collection
-
-entity.heartbeat.add_form:
-  route_name: 'entity.heartbeat.add_page'
-  title: 'Add Heartbeat'
-  appears_on:
-    - entity.heartbeat.collection
-entity.heartbeat_type.add_form:
-  route_name: 'entity.heartbeat_type.add_form'
-  title: 'Add Heartbeat type'
-  appears_on:
-    - entity.heartbeat_type.collection
-
-entity.heartbeat_stream_entity.add_form:
-  route_name: 'entity.heartbeat_stream_entity.add_form'
-  title: 'Add Heartbeat stream entity'
-  appears_on:
-    - entity.heartbeat_stream_entity.collection
-

+ 0 - 41
heartbeat8.links.menu.yml

@@ -1,41 +0,0 @@
-
-# Heartbeat menu items definition
-entity.heartbeat.collection:
-  title: 'Heartbeat'
-  route_name: entity.heartbeat.collection
-  description: 'List Heartbeat (bundles)'
-  parent: system.admin_structure
-  weight: 99
-
-
-# Heartbeat menu items definition
-entity.heartbeat.collection:
-  title: 'Heartbeat'
-  route_name: entity.heartbeat.collection
-  description: 'List Heartbeat entities'
-  parent: system.admin_structure
-  weight: 100
-
-
-# Heartbeat type menu items definition
-entity.heartbeat_type.collection:
-  title: 'Heartbeat type'
-  route_name: entity.heartbeat_type.collection
-  description: 'List Heartbeat type (bundles)'
-  parent: system.admin_structure
-  weight: 99
-
-heartbeat8.template_list:
-  title: 'Heartbeat Templates'
-  description: 'All heartbeat templates'
-  parent: entity.heartbeat.collection
-  route_name: heartbeat8.templates
-  weight: 99
-# Heartbeat stream entity menu items definition
-entity.heartbeat_stream_entity.collection:
-  title: 'Heartbeat stream entity'
-  route_name: entity.heartbeat_stream_entity.collection
-  description: 'List Heartbeat stream entity (bundles)'
-  parent: system.admin_structure
-  weight: 99
-

+ 0 - 23
heartbeat8.links.task.yml

@@ -1,23 +0,0 @@
-# Heartbeat routing definition
-
-entity.heartbeat.canonical:
-  route_name: entity.heartbeat.canonical
-  base_route: entity.heartbeat.canonical
-  title: 'View'
-
-entity.heartbeat.edit_form:
-  route_name: entity.heartbeat.edit_form
-  base_route: entity.heartbeat.canonical
-  title: 'Edit'
-
-entity.heartbeat.version_history:
-  route_name: entity.heartbeat.version_history
-  base_route: entity.heartbeat.canonical
-  title: 'Revisions'
-
-entity.heartbeat.delete_form:
-  route_name:  entity.heartbeat.delete_form
-  base_route:  entity.heartbeat.canonical
-  title: Delete
-  weight: 10
-

+ 0 - 70
heartbeat8.module

@@ -1,70 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains heartbeat8.module.
- */
-
-use Drupal\Core\Routing\RouteMatchInterface;
-use Drupal\Heartbeat8\Entity\Heartbeat;
-use Drupal\Heartbeat8\Entity\HeartbeatType;
-
-//TODO add constants (HEARTBEAT_NONE, HEARTBEAT_PRIVATE, HEARTBEAT_PUBLIC_TO_ADDRESSEE, HEARTBEAT_PUBLIC_TO_ALL_CONNECTED, HEARTBEAT_PUBLIC_TO_ALL)
-//TODO include Streams (Entities already added with use statements on lines 9-10)
-
-/**
- * Implements hook_help().
- */
-function heartbeat8_help($route_name, RouteMatchInterface $route_match) {
-  switch ($route_name) {
-    // Main module help for the heartbeat8 module.
-    case 'help.page.heartbeat8':
-      $output = '';
-      $output .= '<h3>' . t('About') . '</h3>';
-      $output .= '<p>' . t('Heartbeat for Drupal 8') . '</p>';
-      return $output;
-
-    default:
-  }
-}
-
-
-/**
- * Implements hook_theme().
- */
-function heartbeat8_theme() {
-  $theme = [];
-  $theme['heartbeat'] = array(
-    'render element' => 'elements',
-    'file' => 'heartbeat.page.inc',
-    'template' => 'heartbeat',
-  );
-  $theme['heartbeat_content_add_list'] = [
-    'render element' => 'content',
-    'variables' => ['content' => NULL],
-    'file' => 'heartbeat.page.inc',
-  ];
-  return $theme;
-}
-
-/**
-* Implements hook_theme_suggestions_HOOK().
-*/
-function heartbeat8_theme_suggestions_heartbeat(array $variables) {
-  $suggestions = array();
-  $entity = $variables['elements']['#heartbeat'];
-  $sanitized_view_mode = strtr($variables['elements']['#view_mode'], '.', '_');
-
-  $suggestions[] = 'heartbeat__' . $sanitized_view_mode;
-  $suggestions[] = 'heartbeat__' . $entity->bundle();
-  $suggestions[] = 'heartbeat__' . $entity->bundle() . '__' . $sanitized_view_mode;
-  $suggestions[] = 'heartbeat__' . $entity->id();
-  $suggestions[] = 'heartbeat__' . $entity->id() . '__' . $sanitized_view_mode;
-  return $suggestions;
-}
-
-
-
-//TODO Add heartbeat language to Javascript
-//TODO Determine necessity of polling
-//Add

+ 0 - 32
heartbeat8.module.php

@@ -1,32 +0,0 @@
-<?php
-/**
- * Created by IntelliJ IDEA.
- * User: logicp
- * Date: 4/5/17
- * Time: 1:18 AM
- */
-use Drupal\Component\Utility\Xss;
-use Drupal\Core\Access\AccessResult;
-use Drupal\Core\Cache\Cache;
-use Drupal\Core\Database\Query\AlterableInterface;
-use Drupal\Core\Database\Query\SelectInterface;
-use Drupal\Core\Database\StatementInterface;
-use Drupal\Core\Entity\Display\EntityViewDisplayInterface;
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Render\Element;
-use Drupal\Core\Routing\RouteMatchInterface;
-use Drupal\Core\Session\AccountInterface;
-use Drupal\Core\Template\Attribute;
-use Drupal\Core\Url;
-use Drupal\field\Entity\FieldConfig;
-use Drupal\field\Entity\FieldStorageConfig;
-use Drupal\language\ConfigurableLanguageInterface;
-use Drupal\Heartbeat8\Entity\Heartbeat;
-use Drupal\Heartbeat8\Entity\HeartbeatType;
-use Drupal\Heartbeat8\Entity\HeartbeatInterface;
-use Drupal\Heartbeat8\Entity\HeartbeatTypeInterface;
-
-
-function heartbeat8_cron() {
-
-}

+ 0 - 33
heartbeat8.permissions.yml

@@ -1,33 +0,0 @@
-add heartbeat entities:
-  title: 'Create new Heartbeat entities'
-
-administer heartbeat entities:
-  title: 'Administer Heartbeat entities'
-  description: 'Allow to access the administration form to configure Heartbeat entities.'
-  restrict access: true
-
-delete heartbeat entities:
-  title: 'Delete Heartbeat entities'
-
-edit heartbeat entities:
-  title: 'Edit Heartbeat entities'
-
-access heartbeat overview:
-  title: 'Access the Heartbeat overview page'
-
-view published heartbeat entities:
-  title: 'View published Heartbeat entities'
-
-view unpublished heartbeat entities:
-  title: 'View unpublished Heartbeat entities'
-
-view all heartbeat revisions:
-  title: 'View all Heartbeat revisions'
-
-revert all heartbeat revisions:
-  title: 'Revert all Heartbeat revisions'
-  description: 'Role requires permission <em>view Heartbeat revisions</em> and <em>edit rights</em> for heartbeat entities in question or <em>administer heartbeat entities</em>.'
-
-delete all heartbeat revisions:
-  title: 'Delete all revisions'
-  description: 'Role requires permission to <em>view Heartbeat revisions</em> and <em>delete rights</em> for heartbeat entities in question or <em>administer heartbeat entities</em>.'

+ 0 - 23
heartbeat8.routing.yml

@@ -1,23 +0,0 @@
-
-heartbeat8.heartbeat_controller_confirm:
-  path: '/heartbeat/load/{id}'
-  defaults:
-    _controller: '\Drupal\heartbeat8\Controller\HeartbeatController::confirm'
-    _title: 'load'
-  requirements:
-    _permission: 'access content'
-heartbeat8.templates:
-  path: '/admin/structure/heartbeat/templates/list'
-  defaults:
-    _form: '\Drupal\heartbeat8\Form\TemplateList'
-    _title: 'Heartbeat Templates'
-  requirements:
-    _permission: 'administer content'
-heartbeat8.modaltest.modal:
-  path: '/heartbeat/modaltest/{js}'
-  defaults:
-    _title: Heartbeat Modal
-    _controller: '\Drupal\heartbeat8\Controller\HeartbeatController::openModal'
-  requirements:
-    _permission: 'access content'
-    js: 'nojs|ajax'

+ 0 - 149
heartbeatstream.inc

@@ -1,149 +0,0 @@
-<?php
-
-/**
- * @file
- *  HeartbeatStream object takes configuration parameters to create a stream of activity objects.
- *  pre-query, query and post-query phases of the stream can be specified and manipulated here
- */
-
-
-/**
- * Abstract Class HeartbeatStream
- *  Base class with template methods. HeartbeatStream is a state object given to the HeartbeatStreamBuilder
- * to set access on current request
- */
-abstract class HeartbeatStream
-{
-
-
-  // Query object for this stream.
-  protected $query = NULL;
-
-  // Configuration object for this stream.
-  public $config = NULL;
-
-  // Well-formed activity messages.
-  public $messages = array();
-
-  // String prefix on top of the stream.
-  public $prefix = '';
-
-  // String suffix under a stream.
-  public $suffix = '';
-
-  // Templates available to show.
-  public $templates = array();
-
-  // Contextual arguments.
-  public $contextual_arguments = array();
-
-  // Denied templates.
-  protected $templates_denied = array();
-
-  // Language at display time.
-  protected $language = LANGUAGE_NONE;
-
-  // exclude Og.
-  protected $exclude_og = FALSE;
-
-  // The stream owner or activity watcher.
-  protected $_uid = 0;
-
-  // Array of runtime notices, warnings and errors.
-  protected $_errors = array();
-
-  // Indicates if there are runtime errors.
-  protected $_has_errors = FALSE;
-
-  // Indicates whether the page has modal requirement.
-  protected $needsModal = TRUE;
-
-  // Time where activity starts.
-  protected $_offset_time = 0;
-
-  // Maximum time where activity must end.
-  protected $oldest_date = 604800;
-
-  // Maximum number of activity messages to show.
-  protected $messages_max = 0;
-
-  // Latest user activity id fetched.
-  protected $latest_activity_id = 0;
-
-  // Indicates if the stream is displayed on a page or not.
-  protected $_page = FALSE;
-
-  // Indicates if this is an ajax request.
-  protected $ajax = 0;
-
-  // Can page means if we can show more messages
-  protected $canPage = FALSE;
-
-  // User view type of the stream instance.
-  protected $_whoisuser_type = self::VIEWER;
-
-  // The user who is viewing the activity stream.
-  protected $viewer = null;
-
-  // The user who's activity stream is viewed.
-  protected $viewed = null;
-
-  // View mode to display message.
-  protected $view_mode = 'default';
-
-  protected $_whoisuser_types = array(
-    self::VIEWER => 'Viewing user',
-    self::VIEWED => 'Viewed user'
-  );
-
-  // User viewer types.
-  const VIEWER = 0;
-  const VIEWED = 1;
-
-
-  final public function __construct(HeartbeatStreamConfig $streamConfig, $page = FALSE, $account = NULL) {
-
-    $this->_page = $page;
-    $this->setConfig($streamConfig);
-    $this->setAjax();
-
-    if (empty($this->_offset_time)) {
-      $this->setOffsetTime();
-    }
-
-    $this->setViewer(\Drupal::currentUser());
-    $this->setViewed($account);
-
-    $this->setAvailableTemplates();
-
-    $this->construct();
-
-    $this->setContextualArguments();
-
-  }
-
-  /**
-   * Fake Constructor Method
-   */
-
-  public function construct() {
-
-  }
-
-  /**
-   *
-   */
-  protected function setContextualArguments() {
-    $contextualArguments = \Drupal::request()->query->get('contextualArguments');
-    if (!empty($contextualArguments) && isset($contextualArguments['uid_target'])) {
-      $this->contextual_arguments = $contextualArguments['uid_target'];
-    } elseif ($this->viewed->uid != $this->viewer->uid) {
-      $this->contextual_arguments['uid_target'] = $this->viewed->uid;
-    }
-
-    //TODO Figure out a way to attach $this->contextual_arguments to the drupalSettings object with an id of "heartbeatContextualArguments"
-    //see below for implementation in a page callback or form alter
-    //    $variables['#attached']['drupalSettings']['heartbeatContextualArguments'] = $this->contextual_arguments;
-
-  }
-}

+ 0 - 106
includes/heartbeatstreamconfig.inc

@@ -1,106 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\HeartbeatStreamConfig;
-
-/**
- * @file
- *   HeartbeatStream Configuration object
- *   Parameter object given to HeartbeatStreamConfig objects
- *   to create stream stream of activity objects.
- */
-
-/**
- * Class HeartbeatStreamConfig
- *
- * Changeable object with configurations for an activity stream
- */
-class HeartbeatStreamConfig {
-
-  // Class name used.
-  public $name = '';
-
-  // Class to variable for ease of read/write.
-  public $class = '';
-
-  // Real class to load for cloned streams.
-  public $real_class = '';
-
-  // The path to the class.
-  public $path = '';
-
-  // Human readable name.
-  public $title = '';
-
-  // Module where query builder is located.
-  public $module = '';
-
-  // Extra variables.
-  //TODO variables might be put into config api
-  public $variables = array();
-
-  // Indicates whether this stream has a block display or not.
-  public $has_block = TRUE;
-
-  // Max number of items in block display.
-  public $block_items_max = 25;
-
-  // Number to indicate how a block-pager should be shown.
-  public $block_show_pager = 0;
-
-  // View mode for the block.
-  public $block_view_mode = 'default';
-
-  // Maximum number of items in the page display.
-  public $page_items_max = 50;
-
-  // Boolean to indicate of a page-pager should be shown.
-  public $page_show_pager = 0;
-
-  // Boolean to indicate if the pager is ajax-driven.
-  public $page_pager_ajax = 0;
-
-  // View mode for the page.
-  public $page_view_mode = 'default';
-
-  // Setting for the number of grouped items maximum.
-  public $show_message_times = 1;
-
-  // Setting for the number of grouped items maximum in a grouped message.
-  public $show_message_times_grouped = 0;
-
-  // Denied message templates.
-  public $messages_denied = array();
-
-  // Limit the number of messages by maximum messages to load.
-  public $num_load_max = 100;
-
-  // Limit the timespan to group messages.
-  public $grouping_seconds = 7200;
-
-  // Boolean for to skip the viewing user, defaults to false.
-  public $skip_active_user = FALSE;
-
-  // Timestamp used to poll for newer messages.
-  public $poll_messages = 0;
-
-  // How to notify there are newer messages.
-  public $poll_messages_type = 0;
-
-  // Stream path is the path to the stream page (optional).
-  public $stream_path = '';
-
-  // Stream user path is the path to a stream on the profile page (optional).
-  public $stream_profile_path = '';
-
-  // Settings variable
-  public $settings = array();
-
-  /**
-   * Constructor to load the type variable
-   */
-  public function __construct() {
-    //TODO replace variable_get with D8's state system
-//    $this->grouping_seconds = variable_get('heartbeat_activity_grouping_seconds', 7200);
-  }
-
-}

+ 0 - 73
src/Controller/HeartbeatController.php

@@ -1,73 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Controller;
-
-use Drupal\Core\Controller\ControllerBase;
-use Drupal\Core\Ajax\AjaxResponse;
-use Drupal\Core\Ajax\OpenModalDialogCommand;
-use Drupal\heartbeat8\HeartbeatStreamConfig;
-
-/**
- * Class HeartbeatController.
- *
- * @package Drupal\heartbeat8\Controller
- */
-class HeartbeatController extends ControllerBase {
-
-  /**
-   * Confirm.
-   *
-   * @return string
-   *   Return Hello string.
-   */
-  public function confirm($id) {
-    return [
-      '#type' => 'markup',
-      '#markup' => $this->t('Implement method: confirm with parameter(s): $id'),
-    ];
-  }
-
-
-  public function revisionOverview() {
-    return 0;
-  }
-
-  public function revisionShow() {
-    return 0;
-  }
-
-
-  public function page() {
-    return array(
-      '#type' => 'markup',
-      '#markup' => l(
-        t('Link'),
-        'heartbeat/modaltest/nojs',
-        array(
-          'attributes' => array(
-            'class' => 'use-ajax',
-          ),
-        )
-      ),
-      '#attached' => array(
-        'library' => array(
-          array('system', 'drupal.ajax'),
-        ),
-      ),
-    );
-  }
-
-  public function openModal($js = 'nojs') {
-
-    $options = $js == 'ajax' ? array(
-      'width' => '80%',
-      ) : array();
-
-    $response = new AjaxResponse();
-
-    $response->addCommand(new OpenModalDialogCommand(t('Modal'), t('This is the Heartbeat Modal Dialog with AJAX, yo'), $options));
-
-    return $response;
-  }
-
-}

+ 0 - 309
src/Entity/Heartbeat.php

@@ -1,309 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Entity;
-
-use Drupal\Core\Entity\EntityStorageInterface;
-use Drupal\Core\Field\BaseFieldDefinition;
-use Drupal\Core\Entity\RevisionableContentEntityBase;
-use Drupal\Core\Entity\EntityChangedTrait;
-use Drupal\Core\Entity\EntityTypeInterface;
-use Drupal\user\UserInterface;
-
-/**
- * Defines the Heartbeat entity.
- *
- * @ingroup heartbeat8
- *
- * @ContentEntityType(
- *   id = "heartbeat",
- *   label = @Translation("Heartbeat"),
- *   bundle_label = @Translation("Heartbeat type"),
- *   handlers = {
- *     "storage" = "Drupal\heartbeat8\HeartbeatStorage",
- *     "view_builder" = "Drupal\Core\Entity\EntityViewBuilder",
- *     "list_builder" = "Drupal\heartbeat8\HeartbeatListBuilder",
- *     "views_data" = "Drupal\heartbeat8\Entity\HeartbeatViewsData",
- *     "translation" = "Drupal\heartbeat8\HeartbeatTranslationHandler",
- *
- *     "form" = {
- *       "default" = "Drupal\heartbeat8\Form\HeartbeatForm",
- *       "add" = "Drupal\heartbeat8\Form\HeartbeatForm",
- *       "edit" = "Drupal\heartbeat8\Form\HeartbeatForm",
- *       "delete" = "Drupal\heartbeat8\Form\HeartbeatDeleteForm",
- *     },
- *     "access" = "Drupal\heartbeat8\HeartbeatAccessControlHandler",
- *     "route_provider" = {
- *       "html" = "Drupal\heartbeat8\HeartbeatHtmlRouteProvider",
- *     },
- *   },
- *   base_table = "heartbeat",
- *   data_table = "heartbeat_field_data",
- *   revision_table = "heartbeat_revision",
- *   revision_data_table = "heartbeat_field_revision",
- *   translatable = TRUE,
- *   admin_permission = "administer heartbeat entities",
- *   entity_keys = {
- *     "id" = "id",
- *     "revision" = "vid",
- *     "bundle" = "type",
- *     "label" = "name",
- *     "uuid" = "uuid",
- *     "uid" = "user_id",
- *     "langcode" = "langcode",
- *     "status" = "status",
- *   },
- *   links = {
- *     "canonical" = "/admin/structure/heartbeat/{heartbeat}",
- *     "add-page" = "/admin/structure/heartbeat/add",
- *     "add-form" = "/admin/structure/heartbeat/add/{heartbeat_type}",
- *     "edit-form" = "/admin/structure/heartbeat/{heartbeat}/edit",
- *     "delete-form" = "/admin/structure/heartbeat/{heartbeat}/delete",
- *     "version-history" = "/admin/structure/heartbeat/{heartbeat}/revisions",
- *     "revision" = "/admin/structure/heartbeat/{heartbeat}/revisions/{heartbeat_revision}/view",
- *     "revision_revert" = "/admin/structure/heartbeat/{heartbeat}/revisions/{heartbeat_revision}/revert",
- *     "translation_revert" = "/admin/structure/heartbeat/{heartbeat}/revisions/{heartbeat_revision}/revert/{langcode}",
- *     "revision_delete" = "/admin/structure/heartbeat/{heartbeat}/revisions/{heartbeat_revision}/delete",
- *     "collection" = "/admin/structure/heartbeat",
- *   },
- *   bundle_entity_type = "heartbeat_type",
- *   field_ui_base_route = "entity.heartbeat_type.edit_form"
- * )
- */
-class Heartbeat extends RevisionableContentEntityBase implements HeartbeatInterface {
-
-  use EntityChangedTrait;
-
-  /**
-   * {@inheritdoc}
-   */
-  public static function preCreate(EntityStorageInterface $storage_controller, array &$values) {
-    parent::preCreate($storage_controller, $values);
-    $values += array(
-      'user_id' => \Drupal::currentUser()->id(),
-    );
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function preSave(EntityStorageInterface $storage) {
-    parent::preSave($storage);
-
-    foreach (array_keys($this->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;
-  }
-
-  /**
-   * {@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('user_id')->entity;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getOwnerId() {
-    return $this->get('user_id')->target_id;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function setOwnerId($uid) {
-    $this->set('user_id', $uid);
-    return $this;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function setOwner(UserInterface $account) {
-    $this->set('user_id', $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['user_id'] = 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['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['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;
-  }
-
-}

+ 0 - 126
src/Entity/HeartbeatInterface.php

@@ -1,126 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Entity;
-
-use Drupal\Core\Entity\RevisionLogInterface;
-use Drupal\Core\Entity\RevisionableInterface;
-use Drupal\Component\Utility\Xss;
-use Drupal\Core\Url;
-use Drupal\Core\Entity\EntityChangedInterface;
-use Drupal\user\EntityOwnerInterface;
-
-/**
- * Provides an interface for defining Heartbeat entities.
- *
- * @ingroup heartbeat8
- */
-interface HeartbeatInterface extends RevisionableInterface, RevisionLogInterface, EntityChangedInterface, EntityOwnerInterface {
-
-  // Add get/set methods for your configuration properties here.
-
-  /**
-   * Gets the Heartbeat type.
-   *
-   * @return string
-   *   The Heartbeat type.
-   */
-  public function getType();
-
-  /**
-   * Gets the Heartbeat name.
-   *
-   * @return string
-   *   Name of the Heartbeat.
-   */
-  public function getName();
-
-  /**
-   * Sets the Heartbeat name.
-   *
-   * @param string $name
-   *   The Heartbeat name.
-   *
-   * @return \Drupal\heartbeat8\Entity\HeartbeatInterface
-   *   The called Heartbeat entity.
-   */
-  public function setName($name);
-
-  /**
-   * Gets the Heartbeat creation timestamp.
-   *
-   * @return int
-   *   Creation timestamp of the Heartbeat.
-   */
-  public function getCreatedTime();
-
-  /**
-   * Sets the Heartbeat creation timestamp.
-   *
-   * @param int $timestamp
-   *   The Heartbeat creation timestamp.
-   *
-   * @return \Drupal\heartbeat8\Entity\HeartbeatInterface
-   *   The called Heartbeat entity.
-   */
-  public function setCreatedTime($timestamp);
-
-  /**
-   * Returns the Heartbeat published status indicator.
-   *
-   * Unpublished Heartbeat are only visible to restricted users.
-   *
-   * @return bool
-   *   TRUE if the Heartbeat is published.
-   */
-  public function isPublished();
-
-  /**
-   * Sets the published status of a Heartbeat.
-   *
-   * @param bool $published
-   *   TRUE to set this Heartbeat to published, FALSE to set it to unpublished.
-   *
-   * @return \Drupal\heartbeat8\Entity\HeartbeatInterface
-   *   The called Heartbeat entity.
-   */
-  public function setPublished($published);
-
-  /**
-   * Gets the Heartbeat revision creation timestamp.
-   *
-   * @return int
-   *   The UNIX timestamp of when this revision was created.
-   */
-  public function getRevisionCreationTime();
-
-  /**
-   * Sets the Heartbeat revision creation timestamp.
-   *
-   * @param int $timestamp
-   *   The UNIX timestamp of when this revision was created.
-   *
-   * @return \Drupal\heartbeat8\Entity\HeartbeatInterface
-   *   The called Heartbeat entity.
-   */
-  public function setRevisionCreationTime($timestamp);
-
-  /**
-   * Gets the Heartbeat revision author.
-   *
-   * @return \Drupal\user\UserInterface
-   *   The user entity for the revision author.
-   */
-  public function getRevisionUser();
-
-  /**
-   * Sets the Heartbeat revision author.
-   *
-   * @param int $uid
-   *   The user ID of the revision author.
-   *
-   * @return \Drupal\heartbeat8\Entity\HeartbeatInterface
-   *   The called Heartbeat entity.
-   */
-  public function setRevisionUserId($uid);
-
-}

+ 0 - 254
src/Entity/HeartbeatStreamEntity.php

@@ -1,254 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Entity;
-
-use Drupal\Core\Config\Entity\ConfigEntityBase;
-
-
-/**
- * Defines the Heartbeat stream entity entity.
- *
- * @ConfigEntityType(
- *   id = "heartbeat_stream_entity",
- *   label = @Translation("Heartbeat stream entity"),
- *   handlers = {
- *     "list_builder" = "Drupal\heartbeat8\HeartbeatStreamEntityListBuilder",
- *     "form" = {
- *       "add" = "Drupal\heartbeat8\Form\HeartbeatStreamEntityForm",
- *       "edit" = "Drupal\heartbeat8\Form\HeartbeatStreamEntityForm",
- *       "delete" = "Drupal\heartbeat8\Form\HeartbeatStreamEntityDeleteForm"
- *     },
- *     "route_provider" = {
- *       "html" = "Drupal\heartbeat8\HeartbeatStreamEntityHtmlRouteProvider",
- *     },
- *   },
- *   config_prefix = "heartbeat_stream_entity",
- *   admin_permission = "administer site configuration",
- *   entity_keys = {
- *     "id" = "id",
- *     "label" = "label",
- *     "uuid" = "uuid"
- *   },
- *   links = {
- *     "canonical" = "/admin/structure/heartbeat/heartbeat_stream_entity/{heartbeat_stream_entity}",
- *     "add-form" = "/admin/structure/heartbeat/heartbeat_stream_entity/add",
- *     "edit-form" = "/admin/structure/heartbeat/heartbeat_stream_entity/{heartbeat_stream_entity}/edit",
- *     "delete-form" = "/admin/structure/heartbeat/heartbeat_stream_entity/{heartbeat_stream_entity}/delete",
- *     "collection" = "/admin/structure/heartbeat/heartbeat_stream_entity"
- *   }
- * )
- */
-class HeartbeatStreamEntity extends ConfigEntityBase implements HeartbeatStreamEntityInterface {
-  /**
-   * The Heartbeat stream entity ID.
-   *
-   * @var string
-   */
-  protected $id;
-
-  /**
-   * The Heartbeat stream entity label.
-   *
-   * @var string
-   */
-//  protected $label;
-
-
-
-  /*
-   * Sets the unique Message ID
-   *
-   * @param string $messageId
-   *  The unique Message ID to represent
-   *  all messages of this type
-   */
-
-
-  public function setMessageId($messageId) {
-    // TODO: Implement setMessageId() method.
-  }
-
-
-  /*
-  * Gets the unique Message ID
-  *
-  * @return string
-  *  The Stream's Message ID
-  */
-
-  public function getMessageId() {
-    // TODO: Implement getMessageId() method.
-  }
-
-  /**
-   * Sets the description of the stream
-   *
-   * @param string $description
-   *  Describing streams of this type
-   */
-  public function setDescription($description) {
-    // TODO: Implement setDescription() method.
-  }
-
-  /**
-   * Gets the description of the stream
-   *
-   * @return string
-   *  The Stream's description
-   */
-  public function getDescription() {
-    // TODO: Implement getDescription() method.
-  }
-
-  /**
-   * Sets the translatable message
-   * This message creates the structure of each message
-   *
-   * @param string $message
-   *  The template message serving as the foundation of each message structure of this stream type
-   */
-  public function setMessage($message) {
-    // TODO: Implement setMessage() method.
-  }
-
-  /**
-   * Gets the translatable message of the stream
-   *
-   * @return string
-   *  The Stream's message
-   */
-  public function getMessage() {
-    // TODO: Implement getMessage() method.
-  }
-
-  /**
-   * Sets the translatable concatenated message
-   *
-   * @param string $messageConcat
-   *
-   */
-  public function setMessageConcat($messageConcat) {
-    // TODO: Implement setMessageConcat() method.
-  }
-
-  /**
-   * Gets the concatenated message of the stream
-   *
-   * @return string
-   *  The Stream's concatenated message
-   */
-  public function getMessageConcat() {
-    // TODO: Implement getMessageConcat() method.
-  }
-
-  /**
-   * Sets the Permissions for this message stream
-   *
-   * @param int $perms
-   *
-   */
-  public function setPerms($perms) {
-    // TODO: Implement setPerms() method.
-  }
-
-  /**
-   * Gets the Permissions of this message stream
-   *
-   * @return int
-   *  The stream's permissions
-   */
-  public function getPerms() {
-    // TODO: Implement getPerms() method.
-  }
-
-  /**
-   * Sets the Group Type for this message stream
-   *
-   * @param string $groupType
-   *
-   */
-  public function setGroupType($groupType) {
-    // TODO: Implement setGroupType() method.
-  }
-
-  /**
-   * Gets the Group Type of this message stream
-   *
-   * @return string
-   *  The stream's Group Type
-   */
-  public function getGroupType() {
-    // TODO: Implement getGroupType() method.
-  }
-
-  /**
-   * Sets the arguments for the concatenated message
-   *
-   * @param string $concatArgs
-   *
-   */
-  public function setConcatArgs($concatArgs) {
-    // TODO: Implement setConcatArgs() method.
-  }
-
-  /**
-   * Gets the arguments for the concatenated message
-   *
-   * @return string
-   *  The stream's arguments for the concatenated message
-   */
-  public function getConcateArgs() {
-    // TODO: Implement getConcateArgs() method.
-  }
-
-  /**
-   * Sets the variables for this message stream
-   *
-   * @param string $variables
-   *
-   */
-  public function setVariables($variables) {
-    // TODO: Implement setVariables() method.
-  }
-
-  /**
-   * Gets the variables of this message stream
-   *
-   * @return string
-   *  The stream's variables
-   */
-  public function getVariables() {
-    // TODO: Implement getVariables() method.
-  }
-
-  /**
-   * Sets the attachments for this message stream
-   *
-   * @param string $attachments
-   *
-   */
-  public function setAttachments($attachments) {
-    // TODO: Implement setAttachments() method.
-  }
-
-  /**
-   * Gets the attachments of this message stream
-   *
-   * @return string
-   *  The stream's attachments
-   */
-  public function getAttachments() {
-    // TODO: Implement getAttachments() method.
-  }
-
-  public function label() {
-    return parent::label();
-//    == null? "" : parent::label();
-  }
-
-  public function id()
-  {
-    return parent::id();
-//    == null ? 69 : parent::id(); // TODO: Change the autogenerated stub
-  }
-}

+ 0 - 193
src/Entity/HeartbeatStreamEntityInterface.php

@@ -1,193 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Entity;
-
-use Drupal\Core\Config\Entity\ConfigEntityInterface;
-
-/**
- * Provides an interface for defining Heartbeat stream entity entities.
- */
-interface HeartbeatStreamEntityInterface extends ConfigEntityInterface {
-  // Add get/set methods for your configuration properties here.
-
-
-  /*
-   * Sets the unique Message ID
-   *
-   * @param string $messageId
-   *  The unique Message ID to represent
-   *  all messages of this type
-   */
-
-  public function setMessageId($messageId);
-
-  /*
-   * Gets the unique Message ID
-   *
-   * @return string
-   *  The Stream's Message ID
-   */
-
-  public function getMessageId();
-
-
-  /**
-   * Sets the description of the stream
-   *
-   * @param string $description
-   *  Describing streams of this type
-   */
-
-  public function setDescription($description);
-
-  /**
-   * Gets the description of the stream
-   *
-   * @return string
-   *  The Stream's description
-   */
-  public function getDescription();
-
-  /**
-   * Sets the translatable message
-   * This message creates the structure of each message
-   *
-   * @param string $message
-   *  The template message serving as the foundation of each message structure of this stream type
-   */
-
-  public function setMessage($message);
-
-  /**
-   * Gets the translatable message of the stream
-   *
-   * @return string
-   *  The Stream's message
-   */
-
-  public function getMessage();
-
-
-  /**
-   * Sets the translatable concatenated message
-   *
-   * @param string $messageConcat
-   *
-   */
-
-  public function setMessageConcat($messageConcat);
-
-
-  /**
-   * Gets the concatenated message of the stream
-   *
-   * @return string
-   *  The Stream's concatenated message
-   */
-
-  public function getMessageConcat();
-
-
-  /**
-   * Sets the Permissions for this message stream
-   *
-   * @param int $perms
-   *
-   */
-
-  public function setPerms($perms);
-
-
-  /**
-   * Gets the Permissions of this message stream
-   *
-   * @return int
-   *  The stream's permissions
-   */
-
-  public function getPerms();
-
-
-  /**
-   * Sets the Group Type for this message stream
-   *
-   * @param string $groupType
-   *
-   */
-
-  public function setGroupType($groupType);
-
-
-  /**
-   * Gets the Group Type of this message stream
-   *
-   * @return string
-   *  The stream's Group Type
-   */
-
-  public function getGroupType();
-
-
-  /**
-   * Sets the arguments for the concatenated message
-   *
-   * @param string $concatArgs
-   *
-   */
-
-
-  public function setConcatArgs($concatArgs);
-
-
-  /**
-   * Gets the arguments for the concatenated message
-   *
-   * @return string
-   *  The stream's arguments for the concatenated message
-   */
-
-  public function getConcateArgs();
-
-
-
-  /**
-   * Sets the variables for this message stream
-   *
-   * @param string $variables
-   *
-   */
-
-  public function setVariables($variables);
-
-
-  /**
-   * Gets the variables of this message stream
-   *
-   * @return string
-   *  The stream's variables
-   */
-
-  public function getVariables();
-
-
-
-  /**
-   * Sets the attachments for this message stream
-   *
-   * @param string $attachments
-   *
-   */
-
-  public function setAttachments($attachments);
-
-
-  /**
-   * Gets the attachments of this message stream
-   *
-   * @return string
-   *  The stream's attachments
-   */
-
-  public function getAttachments();
-
-}

+ 0 - 62
src/Entity/HeartbeatType.php

@@ -1,62 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Entity;
-
-use Drupal\Core\Config\Entity\ConfigEntityBundleBase;
-
-/**
- * Defines the Heartbeat type entity.
- *
- * @ConfigEntityType(
- *   id = "heartbeat_type",
- *   label = @Translation("Heartbeat type"),
- *   handlers = {
- *     "list_builder" = "Drupal\heartbeat8\HeartbeatTypeListBuilder",
- *     "form" = {
- *       "add" = "Drupal\heartbeat8\Form\HeartbeatTypeForm",
- *       "edit" = "Drupal\heartbeat8\Form\HeartbeatTypeForm",
- *       "delete" = "Drupal\heartbeat8\Form\HeartbeatTypeDeleteForm"
- *     },
- *     "route_provider" = {
- *       "html" = "Drupal\heartbeat8\HeartbeatTypeHtmlRouteProvider",
- *     },
- *   },
- *   config_prefix = "heartbeat_type",
- *   admin_permission = "administer site configuration",
- *   bundle_of = "heartbeat",
- *   entity_keys = {
- *     "id" = "id",
- *     "label" = "label",
- *     "uuid" = "uuid"
- *   },
- *   links = {
- *     "canonical" = "/admin/structure/heartbeat_type/{heartbeat_type}",
- *     "add-form" = "/admin/structure/heartbeat_type/add",
- *     "edit-form" = "/admin/structure/heartbeat_type/{heartbeat_type}/edit",
- *     "delete-form" = "/admin/structure/heartbeat_type/{heartbeat_type}/delete",
- *     "collection" = "/admin/structure/heartbeat_type"
- *   }
- * )
- */
-class HeartbeatType extends ConfigEntityBundleBase implements HeartbeatTypeInterface {
-
-  /**
-   * The Heartbeat type ID.
-   *
-   * @var string
-   */
-  protected $id;
-
-  /**
-   * The Heartbeat type label.
-   *
-   * @var string
-   */
-  protected $label;
-
-  /**
-   * @var string
-   */
-  protected $description;
-
-}

+ 0 - 13
src/Entity/HeartbeatTypeInterface.php

@@ -1,13 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Entity;
-
-use Drupal\Core\Config\Entity\ConfigEntityInterface;
-
-/**
- * Provides an interface for defining Heartbeat type entities.
- */
-interface HeartbeatTypeInterface extends ConfigEntityInterface {
-
-  // Add get/set methods for your configuration properties here.
-}

+ 0 - 24
src/Entity/HeartbeatViewsData.php

@@ -1,24 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Entity;
-
-use Drupal\views\EntityViewsData;
-
-/**
- * Provides Views data for Heartbeat entities.
- */
-class HeartbeatViewsData extends EntityViewsData {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getViewsData() {
-    $data = parent::getViewsData();
-
-    // Additional information for Views integration, such as table joins, can be
-    // put here.
-
-    return $data;
-  }
-
-}

+ 0 - 15
src/Form/HeartbeatDeleteForm.php

@@ -1,15 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Entity\ContentEntityDeleteForm;
-
-/**
- * Provides a form for deleting Heartbeat entities.
- *
- * @ingroup heartbeat8
- */
-class HeartbeatDeleteForm extends ContentEntityDeleteForm {
-
-
-}

+ 0 - 82
src/Form/HeartbeatForm.php

@@ -1,82 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Entity\ContentEntityForm;
-use Drupal\Core\Form\FormStateInterface;
-
-/**
- * Form controller for Heartbeat edit forms.
- *
- * @ingroup heartbeat8
- */
-class HeartbeatForm extends ContentEntityForm {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildForm(array $form, FormStateInterface $form_state) {
-    /* @var $entity \Drupal\heartbeat8\Entity\Heartbeat */
-    $form = parent::buildForm($form, $form_state);
-
-    $entity = $this->entity;
-
-    if (!$this->entity->isNew()) {
-      $form['new_revision'] = array(
-        '#type' => 'checkbox',
-        '#title' => $this->t('Create new revision'),
-        '#default_value' => FALSE,
-        '#weight' => 10,
-      );
-
-      $form['label'] = [
-        '#type' => 'textfield',
-        '#title' => $this->t('Label'),
-        '#maxlength' => 255,
-        '#default_value' => $entity->label(),
-        '#description' => $this->t("Label for the Heartbeat."),
-        '#required' => TRUE,
-      ];
-    }
-
-
-
-    return $form;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function save(array $form, FormStateInterface $form_state) {
-    $entity = &$this->entity;
-
-    // Save as a new revision if requested to do so.
-    if (!$form_state->isValueEmpty('new_revision') && $form_state->getValue('new_revision') != FALSE) {
-      $entity->setNewRevision();
-
-      // If a new revision is created, save the current user as revision author.
-      $entity->setRevisionCreationTime(REQUEST_TIME);
-      $entity->setRevisionUserId(\Drupal::currentUser()->id());
-    }
-    else {
-      $entity->setNewRevision(FALSE);
-    }
-
-    $status = parent::save($form, $form_state);
-
-    switch ($status) {
-      case SAVED_NEW:
-        drupal_set_message($this->t('Created the %label Heartbeat.', [
-          '%label' => $entity->label(),
-        ]));
-        break;
-
-      default:
-        drupal_set_message($this->t('Saved the %label Heartbeat.', [
-          '%label' => $entity->label(),
-        ]));
-    }
-    $form_state->setRedirect('entity.heartbeat.canonical', ['heartbeat' => $entity->id()]);
-  }
-
-}

+ 0 - 123
src/Form/HeartbeatRevisionDeleteForm.php

@@ -1,123 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Database\Connection;
-use Drupal\Core\Entity\EntityStorageInterface;
-use Drupal\Core\Form\ConfirmFormBase;
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Url;
-use Symfony\Component\DependencyInjection\ContainerInterface;
-
-/**
- * Provides a form for deleting a Heartbeat revision.
- *
- * @ingroup heartbeat8
- */
-class HeartbeatRevisionDeleteForm extends ConfirmFormBase {
-
-
-  /**
-   * The Heartbeat revision.
-   *
-   * @var \Drupal\heartbeat8\Entity\HeartbeatInterface
-   */
-  protected $revision;
-
-  /**
-   * The Heartbeat storage.
-   *
-   * @var \Drupal\Core\Entity\EntityStorageInterface
-   */
-  protected $HeartbeatStorage;
-
-  /**
-   * The database connection.
-   *
-   * @var \Drupal\Core\Database\Connection
-   */
-  protected $connection;
-
-  /**
-   * Constructs a new HeartbeatRevisionDeleteForm.
-   *
-   * @param \Drupal\Core\Entity\EntityStorageInterface $entity_storage
-   *   The entity storage.
-   * @param \Drupal\Core\Database\Connection $connection
-   *   The database connection.
-   */
-  public function __construct(EntityStorageInterface $entity_storage, Connection $connection) {
-    $this->HeartbeatStorage = $entity_storage;
-    $this->connection = $connection;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public static function create(ContainerInterface $container) {
-    $entity_manager = $container->get('entity.manager');
-    return new static(
-      $entity_manager->getStorage('heartbeat'),
-      $container->get('database')
-    );
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getFormId() {
-    return 'heartbeat_revision_delete_confirm';
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getQuestion() {
-    return t('Are you sure you want to delete the revision from %revision-date?', array('%revision-date' => format_date($this->revision->getRevisionCreationTime())));
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getCancelUrl() {
-    return new Url('entity.heartbeat.version_history', array('heartbeat' => $this->revision->id()));
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getConfirmText() {
-    return t('Delete');
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildForm(array $form, FormStateInterface $form_state, $heartbeat_revision = NULL) {
-    $this->revision = $this->HeartbeatStorage->loadRevision($heartbeat_revision);
-    $form = parent::buildForm($form, $form_state);
-
-    return $form;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function submitForm(array &$form, FormStateInterface $form_state) {
-    $this->HeartbeatStorage->deleteRevision($this->revision->getRevisionId());
-
-    $this->logger('content')->notice('Heartbeat: deleted %title revision %revision.', array('%title' => $this->revision->label(), '%revision' => $this->revision->getRevisionId()));
-    drupal_set_message(t('Revision from %revision-date of Heartbeat %title has been deleted.', array('%revision-date' => format_date($this->revision->getRevisionCreationTime()), '%title' => $this->revision->label())));
-    $form_state->setRedirect(
-      'entity.heartbeat.canonical',
-       array('heartbeat' => $this->revision->id())
-    );
-    if ($this->connection->query('SELECT COUNT(DISTINCT vid) FROM {heartbeat_field_revision} WHERE id = :id', array(':id' => $this->revision->id()))->fetchField() > 1) {
-      $form_state->setRedirect(
-        'entity.heartbeat.version_history',
-         array('heartbeat' => $this->revision->id())
-      );
-    }
-  }
-
-}

+ 0 - 149
src/Form/HeartbeatRevisionRevertForm.php

@@ -1,149 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Datetime\DateFormatterInterface;
-use Drupal\Core\Entity\EntityStorageInterface;
-use Drupal\Core\Form\ConfirmFormBase;
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Url;
-use Drupal\heartbeat8\Entity\HeartbeatInterface;
-use Symfony\Component\DependencyInjection\ContainerInterface;
-
-/**
- * Provides a form for reverting a Heartbeat revision.
- *
- * @ingroup heartbeat8
- */
-class HeartbeatRevisionRevertForm extends ConfirmFormBase {
-
-
-  /**
-   * The Heartbeat revision.
-   *
-   * @var \Drupal\heartbeat8\Entity\HeartbeatInterface
-   */
-  protected $revision;
-
-  /**
-   * The Heartbeat storage.
-   *
-   * @var \Drupal\Core\Entity\EntityStorageInterface
-   */
-  protected $HeartbeatStorage;
-
-  /**
-   * The date formatter service.
-   *
-   * @var \Drupal\Core\Datetime\DateFormatterInterface
-   */
-  protected $dateFormatter;
-
-  /**
-   * Constructs a new HeartbeatRevisionRevertForm.
-   *
-   * @param \Drupal\Core\Entity\EntityStorageInterface $entity_storage
-   *   The Heartbeat storage.
-   * @param \Drupal\Core\Datetime\DateFormatterInterface $date_formatter
-   *   The date formatter service.
-   */
-  public function __construct(EntityStorageInterface $entity_storage, DateFormatterInterface $date_formatter) {
-    $this->HeartbeatStorage = $entity_storage;
-    $this->dateFormatter = $date_formatter;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public static function create(ContainerInterface $container) {
-    return new static(
-      $container->get('entity.manager')->getStorage('heartbeat'),
-      $container->get('date.formatter')
-    );
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getFormId() {
-    return 'heartbeat_revision_revert_confirm';
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getQuestion() {
-    return t('Are you sure you want to revert to the revision from %revision-date?', ['%revision-date' => $this->dateFormatter->format($this->revision->getRevisionCreationTime())]);
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getCancelUrl() {
-    return new Url('entity.heartbeat.version_history', array('heartbeat' => $this->revision->id()));
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getConfirmText() {
-    return t('Revert');
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getDescription() {
-    return '';
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildForm(array $form, FormStateInterface $form_state, $heartbeat_revision = NULL) {
-    $this->revision = $this->HeartbeatStorage->loadRevision($heartbeat_revision);
-    $form = parent::buildForm($form, $form_state);
-
-    return $form;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function submitForm(array &$form, FormStateInterface $form_state) {
-    // The revision timestamp will be updated when the revision is saved. Keep
-    // the original one for the confirmation message.
-    $original_revision_timestamp = $this->revision->getRevisionCreationTime();
-
-    $this->revision = $this->prepareRevertedRevision($this->revision, $form_state);
-    $this->revision->revision_log = t('Copy of the revision from %date.', ['%date' => $this->dateFormatter->format($original_revision_timestamp)]);
-    $this->revision->save();
-
-    $this->logger('content')->notice('Heartbeat: reverted %title revision %revision.', ['%title' => $this->revision->label(), '%revision' => $this->revision->getRevisionId()]);
-    drupal_set_message(t('Heartbeat %title has been reverted to the revision from %revision-date.', ['%title' => $this->revision->label(), '%revision-date' => $this->dateFormatter->format($original_revision_timestamp)]));
-    $form_state->setRedirect(
-      'entity.heartbeat.version_history',
-      array('heartbeat' => $this->revision->id())
-    );
-  }
-
-  /**
-   * Prepares a revision to be reverted.
-   *
-   * @param \Drupal\heartbeat8\Entity\HeartbeatInterface $revision
-   *   The revision to be reverted.
-   * @param \Drupal\Core\Form\FormStateInterface $form_state
-   *   The current state of the form.
-   *
-   * @return \Drupal\heartbeat8\Entity\HeartbeatInterface
-   *   The prepared revision ready to be stored.
-   */
-  protected function prepareRevertedRevision(HeartbeatInterface $revision, FormStateInterface $form_state) {
-    $revision->setNewRevision();
-    $revision->isDefaultRevision(TRUE);
-    $revision->setRevisionCreationTime(REQUEST_TIME);
-
-    return $revision;
-  }
-
-}

+ 0 - 115
src/Form/HeartbeatRevisionRevertTranslationForm.php

@@ -1,115 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Datetime\DateFormatterInterface;
-use Drupal\Core\Entity\EntityStorageInterface;
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Language\LanguageManagerInterface;
-use Drupal\heartbeat8\Entity\HeartbeatInterface;
-use Symfony\Component\DependencyInjection\ContainerInterface;
-
-/**
- * Provides a form for reverting a Heartbeat revision for a single translation.
- *
- * @ingroup heartbeat8
- */
-class HeartbeatRevisionRevertTranslationForm extends HeartbeatRevisionRevertForm {
-
-
-  /**
-   * The language to be reverted.
-   *
-   * @var string
-   */
-  protected $langcode;
-
-  /**
-   * The language manager.
-   *
-   * @var \Drupal\Core\Language\LanguageManagerInterface
-   */
-  protected $languageManager;
-
-  /**
-   * Constructs a new HeartbeatRevisionRevertTranslationForm.
-   *
-   * @param \Drupal\Core\Entity\EntityStorageInterface $entity_storage
-   *   The Heartbeat storage.
-   * @param \Drupal\Core\Datetime\DateFormatterInterface $date_formatter
-   *   The date formatter service.
-   * @param \Drupal\Core\Language\LanguageManagerInterface $language_manager
-   *   The language manager.
-   */
-  public function __construct(EntityStorageInterface $entity_storage, DateFormatterInterface $date_formatter, LanguageManagerInterface $language_manager) {
-    parent::__construct($entity_storage, $date_formatter);
-    $this->languageManager = $language_manager;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public static function create(ContainerInterface $container) {
-    return new static(
-      $container->get('entity.manager')->getStorage('heartbeat'),
-      $container->get('date.formatter'),
-      $container->get('language_manager')
-    );
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getFormId() {
-    return 'heartbeat_revision_revert_translation_confirm';
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getQuestion() {
-    return t('Are you sure you want to revert @language translation to the revision from %revision-date?', ['@language' => $this->languageManager->getLanguageName($this->langcode), '%revision-date' => $this->dateFormatter->format($this->revision->getRevisionCreationTime())]);
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildForm(array $form, FormStateInterface $form_state, $heartbeat_revision = NULL, $langcode = NULL) {
-    $this->langcode = $langcode;
-    $form = parent::buildForm($form, $form_state, $heartbeat_revision);
-
-    $form['revert_untranslated_fields'] = array(
-      '#type' => 'checkbox',
-      '#title' => $this->t('Revert content shared among translations'),
-      '#default_value' => FALSE,
-    );
-
-    return $form;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  protected function prepareRevertedRevision(HeartbeatInterface $revision, FormStateInterface $form_state) {
-    $revert_untranslated_fields = $form_state->getValue('revert_untranslated_fields');
-
-    /** @var \Drupal\heartbeat8\Entity\HeartbeatInterface $default_revision */
-    $latest_revision = $this->HeartbeatStorage->load($revision->id());
-    $latest_revision_translation = $latest_revision->getTranslation($this->langcode);
-
-    $revision_translation = $revision->getTranslation($this->langcode);
-
-    foreach ($latest_revision_translation->getFieldDefinitions() as $field_name => $definition) {
-      if ($definition->isTranslatable() || $revert_untranslated_fields) {
-        $latest_revision_translation->set($field_name, $revision_translation->get($field_name)->getValue());
-      }
-    }
-
-    $latest_revision_translation->setNewRevision();
-    $latest_revision_translation->isDefaultRevision(TRUE);
-    $revision->setRevisionCreationTime(REQUEST_TIME);
-
-    return $latest_revision_translation;
-  }
-
-}

+ 0 - 55
src/Form/HeartbeatSettingsForm.php

@@ -1,55 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Form\FormBase;
-use Drupal\Core\Form\FormStateInterface;
-
-/**
- * Class HeartbeatSettingsForm.
- *
- * @package Drupal\heartbeat8\Form
- *
- * @ingroup heartbeat8
- */
-class HeartbeatSettingsForm extends FormBase {
-
-  /**
-   * Returns a unique string identifying the form.
-   *
-   * @return string
-   *   The unique string identifying the form.
-   */
-  public function getFormId() {
-    return 'Heartbeat_settings';
-  }
-
-  /**
-   * Form submission handler.
-   *
-   * @param array $form
-   *   An associative array containing the structure of the form.
-   * @param \Drupal\Core\Form\FormStateInterface $form_state
-   *   The current state of the form.
-   */
-  public function submitForm(array &$form, FormStateInterface $form_state) {
-    // Empty implementation of the abstract submit class.
-  }
-
-  /**
-   * Defines the settings form for Heartbeat entities.
-   *
-   * @param array $form
-   *   An associative array containing the structure of the form.
-   * @param \Drupal\Core\Form\FormStateInterface $form_state
-   *   The current state of the form.
-   *
-   * @return array
-   *   Form definition array.
-   */
-  public function buildForm(array $form, FormStateInterface $form_state) {
-    $form['Heartbeat_settings']['#markup'] = 'Settings form for Heartbeat entities. Manage field settings here.';
-    return $form;
-  }
-
-}

+ 0 - 52
src/Form/HeartbeatStreamEntityDeleteForm.php

@@ -1,52 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Entity\EntityConfirmFormBase;
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Url;
-
-/**
- * Builds the form to delete Heartbeat stream entity entities.
- */
-class HeartbeatStreamEntityDeleteForm extends EntityConfirmFormBase {
-  /**
-   * {@inheritdoc}
-   */
-  public function getQuestion() {
-    return $this->t('Are you sure you want to delete %name?', array('%name' => $this->entity->label()));
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getCancelUrl() {
-    return new Url('entity.heartbeat_stream_entity.collection');
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getConfirmText() {
-    return $this->t('Delete');
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function submitForm(array &$form, FormStateInterface $form_state) {
-    $this->entity->delete();
-
-    drupal_set_message(
-      $this->t('content @type: deleted @label.',
-        [
-          '@type' => $this->entity->bundle(),
-          '@label' => $this->entity->label(),
-        ]
-        )
-    );
-
-    $form_state->setRedirectUrl($this->getCancelUrl());
-  }
-
-}

+ 0 - 83
src/Form/HeartbeatStreamEntityForm.php

@@ -1,83 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Entity\EntityForm;
-use Drupal\Core\Form\FormStateInterface;
-
-/**
- * Class HeartbeatStreamEntityForm.
- *
- * @package Drupal\heartbeat8\Form
- */
-class HeartbeatStreamEntityForm extends EntityForm {
-  /**
-   * {@inheritdoc}
-   */
-  public function form(array $form, FormStateInterface $form_state) {
-    $heartbeat_stream_entity = $this->entity;
-
-    \Drupal::logger('HeartbeatStreamEntityFormDEBUG')->notice('This is getting called');
-
-    $form = parent::form($form, $form_state);
-
-
-    $form['id'] = array(
-      '#type' => 'machine_name',
-      '#default_value' => $heartbeat_stream_entity->id(),
-      '#machine_name' => array(
-        'exists' => '\Drupal\heartbeat8\Entity\HeartbeatStreamEntity::load',
-      ),
-      '#disabled' => !$heartbeat_stream_entity->isNew(),
-    );
-
-
-    $form['label'] = array(
-      '#type' => 'textfield',
-      '#title' => $this->t('Label'),
-      '#maxlength' => 255,
-      '#default_value' => $heartbeat_stream_entity->label(),
-      '#description' => $this->t("Label for the Heartbeat stream entity."),
-      '#required' => TRUE,
-    );
-//
-//    $form['Message ID'] = array(
-//      '#type' => 'textfield',
-//      '#title' => $this->t('Message ID'),
-//      '#maxlength' => 255,
-//      '#default_value' => $heartbeat_stream_entity->label(),
-//      '#description' => $this->t("Identifier for this Message Stream type"),
-//      '#required' => TRUE,
-//    );
-
-
-
-
-    /* You will need additional form elements for your custom properties. */
-
-    return $form;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function save(array $form, FormStateInterface $form_state) {
-    $heartbeat_stream_entity = $this->entity;
-    $status = $heartbeat_stream_entity->save();
-
-    switch ($status) {
-      case SAVED_NEW:
-        drupal_set_message($this->t('Created the %label Heartbeat stream entity.', [
-          '%label' => $heartbeat_stream_entity->label(),
-        ]));
-        break;
-
-      default:
-        drupal_set_message($this->t('Saved the %label Heartbeat stream entity.', [
-          '%label' => $heartbeat_stream_entity->label(),
-        ]));
-    }
-    $form_state->setRedirectUrl($heartbeat_stream_entity->urlInfo('collection'));
-  }
-
-}

+ 0 - 53
src/Form/HeartbeatTypeDeleteForm.php

@@ -1,53 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Entity\EntityConfirmFormBase;
-use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Url;
-
-/**
- * Builds the form to delete Heartbeat type entities.
- */
-class HeartbeatTypeDeleteForm extends EntityConfirmFormBase {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getQuestion() {
-    return $this->t('Are you sure you want to delete %name?', ['%name' => $this->entity->label()]);
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getCancelUrl() {
-    return new Url('entity.heartbeat_type.collection');
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getConfirmText() {
-    return $this->t('Delete');
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function submitForm(array &$form, FormStateInterface $form_state) {
-    $this->entity->delete();
-
-    drupal_set_message(
-      $this->t('content @type: deleted @label.',
-        [
-          '@type' => $this->entity->bundle(),
-          '@label' => $this->entity->label(),
-        ]
-        )
-    );
-
-    $form_state->setRedirectUrl($this->getCancelUrl());
-  }
-
-}

+ 0 - 67
src/Form/HeartbeatTypeForm.php

@@ -1,67 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Entity\EntityForm;
-use Drupal\Core\Form\FormStateInterface;
-
-/**
- * Class HeartbeatTypeForm.
- *
- * @package Drupal\heartbeat8\Form
- */
-class HeartbeatTypeForm extends EntityForm {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function form(array $form, FormStateInterface $form_state) {
-    $form = parent::form($form, $form_state);
-
-    $heartbeat_type = $this->entity;
-    $form['label'] = [
-      '#type' => 'textfield',
-      '#title' => $this->t('Label'),
-      '#maxlength' => 255,
-      '#default_value' => $heartbeat_type->label(),
-      '#description' => $this->t("Label for the Heartbeat type."),
-      '#required' => TRUE,
-    ];
-
-    $form['id'] = [
-      '#type' => 'machine_name',
-      '#default_value' => $heartbeat_type->id(),
-      '#machine_name' => [
-        'exists' => '\Drupal\heartbeat8\Entity\HeartbeatType::load',
-      ],
-      '#disabled' => !$heartbeat_type->isNew(),
-    ];
-
-    /* You will need additional form elements for your custom properties. */
-
-    return $form;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function save(array $form, FormStateInterface $form_state) {
-    $heartbeat_type = $this->entity;
-    $status = $heartbeat_type->save();
-
-    switch ($status) {
-      case SAVED_NEW:
-        drupal_set_message($this->t('Created the %label Heartbeat type.', [
-          '%label' => $heartbeat_type->label(),
-        ]));
-        break;
-
-      default:
-        drupal_set_message($this->t('Saved the %label Heartbeat type.', [
-          '%label' => $heartbeat_type->label(),
-        ]));
-    }
-    $form_state->setRedirectUrl($heartbeat_type->toUrl('collection'));
-  }
-
-}

+ 0 - 99
src/Form/TemplateList.php

@@ -1,99 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Form;
-
-use Drupal\Core\Form\FormBase;
-use Drupal\Core\Form\FormStateInterface;
-use Symfony\Component\DependencyInjection\ContainerInterface;
-use Drupal\Core\Form\FormBuilder;
-use Symfony\Component\HttpFoundation\Request;
-use Drupal\user\UserData;
-
-/**
- * Class TemplateList.
- *
- * @package Drupal\heartbeat8\Form
- */
-class TemplateList extends FormBase {
-
-  /**
-   * Drupal\Core\Form\FormBuilder definition.
-   *
-   * @var Drupal\Core\Form\FormBuilder
-   */
-  protected $form_builder;
-
-  /**
-   * Symfony\Component\HttpFoundation\Request definition.
-   *
-   * @var Symfony\Component\HttpFoundation\Request
-   */
-  protected $request;
-
-  /**
-   * Drupal\user\UserData definition.
-   *
-   * @var Drupal\user\UserData
-   */
-  protected $user_data;
-  public function __construct(
-    FormBuilder $form_builder,
-    UserData $user_data
-  ) {
-    $this->form_builder = $form_builder;
-    $this->user_data = $user_data;
-  }
-
-  public static function create(ContainerInterface $container) {
-    return new static(
-      $container->get('form_builder'),
-      $container->get('user.data')
-    );
-  }
-
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getFormId() {
-    return 'template_list';
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildForm(array $form, FormStateInterface $form_state) {
-    $templateNames = ['One', 'Two', 'Three', 'Four'];
-
-    foreach ($templateNames as $templateName) {
-      $form[$templateName] = array(
-        'Template' => array(
-          '#type' => 'details',
-          '#title' => t('Wut'),
-          '#collapsible' => TRUE,
-          '#collapsed' => TRUE,
-          '#states' => array(
-            'expanded' => array(
-              ':input[name="Template name"]' => array('value' => 'expand'),
-            ),
-          ),
-        ),
-        'notes' => array(
-        '#type' => 'textarea',
-        '#title' => $this->t($templateName . ' notes'),
-        '#description' => $this->t('Additional notes'),
-        )
-      );
-    }
-
-    return $form;
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function submitForm(array &$form, FormStateInterface $form_state) {
-
-  }
-
-}

+ 0 - 47
src/HeartbeatAccessControlHandler.php

@@ -1,47 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\Core\Entity\EntityAccessControlHandler;
-use Drupal\Core\Entity\EntityInterface;
-use Drupal\Core\Session\AccountInterface;
-use Drupal\Core\Access\AccessResult;
-
-/**
- * Access controller for the Heartbeat entity.
- *
- * @see \Drupal\heartbeat8\Entity\Heartbeat.
- */
-class HeartbeatAccessControlHandler extends EntityAccessControlHandler {
-
-  /**
-   * {@inheritdoc}
-   */
-  protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account) {
-    /** @var \Drupal\heartbeat8\Entity\HeartbeatInterface $entity */
-    switch ($operation) {
-      case 'view':
-        if (!$entity->isPublished()) {
-          return AccessResult::allowedIfHasPermission($account, 'view unpublished heartbeat entities');
-        }
-        return AccessResult::allowedIfHasPermission($account, 'view published heartbeat entities');
-
-      case 'update':
-        return AccessResult::allowedIfHasPermission($account, 'edit heartbeat entities');
-
-      case 'delete':
-        return AccessResult::allowedIfHasPermission($account, 'delete heartbeat entities');
-    }
-
-    // Unknown operation, no opinion.
-    return AccessResult::neutral();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  protected function checkCreateAccess(AccountInterface $account, array $context, $entity_bundle = NULL) {
-    return AccessResult::allowedIfHasPermission($account, 'add heartbeat entities');
-  }
-
-}

+ 0 - 225
src/HeartbeatHtmlRouteProvider.php

@@ -1,225 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\Core\Entity\EntityTypeInterface;
-use Drupal\Core\Entity\Routing\AdminHtmlRouteProvider;
-use Symfony\Component\Routing\Route;
-
-/**
- * Provides routes for Heartbeat entities.
- *
- * @see Drupal\Core\Entity\Routing\AdminHtmlRouteProvider
- * @see Drupal\Core\Entity\Routing\DefaultHtmlRouteProvider
- */
-class HeartbeatHtmlRouteProvider extends AdminHtmlRouteProvider {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getRoutes(EntityTypeInterface $entity_type) {
-    $collection = parent::getRoutes($entity_type);
-
-    $entity_type_id = $entity_type->id();
-
-    if ($collection_route = $this->getCollectionRoute($entity_type)) {
-      $collection->add("entity.{$entity_type_id}.collection", $collection_route);
-    }
-
-    if ($history_route = $this->getHistoryRoute($entity_type)) {
-      $collection->add("entity.{$entity_type_id}.version_history", $history_route);
-    }
-
-    if ($revision_route = $this->getRevisionRoute($entity_type)) {
-      $collection->add("entity.{$entity_type_id}.revision", $revision_route);
-    }
-
-    if ($revert_route = $this->getRevisionRevertRoute($entity_type)) {
-      $collection->add("entity.{$entity_type_id}.revision_revert", $revert_route);
-    }
-
-    if ($delete_route = $this->getRevisionDeleteRoute($entity_type)) {
-      $collection->add("entity.{$entity_type_id}.revision_delete", $delete_route);
-    }
-
-    if ($translation_route = $this->getRevisionTranslationRevertRoute($entity_type)) {
-      $collection->add("{$entity_type_id}.revision_revert_translation_confirm", $translation_route);
-    }
-
-    if ($settings_form_route = $this->getSettingsFormRoute($entity_type)) {
-      $collection->add("$entity_type_id.settings", $settings_form_route);
-    }
-
-    return $collection;
-  }
-
-  /**
-   * Gets the collection route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getCollectionRoute(EntityTypeInterface $entity_type) {
-    if ($entity_type->hasLinkTemplate('collection') && $entity_type->hasListBuilderClass()) {
-      $entity_type_id = $entity_type->id();
-      $route = new Route($entity_type->getLinkTemplate('collection'));
-      $route
-        ->setDefaults([
-          '_entity_list' => $entity_type_id,
-          '_title' => "{$entity_type->getLabel()} list",
-        ])
-        ->setRequirement('_permission', 'access heartbeat overview')
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-  /**
-   * Gets the version history route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getHistoryRoute(EntityTypeInterface $entity_type) {
-    if ($entity_type->hasLinkTemplate('version-history')) {
-      $route = new Route($entity_type->getLinkTemplate('version-history'));
-      $route
-        ->setDefaults([
-          '_title' => "{$entity_type->getLabel()} revisions",
-          '_controller' => '\Drupal\heartbeat8\Controller\HeartbeatController::revisionOverview',
-        ])
-        ->setRequirement('_permission', 'access heartbeat revisions')
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-  /**
-   * Gets the revision route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getRevisionRoute(EntityTypeInterface $entity_type) {
-    if ($entity_type->hasLinkTemplate('revision')) {
-      $route = new Route($entity_type->getLinkTemplate('revision'));
-      $route
-        ->setDefaults([
-          '_controller' => '\Drupal\heartbeat8\Controller\HeartbeatController::revisionShow',
-          '_title_callback' => '\Drupal\heartbeat8\Controller\HeartbeatController::revisionPageTitle',
-        ])
-        ->setRequirement('_permission', 'access heartbeat revisions')
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-  /**
-   * Gets the revision revert route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getRevisionRevertRoute(EntityTypeInterface $entity_type) {
-    if ($entity_type->hasLinkTemplate('revision_revert')) {
-      $route = new Route($entity_type->getLinkTemplate('revision_revert'));
-      $route
-        ->setDefaults([
-          '_form' => '\Drupal\heartbeat8\Form\HeartbeatRevisionRevertForm',
-          '_title' => 'Revert to earlier revision',
-        ])
-        ->setRequirement('_permission', 'revert all heartbeat revisions')
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-  /**
-   * Gets the revision delete route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getRevisionDeleteRoute(EntityTypeInterface $entity_type) {
-    if ($entity_type->hasLinkTemplate('revision_delete')) {
-      $route = new Route($entity_type->getLinkTemplate('revision_delete'));
-      $route
-        ->setDefaults([
-          '_form' => '\Drupal\heartbeat8\Form\HeartbeatRevisionDeleteForm',
-          '_title' => 'Delete earlier revision',
-        ])
-        ->setRequirement('_permission', 'delete all heartbeat revisions')
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-  /**
-   * Gets the revision translation revert route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getRevisionTranslationRevertRoute(EntityTypeInterface $entity_type) {
-    if ($entity_type->hasLinkTemplate('translation_revert')) {
-      $route = new Route($entity_type->getLinkTemplate('translation_revert'));
-      $route
-        ->setDefaults([
-          '_form' => '\Drupal\heartbeat8\Form\HeartbeatRevisionRevertTranslationForm',
-          '_title' => 'Revert to earlier revision of a translation',
-        ])
-        ->setRequirement('_permission', 'revert all heartbeat revisions')
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-  /**
-   * Gets the settings form route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getSettingsFormRoute(EntityTypeInterface $entity_type) {
-    if (!$entity_type->getBundleEntityType()) {
-      $route = new Route("/admin/structure/{$entity_type->id()}/settings");
-      $route
-        ->setDefaults([
-          '_form' => 'Drupal\heartbeat8\Form\HeartbeatSettingsForm',
-          '_title' => "{$entity_type->getLabel()} settings",
-        ])
-        ->setRequirement('_permission', $entity_type->getAdminPermission())
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-}

+ 0 - 45
src/HeartbeatListBuilder.php

@@ -1,45 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\Core\Entity\EntityInterface;
-use Drupal\Core\Entity\EntityListBuilder;
-use Drupal\Core\Routing\LinkGeneratorTrait;
-use Drupal\Core\Url;
-
-/**
- * Defines a class to build a listing of Heartbeat entities.
- *
- * @ingroup heartbeat8
- */
-class HeartbeatListBuilder extends EntityListBuilder {
-
-  use LinkGeneratorTrait;
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildHeader() {
-    $header['id'] = $this->t('Heartbeat ID');
-    $header['name'] = $this->t('Name');
-    return $header + parent::buildHeader();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildRow(EntityInterface $entity) {
-    /* @var $entity \Drupal\heartbeat8\Entity\Heartbeat */
-    $row['id'] = $entity->id();
-    $row['name'] = $this->l(
-      $entity->label(),
-      new Url(
-        'entity.heartbeat.edit_form', array(
-          'heartbeat' => $entity->id(),
-        )
-      )
-    );
-    return $row + parent::buildRow($entity);
-  }
-
-}

+ 0 - 58
src/HeartbeatStorage.php

@@ -1,58 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\Core\Entity\Sql\SqlContentEntityStorage;
-use Drupal\Core\Session\AccountInterface;
-use Drupal\Core\Language\LanguageInterface;
-use Drupal\heartbeat8\Entity\HeartbeatInterface;
-
-/**
- * Defines the storage handler class for Heartbeat entities.
- *
- * This extends the base storage class, adding required special handling for
- * Heartbeat entities.
- *
- * @ingroup heartbeat8
- */
-class HeartbeatStorage extends SqlContentEntityStorage implements HeartbeatStorageInterface {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function revisionIds(HeartbeatInterface $entity) {
-    return $this->database->query(
-      'SELECT vid FROM {heartbeat_revision} WHERE id=:id ORDER BY vid',
-      array(':id' => $entity->id())
-    )->fetchCol();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function userRevisionIds(AccountInterface $account) {
-    return $this->database->query(
-      'SELECT vid FROM {heartbeat_field_revision} WHERE uid = :uid ORDER BY vid',
-      array(':uid' => $account->id())
-    )->fetchCol();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function countDefaultLanguageRevisions(HeartbeatInterface $entity) {
-    return $this->database->query('SELECT COUNT(*) FROM {heartbeat_field_revision} WHERE id = :id AND default_langcode = 1', array(':id' => $entity->id()))
-      ->fetchField();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function clearRevisionsLanguage(LanguageInterface $language) {
-    return $this->database->update('heartbeat_revision')
-      ->fields(array('langcode' => LanguageInterface::LANGCODE_NOT_SPECIFIED))
-      ->condition('langcode', $language->getId())
-      ->execute();
-  }
-
-}

+ 0 - 61
src/HeartbeatStorageInterface.php

@@ -1,61 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\Core\Entity\ContentEntityStorageInterface;
-use Drupal\Core\Session\AccountInterface;
-use Drupal\Core\Language\LanguageInterface;
-use Drupal\heartbeat8\Entity\HeartbeatInterface;
-
-/**
- * Defines the storage handler class for Heartbeat entities.
- *
- * This extends the base storage class, adding required special handling for
- * Heartbeat entities.
- *
- * @ingroup heartbeat8
- */
-interface HeartbeatStorageInterface extends ContentEntityStorageInterface {
-
-  /**
-   * Gets a list of Heartbeat revision IDs for a specific Heartbeat.
-   *
-   * @param \Drupal\heartbeat8\Entity\HeartbeatInterface $entity
-   *   The Heartbeat entity.
-   *
-   * @return int[]
-   *   Heartbeat revision IDs (in ascending order).
-   */
-  public function revisionIds(HeartbeatInterface $entity);
-
-  /**
-   * Gets a list of revision IDs having a given user as Heartbeat author.
-   *
-   * @param \Drupal\Core\Session\AccountInterface $account
-   *   The user entity.
-   *
-   * @return int[]
-   *   Heartbeat revision IDs (in ascending order).
-   */
-  public function userRevisionIds(AccountInterface $account);
-
-  /**
-   * Counts the number of revisions in the default language.
-   *
-   * @param \Drupal\heartbeat8\Entity\HeartbeatInterface $entity
-   *   The Heartbeat entity.
-   *
-   * @return int
-   *   The number of revisions in the default language.
-   */
-  public function countDefaultLanguageRevisions(HeartbeatInterface $entity);
-
-  /**
-   * Unsets the language for all Heartbeat with the given language.
-   *
-   * @param \Drupal\Core\Language\LanguageInterface $language
-   *   The language object.
-   */
-  public function clearRevisionsLanguage(LanguageInterface $language);
-
-}

+ 0 - 95
src/HeartbeatStreamEntityHtmlRouteProvider.php

@@ -1,95 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\Core\Entity\EntityTypeInterface;
-use Drupal\Core\Entity\Routing\AdminHtmlRouteProvider;
-use Symfony\Component\Routing\Route;
-
-/**
- * Provides routes for Heartbeat stream entity entities.
- *
- * @see Drupal\Core\Entity\Routing\AdminHtmlRouteProvider
- * @see Drupal\Core\Entity\Routing\DefaultHtmlRouteProvider
- */
-class HeartbeatStreamEntityHtmlRouteProvider extends AdminHtmlRouteProvider {
-  /**
-   * {@inheritdoc}
-   */
-  public function getRoutes(EntityTypeInterface $entity_type) {
-    $collection = parent::getRoutes($entity_type);
-
-    $entity_type_id = $entity_type->id();
-
-    if ($collection_route = $this->getCollectionRoute($entity_type)) {
-      $collection->add("entity.{$entity_type_id}.collection", $collection_route);
-    }
-
-    if ($add_form_route = $this->getAddFormRoute($entity_type)) {
-      $collection->add("entity.{$entity_type_id}.add_form", $add_form_route);
-    }
-
-    return $collection;
-  }
-
-  /**
-   * Gets the collection route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getCollectionRoute(EntityTypeInterface $entity_type) {
-    if ($entity_type->hasLinkTemplate('collection') && $entity_type->hasListBuilderClass()) {
-      $entity_type_id = $entity_type->id();
-      $route = new Route($entity_type->getLinkTemplate('collection'));
-      $route
-        ->setDefaults([
-          '_entity_list' => $entity_type_id,
-          // Make sure this is not a TranslatableMarkup object as the
-          // TitleResolver translates this string again.
-          '_title' => (string) $entity_type->getLabel(),
-        ])
-        ->setRequirement('_permission', $entity_type->getAdminPermission())
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-  /**
-   * Gets the add-form route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getAddFormRoute(EntityTypeInterface $entity_type) {
-    if ($entity_type->hasLinkTemplate('add-form')) {
-      $entity_type_id = $entity_type->id();
-      $route = new Route($entity_type->getLinkTemplate('add-form'));
-      // Use the add form handler, if available, otherwise default.
-      $operation = 'default';
-      if ($entity_type->getFormClass('add')) {
-        $operation = 'add';
-      }
-      $route
-        ->setDefaults([
-          '_entity_form' => "{$entity_type_id}.{$operation}",
-          '_title' => "Add {$entity_type->getLabel()}",
-        ])
-        ->setRequirement('_entity_create_access', $entity_type_id)
-        ->setOption('parameters', [
-          $entity_type_id => ['type' => 'entity:' . $entity_type_id],
-        ])
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-}

+ 0 - 31
src/HeartbeatStreamEntityListBuilder.php

@@ -1,31 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\Core\Config\Entity\ConfigEntityListBuilder;
-use Drupal\Core\Entity\EntityInterface;
-
-/**
- * Provides a listing of Heartbeat stream entity entities.
- */
-class HeartbeatStreamEntityListBuilder extends ConfigEntityListBuilder {
-  /**
-   * {@inheritdoc}
-   */
-  public function buildHeader() {
-    $header['label'] = $this->t('Heartbeat stream entity');
-    $header['id'] = $this->t('Machine name');
-    return $header + parent::buildHeader();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildRow(EntityInterface $entity) {
-    $row['label'] = $entity->label();
-    $row['id'] = $entity->id();
-    // You probably want a few more properties here...
-    return $row + parent::buildRow($entity);
-  }
-
-}

+ 0 - 14
src/HeartbeatTranslationHandler.php

@@ -1,14 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\content_translation\ContentTranslationHandler;
-
-/**
- * Defines the translation handler for heartbeat.
- */
-class HeartbeatTranslationHandler extends ContentTranslationHandler {
-
-  // Override here the needed methods from ContentTranslationHandler.
-
-}

+ 0 - 59
src/HeartbeatTypeHtmlRouteProvider.php

@@ -1,59 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\Core\Entity\EntityTypeInterface;
-use Drupal\Core\Entity\Routing\AdminHtmlRouteProvider;
-use Symfony\Component\Routing\Route;
-
-/**
- * Provides routes for Heartbeat type entities.
- *
- * @see Drupal\Core\Entity\Routing\AdminHtmlRouteProvider
- * @see Drupal\Core\Entity\Routing\DefaultHtmlRouteProvider
- */
-class HeartbeatTypeHtmlRouteProvider extends AdminHtmlRouteProvider {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function getRoutes(EntityTypeInterface $entity_type) {
-    $collection = parent::getRoutes($entity_type);
-
-    $entity_type_id = $entity_type->id();
-
-    if ($collection_route = $this->getCollectionRoute($entity_type)) {
-      $collection->add("entity.{$entity_type_id}.collection", $collection_route);
-    }
-
-    return $collection;
-  }
-
-  /**
-   * Gets the collection route.
-   *
-   * @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
-   *   The entity type.
-   *
-   * @return \Symfony\Component\Routing\Route|null
-   *   The generated route, if available.
-   */
-  protected function getCollectionRoute(EntityTypeInterface $entity_type) {
-    if ($entity_type->hasLinkTemplate('collection') && $entity_type->hasListBuilderClass()) {
-      $entity_type_id = $entity_type->id();
-      $route = new Route($entity_type->getLinkTemplate('collection'));
-      $route
-        ->setDefaults([
-          '_entity_list' => $entity_type_id,
-          // Make sure this is not a TranslatableMarkup object as the
-          // TitleResolver translates this string again.
-          '_title' => (string) $entity_type->getLabel(),
-        ])
-        ->setRequirement('_permission', $entity_type->getAdminPermission())
-        ->setOption('_admin_route', TRUE);
-
-      return $route;
-    }
-  }
-
-}

+ 0 - 32
src/HeartbeatTypeListBuilder.php

@@ -1,32 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8;
-
-use Drupal\Core\Config\Entity\ConfigEntityListBuilder;
-use Drupal\Core\Entity\EntityInterface;
-
-/**
- * Provides a listing of Heartbeat type entities.
- */
-class HeartbeatTypeListBuilder extends ConfigEntityListBuilder {
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildHeader() {
-    $header['label'] = $this->t('Heartbeat type');
-    $header['id'] = $this->t('Machine name');
-    return $header + parent::buildHeader();
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function buildRow(EntityInterface $entity) {
-    $row['label'] = $entity->label();
-    $row['id'] = $entity->id();
-    // You probably want a few more properties here...
-    return $row + parent::buildRow($entity);
-  }
-
-}

+ 0 - 37
src/Plugin/Action/Heartbeat.php

@@ -1,37 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Plugin\Action;
-
-use Drupal\Core\Action\ActionBase;
-use Drupal\Core\Ajax\AjaxResponse;
-use Drupal\Core\Session\AccountInterface;
-
-/**
- * Provides a 'Heartbeat' action.
- *
- * @Action(
- *  id = "heartbeat",
- *  label = @Translation("Heartbeat"),
- *  type = "user",
- * )
- */
-class Heartbeat extends ActionBase {
-  /**
-   * {@inheritdoc}
-   */
-  public function execute($object = NULL) {
-    // Insert code here.
-  }
-
-  /**
-   * {@inheritdoc}
-   */
-  public function access($object, AccountInterface $account = NULL, $return_as_object = FALSE) {
-    /** @var \Drupal\user\UserInterface $object */
-    $access = $object->status->access('edit', $account, TRUE)
-      ->andIf($object->access('update', $account, TRUE));
-
-    return $return_as_object ? $access : $access->isAllowed();
-  }
-
-}

+ 0 - 46
src/Tests/LoadTest.php

@@ -1,46 +0,0 @@
-<?php
-
-namespace Drupal\heartbeat8\Tests;
-
-use Drupal\Core\Url;
-use Drupal\simpletest\WebTestBase;
-
-/**
- * Simple test to ensure that main page loads with module enabled.
- *
- * @group heartbeat8
- */
-class LoadTest extends WebTestBase{
-
-  /**
-   * Modules to enable.
-   *
-   * @var array
-   */
-  public static $modules = ['heartbeat8'];
-
-  /**
-   * A user with permission to administer site configuration.
-   *
-   * @var \Drupal\user\UserInterface
-   */
-  protected $user;
-
-  /**
-   * {@inheritdoc}
-   */
-  protected function setUp() {
-    parent::setUp();
-    $this->user = $this->drupalCreateUser(['administer site configuration']);
-    $this->drupalLogin($this->user);
-  }
-
-  /**
-   * Tests that the home page loads with a 200 response.
-   */
-  public function testLoad() {
-    $this->drupalGet(Url::fromRoute('<front>'));
-    $this->assertResponse(200);
-  }
-
-}

+ 0 - 23
templates/heartbeat-content-add-list.html.twig

@@ -1,23 +0,0 @@
-{#
-/**
- * @file
- * Default theme implementation to present a list of custom content entity types/bundles.
- *
- * Available variables:
- * - types: A collection of all the available custom entity types/bundles.
- *   Each type/bundle contains the following:
- *   - link: A link to add a content entity of this type.
- *   - description: A description of this content entity types/bundle.
- *
- * @see template_preprocess_heartbeat_content_add_list()
- *
- * @ingroup themeable
- */
-#}
-{% spaceless %}
-  <dl>
-    {% for type in types %}
-      <dt>{{ type.link }}</dt>
-    {% endfor %}
-  </dl>
-{% endspaceless %}

+ 0 - 22
templates/heartbeat.html.twig

@@ -1,22 +0,0 @@
-{#
-/**
- * @file heartbeat.html.twig
- * Default theme implementation to present Heartbeat data.
- *
- * This template is used when viewing Heartbeat pages.
- *
- *
- * Available variables:
- * - content: A list of content items. Use 'content' to print all content, or
- * - attributes: HTML attributes for the container element.
- *
- * @see template_preprocess_heartbeat()
- *
- * @ingroup themeable
- */
-#}
-<div{{ attributes.addClass('heartbeat') }}>
-  {% if content %}
-    {{- content -}}
-  {% endif %}
-</div>

+ 0 - 1
templates/heartbeat8.html.twig

@@ -1 +0,0 @@
-<!-- Add you custom twig html here -->