Closed
Description
Summary (*)
I don't believe constants should be private as other implementations sometimes need to use them rather than redefining.
Examples (*)
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
namespace Magento\Theme\Block\Html;
use Magento\Framework\App\Config\ScopeConfigInterface;
use Magento\Framework\View\Element\Template;
use Magento\Store\Model\ScopeInterface;
/**
* Html page title block
*
* @method $this setTitleId($titleId)
* @method $this setTitleClass($titleClass)
* @method string getTitleId()
* @method string getTitleClass()
* @api
* @since 100.0.2
*/
class Title extends Template
{
/**
* Config path to 'Translate Title' header settings
*/
private const XML_PATH_HEADER_TRANSLATE_TITLE = 'design/header/translate_title'; // Why is this hidden?
/**
* @var ScopeConfigInterface
*/
private $scopeConfig;
/**
* Own page title to display on the page
*
* @var string
*/
protected $pageTitle;
/**
* Constructor
*
* @param Template\Context $context
* @param ScopeConfigInterface $scopeConfig
* @param array $data
*/
public function __construct(
Template\Context $context,
ScopeConfigInterface $scopeConfig,
array $data = []
) {
parent::__construct($context, $data);
$this->scopeConfig = $scopeConfig; // Can this be gotten from the $context object
}
/**
* Provide own page title or pick it from Head Block
*
* @return string
*/
public function getPageTitle()
{
if (!empty($this->pageTitle)) {
return $this->pageTitle;
}
$pageTitle = $this->pageConfig->getTitle()->getShort();
return $this->shouldTranslateTitle() ? __($pageTitle) : $pageTitle;
}
/**
* Provide own page content heading
*
* @return string
*/
public function getPageHeading()
{
$pageTitle = !empty($this->pageTitle) ? $this->pageTitle : $this->pageConfig->getTitle()->getShortHeading();
return $this->shouldTranslateTitle() ? __($pageTitle) : $pageTitle;
}
/**
* Set own page title
*
* @param string $pageTitle
* @return void
*/
public function setPageTitle($pageTitle)
{
$this->pageTitle = $pageTitle;
}
/**
* Check if page title should be translated
*
* @return bool
*/
private function shouldTranslateTitle(): bool
{
return $this->scopeConfig->isSetFlag(
static::XML_PATH_HEADER_TRANSLATE_TITLE, // Why is this accessed using static if the constant is private?
ScopeInterface::SCOPE_STORE
);
}
}
Proposed solution
- do not make constants private
- If constants are private, access them through
self::
rather thanstatic::
Please provide Severity assessment for the Issue as Reporter. This information will help during Confirmation and Issue triage processes.
- Severity: S4 - Affects aesthetics, professional look and feel, “quality” or “usability”.
Metadata
Metadata
Assignees
Labels
Type
Projects
Status
Done