@@ 78-90 (lines=13) @@ | ||
75 | public function removeTerm($object_id, $params = []) |
|
76 | { |
|
77 | $terms = $this->getTerms($object_id, $params); |
|
78 | foreach($terms as $term => $value) { |
|
79 | $term = $this->getTaxonomyTerm($term); |
|
80 | $data['term_id'] = $term->id; |
|
81 | $data['object_id'] = $object_id; |
|
82 | ||
83 | $query = new Query(); |
|
84 | if ($query->from($this->getTable())->where($data)->exists($this->getDb())) { |
|
85 | $this->getDb()->createCommand()->delete($this->getTable(), $data)->execute(); |
|
86 | ||
87 | $term->updateCounters(['total_count' => -1]); |
|
88 | TaxonomyDef::updateAllCounters(['total_count' => -1], [ 'id' => $this->id ]); |
|
89 | } |
|
90 | } |
|
91 | } |
|
92 | ||
93 | public function getTerms($object_id, $name = []) |
@@ 42-54 (lines=13) @@ | ||
39 | $params = $this->getTerms($object_id); |
|
40 | } |
|
41 | ||
42 | foreach($params as $item) { |
|
43 | $term = $this->getTaxonomyTerm($item); |
|
44 | $data['term_id'] = $term->id; |
|
45 | $data['object_id'] = $object_id; |
|
46 | ||
47 | $query = new Query(); |
|
48 | if ($query->from($this->table)->where($data)->exists($this->getDb())) { |
|
49 | $this->getDb()->createCommand()->delete($this->table, $data)->execute(); |
|
50 | ||
51 | $term->updateCounters(['total_count' => -1]); |
|
52 | Taxonomydef::updateAllCounters(['total_count' => -1], [ 'id' => $this->id ]); |
|
53 | } |
|
54 | } |
|
55 | } |
|
56 | ||
57 | public function getTerms($object_id = null, $name = []) |