Dans SharePoint on a la possibilité d' afficher une liste ou une bibliothèque sur une page (la default.aspx par exemple). En paramétrant la webpart, il possible de sélectionner une vue à afficher et un type de barre d' outils. Vous avez sûrement remarqué, que si vous ajoutez une colonne ou modifier une vue de la liste, le changement n' est pas répercuté au niveau de la webpart. En efet, elle fait une copie de la vue sélectionnée dans son propre espace de stockage.
Après un petit tour dans le model objet de la ListViewWebPart, je n' ai pas trouvé d' objet SPView et les modifications au niveau du XML ne donnait rien. J' ai donc regardé en détail le code de la ListViewWebPart pour regarder en détail son fonctionnement. Et comme je le craignait, on a bien un SPView qui est déclaré en private. Il ne reste plus qu' a faire une peu de reflexion...
Voici le code (avec la modification de la toolbar) :)
// On récupere le webpart manager de la page
Microsoft.SharePoint.WebPartPages.SPLimitedWebPartManager mngr = web.GetLimitedWebPartManager("default.aspx", System.Web.UI.WebControls.WebParts.PersonalizationScope.Shared);
for (int j = 0; j < mngr.WebParts.Count; j++)
{
if (mngr.WebParts[j] is ListViewWebPart)
{
ListViewWebPart listWP = mngr.WebParts[j] as ListViewWebPart;
System.Reflection.PropertyInfo viewProp = listWP.GetType().GetProperty("View", System.Reflection.BindingFlags.NonPublic | System.Reflection.BindingFlags.Instance);
// On a notre SPView !!!
SPView spView = viewProp.GetValue(listWP, null) as SPView;
// Obligatoire !!!
string txt = spView.SchemaXml;
// On récupere le xml pour la toolbard
System.Reflection.PropertyInfo nodeProp = spView.GetType().GetProperty("Node", System.Reflection.BindingFlags.NonPublic | System.Reflection.BindingFlags.Instance);
XmlNode node = nodeProp.GetValue(spView, null) as XmlNode;
XmlNode tBarNode = node.SelectSingleNode("Toolbar");
if (tBarNode != null)
{
// Le type de toolbar: standard / freeform / none
tBarNode.Attributes["Type"].Value = "Freeform";
// Une position
XmlAttribute pos = tBarNode.OwnerDocument.CreateAttribute("Position");
pos.Value = "After";
tBarNode.Attributes.Append(pos);
// CAML pour avoir le bouton: ajouter un element
tBarNode.InnerXml = @"<IfHasRights><RightsChoices><RightsGroup PermAddListItems=""required"" /></RightsChoices><Then><HTML><![CDATA[ <table width=100% cellpadding=0 cellspacing=0 border=0 > <tr> <td colspan=""2"" class=""ms-partline""><IMG SRC=""/_layouts/images/blank.gif"" width=1 height=1 alt=""""></td> </tr> <tr> <td class=""ms-addnew"" style=""padding-bottom: 3px""> <img src=""/_layouts/images/rect.gif"" alt=""""> <a class=""ms-addnew"" ID=""idAddNewItem"" href=""]]></HTML><URL Cmd=""New"" /><HTML><![CDATA["" ONCLICK=""javascript:NewItem(']]></HTML><URL Cmd=""New"" /><HTML><![CDATA[', true);javascript:return false;"" target=""_self"">]]></HTML><HTML>Ajouter un nouvel élément</HTML><HTML><![CDATA[</a> </td> </tr> <tr><td><IMG SRC=""/_layouts/images/blank.gif"" width=1 height=5 alt=""""></td></tr> </table>]]></HTML></Then></IfHasRights>";
spView.Update();
}
}
}
Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :