Logo

dev-resources.site

for different kinds of informations.

Client Extension no Liferay

Published at
11/13/2024
Categories
liferay
performance
bestpractice
webdev
Author
cdfortes
Author
8 person written this
cdfortes
open
Client Extension no Liferay

Client Extensions são uma maneira moderna de integrar ou personalizar o Liferay sem a necessidade de desenvolvimento profundo diretamente no servidor. Elas permitem que você mantenha uma arquitetura desacoplada, facilitando o desenvolvimento e a manutenção contínua.

Em resumo, as client extensions são aplicações externas que interagem com o Liferay por meio de APIs e endpoints personalizados, aproveitando tecnologias modernas como React, Angular, e Vue.js.

Passos para criar uma Client Extension no Liferay

1. Preparação do ambiente de desenvolvimento

Antes de iniciar a criação de uma client extension, é necessário configurar o ambiente de desenvolvimento. Certifique-se de que possui as seguintes ferramentas instaladas:

  • Liferay DXP ou Liferay CE (dependendo da sua versão preferida)
  • Node.js e npm/yarn (para gerenciar pacotes e dependências)
  • Liferay CLI (Liferay Project Generator)

2. Configuração do projeto

A criação de uma client extension começa com a configuração do projeto em si. Utilize o Liferay CLI para inicializar um projeto de extensão:

npx @liferay/cli new <nome-do-projeto> --type client-extension
cd <nome-do-projeto>
Enter fullscreen mode Exit fullscreen mode

Esse comando cria a estrutura básica do projeto, incluindo diretórios específicos para códigos JavaScript/React e arquivos de configuração.

3. Desenvolvimento da extensão

Agora que você tem a estrutura do projeto configurada, é hora de começar a desenvolver a extensão. Dependendo do que deseja criar, o desenvolvimento pode variar. Por exemplo, se você está desenvolvendo um widget React, deve estruturar os componentes dentro da pasta src e configurar corretamente os pontos de entrada no arquivo webpack.config.js.

Exemplo de um componente React simples:

import React from 'react';
import ReactDOM from 'react-dom';

const MeuWidget = () => {
    return <div>Olá, Liferay!</div>;
};

export default MeuWidget;

// Renderização no ponto de entrada
if (document.getElementById('meu-widget-root')) {
    ReactDOM.render(<MeuWidget />, document.getElementById('meu-widget-root'));
}
Enter fullscreen mode Exit fullscreen mode

4. Configuração do manifesto

O Liferay utiliza um arquivo de manifesto (client-extension.json) para identificar e configurar a extensão:

{
    "name": "meu-widget",
    "type": "custom-element",
    "description": "Um exemplo de widget personalizado",
    "friendlyURLMapping": "meu-widget",
    "typeSettings": {
        "htmlElementName": "meu-widget"
    }
}
Enter fullscreen mode Exit fullscreen mode

Esse arquivo define informações essenciais como o tipo da extensão, descrições, URLs amigáveis, e configurações específicas.

5. Teste e deploy

Depois de finalizar o desenvolvimento e configurar o manifesto, é importante testar a extensão localmente para garantir que tudo funcione conforme o esperado.

  • Build do projeto: Para criar a versão final da sua extensão, execute o comando de build:
  npm run build
Enter fullscreen mode Exit fullscreen mode
  • Deploy no Liferay: Para fazer o deploy, mova os arquivos compilados para o diretório de deploy do Liferay ou utilize o comando CLI específico para client extensions:
  liferay deploy
Enter fullscreen mode Exit fullscreen mode

6. Integração e configuração no Portal

Uma vez que o deploy for realizado com sucesso, a extensão aparecerá no painel de administração do Liferay. Para configurá-la:

  1. Navegue até a seção de Configurações > Client Extensions.
  2. Adicione a nova extensão ao layout desejado, configurando sua visualização e permissões conforme necessário.

Melhores práticas e dicas

  • Modularização do Código: Mantenha o código da client extension modular para facilitar a manutenção e evolução do projeto.
  • Documentação e Comentários: Adicione comentários explicativos e mantenha uma boa documentação interna para que outros desenvolvedores possam entender o propósito e a funcionalidade da extensão.
  • Segurança: Evite o uso de dados sensíveis diretamente no código da extensão. Utilize APIs seguras para proteger informações confidenciais.
  • Responsividade: Certifique-se de que a extensão seja responsiva e funcione bem em diferentes dispositivos.

Conclusão

Criar uma client extension no Liferay permite uma enorme flexibilidade para personalizar e estender as funcionalidades do portal, trazendo inovações rápidas e específicas às suas necessidades de negócio. O processo requer conhecimento técnico sobre desenvolvimento de front-end, ferramentas de build e uma compreensão clara do Liferay CLI, mas os resultados podem transformar a experiência de uso para os administradores e usuários finais do portal.

Fontes para Consulta

  1. Documentação Oficial do Liferay DXP: Documentação de Desenvolvimento do Liferay DXP

  2. Exemplos de Código e Recursos Open Source: Liferay GitHub

Gostou? Deixe um ❤️ e compartilhe com sua rede para que mais desenvolvedores possam explorar Client Extensions no Liferay!

bestpractice Article's
30 articles in total
Favicon
From Bi-weekly to Every 5 Minutes: Modern Continuous Deployment Strategies
Favicon
Notación Big O - Python
Favicon
Docker Advance Part 2: Docker Logging
Favicon
Client Extension no Liferay
Favicon
Dockerfile Best Practices: How to Create Efficient Containers
Favicon
Microservice Best Practices: Scale your java microservices using virtual threads & async programming
Favicon
Design Patterns for C
Favicon
Mastering React Hooks: Best Practices for Efficient and Maintainable Code
Favicon
Why You Should End Your Source Files With a New Line
Favicon
Puppet best practice
Favicon
@Nullable et @NonNull
Favicon
Component best practice question.
Favicon
How to Use CodeWhisperer to Identify Issues and Use Suggestions to Improve Code Security in your IDE
Favicon
Mastering React: Best Practices for Cleaner and More Efficient Code
Favicon
AWS Well-Architected Review in Action
Favicon
Improving Code Quality in Java: Best Practices and Examples
Favicon
Mastering JavaScript Event Handling for Enhanced Frontend Functionality
Favicon
TIL: Best Practices for Handling Secret Keys in Sinatra - The Do's and Don'ts
Favicon
Enhancing Website Accessibility: A Guide for Supporting Users with Disabilities
Favicon
Proposal for a framework.json file in Angular applications
Favicon
Part 3: Component Structure - Building Reusable and Maintainable Components in React!
Favicon
Using useReducer and Redux Toolkit Together: A Powerful Combination for State Management
Favicon
Separation of concerns in React and React Native.
Favicon
REST-API Design Best Practices
Favicon
Flags In Programming
Favicon
10 Essential Best Practices for Writing High-Quality C++ Source Code
Favicon
Avoiding code duplication in styled components
Favicon
Es mala práctica renderizar JSX en React Hook?
Favicon
ReactJS Best Practices
Favicon
Why you should adopt Makefile in all of your projects

Featured ones: