• Skip to main content
  • Skip to primary sidebar

Technical Notes Of
Ehi Kioya

Technical Notes Of Ehi Kioya

  • Forums
  • About
  • Contact
MENUMENU
  • Blog Home
  • AWS, Azure, Cloud
  • Backend (Server-Side)
  • Frontend (Client-Side)
  • SharePoint
  • Tools & Resources
    • CM/IN Ruler
    • URL Decoder
    • Text Hasher
    • Word Count
    • IP Lookup
  • Linux & Servers
  • Zero Code Tech
  • WordPress
  • Musings
  • More
    Categories
    • Cloud
    • Server-Side
    • Front-End
    • SharePoint
    • Tools
    • Linux
    • Zero Code
    • WordPress
    • Musings
Home » Backend (Server-Side) » Add Custom Action To SharePoint Ribbon

Add Custom Action To SharePoint Ribbon

By Ehi Kioya Leave a Comment

I wrote this post as a follow up to my last post: Add Custom Action To SharePoint Edit Control Block. Just like with the edit control block, SharePoint Developers often need to add a custom action to the SharePoint Ribbon. I have had to do this many times myself and since there isn’t a lot of resources available on the subject, I decided to write this post for those who might want to do this sometime, and for myself as a future reference.

I have tested the general technique described here on both SharePoint 2010 and SharePoint 2013. Please note that: While SharePoint 2010 is happy with the Image32by32 parameter entered in this format:

1
Image32by32='/_layouts/images/dummyproject/workflow32.gif'

…this will not work for SharePoint 2013! Took me a while to figure this out. For the Image32by32 parameter, SharePoint 2013 seems to expect the actual data uri of the image instead of the server relative url.

To get the data uri of my image, I used this online tool to do the conversion.

The code I share below is the SharePoint 2013 version. If you want to work with SharePoint 2010, then change this line (your own image uri will of course be different):

1
Image32by32=''

To this (with your own project name of course):

1
Image32by32='/_layouts/images/dummyproject/workflow32.gif'

Add The Custom Action To The SharePoint Ribbon

Lets assume you want to add the custom action to the SharePoint ribbon using a feature (Yes, this is the most common scenario). And let’s further assume that you want the custom action to open a modal dialog (this is also a very common requirement). Here’s the complete code you would need for the feature activated event handler (there are a few extra bells and whistles in the code specific to my requirements. Ignore these where necessary).

Notice how I pass the site url {SiteUrl} and item id of the selected item {SelectedItemId} as parameters.

A couple of interesting notes:

  • Unlike the code for the edit control block, the ribbon code will NOT work with {ItemId}. You must enter {SelectedItemId}.
  • Since we only want the ribbon custom action to be active when one (and only one) item is selected, I had to add code to specifically satisfy that condition. See the “EnabledScript” parameter within the code below.
public override void FeatureActivated(SPFeatureReceiverProperties properties)
{
    SPSite site = (SPSite)properties.Feature.Parent;
    foreach (SPWeb web in site.AllWebs)
    {
        if (web.ServerRelativeUrl.TrimEnd('/').ToLower().EndsWith("dummysite"))
        {
            for (int i = 0; i < web.Lists.Count; i++)
            {
                SPList list = web.Lists.TryGetList("Dummy List");
                if (list != null && list.BaseType == SPBaseType.GenericList)
                {
                    web.AllowUnsafeUpdates = true;
                    if (list.UserCustomActions.Count > 0)
                    {
                        foreach (SPUserCustomAction action2 in list.UserCustomActions)
                        {
                            if (action2.Name == "ContentTypeRibbonCustomization")
                            {
                                action2.Delete();
                                list.Update();
                                break;
                            }
                        }
                    }
                    SPUserCustomAction ribbonCustomAction = list.UserCustomActions.Add();
                    ribbonCustomAction.Name = "ContentTypeRibbonCustomization";
                    ribbonCustomAction.Location = "CommandUI.Ribbon.ListView";

                    //Notice that I added the actual data uri of the image instead of a url.
                    //Here's the converter I used http://websemantics.co.uk/online_tools/image_to_data_uri_convertor/
                    ribbonCustomAction.Title = "Generate Output";
                    ribbonCustomAction.CommandUIExtension = @"
                        &lt;CommandUIExtension&gt;
                            &lt;CommandUIDefinitions&gt;
                            &lt;CommandUIDefinition Location='Ribbon.ListItem.Actions.Controls._children'&gt;
                                &lt;Button Id='ListViewButton'
                                    Command='ListViewButtonCommand'
                                    Description='Generate Output'
                                    TemplateAlias='o2' Sequence='95'
                                    Image32by32=''
                                    ToolTipDescription='Generate Output'
                                    LabelText='Generate Output'/&gt;
                            &lt;/CommandUIDefinition&gt;
                            &lt;/CommandUIDefinitions&gt;
                            &lt;CommandUIHandlers&gt;
                            &lt;CommandUIHandler Command='ListViewButtonCommand'
                                                EnabledScript='javascript: var EnableDisable = function() {
                                                                this.clientContext = SP.ClientContext.get_current();
                                                                var currentWeb = clientContext.get_web();
                                                                this.selectedItems = SP.ListOperation.Selection.getSelectedItems(this.clientContext);
                                                                var currentListGuid = SP.ListOperation.Selection.getSelectedList();
                                                                var ret;
                                                                var ci = CountDictionary(selectedItems);
                                                                return (ci == 1)
                                                                };
                                                                EnableDisable();'
                                                CommandAction=""javascript: var options = {
                                                        url: '{SiteUrl}' + '/_layouts/dummyproject/dummypage.aspx/?ProjectProfileID={SelectedItemId}',
                                                        allowMaximize: false,
                                                        width: 500,
                                                        height: 440 };
                                                    SP.UI.ModalDialog.showModalDialog(options);"" /&gt;
                            &lt;/CommandUIHandlers&gt;
                        &lt;/CommandUIExtension&gt;";
                    ribbonCustomAction.Update();
                    list.Update();
                    web.AllowUnsafeUpdates = false;
                    break;
                }
            }
        }
    }
}

Remove The Custom Action From The SharePoint Ribbon

When the feature is deactivated, you would typically want to undo the addition of the custom action so that your environment reverts to the original state. To do this, add the following block of code to the feature deactivating event handler:

public override void FeatureDeactivating(SPFeatureReceiverProperties properties)
{
    SPSite site = (SPSite)properties.Feature.Parent;
    foreach (SPWeb web in site.AllWebs)
    {
        if (web.ServerRelativeUrl.TrimEnd('/').ToLower().EndsWith("dummysite"))
        {
            for (int i = 0; i < web.Lists.Count; i++)
            {
                SPList list = web.Lists.TryGetList("Dummy List");
                if (list != null && list.BaseType == SPBaseType.GenericList)
                {
                    web.AllowUnsafeUpdates = true;
                    if (list.UserCustomActions.Count > 0)
                    {
                        foreach (SPUserCustomAction action2 in list.UserCustomActions)
                        {
                            if (action2.Name == "ContentTypeRibbonCustomization")
                            {
                                action2.Delete();
                                list.Update();
                                break;
                            }
                        }
                    }
                    web.AllowUnsafeUpdates = false;
                    break;
                }
            }
        }
    }
}

That removes the custom action from the SharePoint ribbon.

Found this article valuable? Want to show your appreciation? Here are some options:

  1. Spread the word! Use these buttons to share this link on your favorite social media sites.
  2. Help me share this on . . .

    • Facebook
    • Twitter
    • LinkedIn
    • Reddit
    • Tumblr
    • Pinterest
    • Pocket
    • Telegram
    • WhatsApp
    • Skype
  3. Sign up to join my audience and receive email notifications when I publish new content.
  4. Contribute by adding a comment using the comments section below.
  5. Follow me on Twitter, LinkedIn, and Facebook.

Related

Filed Under: Backend (Server-Side), Frontend (Client-Side), SharePoint Tagged With: JavaScript, SharePoint

About Ehi Kioya

I am a Toronto-based Software Engineer. I run this website as part hobby and part business.

To share your thoughts or get help with any of my posts, please drop a comment at the appropriate link.

You can contact me using the form on this page. I'm also on Twitter, LinkedIn, and Facebook.

Reader Interactions

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Primary Sidebar

26,207
Followers
Follow
30,000
Connections
Connect
14,641
Page Fans
Like

POPULAR   FORUM   TOPICS

  • How to find the title of a song without knowing the lyrics
  • Welcome Message
  • How To Change Or Remove The WordPress Login Error Message
  • The Art of Exploratory Data Analysis (Part 1)
  • Getting Started with SQL: A Beginners Guide to Databases
  • Replacing The Default SQLite Database With PostgreSQL In Django
  • 100% Disk Usage In Windows 10 Task Manager – How To Fix
  • Setting up an Ecommerce page: WordPress (WooCommerce) vs Shopify
  • What Is HTTPS? And Why Should You Care?
  • How To Free-up Space On Your Devices Without Losing Your Files
  • Recently   Popular   Posts   &   Pages
  • Actual Size Online Ruler Actual Size Online Ruler
    I created this page to measure your screen resolution and produce an online ruler of actual size. It's powered with JavaScript and HTML5.
  • Allowing Multiple RDP Sessions In Windows 10 Using The RDP Wrapper Library Allowing Multiple RDP Sessions In Windows 10 Using The RDP Wrapper Library
    This article explains how to bypass the single user remote desktop connection restriction on Windows 10 by using the RDP wrapper library.
  • WordPress Password Hash Generator WordPress Password Hash Generator
    With this WordPress Password Hash Generator, you can convert a password to its hash, and then set a new password directly in the database.
  • Forums
  • About
  • Contact

© 2021   ·   Ehi Kioya   ·   All Rights Reserved
Privacy Policy