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:
Agora:
Resultado:
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:
Todas 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:
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:
Depois:
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:
Leia a documentação aqui.
Agora também é possível obter um parâmetro específico utilizando o método:
As 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:
Leia a documentação aqui.
Versão estável inicial do Luna.
Last updated