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 }
|