mirror of
https://github.com/SkillDisplay/PHPToolKit.git
synced 2024-11-22 07:56:09 +01:00
Make skill ID optional when creating link instance
Link looks more like a service. When dealing with dependency injection it would make sense to create a single instance with settings. Following calls can then ask to create a button or link with all necessary information.
This commit is contained in:
parent
ed73b6d3f0
commit
bf1e666091
2 changed files with 22 additions and 6 deletions
|
@ -12,7 +12,7 @@ use SkillDisplay\PHPToolKit\Configuration\Settings;
|
||||||
*/
|
*/
|
||||||
class Link
|
class Link
|
||||||
{
|
{
|
||||||
private int $skillID;
|
private ?int $skillID;
|
||||||
private Settings $settings;
|
private Settings $settings;
|
||||||
|
|
||||||
/* SVG Definitions */
|
/* SVG Definitions */
|
||||||
|
@ -48,7 +48,7 @@ class Link
|
||||||
<circle cx="25" cy="25" r="12" stroke="white" stroke-width="2"/>
|
<circle cx="25" cy="25" r="12" stroke="white" stroke-width="2"/>
|
||||||
</svg>';
|
</svg>';
|
||||||
|
|
||||||
public function __construct(Settings $settings, int $skillID)
|
public function __construct(Settings $settings, ?int $skillID = null)
|
||||||
{
|
{
|
||||||
$this->settings = $settings;
|
$this->settings = $settings;
|
||||||
$this->skillID = $skillID;
|
$this->skillID = $skillID;
|
||||||
|
@ -58,9 +58,15 @@ class Link
|
||||||
* @param string $vtype one of VERIFICATION_SELF, VERIFICATION_EDUCATIONAL, VERIFICATION_BUSINESS, VERIFICATION_CERTIFICATION
|
* @param string $vtype one of VERIFICATION_SELF, VERIFICATION_EDUCATIONAL, VERIFICATION_BUSINESS, VERIFICATION_CERTIFICATION
|
||||||
* @return string URL to a Verification that a user can click, he/she will see the Verification interface and can choose a verifier
|
* @return string URL to a Verification that a user can click, he/she will see the Verification interface and can choose a verifier
|
||||||
*/
|
*/
|
||||||
public function getVerificationLink(string $vtype): string
|
public function getVerificationLink(string $vtype, ?int $skillID = null) : string
|
||||||
{
|
{
|
||||||
$link = $this->settings->getMySkillDisplayUrl() . '/skillup/skill/' . $this->skillID . '/0/';
|
$skillID = $skillID ?? $this->skillID;
|
||||||
|
|
||||||
|
if ($skillID === null) {
|
||||||
|
throw new \InvalidArgumentException('No skill ID provided.', 1599723825);
|
||||||
|
}
|
||||||
|
|
||||||
|
$link = $this->settings->getMySkillDisplayUrl() . '/skillup/skill/' . $skillID . '/0/';
|
||||||
switch ($vtype) {
|
switch ($vtype) {
|
||||||
case VERIFICATION_EDUCATIONAL:
|
case VERIFICATION_EDUCATIONAL:
|
||||||
$link .= '2';
|
$link .= '2';
|
||||||
|
@ -83,7 +89,7 @@ class Link
|
||||||
* @param string $vtype one of VERIFICATION_SELF, VERIFICATION_EDUCATIONAL, VERIFICATION_BUSINESS, VERIFICATION_CERTIFICATION
|
* @param string $vtype one of VERIFICATION_SELF, VERIFICATION_EDUCATIONAL, VERIFICATION_BUSINESS, VERIFICATION_CERTIFICATION
|
||||||
* @return string SVG Button to a Verification that a user can click, he/she will see the Verification interface and can choose a verifier
|
* @return string SVG Button to a Verification that a user can click, he/she will see the Verification interface and can choose a verifier
|
||||||
*/
|
*/
|
||||||
public function getVerificationButton(string $vtype): string
|
public function getVerificationButton(string $vtype, ?int $skillID = null) : string
|
||||||
{
|
{
|
||||||
switch ($vtype) {
|
switch ($vtype) {
|
||||||
case VERIFICATION_EDUCATIONAL:
|
case VERIFICATION_EDUCATIONAL:
|
||||||
|
@ -100,7 +106,7 @@ class Link
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return <<<BUTTON
|
return <<<BUTTON
|
||||||
<a href="{$this->getVerificationLink($vtype)}" target="_blank">{$buttonsvg}</a>
|
<a href="{$this->getVerificationLink($vtype, $skillID)}" target="_blank">{$buttonsvg}</a>
|
||||||
BUTTON;
|
BUTTON;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,16 @@ class LinkTest extends TestCase
|
||||||
static::assertInstanceOf(Link::class, $subject);
|
static::assertInstanceOf(Link::class, $subject);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function instanceCanBeCreatedWithoutSkillId()
|
||||||
|
{
|
||||||
|
$settings = $this->prophesize(Settings::class);
|
||||||
|
$subject = new Link($settings->reveal());
|
||||||
|
static::assertInstanceOf(Link::class, $subject);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in a new issue