Il suffit de désactiver la feature de ferme correspondante avec le code suivant :
Disable-SPFeature -id "756D8A58-4E24-4288-B981-65DC93F9C4E5" -force
Du SharePoint, du silverlight, pas mal de C#, un peu de powershell et surtout du Microsoft
Affichage des articles dont le libellé est Sharepoint Designer. Afficher tous les articles
Affichage des articles dont le libellé est Sharepoint Designer. Afficher tous les articles
mardi 23 octobre 2012
Hide top navigation bar for Sharepoint 2010 / Cacher le ruban et la barre de navigation supérieur via code depuis la masterPage
Il ne faut pas oublier de passer les différents div en "runat='server'" pour que le code marche.
private void HideShowElement(bool value)
{
if(value) // Administrateur
{
Control haut = this.FindControl("msWwpselectlink");
//((HtmlControl)haut).Width="0px";
((HtmlControl)haut).Attributes.Add("style","display:block;");
Control hautLien = this.FindControl("topNavgationBar");
((HtmlControl)hautLien).Attributes.Add("style","display:block;");
Control crt = this.FindControl("PanelAdminLeft");
if(crt!= null)
{
crt.Visible = true;
//Supprime le css pour aligner à gauche.
Control content = this.FindControl("MSO_ContentTable");
if(content != null){
((HtmlControl)content).Attributes.Add("class","s4-ca s4-ca-dlgNoRibbon");}
}
}
else // Non administrateur
{
Control haut = this.FindControl("msWwpselectlink");
// haut.Visible = false;
((HtmlControl)haut).Attributes.Add("style","display:none;");
Control hautLien = this.FindControl("topNavgationBar");
((HtmlControl)hautLien).Attributes.Add("style","display:none;");
Control crt = this.FindControl("PanelAdminLeft");
if(crt!= null)
{
crt.Visible = false;
//Supprime le css pour aligner à gauche.
Control content = this.FindControl("MSO_ContentTable");
if(content != null){
((HtmlControl)content).Attributes.Remove("class");}
}
}
}
Hide button in sharepoint 2010 Ribbon / Cacher les boutons du ruban SharePoint 2010
Feature à appliquer sur un type de contenu / template de liste par exemple.
Il suffit ensuite de spécifier la localisation du bouton.
<?xml version="1.0" encoding="utf-8"?>
<Elements xmlns="http://schemas.microsoft.com/sharepoint/">
<CustomAction Id="HideCustomActionDocumentSource"
Location="CommandUI.Ribbon"
RegistrationType="ContentType"
RegistrationId="0x0101002D02DF72FAFB4EAB9446F92337C759AE01">
<CommandUIExtension>
<CommandUIDefinitions>
<CommandUIDefinition Location="Ribbon.Library.ViewFormat.Standard" />
<CommandUIDefinition Location="Ribbon.Library.ViewFormat.Datasheet" />
<CommandUIDefinition Location="Ribbon.Library.Datasheet.NewRow" />
<CommandUIDefinition Location="Ribbon.Library.Datasheet.ShowTaskPane" />
<CommandUIDefinition Location="Ribbon.Library.Datasheet.ShowTotals" />
<CommandUIDefinition Location="Ribbon.Library.Datasheet.RefreshData" />
<CommandUIDefinition Location="Ribbon.Library.CustomViews.CreateView" />
<CommandUIDefinition Location="Ribbon.Library.CustomViews.ModifyView" />
<CommandUIDefinition Location="Ribbon.Library.CustomViews.CreateColumn" />
<CommandUIDefinition Location="Ribbon.Library.CustomViews.NavigateUp" />
<CommandUIDefinition Location="Ribbon.Library.CustomViews.CurrentView" />
<CommandUIDefinition Location="Ribbon.Library.CustomViews.DisplayView" />
<CommandUIDefinition Location="Ribbon.Library.CustomViews.PreviousPage" />
<CommandUIDefinition Location="Ribbon.Library.CustomViews.CurrentPage" />
<CommandUIDefinition Location="Ribbon.Library.CustomViews.NextPage" />
<CommandUIDefinition Location="Ribbon.Library.Share.AlertMe" />
<CommandUIDefinition Location="Ribbon.Library.Share.ViewRSSFeed" />
<CommandUIDefinition Location="Ribbon.Library.Actions.TakeOfflineToClient" />
<CommandUIDefinition Location="Ribbon.Library.Actions.ConnectToClient" />
<CommandUIDefinition Location="Ribbon.Library.Actions.ExportToSpreadsheet" />
<CommandUIDefinition Location="Ribbon.Library.Actions.OpenWithExplorer" />
<CommandUIDefinition Location="Ribbon.Library.Actions.AllMeetings" />
<CommandUIDefinition Location="Ribbon.Library.CustomizeLibrary.AddButton" />
<CommandUIDefinition Location="Ribbon.Library.CustomizeLibrary.EditList" />
<CommandUIDefinition Location="Ribbon.Library.CustomizeLibrary.EditDefaultForms" />
<CommandUIDefinition Location="Ribbon.Library.Settings.ManageWorkflows" />
<CommandUIDefinition Location="Ribbon.Library.Settings.LibraryPermissions" />
<CommandUIDefinition Location="Ribbon.Documents.New.NewFolder" />
<CommandUIDefinition Location="Ribbon.ListItem.New.NewFolder" />
<CommandUIDefinition Location="Ribbon.Documents.New.NewDocument" />
<CommandUIDefinition Location="Ribbon.Documents.EditCheckout.CheckOut" />
<CommandUIDefinition Location="Ribbon.Documents.EditCheckout.CheckIn" />
<CommandUIDefinition Location="Ribbon.Documents.EditCheckout.DiscardCheckOut" />
<CommandUIDefinition Location="Ribbon.Documents.Manage.ManagePermissions" />
<CommandUIDefinition Location="Ribbon.Documents.Share.EmailItemLink" />
<CommandUIDefinition Location="Ribbon.Documents.Share.AlertMe" />
<CommandUIDefinition Location="Ribbon.Documents.Copies.SendTo" />
<CommandUIDefinition Location="Ribbon.Documents.Copies.ManageCopies" />
<CommandUIDefinition Location="Ribbon.Documents.Copies.GoToSourceItem" />
<CommandUIDefinition Location="Ribbon.Documents.Workflow.ViewWorkflows" />
<CommandUIDefinition Location="Ribbon.Documents.Workflow.Publish" />
<CommandUIDefinition Location="Ribbon.Documents.Workflow.Unpublish" />
<CommandUIDefinition Location="Ribbon.Documents.Workflow.Moderate" />
<CommandUIDefinition Location="Ribbon.Documents.Workflow.CancelApproval" />
<CommandUIDefinition Location="Ribbon.Documents.FormActions.RepairItems" />
<CommandUIDefinition Location="Ribbon.Documents.FormActions.RepairAllItems" />
<CommandUIDefinition Location="Ribbon.Documents.FormActions.MergeDocuments" />
</CommandUIDefinitions>
</CommandUIExtension>
</CustomAction>
</Elements>
Liste complète
http://msdn.microsoft.com/en-us/library/ee537543.aspx
vendredi 14 septembre 2012
Comment cacher les actions dans un site SharePoint grâce au Javascript(Session, Site, Liste, Bibliothèques de documents)
L'utilisation du JavaScript est un moyen efficace et peut coûteux en développement pour cacher les différentes actions qui peuvent apparaître sur une page SharePoint.
Il est en effet possible grâce à une simple fonction Javascript insérable dans la masterpage, de cacher les différentes actions :
- Mes paramètres
- Se connecter en tant qu'utilisateur différent
- Demander l'accès
- Se déconnecter
- Personnaliser cette page
- Créer
- Modifier la page
- Paramètres du site
- Nouvel élément
- M'avertir
- Créer une colonne
- Créer un affichage
- Paramètres - Liste
- Tous les éléments
- Modifier cet affichage
- Créer un affichage
- Télécharger un document
- Télécharger plusieurs documents
- Modifier dans la feuille de données
- Ouvrir avec l'Explorateur Windows
- Exporter vers une feuille de calcul
- Afficher le flux RSS
La fonction javascript est la suivante :
<script type="text/javascript" language="javascript">
function cacherActionPortail()
{
var menuItem;
var menuItemName;
var menuItemIndex=-1;
var menuItemNames=new Array("Mes paramètres",
"Se connecter en tant qu'utilisateur différent",
"Demander l'accès",'se déconnecter','Personnaliser cette page','Créer'
,"Modifier la page","Paramètres du site","Nouvel élément",
"M'avertir","Créer une colonne","Créer un affichage",
"Paramètres - Liste","Tous les éléments",
"Modifier cet affichage","Créer un affichage",
"Télécharger un document","Télécharger plusieurs documents","Modifier dans la feuille de données",
"Ouvrir avec l'Explorateur Windows","undefined","Exporter vers une feuille de calcul","Afficher le flux RSS");
var menuItems = new Array("PersonalInformation",
"LoginAsDifferentUser","RequestAccess",
"Logout","PersonalizePage",
"MenuItem_Create","MenuItem_EditPage",
"MenuItem_Settings","New0","SubsribeButton",
"AddColumn","AddView",
"ListSettings","DefaultView","ModifyView",
"CreateView","Upload",
"MultipleUpload","EditInGridButton","OpenInExplorer","OfflineButton",
"ExportToSpreadsheet","ViewRSS");
var allMenuItems = document.getElementsByTagName('ie:menuitem');
for(var i = 0; i < cacherActionPortail .arguments.length; i++ )
{
menuItemName= cacherActionPortail .arguments[i].toLowerCase();
for (j=0; j < menuItemNames.length; j++)
{
if(menuItemNames[j].toLowerCase()==menuItemName)
{
menuItemIndex = j;
break;
}
}
menuItem=menuItems[menuItemIndex];
for (var l = 0; l < allMenuItems.length; l++)
{
if(menuItemName.indexOf(":")!=-1)
{
menuItemName = menuItemName.split(":")[1];
}
if (allMenuItems[l].id.indexOf(menuItem)!=-1
&& allMenuItems[l].text.toLowerCase() == menuItemName)
{
// For FireFox Compatibility
var parentNodeOfMenuItem = allMenuItems[l].parentNode;
parentNodeOfMenuItem.removeChild(allMenuItems[l]);
break;
}
}
}
}
</script>
Ainsi que l'appel de la fonction depuis le 'Page_Load' de la master page :
protected void Page_Load(object sender, EventArgs e)
{
Page.ClientScript.RegisterStartupScript(this.GetType(), "click","cacherActionPortail (\"Afficher le flux RSS\",\"Modifier dans la feuille de données\",\"Exporter vers une feuille de calcul\");", true);
}
lundi 25 juin 2012
Création Business Connectivity Service (BCS) pour SharePoint Server 2010
Présentation
Le but de ce
développement est de permettre d’avoir une vue synthétique sur les utilisateurs
des plannings fournit par Microsoft Project Server via SharePoint.
En effet, les données
sont stockés dans la base de données SQL Server et donc uniquement accessible
via requête SQL.
Ce développement va
permettre d’afficher les informations relatives à la saisie des plannings par
les utilisateurs via une liste SharePoint.
Plusieurs étapes sont
nécessaires à cette réalisation :
- Créer une vue des données à partir de la BDD SQL Server et nécessaire à la liste SharePoint
- Créer une entrée dans la Secure Store Service, qui va permettre au service SharePoint de stocker les informations relatives à la connexion avec le serveur de BDD.
- Créer un Type de contenu externe via un BCS (Business Connectivity Services) permettant de récupérer les données externes à la base de contenu SharePoint
- Attribuer les droits utilisateurs sur le type de contenu
- Créer une liste externe qui permettra d’afficher le type de contenu externe crée précédemment.
Rendu final de la liste externe cree via bcs sharepoint 2010 |
Création de la vue
Avec un utilisateur ayant suffisamment de droit sur la base donnée MSProject, se connecter et exécuter le script :
CREATE VIEW
[dbo].[V_UTILISATEUR_WITH_DAY_LAST_PUBLISHED_TIMESHEET]
AS
(SELECT res.res_uid as id_utilisateur,
res.res_name as
nom_utilisateur,
res.WRES_ACCOUNT as
account_utilisateur,
res.wres_email as
email_utilisateur,
max(act.MOD_DATE)
as date_last_published,
DATEDIFF(day,max(act.MOD_DATE),SYSDATETIME()) as
nombre_jour_derniere_saisie
FROM
[ProjectServer_Published_project_portfolio].[dbo].[MSP_RESOURCES] res,
[ProjectServer_Published_project_portfolio].[dbo].MSP_TIMESHEETS
ts,
[ProjectServer_Published_project_portfolio].[dbo].MSP_TIMESHEET_LINES
line,
[ProjectServer_Published_project_portfolio].[dbo].MSP_TIMESHEET_ACTUALS
act
WHERE
res.WRES_ACCOUNT IS
NOT NULL
AND
res.RES_UID =
ts.RES_UID AND
ts.TS_UID =
line.TS_UID
AND
line.TS_LINE_UID =
act.TS_LINE_UID
group
by res.res_uid, res.RES_NAME, res.wres_email, res.wres_account)
UNION
(
SELECT res.res_uid
as id_utilisateur,
res.res_name as
nom_utilisateur,
res.WRES_ACCOUNT as
account_utilisateur,
res.wres_email as
email_utilisateur,
null as
date_last_published,
null as nombre_jour_derniere_saisie
FROM
[ProjectServer_Published_project_portfolio].[dbo].[MSP_RESOURCES] res
WHERE
res.WRES_ACCOUNT IS
NOT NULL AND
res.res_uid not in
(SELECT distinct res.res_uid FROM
[ProjectServer_Published_project_portfolio].[dbo].[MSP_RESOURCES]
res,
[ProjectServer_Published_project_portfolio].[dbo].MSP_TIMESHEETS
ts,
[ProjectServer_Published_project_portfolio].[dbo].MSP_TIMESHEET_LINES
line,
[ProjectServer_Published_project_portfolio].[dbo].MSP_TIMESHEET_ACTUALS
act
WHERE res.WRES_ACCOUNT
IS NOT NULL
AND res.RES_UID = ts.RES_UID
AND ts.TS_UID = line.TS_UID
AND line.TS_LINE_UID =
act.TS_LINE_UID)
);
|
Une fois la requête exécutée
la vue nouvellement crée apparaitra dans la liste des vues disponible après
rafraichissement de la liste.
Création de la Vue Sql Server 2008 sur base de donnees Microsoft Server Project |
Création du secure store service
Se rendre dans la console d’administration SharePoint
Puis dans Application Management
- > Manage Service Applications
Et sélectionner le
service « Secure Store
Service »
Secure store service Sharepoint 2010 |
Il faut ensuite créer une
nouvelle entrée et fournir les informations demandés en respectant bien le
« Target Application Type » à « Group ».
Configuration du Secure Store Application pour Sharepoint 2010 |
L’authentification avec
SQL Server se fait avec des identifiants Windows il n’est donc pas la peine de
changer les champs dans l’écran suivant.
Login credentials pour authentification windows |
L’écran suivant permet de
spécifier qui pourra administrer et qui sera membres de cette nouvelle entrée.
Attribution des droits sur le secure store service sharepoint 2010 |
Ceci fait il ne reste
plus qu’à fournir les identifiant de connexion via l’icône de la page
principale.
Identifiants de connexion à sql server 2008 |
Un temps d’attente pour
que le Secure Store Application est nécessaire pour que celui-ci soit pris en
compte par le serveur SQL Server (environ 1h, peut dépendre de votre
configuration réseau/serveur).
Création du BCS
Grâce à SharePoint Designer, ouvrir le site concerné par la création du type de contenu externe.Création via Sharepoint 2010 designer du type de contenu externe |
Et créer le nouveau type
de contenu externe :
Creation of external content types with sharepoint designer 2010 |
Saisir le nom du nouveau
type de contenu et cliquez sur « External System »:
Configuration external content type |
Ajoutez une connexion, et
choisir « SQL Server », puis saisir le nom du serveur, le nom de la
base de données, et le nom de l’ID de la Secure
Store Application crée précédemment.
Provide the different informations for Secure Store Application configuration |
Il suffit ensuite de
sélectionner la vue dans l’explorateur d’objet de la base de données et
d’ajouter les opérations de lecture d’item et de liste.
Création des opérations ,new read item operation, new read list operation |
Input parameters configuration new read item operation bcs sharepoint 2010 |
Création de la liste externe
Une fois le type de contenu externe il ne reste plus qu’a créé la liste externe.Création de la liste externe à partir du type de contenu externe |
Attribution des droits sur le type de contenu
Un réglage au niveau des permissions sur le type de contenu est nécessaire pour permettre aux utilisateurs de consulter la liste.
Se rendre dans la console
d’administration SharePoint
Et se rendre dans Application Management
- > Manage Service Applications
Business data connectivity service |
Sélectionnez le type de
contenu nouvellement crée puis cliquez sur le bouton « Set Object
Permissions »
Set object permissions on BDC business data connectivity metadata store |
Rendu de la liste externe
La liste externe ainsi crée est disponible sur le site et propose la même interface de gestion au niveau droits, vues et paramétrage qu’une liste SharePoint.Rendu final de la liste externe cree via bcs sharepoint 2010 |
Plus loin avec les Business Connectivity Service (BCS) : What's New: Business Connectivity Services (BCS) in SharePoint Server 2010
Plus loin avec les type de contenu externe (external content type) : What Are External Content Types?
Plus loin avec Business Data Connectivity (BDC) : Service BDC (Business Data Connectivity)
Plus loin avec le Secure Store Service Application : Configuring the Secure Store Service
Téléchargement : Microsoft SharePoint Designer 2010
Inscription à :
Articles
(
Atom
)