Bruno's profileBruno Velaz - SharePoint...PhotosBlogListsMore Tools Help

Blog


    June 14

    :: CODE :: Chamar um usercontrol dentro de outro user control

     

    CENÁRIO

    Estes dias me perguntaram como faço para chamar um usercontrol dentro de outro user control.

    Então, perguntei para que isto?

    Ele queria criar um processo de cadastro usando webparts que tinha 2 user control.

    Passo 1 – Dados Pessoais

    Passo 2 – Dados Comerciais.

    RESPOSTA

    1. Dinamicamente usando codigo
    2. Inserir a tag usercontrol aspx/ascx

    A forma que ele queria era dinamicamente pois, depois que clicar no botão PROCESSGUIR, mostrar o outro user control.

    Mas mesmo assim vai os dois exemplos.

    • 1) Coloque este código no sua página, tanto ASPX como ASCX, no nosso caso é ASCX pois quer carregar um userControl dentro de outro.

    <%@ Reference Control="~/NomeDoSeuUserControlPasso2.ascx" %>

    Cria agora no seu código a instancia do seu userControl.

    NomeDoSeuUserControlPasso2 control = (NomeDoSeuUserControlPasso2);
    base.LoadControl("~/NomeDoSeuUserControlPasso2");

    Aí todo o código do userControlPasso2 vai carregar normalmente.

    • 2) Esta forma é que todos conhecem. Basta arrastar o seu userControlPasso2 para dentro do seu userControlPasso1, porém ele sempre vai aparecer desde do primeiro load.

    <%@ Register src="NomeDoSeuUserControlPasso2.ascx"
    tagname="NomeDoSeuUserControlPasso2" tagprefix="uc1" %>

    Depois no seu HTML basta colocar em qualquer lugar o código abaixo.

    <uc1:Name_of_your_child_control ID="Name_of_your_child_control1"
    runat="
    server”" />

    Acho que era isto

    Abraços.

    Bruno Velaz

    June 04

    :: WebCasts e Vídeos :: Trabalhando com SSIS (Integration Services 2005)

    Boa tarde a todos.

    Estou aqui para publicar várias fontes relacionadas ao SSIS o famoso Integration Services 2005.

    Hoje não irei falar sobre algum cenário específico, mas sim quero trocar informações com vocês em relação em  tranformar dados (ETL) usando SSIS, para algum objetivo específico.

    Entretanto posso focar sobre um determinado cenário.

    Imagine você, que precisa fazer várias integrações e tranformações de dados(ETL) usando várias fontes como Oracle, Excel, Sql Server e etc, para colocar alguma informação disponibilizado em uma BD qualquer, onde você irá depois usar o BDC para integrar com o SharePoint, você sabe fazer tranquilamente este cenário?

    Bom se você imagina criar um programa em C# para fazer alguma tranformação de dados onde vai se repetir em x em x tempo, realmente está “errado”, seu esforço vai ser muitoooo maior. Use a ferramenta SSIS onde existe componentes totalmente integrados com Visual Studio e linguagem de progração Framework .Net.

    Neste ambiente existe vários componentes como Data Flow, Control Flow, conexões distintas e principalmente como fazer deploy na sua estrutura da sua empresa.

    Bom com isto segue algumas informações, que serão muitooooo úteis para DBAs, desenvolvedores e etc.

    Deployment e configuração de pacotes do SSIS
    Palestrante: Roberto Fonseca. Neste webcast nós falaremos sobre o processo de deployment de pacotes SSIS no SQL Server 2005. O Microsoft SQL Server 2005 Integration Services possui ferramentas específicas para facilitar a distribuição de pacotes SSI...
    Publicado em: 13/08/2008
    Categoria(s): SQL Server 2005, SQL Server
    Autor(es): MIcrosoft Corporation

    SQL Server Integration Services 2008 - Data flow
    Seguindo o webcast sobre o SQL Server 2008 Integration Services, demonstraremos como trabalhar com Data Flow utlizando os Sources, Transformations, Destinations e os caminhos para conectá-los.
    Publicado em: 09/04/2008
    Categoria(s): SQL Server 2008, SQL Server, SQL 2005
    Autor(es): Luiz Felipe Pimenta

    SQL Server Integration Services - Control Flow
    Neste webcast veremos como trabalhar com o control flow do SQL Server 2008 Integration Services (SSIS). Será demonstrado de forma resumida como utilizar os principais recursos como Tasks, Containers e Precedence constraints, além de um overview do que mudou em relação ao SSIS 2005.
    Publicado em: 09/04/2008
    Categoria(s): SQL Server 2008, SQL Server, SQL 2005, Recursos
    Autor(es): Lucas Almeida

    Segue o link para download do webcast para verificarem um pouco sobre o deploy.

     

     

    Top on WebCasts, sobre estes assuntos.

    http://www.microsoft.com/events/series/bi.aspx?tab=webcasts

    Espero que seja útil para todos.

    Abraços.

    Bruno Velaz

    :: CODE :: Como deletar uma View usando OM

    Pessoal, gostaria de colocar este código para vocês.

    CENÁRIO:

    Quando precisar deletar uma VIEW específica, segue um código completo, para facilitar seu dia.

    Onde, você informa o ID da view e deleta ela. Veja a imagem.

    image

    Note que tem duas views que criei: (Teste1 e Teste2 Bruno).

    Onde irei deletar a Teste 2 Bruno.

    image

    Resulstado…

    image

    CÓDIGO:

    sing System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Text;
    using System.Windows.Forms;
    using Microsoft.SharePoint;
    using Microsoft.SharePoint.WebControls;

    namespace prViewsBaca
    {
        public partial class Form1 : Form
        {
            public Form1()
            {
                InitializeComponent();
            }

            private void Form1_Load(object sender, EventArgs e)
            {
                //informando qual site vai pesquisar as views
                this.txtNome.Text = "http://" + System.Environment.MachineName;           
            }

            private void Verificar_Click(object sender, EventArgs e)
            {
                this.Preenche(false);
            }

            public void Preenche(bool delview)
            {
                //uma validação simples se foi informado ou não a view
                if (this.txtNome.Text.ToString().Trim() == string.Empty)
                {
                    MessageBox.Show("Não foi informado o site para geração do dccumento.");
                    return;
                }

                //pegando SPSite para pegar a Listas dentro delas
                using (SPSite oSiteCollection = new SPSite(this.txtNome.Text))
                {
                    //veriricando o Sitecollection
                    SPWebCollection collWebsites = oSiteCollection.AllWebs;
                    //Site especifico - root
                    //lista que voce quer ver

                    SPList list = collWebsites[0].Lists["Paginas"];

                    //deleta a view agora?
                    if (delview)
                    {
                        //cria o guid em relação ao guid string que vc informou no text
                        Guid ogui = new Guid(this.txtIdView.Text);
                        //aciona a deleção de forma explicita
                        collWebsites[0].Lists["Paginas"].AllowDeletion = true;
                        //deletar a view                   
                        collWebsites[0].Lists["Paginas"].Views.Delete(ogui);
                        MessageBox.Show("View deletada!");                   
                    }

                    //busca tudo
                    SPViewCollection objviewitems = list.Views;
                    Views.tdDataVewDataTable xsdTipado = new Views.tdDataVewDataTable();
                    foreach (SPView viewitem in objviewitems)
                    {
                        xsdTipado.AddtdDataVewRow(viewitem.ID.ToString(), viewitem.Title);
                    }
                    //cololca os dados aqui no gridview
                    this.dataGridView1.DataSource = xsdTipado;
                    this.dataGridView1.Show();

                    MessageBox.Show("Dados Preenchidos!");
                }
            }

            private void DeletarView_Click(object sender, EventArgs e)
            {
                this.Preenche(true);
           }
        }
    }

    Link para download do código:

    View_Bruno_Velaz

    Bruno Velaz