Capítulo 3: Criando um protótipo com low-code
Observação
O capítulo 2 referenciou o aplicativo móvel usado pelos técnicos e engenheiros de campo e o aplicativo de desktop usado pela equipe da local. Os capítulos a seguir se concentram no design, na implementação e no lançamento dos aplicativos móveis criados com o Power Apps. Os aplicativos de desktop são deixados como um exercício para o leitor.
Kiana é cética em relação a soluções low-code e ao Power Apps. Contudo, Kiana e Maria decidem criar um aplicativo juntas para ajudar os técnicos de campo a verificar o inventário (e solicitar peças, se necessário), consultar a base de dados de conhecimento e verificar o próximo compromisso enquanto estão fora do escritório em chamadas de serviço. Kiana e Maria planejam usar essa experiência para explorar como adicionar controles e usar fórmulas no Power Apps.
Embora criar um protótipo inicial low-code seja normalmente uma tarefa do desenvolvedor cidadão, Kiana decide prestar atenção ao processo para entender como o aplicativo é construído. Kiana precisa dessas informações para ajudar Maria a integrar as fontes de dados reais, as APIs Web e outros serviços necessários ao aplicativo.
Item 1: Gerenciamento de inventário de campo
O objetivo inicial de Maria é criar um aplicativo de tela que exibe uma lista de peças e permite ao usuário visualizar os detalhes de qualquer peça. Eventualmente, o usuário também deve ser capaz de solicitar uma peça; no entanto, esta versão inicial do aplicativo será simplesmente um protótipo e não será conectada a um back-end ainda. Depois de obter os comentários de Caleb, o técnico de campo principal, Maria trabalhará com Kiana na integração do aplicativo de tela com o sistema de inventário em execução no local.
Maria conhece muito bem o sistema de gerenciamento de inventário existente e entende as informações que ele contém. Maria começa criando uma pasta de trabalho do Excel que contém tabelas com dados simulados com detalhes de algumas peças de exemplo. Os campos da tabela são ID, Nome, CategoryID, Preço, Visão geral, NumberInStock e Imagem (uma URL que faz referência a uma imagem da peça). Essa pasta de trabalho pode ser usada para criar e testar o aplicativo de tela, a fim de garantir que ele exiba os dados necessários corretamente. Maria armazena essa pasta de trabalho apostila em uma conta do OneDrive com o nome BoilerParts.xlsx.
Observação
É possível encontrar uma cópia desta pasta de trabalho na pasta Ativos no repositório Git deste guia.
Se você for um designer de banco de dados relacional, notará que a pasta de trabalho do Excel apresenta uma exibição desnormalizada dos dados. Por exemplo, em um banco de dados relacional, CategoryID provavelmente seria um identificador numérico que referencia uma tabela separada que contém os detalhes da categoria, incluindo o nome.
Observação
Atualmente, as URLs na coluna Imagem são apenas espaços reservados. No aplicativo concluído, essas URLs serão substituídas pelos endereços de arquivos de imagens reais.
Siga estas etapas para criar o aplicativo com o Power Apps.
Entre no Power Apps.
Na Página Inicial, em Iniciar pelos dados, selecione Excel Online.
Na página Conexões, selecione OneDrive for Business e Criar.
Na página OneDrive for Business, selecione o arquivo BoilerParts.xlsx.
Selecione a tabela no arquivo Excel (Maria criou a tabela usando o nome padrão, Table1) e selecione Conectar.
Espere enquanto o Power Apps gera o aplicativo.
Quando o aplicativo for gerado, você verá a tela Procurar, que exibe os campos CategoryID, ID e Imagem de cada linha da tabela de peças na pasta de trabalho.
Os campos que são exibidos atualmente não são muito úteis para ajudar um engenheiro a selecionar um produto. No painel que exibe a tela Procurar, selecione o rótulo Trocador de Calor na primeira linha de dados. Na barra de fórmulas, selecione a propriedade Texto na lista suspensa. Altere o valor desta propriedade para ThisItem.Name. O texto no primeiro campo de cada linha mudará para exibir o nome da peça.
Observação
Na imagem a seguir, o rótulo Trocador de Calor originalmente exibido no formulário mudou para o nome do produto: Aquecedor 3,5 W/S.
Repita a etapa anterior para os rótulos ID e Imagem. Altere a propriedade Texto do campo ID para CategoryID, e a propriedade Texto do campo Imagem para Visão geral. A tela Procurar agora deve se parecer com a imagem a seguir, que um engenheiro de campo provavelmente achará útil para selecionar peças.
O recurso de pesquisa da tela Procurar usa como padrão os campos que foram inicialmente selecionados quando a tela foi gerada — nesse caso, CategoryID, ID e Imagem. Os resultados são classificados por CategoryID. Faz sentido mudar isso para os campos Nome, CategoryID e Visão geral, com resultados classificados por Nome. Selecione o controle BrowseGallery1 no painel Exibição de árvore. Na lista suspensa do lado esquerdo da barra de fórmula, selecione a propriedade Itens. Arraste a borda inferior da barra de fórmula para baixo, a fim de que a fórmula fique completamente visível. A fórmula contém a seguinte expressão:
**SortByColumns(Search([\@Table1], TextSearchBox1.Text, "CategoryID","ID","Image"), "CategoryID", If(SortDescending1, Descending, Ascending))
Altere a expressão Pesquisar para fazer referência aos campos Nome, CategoryID e Visão geral usando a seguinte fórmula:
SortByColumns(Search([\@Table1], TextSearchBox1.Text, "Name", "CategoryID", "Overview"), "Name", If(SortDescending1, Descending, Ascending))
O título no cabeçalho do formulário não é útil, e o tema padrão não corresponde à aparência corporativa da VanArsdel. Na tela Procurar, selecione o rótulo Table1 e, na barra Fórmula, altere a propriedade Texto do rótulo para "Procurar peças" (inclua as aspas duplas no valor).
Na barra de ferramentas, selecione Tema (pode ser necessário expandir a barra de ferramentas para exibir mais itens) e selecione o tema Floresta. As cores e o estilo da tela Procurar mudarão para combinar com o tema.
Torne a tela Detalhes mais útil
Você criou o aplicativo básico e modificou a tela Procurar para exibir campos que um engenheiro pode usar para identificar uma peça. O aplicativo também contém uma tela Detalhes, que mostra todas as informações de uma peça selecionada. Os campos nesta tela não são exibidos em uma sequência lógica, portanto, será necessário reorganizá-los. Você também pode excluir o campo ID desta tela, porque esta informação é irrelevante para um engenheiro.
No painel Exibição de árvore, role para baixo e selecione DetailScreen1. Esta tela exibe detalhes sobre a peça que um usuário seleciona na tela Procurar.
No cabeçalho da tela Detalhes no painel do meio, selecione o rótulo Table1. No painel direito, na guia Propriedades, altere a propriedade Texto para Detalhes da Peça.
Observação
Em muitos casos, você pode obter os mesmos resultados usando a barra de fórmulas como o painel Propriedades. No entanto, algumas propriedades estão disponíveis apenas por meio do painel Propriedades.
No painel Exibição de árvore, em DetailScreen1, selecione DetailForm1. No painel direito, na guia Propriedades, selecione Editar campos ao lado de Campos. No painel do meio, selecione e arraste os campos para que sejam exibidos na seguinte ordem, de cima para baixo:
- Nome
- CategoryID
- Visão Geral
- Preço
- NumberInStock
- Imagem
- ID
Selecione o campo ID, selecione as reticências que aparecem no lado direito do campo e selecione Remover no menu suspenso que aparece. Esta ação remove o campo ID do formulário.
No painel Exibição de árvore, em DetailForm1, selecione CategoryID_DataCard1. Este elemento é um controle DataCard que exibe o nome de um campo (chamado de chave) e seu valor.
No painel direito, na guia Avançado, selecione Desbloquear para alterar as propriedades. Na seção Dados, altere o campo DisplayName para "Categoria" (inclua as aspas).
Observação
Tal como acontece com a guia Propriedades, muitas das propriedades na guia Avançado também podem ser acessadas por meio da barra de fórmulas. Para definir essas propriedades, você pode usar a barra de fórmulas, se preferir.
Repita a etapa anterior para alterar a chave de NumberInStock_DataCard1 para "Número em inventário" (inclua as aspas).
É necessário ajustar a formatação do campo Preço para exibir os dados como um valor de moeda. No painel Exibição de árvore, em DetailForm1, em Price_DataCard1, selecione DataCardValue7. Este é o campo que exibe o valor do campo Preço. No painel DataCardValue7 à direita, na guia Avançado, altere a propriedade Texto para Text(Value(Parent.Default), "[$-en-US]$ ###,##0.00")
A expressão Parent.Default refere-se ao item de dados ao qual o controle pai (o DataCards) está vinculado — neste caso, a coluna Preço. A função Texto reformata esse valor usando o formato especificado como o segundo argumento; neste exemplo, esta é a moeda local com duas casas decimais.
O cartão de dados da imagem deve exibir uma imagem da peça em vez da URL do arquivo de imagem. No painel Exibição de árvore, em DetailForm1, em Image_DataCard1, selecione DataCardValue3 e selecione Excluir para remover este controle.
Selecione Image_DataCard1. No painel esquerdo, selecione + Inserir. No painel Inserir, expanda Mídia e selecione Imagem.
Retorne para o painel Exibição de árvore e verifique se o controle de texto Image1 foi adicionado ao controle Image_DataCard1.
No painel Exibição de árvore, selecione Image_DataCard1. No painel direito, na guia Avançado, altere Altura para 500, para permitir espaço suficiente para a exibição de uma imagem.
No painel Exibição de árvore, selecione Image1. Defina as seguintes propriedades:
- Imagem: Parent.Default
- ImagePosition: ImagePosition.Fit
- Largura: 550
- Altura: 550
Observação
A imagem exibida está vazia porque a URL na pasta de trabalho do Excel é apenas um espaço reservado. Você resolverá esse problema e buscará uma URL real ao vincular o aplicativo a uma API Web em um capítulo posterior.
O aplicativo também contém uma tela Editar, que permite ao usuário alterar as informações de uma peça. Um engenheiro não deve ser capaz de alterar os detalhes de uma peça, criar novas peças ou excluir peças do catálogo.
No painel Exibição de árvore, selecione EditScreen1. Selecione o botão de reticências e, em seguida, selecione Excluir para remover esta tela.
No painel Exibição de árvore, selecione DetailsScreen1. Note que o Power Apps Studio exibe uma mensagem de erro para esta tela. Este erro ocorre porque a DetailsScreen1 contém expressões que fazem referência à tela EditScreen1, que não existe mais.
No cabeçalho da DetailsScreen1, selecione o ícone de lápis (IconEdit1). A propriedade OnSelect deste controle contém a expressão EditForm(EditForm1);Navigate(EditScreen1, ScreenTransition.None). Quando o ícone Editar é selecionado, esta expressão é executada e tenta mover-se para a tela EditScreen1.
No painel Exibição de árvore, selecione IconEdit1 e, em seguida, selecione Excluir. Este ícone não é mais necessário.
Selecione IconDelete1 e, em seguida, selecione Excluir. Este ícone é usado para excluir a peça atual e também não é necessário.
Observe que o texto Detalhes da Peça desapareceu do cabeçalho da tela e, em vez disso, o Power Apps Studio exibe uma mensagem de erro. Isso aconteceu porque a largura do controle de rótulo que exibe o texto é calculada. No painel Exibição de árvore, selecione LblAppName2. Examine a propriedade Largura. O valor desta propriedade é o resultado da expressão Parent.Width - Self.X - IconDelete1.Width - IconEdit1.Width.
Altere a expressão da propriedade Largura para Parent.Width - Self.X. O erro deve desaparecer, e o texto Detalhes da Peça deve reaparecer no cabeçalho da tela.
No painel Exibição de árvore, selecione BrowseScreen1. Esta tela também exibirá uma mensagem de erro. O ícone + na barra de ferramentas (IconNewItem1) permite que o usuário adicione uma nova peça. A propriedade OnSelect deste ícone faz referência à telaEditScreen1.
Selecione IconNewItem1 e, em seguida, selecione Excluir. Como antes, o texto no cabeçalho da tela desaparece e é exibida uma mensagem de erro, pelo mesmo motivo.
No painel Exibição de árvore, em BrowseScreen1, selecione LblAppName1. Modifique a expressão da propriedade Largura removendo a referência a IconNewItem1.Width. A nova expressão deve ser Parent.Width - Self.X - IconSortUpDown1.Width - IconRefresh1.Width.
Ainda há um problema com o cabeçalho. Embora o texto Procurar Peças tenha reaparecido, um erro está sendo exibido, e os ícones de atualização e classificação estão no lugar errado. No painel Exibição de árvore, selecione IconSortUpDown1. Encontre a propriedade X deste controle. Esta propriedade determina a posição horizontal do ícone no cabeçalho. Atualmente, ela é calculada com base na largura do controle IconNewItem1.
Altere a expressão da propriedade X para Parent.Width - Self.Width.
No painel Exibição de árvore, selecione IconRefresh1. Altere a expressão da propriedade X para Parent.Width - IconSortUpDown1.Width - Self.Width. Todos os erros devem desaparecer.
Salvar e testar o aplicativo
Agora você pode salvar e testar o aplicativo.
Selecione Arquivo > Salvar como.
Em Salvar como, selecione A nuvem, digite o nome VanArsdelApp e, em seguida, selecione Salvar.
Selecione a seta para retornar à Página Inicial.
Selecione F5 para visualizar o aplicativo. Na página Procurar Peças, selecione o colchete angular direito (>) à direita de qualquer peça. A tela Detalhes da peça aparece.
Selecione o colchete angular esquerdo (<) no cabeçalho da tela Detalhes para retornar à tela Procurar.
Na tela Procurar Peças, digite o texto na caixa Pesquisar. Conforme você digita, os itens são filtrados para mostrar apenas aqueles que têm texto correspondente nos campos Nome, CategoryID ou Visão geral.
Feche a janela de visualização e retorne ao Power Apps Studio.
Item 2: Base de dados de conhecimento de campo
Para ter acesso à base de dados de conhecimento, Maria e Caleb (o técnico) imaginam uma interface simples em que o usuário insere um termo de pesquisa e o aplicativo exibe todos os artigos da base de dados de conhecimento que mencionam o termo. Maria sabe que esse processo envolverá a Pesquisa Cognitiva do Azure, mas não precisa — ou nem mesmo deseja — entender como funciona. Portanto, Maria decide fornecer apenas a interface de usuário básica e trabalhar com Kiana posteriormente para adicionar a funcionalidade real.
Maria decide criar uma nova tela com base no modelo Lista disponível no Power Apps Studio.
Na barra de ferramentas da tela Página Inicial do Power Apps Studio, selecione Nova Tela e, em seguida, selecione Lista.
No cabeçalho da tela, selecione o rótulo que exibe o texto [Title]. Altere a propriedade Texto para "Consulta" (inclua as aspas).
No cabeçalho da tela, selecione o sinal de mais (+) e, em seguida, selecione Excluir. O ícone + destina-se a permitir que o usuário adicione mais itens à lista. A base de dados de conhecimento é apenas para consulta, portanto, esse recurso não é necessário.
Observe que a remoção deste ícone causa um erro no cabeçalho devido à forma como a localização e as larguras dos outros itens são calculadas. Você viu isso anteriormente com a tela de gerenciamento de inventário, e a solução é a mesma, conforme descrito nas etapas a seguir.
No painel Exibição de árvore, role para baixo até a seção Screen1 e selecione LblAppName3. Altere a propriedade Largura para a fórmula Parent.Width - LblAppName3.X - IconSortUpDown2.Width - IconRefresh2.Width.
No painel Exibição de árvore, selecione IconSortUpDown2. Modifique a propriedade X para a fórmula Parent.Width - IconSortUpDown2.Width.
No painel Exibição de árvore, selecione IconRefresh2. Modifique a propriedade X para a fórmula Parent.Width - IconSortUpDown2.Width - IconRefresh2.Width. Isso deve resolver todos os erros com a tela.
Selecione Arquivo > Salvar.
Na caixa Nota de versão, digite o texto IU da base de dados de conhecimento adicionada e, em seguida, selecione Salvar.
Retorne para a tela Página Inicial e selecione F5 para visualizar a nova tela. Ela deve ser semelhante à seguinte imagem.
Observe que se você selecionar o ícone > próximo a qualquer uma das entradas fictícias, a funcionalidade de detalhes não funciona no momento. Você resolverá isso mais tarde, ao integrar a Pesquisa Cognitiva do Azure ao aplicativo.
Feche a janela de visualização e retorne ao Power Apps Studio.
Item 3: Agendamento de campo e notas
Maria trabalha com Malik, recepcionista do escritório, para projetar a interface para o agendamento de campo e parte dos compromissos do aplicativo. Malik fornece uma pasta de trabalho do Excel com alguns dados de exemplo que Maria pode usar para criar a tela de compromissos. A pasta de trabalho contém uma tabela com as seguintes colunas:
- ID (a ID de compromisso)
- ID do cliente (um identificador exclusivo para o cliente)
- Nome do Cliente
- Endereço do Cliente
- Detalhes do problema (uma descrição de texto do problema que o cliente está enfrentando)
- Número do contato
- Status
- Data do compromisso
- Horário do Compromisso
- Notas (uma descrição de texto com quaisquer notas adicionadas pelo engenheiro)
- Imagem (uma fotografia do dispositivo, em condições de funcionamento após a reparação ou como uma imagem complementar para as notas do engenheiro)
Observação
Tal como acontece com os dados de gerenciamento de inventário de campo, esta pasta de trabalho apresenta uma visão desnormalizada dos dados. No sistema de compromissos existente, esses dados são armazenados em tabelas separadas que contêm dados de compromissos e dados do cliente.
Maria armazena esse arquivo em uma conta do OneDrive com o nome Appointments.xlsx. Lembrando que anteriormente usava-se o nome padrão para a tabela da pasta de trabalho e que o título precisou ser alterado em várias telas que foram geradas, Maria renomeou a tabela da pasta de trabalho para Appointments.
Observação
Esta pasta de trabalho está disponível na pasta Ativos do repositório Git deste guia.
Maria deseja criar a seção de compromissos do aplicativo diretamente no arquivo Excel. Maria decide seguir uma abordagem semelhante à da funcionalidade de gerenciamento de inventário de campo, exceto que, desta vez, o engenheiro terá permissão para criar e editar compromissos.
Maria decide criar as telas de compromissos inicialmente como um aplicativo separado. Dessa forma, Maria pode usar o Power Apps Studio para gerar grande parte do aplicativo automaticamente. Atualmente, o Power Apps Studio não permite gerar telas adicionais a partir de uma conexão de dados em um aplicativo existente. Depois de criar e testar as telas, Maria copiará para o inventário de campo e o aplicativo de base de dados de conhecimento.
Observação
Uma abordagem alternativa é adicionar a tabela Compromissos no arquivo do Excel como uma segunda fonte de dados para o aplicativo existente e, em seguida, criar manualmente as telas de compromissos. Maria optou por gerar as novas telas direto da pasta de trabalho e copiar as telas. No momento, Maria está mais familiarizada com os conceitos de copiar e colar do que de criar telas manualmente, e aprenderá gradualmente a criar telas do zero à medida que o processo de criação desse aplicativo avançar.
Como criar o aplicativo de compromissos
Na barra de menu do Power Apps Studio, selecione Arquivo.
No painel esquerdo, selecione Novo. No painel principal, selecione a caixa OneDrive for Business - Layout de telefone.
No painel Conexões, selecione Appointments.xlsx.
No arquivo do Excel, selecione a tabela Compromissos e, em seguida, selecione Conectar.
Aguarde enquanto o aplicativo é gerado. Quando o novo aplicativo aparecer, ele conterá uma tela Procurar, uma tela Detalhes e outra tela Editar, usando o tema padrão.
No painel Exibição de árvore, na seção BrowseScreen1 em BrowseGallery1, selecione Image1 e, em seguida, selecione Excluir. A tela Procurar deve apenas listar os compromissos, não as imagens associadas a eles.
Observe que remover o controle Image1 causa vários erros na tela porque as larguras e a localização do controle Title1 fazem referência ao controle Imagem. Você corrigirá esses problemas na etapa seguinte.
No painel Exibição de árvore, em BrowseGallery1, selecione Title1. Altere o valor na propriedade X para 16. Altere a fórmula na propriedade Largura para Parent.TemplateWidth - 104. Isso deve resolver todos os erros da tela.
No painel Exibição de árvore, em BrowseGallery1, selecione Body1. Atualmente, esse controle exibe os detalhes do telefone de contato do cliente. Altere o valor na propriedade Texto para ThisItem.'Customer Name' (inclua as aspas simples).
Os detalhes na tela Procurar agora exibem o nome do cliente.
No painel Exibição de árvore, selecione BrowseGallery1. Usando a barra de fórmulas, examine a expressão na propriedade Itens. O controle procura compromissos usando a data, a hora e o número de contato do compromisso. Altere esta fórmula para pesquisar o nome do cliente em vez do número de contato:
SortByColumns(Search([@Appointments], TextSearchBox1.Text, "Appointment_x0020_Date","Appointment_x0020_Time","Customer_x0020_Name"), "Appointment_x0020_Date", If(SortDescending1, Descending, Ascending)).
Observe que os compromissos são ordenados por data e hora (os primeiros dois campos exibidos).
No painel Exibição de árvore, exclua IconNewItem1. Apenas a equipe local pode agendar novos compromissos para engenheiros e técnicos. Observe que essa ação resulta em erros no formulário porque a largura e a posição de outros controles no cabeçalho fazem referência ao ícone que você acabou de remover.
No painel Exibição de árvore, selecione LblAppName1. Altere a fórmula da propriedade Largura. para Parent.Width - Self.X - IconSortUpDown1.Width - IconRefresh1.Width.
No painel Exibição de árvore, selecione IconRefresh1. Altere o valor da propriedade X para Parent.Width - IconSortUpDown1.Width - Self.Width.
No painel Exibição de árvore, selecione iconSortUpDown1. Altere o valor da propriedade X para Parent.Width - Self.Width.
No painel Exibição de árvore, selecione BrowseScreen1 e, em seguida, selecione o botão de reticências (...). No menu suspenso que aparece, selecione Renomear e mude o nome da tela para BrowseAppointments.
Usando a mesma técnica, altere o nome do controle BrowseGallery1 para BrowseAppointmentsGaleria.
Isso completa a tela Procurar.
Como criar a tela de detalhes
Agora você pode voltar sua atenção para a tela Detalhes.
No painel Exibição de árvore, role para baixo até a seção DetailsScreen1. Você pode ver que os detalhes são apresentados em ordem alfabética pelos nomes dos campos, e algumas informações úteis — tais como o campo Notas — não são exibidas.
No painel Exibição de árvore, selecione DetailForm1. No painel direito, na guia Propriedades, selecione Editar campos ao lado de Campos. No painel do meio, selecione cada um dos campos a seguir e, em seguida, selecione Excluir:
- Data do compromisso
- Horário do Compromisso
- ID do Cliente
- ID
Selecione + Adicionar campo e adicione os seguintes campos:
- Notas
- Detalhes do Problema
- Status
Arraste cada campo para que sejam exibidos na seguinte ordem, de cima para baixo:
- Nome do Cliente
- Endereço do Cliente
- Número do contato
- Detalhes do Problema
- Status
- Notas
- Imagem
No painel Exibição de árvore, selecione Notes_DataCard1. Altere a propriedade Altura para 320.
No painel Exibição de árvore, exclua IconDelete1. Os engenheiros não devem ser capazes de remover compromissos do sistema.
Selecione LblAppName2 e altere a propriedade Largura para Parent.Width - Self.X - IconEdit1.Width.
Usando a técnica descrita anteriormente, altere o nome de DetailsScreen1 para AppointmentDetails.
Como editar a tela de edição
A última tela a ser analisada, por enquanto, é a tela Editar.
No painel Exibição de árvore, selecione EditScreen1.
No painel Exibição de árvore, na seção EditScreen1, selecione EditForm1. No painel direito, na guia Propriedades, selecione Editar campos ao lado de Campos.
Remova os seguintes campos:
- Endereço do Cliente
- ID
- ID do Cliente
- Data do compromisso
- Horário do Compromisso
Adicione os seguintes campos:
- Detalhes do Problema
- Status
- Notas
Arraste cada campo para que sejam exibidos na seguinte ordem, de cima para baixo:
- Nome do Contato
- Número do Cliente
- Detalhes do Problema
- Status
- Notas
- Imagem
Selecione o campo Nome do Cliente e expanda-o para ver suas propriedades. Altere o Tipo de controle para Exibir texto. Essa alteração torna o controle somente leitura. É útil ver o nome do cliente na tela Editar, mas um engenheiro não deve ser capaz de alterá-lo.
Selecione o campo Nome de Contato e expanda-o para ver suas propriedades. Altere o Tipo de controle para Exibir texto. Este campo também deve ser somente leitura.
Selecione o campo Notas, expanda-o e altere o Tipo de controle para Editar texto multilinha. Esta configuração permite que o engenheiro adicione notas detalhadas que podem abranger várias linhas.
Selecione o campo Status, expanda-o e altere o Tipo de controle para Valores permitidos.
No painel Exibição de árvore, selecione Status_DataCard5. No painel direito, na guia Propriedades, selecione Desbloquear para alterar as propriedades. Role para baixo até a propriedade AllowedValues e altere o texto para ["Fixed", "Parts Ordered", "Unresolved"] (inclua os colchetes). O engenheiro de campo só pode definir o Status como um desses valores definidos.
No painel Exibição de árvore, renomeie EditScreen1 como EditAppointment.
Agora você pode salvar e testar o aplicativo.
Selecione Arquivo > Salvar como.
Em Salvar como, selecione A nuvem, digite o nome VanArsdelAppointments e, em seguida, selecione Salvar.
Selecione a seta para voltar na barra de ferramentas do Power Apps Studio para retornar à tela Página Inicial.
Selecione F5 para visualizar o aplicativo. Na página Compromissos, selecione o ícone > ao lado de qualquer compromisso. A tela Detalhes do compromisso deve aparecer. No cabeçalho, selecione Editar para atualizar o compromisso. Verifique o seguinte:
- Os campos de nome do cliente e número de contato são somente leitura.
- O campo de status é limitado aos valores da lista suspensa.
- É possível inserir notas que abrangem várias linhas.
- É possível carregar um arquivo de imagem no campo de imagem.
Observação
Um aprimoramento que será adicionado posteriormente permitirá que você tire uma foto com seu telefone no aplicativo e adicione-a ao campo de imagem.
Combinando as telas em um único aplicativo
Maria criou dois aplicativos, mas deseja combiná-los em um único aplicativo. Para fazer isso, Maria copia as telas do aplicativo de compromissos para o aplicativo de gerenciamento de inventário de campo e de base de dados de conhecimento, da seguinte maneira:
Abra uma nova janela do navegador e faça login no Power Apps Studio com os detalhes da sua conta.
No painel esquerdo, selecione Aplicativos, selecione VanArsdelApp e, em seguida, selecione Editar.
Na barra de ferramentas, selecione Nova tela e, em seguida, selecione Em branco. Esta ação adicionará uma nova tela ao aplicativo para a qual você copiará os controles para a tela Procurar do aplicativo VanArsdelAppointments.
A nova tela será nomeada como Screen2. No painel Exibição de árvore, renomeie-a como BrowseAppointments.
Repita a etapa anterior mais duas vezes, para adicionar mais duas telas em branco (Screen3 e Screen4).
Renomeie Screen3 como AppointmentDetails e renomeie Screen4 como EditAppointment.
Na barra de ferramentas esquerda do Power Apps Studio, selecione o ícone Dados. No painel Dados, selecione Adicionar dados. Na lista suspensa Selecionar uma fonte de dados, no campo Procurar, digite OneDrive e, em seguida, selecione OneDrive for Business.
Selecione o arquivo do Excel Appointments.xlsx, selecione a tabela Compromissos e, em seguida, selecione Conectar.
Mude para a janela do navegador que mostra o aplicativo VanArsdelAppointments.
Na barra de ferramentas, selecione Tema (pode ser necessário expandir a barra de ferramentas para exibir mais itens) e selecione o tema Floresta. Este é o mesmo tema usado pelo aplicativo VanArsdel.
Na barra de ferramentas esquerda, selecione o ícone Exibição de árvore, selecione a tela BrowseAppointments e, em seguida, selecione Ctrl+A. Esta ação seleciona todos os controles na tela.
Selecione Ctrl+C para copiar esses controles para a área de transferência.
Volte para a janela do navegador que mostra o aplicativo VanArsdelAppointments.
Na barra de ferramentas esquerda, selecione o ícone Exibição de árvore e, em seguida, selecione a tela BrowseAppointments.
Selecione Ctrl+V para colar os controles na tela.
Observação
Às vezes, o cabeçalho da tela aparece um pouco baixo demais. Para corrigir este problema, selecione os controles IconSortUpDOwn1_1, IconRefresh1_1, LblAppName1_1 e RectQuickActionBar1_1 no painel Exibição de árvore (mantenha pressionado Shift enquanto clica para selecionar mais de um controle por vez) e, em seguida, use o mouse ou as teclas de seta para movê-los para cima no painel de visualização do projeto.
Volte para a janela do navegador que mostra o aplicativo VanArsdelAppointments e, em seguida, selecione e copie os controles na tela AppointmentDetails para a área de transferência (Ctrl+A seguido por Ctrl+C).
Volte para a janela do navegador que mostra o aplicativo VanArsdelApp, selecione a tela AppointmentDetails e cole os controles (Ctrl+V). Ajuste a posição dos controles no cabeçalho da tela, se necessário.
Observação
Você verá um erro relatado no cabeçalho da tela AppointmentDetails. Este erro ocorre porque a tela faz referência a controles na tela EditAppointment, que ainda não foram copiados. As próximas etapas devem resolver esse erro.
Volte para a janela do navegador que mostra o aplicativo VanArsdelAppointments e, em seguida, selecione e copie os controles na tela EditAppointment para a área de transferência.
Volte para a janela do navegador que mostra o aplicativo VanArsdelApp, selecione a tela EditAppointment e cole os controles. Novamente, mova os controles no cabeçalho da tela, se necessário.
No painel Exibição de árvore, selecione a tela AppointmentDetails e verifique se o erro indicado anteriormente desapareceu.
No painel Exibição de árvore, selecione a tela BrowseScreen1. Renomeie esta tela como BrowseParts.
Renomeie a tela DetailsScreen1 como PartDetails.
Renomeie a tela Screen1 como Base de dados de conhecimento.
Observação
É uma boa prática renomear as telas para refletir a função, em vez de usar os nomes padrão gerados pelo Power Apps Studio, especialmente se um aplicativo contém várias telas. Isso pode ajudar a evitar confusão posteriormente, se o aplicativo for modificado por outro desenvolvedor.
Adicionando uma tela Página Inicial ao aplicativo
O estágio final é adicionar uma tela Página Inicial ao aplicativo. A tela Página Inicial permitirá que o engenheiro se mova entre as diferentes partes do aplicativo (gerenciamento de inventário, base de dados de conhecimento e compromissos).
No aplicativo VanArsdelApp na barra de ferramentas, selecione Nova tela e, em seguida, selecione Em branco.
No painel Exibição de árvore, renomeie Screen2 como Página Inicial.
Na barra de ferramentas, selecione Inserir. Na lista de controles, expanda Mídia e, em seguida, selecione Imagem. O controle será adicionado à tela.
Defina a posição X do controle como 16, e a posição Y como 22. Altere a Largura para 605, e a Altura para 127. Altere a Posição da imagem para Preencher.
Ainda na guia Propriedades, na lista suspensa Imagem, selecione + Adicionar um arquivo de imagem e, em seguida, carregue a imagem VanArsdelLogo.png no controle.
Observação
O arquivo de imagem está disponível na pasta Ativos no repositório Git deste guia.
Na lista de controles, adicione quatro controles Rótulo do texto ao formulário e posicione-os de forma que fiquem empilhados sob o logotipo da VanArsdel.
Selecione o controle Rótulo do texto superior. No painel direito, na guia Propriedades, defina a propriedade Texto como Próximo Compromisso. Defina Tamanho da Fonte como 30 e use o seletor de cores para definir a cor da fonte como verde (para corresponder ao logotipo).
Selecione o segundo controle Rótulo do texto. Altere o valor da propriedade Texto para First(Appointments).'Customer Name' (inclua as aspas). Esta fórmula recupera o nome do cliente na primeira linha da tabela de compromissos.
Observação
Atualmente, essa fórmula atua apenas como um espaço reservado. Você modificará o rótulo posteriormente para recuperar o próximo compromisso do engenheiro, em vez de sempre exibir o primeiro.
Selecione o terceiro controle Rótulo do texto e defina a propriedade Texto como First(Appointments).'Appointment Date'.
Defina a propriedade Texto do quarto controle de rótulo como First(Appointments).'Appointment Time'. Defina a propriedade Tamanho da fonte como 30.
Na lista de controles, adicione um Retângulo ao controle. Defina as seguintes propriedades para este controle:
- Modo de exibição: Exibição
- X: 0
- Y: 632
- Largura: 635
- Altura: 1
Esse controle atua como um separador visual no meio da tela.
Adicione três controles Botão à tela, dispostos verticalmente e espaçados uniformemente abaixo do separador. Defina a propriedade Texto do botão superior como Compromissos, a propriedade Texto do botão do meio como Peças e a propriedade Texto do botão inferior como Base de Dados de Conhecimento.
Selecione o botão Compromissos. Altere a expressão na ação OnSelect para a fórmula Navigate(BrowseAppointments, ScreenTransition.Fade). Esta ação muda a exibição para a tela de compromissos quando o usuário seleciona o botão.
Defina a ação OnSelect do botão Peças como Navigate(BrowseParts, ScreenTransition.Fade).
Defina a ação OnSelect do botão Base de Dados de Conhecimento como Navigate(Knowledgebase, ScreenTransition.Fade).
Além de navegar da tela Página Inicial para as outras telas do sistema, as telas Compromissos, Peças e Base de Dados de Conhecimento precisam de uma maneira de permitir que o usuário retorne à tela Página Inicial. Maria decide adicionar botões Voltar a essas telas.
No painel Exibição de árvore, selecione a tela BrowseParts.
Selecione o controle RectQuickActionBar1 para dar o foco.
Selecione o menu Inserir e selecione Adicionar ícone. Mova o ícone à esquerda do controle RectQuickActionBar1. Observe que o ícone obscurecerá parte do rótulo Procurar Peças.
No menu Exibição de árvore, altere o nome do novo controle de ícone para IconReturn1.
Altere a fórmula da ação OnSelect para a expressão Back(ScreenTransition.Fade). A função Voltar leva o usuário à tela anterior que ele visitou.
Na guia Propriedades, altere a propriedade do ícone para < Left.
No cabeçalho da tela, selecione o rótulo Procurar Peças. Altere a propriedade X para IconReturn1.Width + 20. O rótulo Procurar peças não deve mais estar parcialmente obscurecido.
Seguindo o processo descrito nas etapas 16 a 22, adicione um ícone chamado IconReturn2 ao controle RectQuickActionBar3 na tela Base de Dados de Conhecimento.
Da mesma forma, adicione um ícone chamado IconReturn3 ao controle RectQuickActionBar1_1 na tela BrowseAppointments.
No painel Exibição de árvore, selecione o objeto App. Altere a propriedade StartScreen para a expressão Home. Esta ação garante que a tela Página Inicial seja exibida sempre que o aplicativo for iniciado:
Observação
Se você não especificar qual tela exibir quando o aplicativo for iniciado, a tela que aparece na parte superior do painel Exibição de árvore será usada. Para mover uma tela para o início da lista, clique com o botão direito na tela do painel Exibição de árvore e selecione Mover para cima até que esteja no topo.
Finalmente, você pode testar o aplicativo.
Selecione Arquivo > Salvar. Na caixa Notas de versão, insira Versão completa com a tela Página Inicial e, em seguida, selecione Salvar.
Selecione a seta para trás para retornar à tela Página Inicial e, em seguida, selecione F5 para executar o aplicativo.
Verifique se a tela Página Inicial do aplicativo aparece.
Selecione Compromissos. A tela de compromissos deve aparecer.
Selecione a seta para retornar à Página Inicial.
Selecione Peças. O navegador de peças deve aparecer.
Selecione a seta para retornar à Página Inicial.
Selecione Base de Dados de Conhecimento. A tela de consulta da base de dados de conhecimento deve aparecer.
Selecione a seta para retornar à Página Inicial.
Feche a janela de visualização e retorne ao Power Apps Studio.
O aplicativo protótipo agora está completo.