Compilar seu Modelo

Quando você compila seu modelo, ele cria uma página HTML estática para cada página no arquivo structure.json do site no modelo.

A etapa de compilação combina os metadados da página (por exemplo, 100.json) com o layout da página (por exemplo, about.html), de modo que você tem uma página HTML que será exibida imediatamente sem a necessidade de um controlador no runtime. Os compiladores personalizados permitem reduzir ainda mais a execução de JavaScript do runtime tendo anteriormente itens dinâmicos, como navegação e componentes, compilados na página.

O comando cec compile-template executará as seguintes ações para cada página no site:

  • Ler os metadados do site e da página
  • Ler o layout da página e aplicar qualquer compilador de layout de página
  • Para cada slot na página:
    • Expandir o slot com a grade definida no arquivo page.json
    • Para cada componente no slot:
      • Aplicar qualquer compilador de componente
      • Inserir a marcação gerada do componente no local correspondente dentro do slot
  • Expandir qualquer macro na marcação compilada e inserir o objeto JavaScript SCS usado pelo renderizador do Oracle Content Management no runtime
  • Salvar a marcação da página compilada na pasta src/templates/<template>/static

Para compilar seu site, execute:

> cec compile-template BlogTemplate
Compile Template: compiling template BlogTemplate
Oracle Content Management Site Compiler

createPage: Processing pageId 100. Preview URL: 
http://localhost:8085/templates/BlogTemplate/index.html 
createPage: Processing pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail.html 
createPage: Processing pageId 401. Preview URL: 
http://localhost:8085/templates/BlogTemplate/about.html 
createPage: Processing pageId 402. Preview URL: 
http://localhost:8085/templates/BlogTemplate/search.html 
createPage: Processing pageId 403. Preview URL: 
http://localhost:8085/templates/BlogTemplate/authors.html 
All page creation calls complete.

Creating detail pages: 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063051-developing-content-layout- for-content-and-experience-cloud
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063052-dynamic-dom- manipulation-in-content-layout 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063045-getting-media-url-in- the-content-layout 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063053-getting-reference- items-in-content-layout 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063048-navigating-to-a- search-page-with-search-query 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063050-alex-read 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063047-jerrold-summers 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063049-kelly-emerson 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063043-samantha-howard 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063046-raising-triggers-from- content-layout 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063044-rendering-the-content- layout-using-mustache-template 
All detail page creation calls complete.

Erros de Compilação

Durante a compilação, você obterá três tipos de mensagens: Informações, Advertência e Erros.

  1. As mensagens informativas são sobre problemas dos quais você deve estar ciente, mas são mensagens provavelmente esperadas como parte da compilação:
    • Itens de conteúdo de espaço reservado que serão renderizados no runtime.
    • Compiladores de layout de página ausentes. Os layouts de página podem não tem qualquer elemento dinâmico e por isso não são considerados um problema se estiverem faltando.
    • Itens marcados como "renderizar no acesso"; isto é, o desenvolvedor do site deseja que esse componente seja renderizado dinamicamente no runtime, mesmo que a página seja compilada.
  2. As mensagens de advertência são sobre problemas que provavelmente afetarão o desempenho do site em execução e deverão ser corrigidos quando possível. Estes são os itens dessa categoria:
    • Compiladores de layout de conteúdo ou componente personalizado ausentes. Sem eles, os componentes serão renderizados dinamicamente na página como eram anteriormente.
    • Mapas de layout de conteúdo ausentes. É improvável que você queira usar o layout de conteúdo padrão do sistema para renderizar itens de conteúdo.
  3. As mensagens de erro são sobre problemas que indicam uma falha de compilação. As páginas continuarão a ser compiladas quando possível, mas a compilação geral será encerrada com erro.
    • Isso muito provavelmente é causado por erros de JavaScript em compiladores personalizados e todos os erros devem ser resolvidos.

Nota:

Para reduzir mensagens repetitivas, a mesma mensagem só aparecerá uma vez por compilação, independentemente de ocorrer em várias páginas.

O exemplo anterior tem o seguinte status de saída de compilação:

Compilation completed with 0 errors and 3 warnings. 
to display warnings, run with --verbose (-v) option.

Se você executar novamente a etapa de compilação com a opção "-v", verá a seguinte saída:

> cec compile-template BlogTemplate --verbose
Compile Template: compiling template BlogTemplate 
Oracle Content Management Site Compiler

createPage: Processing pageId 100. Preview URL: 
http://localhost:8085/templates/BlogTemplate/index.html 
createPage: Processing pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail.html
Info: no content item specified for placeholder: a890a65c-c0fc-451b-966b-e606ca18a1f4 
component will render at runtime. 
Info: no content item specified for placeholder: c90bbc10-c9d8-4a54-8dd4-7a8251e8efbb 
component will render at runtime. 
Info: no content item specified for placeholder: f12691e1-79ab-4d1f-a8b9-3af8c638dd26 
component will render at runtime.
createPage: Processing pageId 401. Preview URL: 
http://localhost:8085/templates/BlogTemplate/about.html 
createPage: Processing pageId 402. Preview URL: 
http://localhost:8085/templates/BlogTemplate/search.html
Info: Component: "fdfd0392-e901-48f6-8044-36803c836aa1" of type "scs-contentlist" marked as 
"render on access", will not be compiled. 
Info: Component: "ba9f3711-4367-444e-ae38-71289fc10e73" of type "scs-contentlist" marked as 
"render on access", will not be compiled. 
createPage: Processing pageId 403. Preview URL: 
http://localhost:8085/templates/BlogTemplate/authors.html 
All page creation calls complete. 

Creating detail pages: 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063051-developing-content- layout-for-content-and-experience-cloud 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063052-dynamic-dom- manipulation-in-content-layout 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063045-getting-media-url-in- the-content-layout 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063053-getting-reference- items-in-content-layout 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063048-navigating-to-a- search-page-with-search-query 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063050-alex-read 
Warning: failed to find content layout map entry for: Starter-Blog-Author:header. Will compile 
using the system default layout.
Warning: failed to find content layout map entry for: Starter-Blog-Author:content. Will compile 
using the system default layout. 
Warning: failed to find content layout map entry for: Starter-Blog-Author:sidebar. Will compile 
using the system default layout.  
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063047-jerrold-summers 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063049-kelly-emerson 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063043-samantha-howard 
createPage: Processing detail pageId 105. 
Preview URL: http://localhost:8085/templates/BlogTemplate/post-detail/1481786063046-raising-triggers-from- content-layout 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063044-rendering-the-content- layout-using-mustache-template 
All detail page creation calls complete. 

Compilation completed with 0 errors and 3 warnings. 

*** compiled template is ready to test 
*** to render non-compiled pages, remove compiled files from under: /private/tmp/cec-
src/src/templates/BlogTemplate/static

Compilação de Página Detalhada

A compilação de página detalhada contrai todos os itens de conteúdo que ela encontra durante a execução. Em seguida, ela recompila a página detalhada de cada item de conteúdo que ela encontra, usando o valor do slug para definir o URL para a nova página detalhada.

A saída da compilação anterior acontece em duas seções:

  1. Compilação de Página
  2. Compilação de Página Detalhada

No exemplo anterior, você verá advertências sobre nenhuma entrada no mapa de layout de conteúdo para a página Starter-Blog-Author. Entretanto, não queremos páginas detalhadas para Starter-Blog-Author. A página detalhada destina-se apenas a itens de conteúdo do Starter-Blog-Post. Para remover esses erros, podemos excluir itens de conteúdo da compilação de página detalhada se eles tiverem uma página detalhada explícita referenciada nas definições deles, com a seguinte opção:

--noDefaultDetailPageLink, -o  Do not generate compiled detail page for items/content lists
      that use the default detail page.

Assim sendo, a reexecução da compilação, excluindo a criação de página detalhada que utiliza a página detalhada padrão, produz a seguinte saída:

> cec compile-template BlogTemplate --noDefaultDetailPageLink 
Compile Template: compiling template BlogTemplate 
Oracle Content Management Site Compiler 

createPage: Processing pageId 100. Preview URL: 
http://localhost:8085/templates/BlogTemplate/index.html 
createPage: Processing pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail.html 
createPage: Processing pageId 401. Preview URL: 
http://localhost:8085/templates/BlogTemplate/about.html 
createPage: Processing pageId 402. Preview URL: 
http://localhost:8085/templates/BlogTemplate/search.html 
createPage: Processing pageId 403. Preview URL: 
http://localhost:8085/templates/BlogTemplate/authors.html 
All page creation calls complete.

Creating detail pages: 
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063051-developing-content-
layout-for-content-and-experience-cloud
createPage: Processing detail pageId 105. Preview URL:
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063052-dynamic-dom -manipulation-in-content-layout
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063045-getting-media-url-in- the-content-layout
createPage: Processing detail pageId 105. Preview URL:  
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063053-getting-reference- items-in-content-layout
createPage: Processing detail pageId 105. Preview URL: 
http://localhost:8085/templates/BlogTemplate/post-detail/1481786063048-navigating-to-a- search-page-with-search-query
All detail page creation calls complete.

Compilation completed with no errors.

*** compiled template is ready to test 
*** to render non-compiled pages, remove compiled files from under: /private/tmp/cec-
src/src/templates/BlogTemplate/static

Compilar Páginas Específicas

Não é preciso compilar todas as páginas no modelo; você pode selecionar quais páginas compilar. Isso será útil se você estiver trabalhando em páginas específicas que deseja depurar ou atualizar, em vez de ter de recompilar continuamente o site inteiro.

Para compilar páginas específicas, use a opção --pages (-p) seguida pela lista de páginas do seu interesse na compilação.

Nota:

Observação: Se os itens de conteúdo das páginas na lista referenciarem páginas de detalhes, estas também serão compiladas mesmo que não sejam explicitamente incluídas.

cec compile-template BlogTemplate --pages 401,402 
Compile Template: compiling template BlogTemplate 
Oracle Content Management Site Compiler

createPage: Processing pageId 401. Preview URL: 
http://localhost:8085/templates/BlogTemplate/about.html 
createPage: Processing pageId 402. Preview URL: 
http://localhost:8085/templates/BlogTemplate/search.html 
All page creation calls complete.

Compilation completed with no errors. 
*** compiled template is ready to test 
*** to render non-compiled pages, remove compiled files from under: /private/tmp/cec- 
src/src/templates/BlogTemplate/static