-
Notifications
You must be signed in to change notification settings - Fork 127
Adding GitHub Wiki to IntelliJ Project
GitHub wiki pages can be added as a sub-module of the main project and you will then be able to maintain the wiki in the IDE and use the Markdown Navigator plugin for editing and previewing.
The IntelliJ IDE's commit and push will update your GitHub Wiki Pages.
It also makes it easy to add images into your wiki repository which is not as comfortable as adding images to GitHub issues where you can just drag and drop them from your computer.
-
If you don't already have a GitHub wiki for your project (this you do on GitHub):
- Enable wiki's in the project settings by clicking the settings tab
- Create the wiki by clicking on the wiki tab in your repository.
- Save the page.
-
Clone the wiki to a subdirectory of your project. The wiki URL is your project URL's with
.wiki.git
at the end. For example idea-markdown URL is https://github.com/vsch/idea-multimarkdown its wiki git repository is athttps://github.com/vsch/idea-multimarkdown.wiki.git
. Clone it to theidea-multimarkdown.wiki
subdirectory of the main project so that you can maintain these pages in the IDE using the plugin, while working on the plugin's source and so that the plugin will know that it is a wiki for the main project.⚠️ Name the subdirectory with the same name as the main project directory with a.wiki
suffix. Markdown Navigator uses this to treat all Markdown files below it as GitHub wiki pages for the project and not regular Markdown files. -
You will now see the the wiki sub-module in your project.
-
Add the wiki as a VCS sub-module to your IntelliJ IDE by going to Preferences on OS X and File/Settings on Windows and Linux, Version Control. IntelliJ is aptly named and it already detected an Unregistered VCS Root of the wiki subdirectory. Just click on the item for your wiki and then the + button at the bottom of the pane as in the image below:
-
GitHub Wiki Links
check box is selected by default to match wiki link syntax of GitHub Wiki.
You can now rename files, drop images from your desktop and add these images to your wiki. When you commit your changes your GitHub wiki will be updated. Any changes made on the GitHub site will need to be pulled into the wiki on your repository.
In the plugin HTML Preview tab clicking on a Wiki Link for a file in your project will open the corresponding wiki page on GitHub, unless the file is marked ignored or newly added, in which case the file will be opened in the IDE so you can edit it or view it on the preview tab.
Links that are missing or incorrect, [[Missing Page Link]]
will show up in the HTML Preview
tab in red. Like this: Missing Page Link. They will also highlight as Unknown Symbol in the
markdown text file. For example: .
The basic version does all the link validation for wiki links only. The enhanced will do it for all links based on GitHub rules for resolving relative links. In the enhanced version you can exchange a wiki link to explicit and back, you can also change explicit links between relative and absolute addressing. The plugin ensures that the links resolve and if they do not then a tooltip annotation is added and a quick fix intention action is offered that will fix the problem.
GitHub Wiki links with optional link text are the reverse of Creole's [[Link text|Link address]]
. You can also append an anchor reference to the end of the link address via the #
.
If you get the order wrong and the link text resolves to a page then a quick fix will be offered
to swap the text and address parts.
GitHub wiki link addresses cannot contain /
, more accurately /
will be changed to -
in the
rendered HTML href attribute. This means that you cannot put sub-directory references into the
wiki links. All links resolve strictly by page name, even if these pages are located in
sub-directories. This means that all your wiki pages must have unique names in order to be
resolvable. Pages with duplicate names will resolve, as far as I have tested, to the first page,
alphabetically sorted by path. Note that this means that a page with .markdown
extension will
match before one with a .md
extension, if the file paths are the same.
This behaviour is duplicated by the plugin for GitHub wiki pages with any link that resolves to multiple pages annotated with a warning and all the pages are accessible via the line navigation marker, with the page that will be resolved to by the link at the top of the list and the rest below.
When you have duplicate matching pages you will get a warning annotation with some quick fixes to rename conflicting duplicate targets so that they can be targets of other links.
GitHub recommends using relative links in all pages as much as possible so that a repository, once forked will not have to be edited to correct for absolute links. Wiki pages are no exception but without the plugin resolving relative links is a pain.
The wiki home page resolves relative links differently than the rest of the pages. Relative
image links have different rules than absolute links. Files with a non-markdown extension can be
obscured by a markdown file with an embedded extension. For example, if you have a test.java
file in the wiki and a test.java.md
file, then you will not be able to create a link that
resolves to the test.java
file. The link will always resolve to test.java.md
.
Another example is relative image links from wiki pages to the main repository. These must always reference the raw/... not the blob/... address prefix or they will not resolve. Absolute addresses are not affected, neither are explicit links.
Keep this in mind when copying text between files. Refactoring on copy/paste is not yet implemented. Refactoring links within a file on file move is implemented in the Enhanced edition.
The easiest way to get the links right is to use completion in wiki links or in explicit link's
address. If you want to resolve absolute addresses invoke the completions function multiple
times, every invocation cycles to the next available link addressing format, or type https://
into the link and then start auto complete. Similarly, if you want to resolve to a non-markdown
file extension just enter the extension in the address part of the link and launch
auto-complete. You can combine the two so [ ](https://.java)
will show all available .java
files using absolute links.
The easiest way to add images is to copy them into the wiki sub-module right in the IDE
You can organize your images by creating an img
sub-directory, for example, under your wiki
folder in the IDE and moving all your images into it. Refer to these images from the wiki pages
via the img markdown syntax ![alt text](img/image-file-name.png)
. Having the images in a
separate directory will clean up the main wiki folder.
To refer to the image files in your wiki folder use the img markdown syntax. For example, for an
image file named image-file-name.png
located in img
directory the link would be ![alt text](img/image-file-name.png)
.
NOTE For the Home
page you will need to include the either full GitHub URL to images in
your wiki or add wiki/
prefix to all relative image link addresses. The Home
page resolves
image link addresses relative to the main repository URL not the wiki/ URL. For the example
above the link in the wiki home page should be ![alt text](wiki/img/image-file-name.png)
. The
rest of the wiki pages behave more intuitively. If you use use the plugin's link address
completion then all these details are handled by the plugin.
Automatic changes to references for the moved images is only available in the enhanced version of the plugin, you can get a 15-day free trial here: Markdown Navigator Enhanced
If you want to move existing images from the root wiki folder then use the IDE's change in files feature and use Regular expression to rename all your image references.
If you want to move existing images from the root wiki folder then use the IDE's change in files feature and use Regular expression to rename all your image references.
The page title is the file name with dashes -
, along with a few other characters, changed to
spaces and the .md
extension removed. It is automatically added by GitHub so you should not
have an H1 header on the page.
You create links that refer to other pages by using the Wiki Link format: [[Page Name]]
.
GitHub converts this to a link to the HTML page of the markdown wiki page, with spaces changed
to -
. The plugin will automatically convert it to a markdown file reference, also with spaced
changed to -
.
To reference anchor links in pages just add the # after the page name [[Page Name#anchor-name]]
if you want the link text to be different from the page link add it after
|
in the wiki link, [[Page Link Text|Page Name]]
or if it has an anchor [[Page Link Text|Page Name#anchor-name]]
Anchor refs are created automatically matching GitHub rules so that they will resolve correctly when the links with anchor refs are navigated on GitHub.
You cannot have a wiki link with only an anchor reference as you can with explicit links. The plugin will highlight it as an unresolved link and offer a quick fix.
If you want a custom footer for your wiki pages then create _Footer.md
file in the root folder
of your wiki and GitHub will use it as the custom footer for every page.
If you want a custom sidebar for your wiki pages then create _Sidebar.md
file in the root
folder of your wiki and GitHub will use it as the custom sidebar for every page.
Copyright © 2015-2019 Vladimir Schneider, Released under Apache 2.0 License