annotate core/modules/book/src/BookOutlineStorage.php @ 19:fa3358dc1485 tip

Add ndrum files
author Chris Cannam
date Wed, 28 Aug 2019 13:14:47 +0100
parents af1871eacc83
children
rev   line source
Chris@0 1 <?php
Chris@0 2
Chris@0 3 namespace Drupal\book;
Chris@0 4
Chris@0 5 use Drupal\Core\Database\Connection;
Chris@0 6
Chris@0 7 /**
Chris@0 8 * Defines a storage class for books outline.
Chris@0 9 */
Chris@0 10 class BookOutlineStorage implements BookOutlineStorageInterface {
Chris@0 11
Chris@0 12 /**
Chris@0 13 * Database Service Object.
Chris@0 14 *
Chris@0 15 * @var \Drupal\Core\Database\Connection
Chris@0 16 */
Chris@0 17 protected $connection;
Chris@0 18
Chris@0 19 /**
Chris@0 20 * Constructs a BookOutlineStorage object.
Chris@0 21 */
Chris@0 22 public function __construct(Connection $connection) {
Chris@0 23 $this->connection = $connection;
Chris@0 24 }
Chris@0 25
Chris@0 26 /**
Chris@0 27 * {@inheritdoc}
Chris@0 28 */
Chris@0 29 public function getBooks() {
Chris@0 30 return $this->connection->query("SELECT DISTINCT(bid) FROM {book}")->fetchCol();
Chris@0 31 }
Chris@0 32
Chris@0 33 /**
Chris@0 34 * {@inheritdoc}
Chris@0 35 */
Chris@0 36 public function hasBooks() {
Chris@0 37 return (bool) $this->connection
Chris@0 38 ->query('SELECT count(bid) FROM {book}')
Chris@0 39 ->fetchField();
Chris@0 40 }
Chris@0 41
Chris@0 42 /**
Chris@0 43 * {@inheritdoc}
Chris@0 44 */
Chris@0 45 public function loadMultiple($nids, $access = TRUE) {
Chris@0 46 $query = $this->connection->select('book', 'b', ['fetch' => \PDO::FETCH_ASSOC]);
Chris@0 47 $query->fields('b');
Chris@0 48 $query->condition('b.nid', $nids, 'IN');
Chris@0 49
Chris@0 50 if ($access) {
Chris@0 51 $query->addTag('node_access');
Chris@0 52 $query->addMetaData('base_table', 'book');
Chris@0 53 }
Chris@0 54
Chris@0 55 return $query->execute();
Chris@0 56 }
Chris@0 57
Chris@0 58 /**
Chris@0 59 * {@inheritdoc}
Chris@0 60 */
Chris@0 61 public function getChildRelativeDepth($book_link, $max_depth) {
Chris@0 62 $query = $this->connection->select('book');
Chris@0 63 $query->addField('book', 'depth');
Chris@0 64 $query->condition('bid', $book_link['bid']);
Chris@0 65 $query->orderBy('depth', 'DESC');
Chris@0 66 $query->range(0, 1);
Chris@0 67
Chris@0 68 $i = 1;
Chris@0 69 $p = 'p1';
Chris@0 70 while ($i <= $max_depth && $book_link[$p]) {
Chris@0 71 $query->condition($p, $book_link[$p]);
Chris@0 72 $p = 'p' . ++$i;
Chris@0 73 }
Chris@0 74
Chris@0 75 return $query->execute()->fetchField();
Chris@0 76 }
Chris@0 77
Chris@0 78 /**
Chris@0 79 * {@inheritdoc}
Chris@0 80 */
Chris@0 81 public function delete($nid) {
Chris@0 82 return $this->connection->delete('book')
Chris@0 83 ->condition('nid', $nid)
Chris@0 84 ->execute();
Chris@0 85 }
Chris@0 86
Chris@0 87 /**
Chris@0 88 * {@inheritdoc}
Chris@0 89 */
Chris@0 90 public function loadBookChildren($pid) {
Chris@0 91 return $this->connection
Chris@0 92 ->query("SELECT * FROM {book} WHERE pid = :pid", [':pid' => $pid])
Chris@0 93 ->fetchAllAssoc('nid', \PDO::FETCH_ASSOC);
Chris@0 94 }
Chris@0 95
Chris@0 96 /**
Chris@0 97 * {@inheritdoc}
Chris@0 98 */
Chris@0 99 public function getBookMenuTree($bid, $parameters, $min_depth, $max_depth) {
Chris@0 100 $query = $this->connection->select('book');
Chris@0 101 $query->fields('book');
Chris@0 102 for ($i = 1; $i <= $max_depth; $i++) {
Chris@0 103 $query->orderBy('p' . $i, 'ASC');
Chris@0 104 }
Chris@0 105 $query->condition('bid', $bid);
Chris@0 106 if (!empty($parameters['expanded'])) {
Chris@0 107 $query->condition('pid', $parameters['expanded'], 'IN');
Chris@0 108 }
Chris@0 109 if ($min_depth != 1) {
Chris@0 110 $query->condition('depth', $min_depth, '>=');
Chris@0 111 }
Chris@0 112 if (isset($parameters['max_depth'])) {
Chris@0 113 $query->condition('depth', $parameters['max_depth'], '<=');
Chris@0 114 }
Chris@0 115 // Add custom query conditions, if any were passed.
Chris@0 116 if (isset($parameters['conditions'])) {
Chris@0 117 foreach ($parameters['conditions'] as $column => $value) {
Chris@0 118 $query->condition($column, $value);
Chris@0 119 }
Chris@0 120 }
Chris@0 121
Chris@0 122 return $query->execute();
Chris@0 123 }
Chris@0 124
Chris@0 125 /**
Chris@0 126 * {@inheritdoc}
Chris@0 127 */
Chris@0 128 public function insert($link, $parents) {
Chris@0 129 return $this->connection
Chris@0 130 ->insert('book')
Chris@0 131 ->fields([
Chris@0 132 'nid' => $link['nid'],
Chris@0 133 'bid' => $link['bid'],
Chris@0 134 'pid' => $link['pid'],
Chris@0 135 'weight' => $link['weight'],
Chris@0 136 ] + $parents
Chris@0 137 )
Chris@0 138 ->execute();
Chris@0 139 }
Chris@0 140
Chris@0 141 /**
Chris@0 142 * {@inheritdoc}
Chris@0 143 */
Chris@0 144 public function update($nid, $fields) {
Chris@0 145 return $this->connection
Chris@0 146 ->update('book')
Chris@0 147 ->fields($fields)
Chris@0 148 ->condition('nid', $nid)
Chris@0 149 ->execute();
Chris@0 150 }
Chris@0 151
Chris@0 152 /**
Chris@0 153 * {@inheritdoc}
Chris@0 154 */
Chris@0 155 public function updateMovedChildren($bid, $original, $expressions, $shift) {
Chris@0 156 $query = $this->connection->update('book');
Chris@0 157 $query->fields(['bid' => $bid]);
Chris@0 158
Chris@0 159 foreach ($expressions as $expression) {
Chris@0 160 $query->expression($expression[0], $expression[1], $expression[2]);
Chris@0 161 }
Chris@0 162
Chris@0 163 $query->expression('depth', 'depth + :depth', [':depth' => $shift]);
Chris@0 164 $query->condition('bid', $original['bid']);
Chris@0 165 $p = 'p1';
Chris@0 166 for ($i = 1; !empty($original[$p]); $p = 'p' . ++$i) {
Chris@0 167 $query->condition($p, $original[$p]);
Chris@0 168 }
Chris@0 169
Chris@0 170 return $query->execute();
Chris@0 171 }
Chris@0 172
Chris@0 173 /**
Chris@0 174 * {@inheritdoc}
Chris@0 175 */
Chris@0 176 public function countOriginalLinkChildren($original) {
Chris@0 177 return $this->connection->select('book', 'b')
Chris@0 178 ->condition('bid', $original['bid'])
Chris@0 179 ->condition('pid', $original['pid'])
Chris@0 180 ->condition('nid', $original['nid'], '<>')
Chris@0 181 ->countQuery()
Chris@0 182 ->execute()->fetchField();
Chris@0 183 }
Chris@0 184
Chris@0 185 /**
Chris@0 186 * {@inheritdoc}
Chris@0 187 */
Chris@0 188 public function getBookSubtree($link, $max_depth) {
Chris@18 189 $query = $this->connection->select('book', 'b', ['fetch' => \PDO::FETCH_ASSOC]);
Chris@0 190 $query->fields('b');
Chris@0 191 $query->condition('b.bid', $link['bid']);
Chris@0 192
Chris@0 193 for ($i = 1; $i <= $max_depth && $link["p$i"]; ++$i) {
Chris@0 194 $query->condition("p$i", $link["p$i"]);
Chris@0 195 }
Chris@0 196 for ($i = 1; $i <= $max_depth; ++$i) {
Chris@0 197 $query->orderBy("p$i");
Chris@0 198 }
Chris@0 199 return $query->execute();
Chris@0 200 }
Chris@0 201
Chris@0 202 }