This tutorial shows you how to add an option to the Confluence editor's 'Insert' menu, allowing people to access your plugin feature from within the editor.
| Applicable: | This tutorial applies to Confluence 4.3. | 
| Level of experience: | This is an intermediate tutorial. You should have completed at least one beginner tutorial before working through this tutorial. See the list of developer tutorials. | 
| Status | LEGACY This tutorial applies to Confluence versions that have reached end of life. | 
If you want to take a look at the complete source for this example, you can find it on Bitbucket here: https://bitbucket.org/appfusions/tutorial-editoricon
If you do not already have a plugin that needs the option in the editor menu, create a new Confluence plugin. You can use the Atlassian Plugin SDK to do this. See Set up the Atlassian Plugin SDK and Build a Project.
You need to set up the icon file that you will use, both in terms of putting the file in the right location in your plugin's resources directory and in terms of defining the image as a resource for use in your atlassian-plugin.xml file.
To refer to an image file that you will provide with your plugin, you must define an images directory as a plugin resource. (You can define just the image file as a resource, but it is neater to define a directory. Thisl will mean fewer changes to the plugin file later if you need more images.)
Reference: Adding Plugin and Module Resources.
Defining an images directory resource and choosing a location for your icon file:
Edit your atlassian-plugin.xml file and add an element to define your images directory like this:
1 2<resource name="images/" type="download" location="${project.artifactId}/includes/images"/>
Notice the variable ${project.artifactId} used in the above definition. That is a nice shortcut if you are planning to build multiple plugins with a similar architecture. The Atlassian SDK has defined that variable for you in your pom.xml. Let's say, for example, that the artifactId in your pom.xml is 'my-macro'. The definition in your pom.xml looks like this:
1 2<modelVersion>4.0.0</modelVersion> <groupId>com.appfusions.confluence.macros</groupId> <artifactId>my-macro</artifactId>
Add your icon file and the necessary directories to your plugin project. Because you are using the Atlassian plugin SDK to build your plugin, we recommend that you use the default location for resources. All your non-Java files should be located under src/main/resources. The path to your images directory looks like this:
1 2src/main/resources/my-macro/includes/images/
In our example, the file will be called icon.png.
The icon file in the plugin and the resources definition is in place now. You still need to communicate to the editor to use the icon via a CSS class.
We will follow a standard naming convention to define the CSS class.
To set up the CSS:
Edit the atlassian-plugin.xml for your plugin.
Add a web-resource definition pointing to your editor CSS class, and set its usage context to be the editor:
1 2<web-resource key="editorWebResource" name="Editor Web Resource"> <context>editor</context> <dependency>com.atlassian.confluence.tinymceplugin:editor-resources</dependency> <resource type="download" name="editor.css" location="${project.artifactId}/includes/editor/css/editor.css"/> </web-resource>
Create the CSS class editor.css in the indicated location. As with the images resource defined previously, the location will be the src/main/resources directory.
1 2src/main/resources/my-macro/includes/editor/css/editor.css
The naming convention for the relevant class is 'macro-NAMEOFMACRO'.
While we have not defined the macro yet, in our example, the name attribute of the macro will be defined as 'mymacro'. So, the class will be called macro-mymacro. 
In addition, we must scope the CSS class within the insert menu, and identify the element that will be styled. So, the full class description will be#insert-menu .macro-mymacro .icon. You must set the background of this class to use the icon image resource we defined earlier. This will look like this:
1 2#insert-menu .macro-mymacro .icon { background: transparent url("images/icon.png") 0 0 no-repeat; margin-top: 0px; }
Your addition to the editor should point to some functionality. For this example, you will add a Confluence macro module.
If you are not sure how to write a Confluence macro, you may want to review the following documentation:
To create a macro module:
atlassian-plugin.xml for your plugin.<xhtml-macro>  element containing the 'ExampleMacro' definition added by the Atlassian Plugin SDK, if present.com.appfusions.confluence.macros) to contain the groupId of your macro.Example definition:
1 2<xhtml-macro key="mymacro" name="mymacro" class="com.appfusions.confluence.macros.ExampleMacro"> <description>Description of My Macro goes here</description> <category name="external-content"/> <!-- see Including Information in your Macro for the Macro Browser for options --> <parameters> <!-- optional, if you have parameters --> <parameter name="param1" type="string" required="true"> </parameter> <parameter name="param2" type="string"> </parameter> </parameters> </xhtml-macro>
The final step is to define a web-item module in your atlassian-plugin.xml. This will tell the editor to display your icon as a link to your macro. 
You may wish to review the web-item module documentation:
To add the web-item:
atlassian-plugin.xml for your plugin.web-item definition. 
system.editor.featured.macros.default.It will look like this:
1 2<web-item key="editor-macrolinkkey" name="Name of my Editor Feature" section="system.editor.featured.macros.default" weight="11"> <label key="i18n.property.key.for.the.text.describing.your.icon"/> <link linkId="mymacro"/> </web-item>
Follow these steps to build and install your plugin, so that you can test your code. If you have not already started the application, start it now:
pom.xml is located).atlas-run (or atlas-debug if you might want to launch the debugger in your IDE).The atlas-run command will compile the plugin project and then launch a local instance of Confluence.
Once Confluence has loaded, access your local instance with this URL:
1 2http://localhost:1990/confluence/
Log in to Confluence with username "admin" and password "admin, then edit a page in the demonstration ('ds') space.
Congratulations, you've completed this tutorial.
Rate this page: