Set a Custom Homepage in SharePoint 2013 (Online)
I have been forced to learn my way around Microsoft’s ‘sharing and collaboration’ platform over the past few weeks, but, I had issues when trying to load an HTML page in SharePoint Online…
I compiled a static website using Jekyll with the usual standard HTML, CSS, & JS files generated. The plan was to deploy all of the files somewhere inside an internally used SharePoint Online site.
Unlike a normal SharePoint instance, SharePoint Online doesn’t support using an html page as a site homepage. The files could be uploaded, however instead of loading the HTML pages in the browser they would download locally when you tried to load them.
Here’s how I got it to work…
‘Add an App’ to your SharePoint Site
- Within your SharePoint Online Site navigate to
Site Contents, add a Document Library, set the library name and title to
- You should be able to access the library via this address:
Setup your Jekyll Config file(s)
I used two different config files,
_config.yml for local development,
_config-prod.yml for deployment:
jekyll s in terminal will compile all of your files to an
/APP directory, and set the site URL to your SharePoint domain.
jekyll s --config _config-prod.yml will, in addition, set the environment to
sharepoint, enabling us to add environment-specific ‘if’ statements, and, set the base URL to
/[SITE_NAME]/APP - which makes sure that all of the URL references in the webpages point to the correct folders inside our SharePoint site.
head of each HTML page which only runs for production…
This .js file automatically changes all
.html page links to
.aspx. This is important as SharePoint Online will only load .aspx files in the browser - we can’t have any links pointing to HTML pages.
As the script is only included if the environment is production we don’t need to worry about this interfering with development and we can continue to build our Jekyll site with either Markdown or HTML files as normal.
Changing your HTML pages to ASPX
As I mentioned, SharePoint Online will only read ASPX files in the browser, so after generating the Jekyll site, you will still needed to change all of the HTML files to ASPX format.
I did this with a simple Mac Automator Script, which changes the file extension - I run it before every deployment.
Upload files and set the Home Page in SharePoint Online 2013
I found SharePoint Designer 2013 (Windows only) to be the best connectioon/transfering method.
After download/install, you can add your SharePoint site and access the
/APP Library to upload all of your compiled Jekyll files from the
Once the files have uploaded, select the top level
index.aspx (or whichever file is your generated site’s homepage) and click ‘Set as Home Page’ from the ‘All Files’ tab.
This will produce the following redirection for all users:
And, all pages and links will load in the browser as all the HTML files or links have been changed to ASPX.