Criar uma ação personalizada de barra de ferramentas creating-a-custom-toolbar-action
Pré-requisitos prerequisite
Antes de criar uma ação personalizada na barra de ferramentas, familiarize-se com o Uso de bibliotecas do lado do cliente e Desenvolvimento com o CRXDE Lite.
O que é uma ação what-is-an-action-br
Um formulário adaptável fornece uma barra de ferramentas que permite ao autor do formulário configurar um conjunto de opções. Essas opções são definidas como ações para o formulário adaptável. Clique no botão Editar na barra de ferramentas do Painel para definir as ações compatíveis com formulários adaptáveis.
Além do conjunto de ações fornecido por padrão, você pode criar ações personalizadas na barra de ferramentas. Por exemplo, você pode adicionar uma ação para permitir que o usuário revise todos os campos de formulário adaptáveis antes que um formulário seja enviado.
Etapas para criar uma ação personalizada em formulários adaptáveis steps
Para ilustrar a criação de uma ação personalizada de barra de ferramentas, as etapas a seguir orientam você a criar um botão para que os usuários finais revisem todos os campos de formulário adaptáveis antes de enviar um formulário preenchido.
-
Todas as ações padrão compatíveis com formulários adaptáveis estão presentes em
/libs/fd/af/components/actions
pasta. No CRXDE, copie a variávelfileattachmentlisting
nó de/libs/fd/af/components/actions/fileattachmentlisting
para/apps/customaction
. -
Depois de copiar o nó para
apps/customaction
pasta, renomeie o nome do nó parareviewbeforesubmit
. Além disso, altere ojcr:title
ejcr:description
propriedades do nó.A variável
jcr:title
A propriedade contém o nome da ação que é exibida na caixa de diálogo da barra de ferramentas. A variáveljcr:description
A propriedade contém mais informações que são exibidas quando um usuário passa o ponteiro sobre a ação. -
Selecionar
cq:template
nó emreviewbeforesubmit
nó. Verifique se o valor deguideNodeClass
propriedade éguideButton
e alterarjcr:title
propriedade em conformidade. -
Altere a propriedade de tipo na variável
cq:Template
nó. Para o exemplo atual, altere a propriedade type para button.O valor de tipo é adicionado como uma classe CSS no HTML gerado para o componente. Os usuários podem usar essa classe CSS para estilizar suas ações. O estilo padrão para dispositivos móveis e desktop é fornecido para os valores de botão, enviar, redefinir e salvar.
-
Selecione a ação personalizada na caixa de diálogo da barra de ferramentas de edição do formulário adaptável. Um botão Revisar é exibido na barra de ferramentas do painel.
-
Para fornecer funcionalidade ao botão Revisar, adicione algum código JavaScript e CSS e código do lado do servidor no arquivo init.jsp, presente no
reviewbeforesubmit
nó.Adicione o código a seguir em
init.jsp
.code language-jsp <%@include file="/libs/fd/af/components/guidesglobal.jsp" %> <guide:initializeBean name="guideField" className="com.adobe.aemds.guide.common.GuideButton"/> <c:if test="${not isEditMode}"> <cq:includeClientLib categories="reviewsubmitclientlibruntime" /> </c:if> <%--- BootStrap Modal Dialog --------------%> <div class="modal fade" id="reviewSubmit" tabindex="-1"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <h3>Review the Form Fields</h3> </div> <div class="modal-body"> <div class="modal-list"> <table class="table table-bordered"> <tr class="name"> <td class="reviewlabel col-md-3 active"> <label>Your Name is: </label> </td> </tr> <tr class="pan"> <td class="reviewlabel col-md-3 active"> <label>Your Pan Number is: </label> </td> </tr> <tr class="dob"> <td class="reviewlabel col-md-3 active"> <label>Your Date Of Birth is: </label> </td> </tr> <tr class="80cdeclaration"> <td class="reviewlabel col-md-3 active"> <label>Your Total 80C Declaration Amount is: </label> </td> </tr> <tr class="rentpaid"> <td class="reviewlabel col-md-3 active"> <label>Your Total HRA Amount is: </label> </td> </tr> </table> </div> </div><!-- /.modal-body --> <div class="modal-footer"> <div class="fileAttachmentListingCloseButton col-md-2 col-xs-2 col-sm-2"> <button data-dismiss="modal">Close</button> </div> </div> </div><!-- /.modal-content --> </div><!-- /.modal-dialog --> </div><!-- /.modal -->
Adicione o seguinte código na
ReviewBeforeSubmit.js
arquivo.code language-javascript /*anonymous function to handle show of review before submit view */ $(function () { if($("div.reviewbeforesubmit button[id*=reviewbeforesubmit]").length > 0) { $("div.reviewbeforesubmit button[id*=reviewbeforesubmit]").click(function(){ // Create the options object to be passed to the getElementProperty API var options = {}, result = []; options.somExpressions = []; options.propertyName = "value"; guideBridge.visit(function(model){ if(model.name === "name" || model.name === "pan" || model.name === "dateofbirth" || model.name === "total" || model.name === "totalmonthlyrent"){ options.somExpressions.push(model.somExpression); } }, this); result = guideBridge.getElementProperty(options); $('#reviewSubmit .reviewlabel').each(function(index, item){ var data = ((result.data[index] == null) ? "No Data Filled" : result.data[index]); if($(this).next().hasClass("reviewlabelvalue")){ $(this).next().html(data); } else { $(this).after($("<td></td>").addClass("reviewlabelvalue col-md-6 active").html(data)); } }); // added because in mobile devices it was causing problem of backdrop $("#reviewSubmit").appendTo('body'); $("#reviewSubmit").modal("show"); }); } });
Adicione o código a seguir a
ReviewBeforeSubmit.css
arquivo.code language-css .modal-list .reviewlabel { white-space: normal; text-align: right; padding:2px; } .modal-list .reviewlabelvalue { border: #cde0ec 1px solid; padding:2px; } /* Adding icon for this action in mobile devices */ /* This is the glyphicon provided by bootstrap eye-open */ /* .<type> .iconButton-icon */ .reviewbeforesubmit .iconButton-icon { position: relative; top: -8px; font-family: 'Glyphicons Halflings'; font-style: normal; } .reviewbeforesubmit .iconButton-icon:before { content: "\e105" }
-
Para verificar a funcionalidade da ação personalizada, abra o formulário adaptável no modo de Visualização e clique em Revisar na barra de ferramentas.
note note NOTE A variável GuideBridge
a biblioteca não está carregada no modo de criação. Portanto, essa ação personalizada não funciona no modo de criação.
Amostras samples
O arquivo a seguir contém um pacote de conteúdo. O pacote inclui um formulário adaptável relacionado à demonstração acima da ação personalizada da barra de ferramentas.