Notas de atualizações
Nova função multiRender() para renderização múltipla de componentes semelhantes com dados diferentes utilizando um array numérico.
Antes:
$products = ProductService::list();
$productElements = "";
foreach($products as $product) {
$productElements .= Component::render('product-box', $product);
}
return $productElements;Agora:
$products = ProductService::list();
return Component::multiRender('product-box', $products);Buscando uma melhor forma de renderizar views e components utilizando um array, agora é possível acessar valores em diferentes níveis, como por exemplo, para renderizar o valor de $product['category']['name'] :
Antes:
<h1>{{name}}</h1>
<h2>{{categoryName}}</h2>$product['categoryName'] = $product['category']['name']; // 😫
$content = View::render('product', $product);Agora:
<h1>{{name}}</h1>
<h2>{{category->name}}</h2>$content = View::render('product', $product);Resultado:
<h1>Produto Nome</h1>
<h2>Categoria Nome</h2>Os valores podem ser acessados utilizando ->, para acessar $product['category']['icon']['full'] por exemplo, deve-se utilizar {{category->icon->full}}.
Para melhorar a renderização da função getPage(), agora a variável $opts pode receber múltiplos itens, anteriormente era possível utilizar apenas os valores para header, footer e seo. Essa atualização permite que valores de variáveis para renderização da página sejam enviados corretamente.
A função setConfigs() do arquivo app/Db/Database.php foi levemente corrigida para que seja utilizada corretamente como Static e resolver o erro que ocorria ao tentar utilizar o Luna no PHP 8 em diante.
O erro não ocorre nas versões do PHP 7
Buscando evitar problemas com servidores ou erros de gerenciamento de valores nativos do PHP, a classe Environment sofreu alterações para utilizar a variável global $_ENV ao invés das funções nativas putenv() ou getenv().
Com a alteração, os valores informados no arquivo .env agora devem ser obtidos utilizando a classe:
use \App\Common\Environment as Env;
Env::get($key); // Obter item específico
Env::get(); // Obter todos os itemsTodas as classes e arquivos do Luna que utilizavam as funções nativas foram modificadas para utilizar a classe atualizada.
Configurações de SEO fácil e rápida na renderização da página ou view:
$seo = new Seo();
$seo->setTitle("Produto nome");
$seo->setDescription("Produto descrição");
$seo->setKeywords(["produto-chave-1", "produto-chave-2"]);Leia a documentação aqui.
O header e footer agora fazem parte de um array de configurações opcionais. A alteração ocorreu devido a necessidade de novas informações na renderização da página, como o SEO:
Antes:
$content = parent::getPage("Página administrativa", $content, 'header-admin', 'footer-admin');Depois:
$content = parent::getPage("Página administrativa", $content, [
'header' => 'header-admin',
'footer' => 'footer-admin'
]);Para evitar que, em etapa de desenvolvimento ou de manutenções, o arquivo index.php sofresse modificações, as configurações das variáveis padrões das views (antigo View::init) View::define e as variáveis das flash messages Flash::define foram movidas para o arquivo define.php, isolando o arquivo para exclusivamente definições de variáveis e permitindo que o arquivo index.php não exija alterações durante o desenvolvimento.
Correções de erros
Quando uma páginação estava vazia (zero itens resultantes) a renderização da páginação era problemática, uma simples correção de retorno resolveu o problema.
Os headers do retorno da requisição não eram corretamente enviados devido ao uso incorreto da variável $this->headers.
Alguns avisos (WARNING ou ALERT) geram logs desnecessários, algumas correções foram realizadas para que não ocorra, como:
Variável
$responsedefinida previamente no métodonextdeMiddleware.php;Definição de variáveis de ambiente do arquivo
.envcorrigidas em caso de linha em branco para evitar o uso do métodoputenvem strings vazias;Correção de uso da string
DEFAULT_CONTENT_TYPEde variável para string, o aviso poderia se tornar um erro fatal em futuras atualizações do PHP.
Criação e renderização de flash messages na view:
Flash::create("productNotFound", "Produto não encontrado", FLASH_DANGER);
$flash = Flash::render("productNotFound");Leia a documentação aqui.
$req->header(); // getHeaders();
$req->query(); // getQueryParams();
$req->body(); // getPostVars();
$req->param(); // getPathParams();Agora também é possível obter um parâmetro específico utilizando o método:
// ?id=1
$id = $req->query('id');
var_dump($id); // 1As classes
PaginationeCacheforam atualizadas para suportar as atualizações.
Leia a documentação aqui.
As respostas do $response agora podem conter alias para facilitar a definição:
$res->send(200, $content, 'json');
// $res->send(200, $content, 'application/json');
$res->send(200, $content, 'html');
// $res->send(200, $content, 'text/html');Leia a documentação aqui.
Versão estável inicial do Luna.
Last updated