From 7950258b1cb1c5eb939e5fe5b00723cecf2a1ae0 Mon Sep 17 00:00:00 2001 From: niqingyang Date: Tue, 2 Jan 2024 17:22:54 +0800 Subject: [PATCH] Update the comments of the method createQueryTo in ActiveRecordFactory so that the IDE can automatically identify the specific class of ActiveRecord --- src/BaseActiveRecord.php | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/src/BaseActiveRecord.php b/src/BaseActiveRecord.php index d6cb497e3..10621a408 100644 --- a/src/BaseActiveRecord.php +++ b/src/BaseActiveRecord.php @@ -320,12 +320,15 @@ public function hasAttribute($name): bool * * Call methods declared in {@see ActiveQuery} to further customize the relation. * - * @param string $class The class name of the related record + * @param class-string $class The class name of the related record * @param array $link The primary-foreign key constraint. The keys of the array refer to the attributes of the * record associated with the `$class` model, while the values of the array refer to the corresponding attributes in * **this** AR class. * * @return ActiveQueryInterface The relational query object. + * + * @psalm-template T of ActiveRecordInterface + * @psalm-param class-string $arClass */ public function hasMany(string $class, array $link): ActiveQueryInterface { @@ -356,18 +359,28 @@ public function hasMany(string $class, array $link): ActiveQueryInterface * * Call methods declared in {@see ActiveQuery} to further customize the relation. * - * @param string $class The class name of the related record. + * @param class-string $class The class name of the related record. * @param array $link The primary-foreign key constraint. The keys of the array refer to the attributes of the * record associated with the `$class` model, while the values of the array refer to the corresponding attributes in * **this** AR class. * * @return ActiveQueryInterface The relational query object. + * + * @psalm-template T of ActiveRecordInterface + * @psalm-param class-string $arClass */ public function hasOne(string $class, array $link): ActiveQueryInterface { return $this->createRelationQuery($class, $link, false); } + /** + * @param class-string $arClass + * @return ActiveQueryInterface + * + * @psalm-template T of ActiveRecordInterface + * @psalm-param class-string $arClass + */ public function instantiateQuery(string $arClass): ActiveQueryInterface { return new ActiveQuery($arClass, $this->db, $this->arFactory); @@ -1114,11 +1127,14 @@ private function setRelationDependencies( /** * Creates a query instance for `has-one` or `has-many` relation. * - * @param string $arClass The class name of the related record. + * @param class-string $arClass The class name of the related record. * @param array $link The primary-foreign key constraint. * @param bool $multiple Whether this query represents a relation to more than one record. * * @return ActiveQueryInterface The relational query object. + * + * @psalm-template T of ActiveRecordInterface + * @psalm-param class-string $arClass * {@see hasOne()} * {@see hasMany()}