Topic::class, 'foreign_key' => 'category_id', 'assoc_foreign_key' => 'category_id', 'order_by' => 'ORDER BY position ASC, mkdate DESC', ]; $config['additional_fields']['range'] = [ 'set' => function (Category $category, string $field, Range $range) { $category->range_id = $range->getRangeId(); }, 'get' => function (Category $category): Range { return get_object_by_range_id($category->range_id); }, ]; $config['additional_fields']['metadata']['get'] = 'getMetaData'; $config['registered_callbacks']['after_delete'][] = 'onDelete'; parent::configure($config); } /** * @return self[] */ public static function getCourseCategories($range_id): array { return self::findBySQL("range_id = ? ORDER BY position ASC, mkdate DESC", [$range_id]); } public function getMetadata(): array { $metadata= DBManager::get()->fetchOne( "SELECT COUNT(DISTINCT`forum_topics`.`topic_id`) AS 'topics_count', COUNT(DISTINCT `forum_discussions`.`discussion_id`) AS 'discussions_count', COUNT(DISTINCT `forum_postings`.`posting_id`) AS 'postings_count', COUNT(DISTINCT `forum_postings`.`user_id`) AS 'users_count', MAX(`forum_postings`.`mkdate`) AS 'recent_activity', ( SELECT SUM(fpr.read_index) FROM forum_topics ft2 LEFT JOIN forum_discussions fd2 USING (`topic_id`) JOIN forum_posting_reads fpr ON fpr.discussion_id = fd2.discussion_id AND fpr.user_id = :user_id WHERE ft2.category_id = :category_id ) AS 'user_read_index', ( SELECT COUNT(DISTINCT fp.posting_id) FROM forum_postings fp JOIN `forum_discussions` fd USING (discussion_id) JOIN `forum_topics` ft USING (topic_id) WHERE ft.category_id = :category_id AND fp.user_id != :user_id ) AS 'others_postings_count' FROM `forum_topics` LEFT JOIN `forum_discussions` USING (`topic_id`) LEFT JOIN `forum_postings` USING (`discussion_id`) WHERE `forum_topics`.`category_id` = :category_id", [ 'category_id' => $this->category_id, 'user_id' => User::findCurrent()?->user_id ] ); return [ ...$metadata, 'unread_postings_count' => max( 0, $metadata['others_postings_count'] - (int) $metadata['user_read_index'] ) ]; } public function transformData(): array { return [ 'category_id' => $this->category_id, 'range_id' => $this->range_id, 'name' => $this->name, 'description' => $this->description, 'color' => $this->color, 'position' => $this->position, 'chdate' => date('c', $this->chdate), 'mkdate' => date('c', $this->mkdate) ]; } public function onDelete(): void { DBManager::get()->execute( "Update `forum_topics` SET `category_id` = null WHERE `category_id` = ?", [$this->category_id] ); } }