Blog https://i7media.com/weblog http://www.rssboard.org/rss-specification mojoPortal Blog Module en-US 120 no Ensuring Inbox Success Ensuring the emails our customers send are actually delivered to their recipients is one of our top priorities. We are always watching our email systems and evaluating ways to ensure our clients receive the absolute best email delivery rates possible.

Recently, two of the world's largest email providers, Google and Yahoo, announced they will soon require email senders to comply with more stringent email authentication policies—senders not in compliance with the new requirements will see issues getting their emails delivered in 2024.

The good news is that for the vast majority of i7MEDIA customers, there's nothing anyone needs to do to ensure emails are delivered to Google and Yahoo once these rules take effect. We've already been compliant with the rules for years. Additionally, we welcome these new requirements because we have tried to enforce them on emails being sent to our customers in the past but have not been able to because the "big guys" weren't doing it causing our customers to believe our systems weren't working properly. So, we're pretty excited about these changes as they will help us protect our customers Inboxes.

Google and Yahoo have good reason to change the rules for email senders

Properly authenticating emails has been a best practice for a long time, but most providers haven't bothered to ensure their services are using the tools available to protect their emails. That’s a major problem: If emails aren't properly authenticated, it is incredibly easy for bad actors to impersonate domains and to send phishing attacks—that will damage an entire domains sending reputation.

We are focused on protecting our users from spam and unwanted emails, but if other senders fail to properly secure their systems and leave their customers wide open to exploitation, that job is incredibly difficult. Gmail and Yahoo have finally decided that proper email authentication and following deliverability best practices are no longer a nice-to-have (THANK YOU!). To ensure our clients emails continue to make it to the inbox, we have to comply with key best practices for email authentication and spam prevention. That means:

  1. Authenticating your emails using DKIM, SPF, and DMARC.

  2. Reducing spam and maintaining a spam complaint rate under 0.3%.

  3. Allowing people to unsubscribe by clicking just one link, and honor unsubscribes within two days. 
    We handle this automatically for our customers on our "professional" email service plans.

  4. RFC 5322 compliance, PTR records, rDNS
    We have our customers covered here.

  5. Making sure your sending server IP addresses have valid reverse DNS records.
    We have our customers covered here.

  6. Use a TLS connection for transmitting email.
    We have supported opportunistic TLS for all outbound email since we first started hosting email, ensuring messages are encrypted in transit.

These changes benefit all of us

While these new requirements primarily target large bulk senders (many requirements will only apply to high-volume senders who send more than 5,000 emails a day). For smaller senders (most of our clients) sending mostly transactional email (not newsletters), there is less of a chance you're going to be impacted by the changes—but you can't ignore them.

We know from experience that these requirements will likely apply to all senders in the future. Besides, who would want to run their business in a "sort of compliant” and haphazard manner? 

So, whether our clients send just a few emails a day or a few million an hour, protecting their domains, avoiding spam, and following deliverability standards is top priority for us to keep our clients safe and their email delivered reliably.

What our clients can expect

For most of our clients, you can just expect to have your email delivered as always. For some, you will hear from us asking you to create some DNS records (DKIM, DMARC, SPF) or give us temporary access so we can create these records. That's it. We'll handle the rest and that's not much because we've always done this for customers who host their DNS with us and we've always tried to get it done for those who do not.

If you have any trouble with your email or questions about this article and the new requirements, please contact us as we'd be very happy to help you out. If your email provider isn't responsive, hasn't bothered implementing these changes, or doesn't have U.S.-based support, those are all really good reasons to give us a shout


Joe Davis  ...]]>
https://i7media.com/blog/ensuring-inbox-success joe@i7media.net (Joe Davis) https://i7media.com/blog/ensuring-inbox-success https://i7media.com/blog/ensuring-inbox-success Mon, 13 Nov 2023 22:56:00 GMT
Horizon Engineering Website We are very proud to have created this beautiful new website for Horizon Engineering Associates! They have been a loyal i7MEDIA customer for over 10 years, and we happily continue to serve them with our managed hosting services and content management. Check it out! 


Joe Davis  ...]]>
https://i7media.com/projects/horizon-engineering-website joe@i7media.net (Joe Davis) https://i7media.com/projects/horizon-engineering-website https://i7media.com/projects/horizon-engineering-website Thu, 02 Jun 2022 16:49:00 GMT
Self-Evident Ministries When Self-Evident Ministries reached out to our company with the hopes of rebuilding and revamping their website, we were happy to help! We are very excited to have developed and designed this new site, using nopCommerce and mojoPortal, into a more interactive platform. Check it out!


  ...]]>
https://i7media.com/projects/self-evident-ministries () https://i7media.com/projects/self-evident-ministries https://i7media.com/projects/self-evident-ministries Thu, 26 May 2022 18:38:00 GMT
Wild Ginger Software, Inc. We were very pleased when Wild Ginger asked us to build them a custom integration of their existing licensing software and nopCommerce, while being even more pleased to continue supporting them with our managed premium hosting services. Check it out!


  ...]]>
https://i7media.com/projects/wild-ginger-software-inc () https://i7media.com/projects/wild-ginger-software-inc https://i7media.com/projects/wild-ginger-software-inc Tue, 24 May 2022 19:25:00 GMT
Grandma's Office Catering We are very proud to have created this new site for Grandma's Office Catering! With the use of nopCommerce, this new site is easier to manage and more user-friendly. We continue to support Grandma's Office Catering by providing them with our managed premium hosting services. Check it out!


  ...]]>
https://i7media.com/projects/grandmas-office-catering () https://i7media.com/projects/grandmas-office-catering https://i7media.com/projects/grandmas-office-catering Tue, 24 May 2022 19:11:00 GMT
i7MEDIA purchases mojoPortal $(document).ready(function() { $('[data-b64]').each(function() { var b64 = $(this).data('b64') oValue = window.atob(b64); $(this).attr('href', 'mailto:' + oValue).html(oValue); }); });
Media wishing to learn more about this event, please send all questions to  

FOR IMMEDIATE PUBLIC RELEASE:

i7MEDIA has purchased mojoPortal and all of its commercial modules

Kearney, Mo (Feb 6,  2017) - It is an exciting day for the mojoPortal project! i7MEDIA, a longtime supporter of the mojoPortal project, has completed the purchase of the open source project and the commercial modules available on the mojoPortal website from Source Tree Solutions.

Joe Davis, i7MEDIA President, has been strong supporter of mojoPortal since 2008. Joe built his business around this versatile and user-friendly content management system. i7MEDIA, is dedicated to furthering the development of mojoPortal and its tools.

Rest assured mojoPortal will remain an open source project and there are no plans to change that. However, I7MEDIA has plans for expanding mojoPortal to help it stay relevant and provide the very best .NET CMS platform on the market today. 

Joe Audette, of Source Tree Solutions, is very enthusiastic about the new life of mojoPortal:

Joe Davis and i7MEDIA have always been the most qualified consultants for mojoPortal other than myself, and I've always had great confidence in referring customers and projects to them over the years.  Joe Davis has been a good friend and has been my go to guy when I needed to refer a customer or project that I did not have the capacity for. Whether you need design help, hosting, or custom feature development, i7MEDIA is the team you want with years of experience. mojoPortal was my baby for over a decade, and I am very glad to know my baby is in good hands! Long live mojoPortal! Joe Audette, mojoPortal Founder

mojoPortal has always been easy for users to add and manage their content. Over the past few years, though, it has fallen behind other systems which have taken more modern approaches to management and more fully utilized the capabilities of modern browsers. i7MEDIA has developed add-on features for mojoPortal which make content management easier and they are working on packaging these features for the masses to use.

Development of add-ons for mojoPortal isn't necessarily hard but there is a bit of a learning curve and quite a few steps one must take to prepare a working development environment. The focus will be on cutting down on the number of steps and making the process easier overall. They will also explore possible MVC and WebApi implementations of some features, especially administration features like the File Manager. 

It has always been possible to create beautiful sites with mojoPortal but the built-in skins were not good examples. i7MEDIA is working on providing newer skins to help showcase the power or mojoPotral.  i7MEDIA is committed to making sure that mojoPortal is seen as a designer-friendly CMS. 

A new version of mojoPortal is scheduled for release in the next couple of weeks with several small fixes, a few clean bootstrap-based skins and a brand-new file manager to replace both of the current file managers and the link and image picker used in the WYSIWYG editors. That's right, one file manager that does it all. 

For the latest news, check out mojoPortal’s Facebook and Twitter feeds.


Joe Davis  ...]]>
https://i7media.com/i7media-purchases-mojoportal joe@i7media.net (Joe Davis) https://i7media.com/i7media-purchases-mojoportal https://i7media.com/i7media-purchases-mojoportal Mon, 06 Feb 2017 14:56:00 GMT
Long Term Support for mojoPortal Update: i7MEDIA is now the owner of mojoPortal and is committed to its future success. Read more

As you may know, Joe Audette, founder and chief developer of mojoPortal, has announced that he will no longer be developing mojoPortal.

In the 7+ years I have known Joe and worked with mojoPortal, i7MEDIA has become the most trusted and experienced mojoPortal consultancy in the world. We have happy clients on every continent except Antarctica ranging in size from small start-ups to major international corporations and organizations. We've built and helped others build hundreds of mojoPortal sites. Most of our projects involving mojoPortal are still operational and we're adding more even as I'm writing this post.

Technology moves fast and that's a good thing, but sometimes it can move at a pace which can cause businesses to lose money if they're not careful. Whether a small company spends a few thousand dollars to build a nice website and customer portal or a large one spends several thousand dollars, scrapping what they have and building new just because there's a new technology (or even not new but more popular) doesn't make business sense.

We have a lot of clients who are using perfectly good and reliable WebForms systems like mojoPortal. We take a great deal of pride in the support we provide to our clients so we will be supporting and even providing enhancements to mojoPortal until we don't have any clients needing it anymore. After speaking with several of our clients over the past couple of months I can tell you, definitively, that we'll be supporting mojoPortal for quite a long while and that's fine by me and my team of mojoPortal experts.

So, if you're using mojoPortal already and you are looking for support, we will help you. If you're considering using mojoPortal because of its rich feature set, we will help you. Contact us today so we can help you!


Joe Davis  ...]]>
https://i7media.com/long-term-support-for-mojoportal joe@i7media.net (Joe Davis) https://i7media.com/long-term-support-for-mojoportal https://i7media.com/long-term-support-for-mojoportal Fri, 20 Nov 2015 15:12:00 GMT
Ultimate mojoPortal Upgrade Guide Due to its structure, upgrading mojoPortal is quite simple. The short story is you backup your site and database, download the new version, copy the files to your server, open the setup page and you're done. There are a few areas where one might start over thinking the process and make it harder than it really is so we decided we would write this guide to help quell the desire to make it difficult.

THE GREAT BIG WARNING: If you do not backup your website and its database you are asking for trouble. While we have never had an upgrade break a site, it could happen and having a backup is the only way to insure yourself against it.

The Canon

The process for upgrading mojoPortal is no different if you are upgrading from a really old version or a relatively new version. mojoPortal doesn't have "minor" updates or "major" upgrades. The terms update and upgrade can be used interchangeably when referring to mojoPortal. Version numbers don't mean much, version 2.4.0.0 didn't necessarily contain any more new features or bug fixes than 2.3.7.2. The version numbers increase by 0.0.0.1 each time a database change or a set of database changes is needed. There are never "upgrade" or "update" packages released by mojoPortal. All releases packages contain a full installation which if copied to an existing site will upgrade the site. If you do not backup your site and database before upgrading, you are not being responsible.

Process Overview

  1. Take the Site Offline
  2. Backup the Site Files and Database
  3. Prepare the web.config File
  4. Copy New Files to the Site
  5. Bring the Site Online
  6. Run the Setup Page
  7. Make Skin Changes if Needed

Take the Site Offline

You want to do this prior to backing up the site because once the site is offline, no one can make any changes to it. If you were to backup the site before taking it offline, someone could make a change which is not backed up.

To take the site offline, add an "App_Offline.htm" file to the root of the site. The root of the site is the same location where the web.config file resides. You can download an example App_Offline.htm here.

Backing up

There are many, many ways to backup files and databases. We will cover two methods for backing up files and two methods for backing up databases (one for MSSQL and one for MySQL).

Backing up Files When You Have Access to the Server's Desktop

Use this method if you have access to the servers desktop. If you don't have access to the servers desktop, use the FTP method.

In general, you will want to browse to the location of your site files. If you do not know what this is, you should contact your server admin or, if you are familiar with IIS, check the physical path for the site in IIS. Once you have located the site files, select all of them and create a zip file of them. We use 7-Zip but you can use whatever you like.

Backing up Files with FTP

Download a good FTP client which provides verbose logging and an easy way to retry operations which may have failed. We use FileZilla and recommend it above any other FTP client.

Open your FTP client and connect to your server. Download all of the files in your site to a directory on your computer. Check the FTP Client's log for any failures and re-download any files which did not download properly.

Backing up MSSQL Database in SQL Server Management Studio

Use this method if you have access to the database using SQL Server Management Studio (SSMS). Some hosting providers provide this access but the more security minded hosting providers (like i7MEDIA) do not. If you cannot access the database with SSMS, use your hosting providers control panel tools to back up your database. If you are an i7MEDIA customer, follow the instructions in our "Backing up and Restoring SQL Server Databases" knowledge base article.

Create the Backup

  1. Open SSMS and connect to the database server hosting the database.
  2. Right-click the database in the Object Explorer of SSMS and then select Tasks > Back Up. For further instructions, read the "Create a Full Database Backup" article on the MSDN website.

Backing up MySQL Database using MySQL Workbench

Use this method if you have access to the database using MySQL Workbench. Some hosting providers provide this access but the more security minded hosting providers (like i7MEDIA) do not. If you cannot access the database with MySQL Workbench, use your hosting providers control panel tools to back up your database. Many hosting providers do provide access to a tool called PHPMyAdmin which you can use to back up your database as well. If you are an i7MEDIA customer, follow the instructions in our "Backing up and Restoring MySQL Server Databases" knowledgebase article.

Create the Backup

  1. Open MySQL Workbench and connect to the database server hosting the database.
  2. Select "Data Export" under "Management" in the Navigator.
  3. Select the database in the "Object Selection" panel.
  4. Select your desired options in the Options section and click the "Start Export" button. Note: do not select the "Skip table data" option because you will not end up with any of your site data if you do select this option.

Prepare the web.config File

You should use the web.config file which comes with the mojoPortal release. This cannot be stressed enough because trying to compare every line of your old web.config file and the new one will take a long time and you may miss something. Nearly all of the settings you might change should be done in the user.config file anyway so you shouldn't have many changes to the web.config file in the first place. A few exceptions to this rule are listed below:

machineKey
The machineKey is used for encryption and decryption of authentication cookie data and view-state data. In mojoPortal it is also used for encryption and decryption of stored passwords if the Password Storage option is set to "Encrypted." You should copy this from your previous web.config file to the new web.config file. Read our "Separating Sections From the mojoPortal web.config File" article if you have a lot of sites and don't want to modify the new web.config for each of them.
Keys Related to Large File Uploads
The httpRuntime and requestFiltering elements in the web.config help with the support of large file uploads. If you have made changes to these elements, you will need to copy those changes to the new web.config file. Read the Supporting Large File Uploads article in the mojoPortal documentation for more information on this topic.
Keys Related to Error Pages
The configuration of custom and http error pages for a website hosted in IIS is saved in the web.config file. If you have changed these settings from the default values, you'll need to copy them over to the new web.config file. The customErrors element contains the settings for handling .net related errors and the httpErrors element contains the settings for handling http errors (e.g., 404). Tip: take a look at our article "Pretifying the mojoPortal Error Page" for information on how to modify the .net error page.

If you have several items which cannot go in the user.config file, you should keep them saved in some kind of notes file with the site. For best security, save your notes file with a .config extension to prevent it from being download via the web.

Note: this is an upgrade, not a new install so you should not copy create a new user.config file.

Copy New Files to the Site

If you have access to the servers desktop you can simply copy the files from the release (with changes made to the web.config) to the location of your site files in the order listed below. When prompted to with the option merge existing folders or not, select "yes." When prompted to "Copy and Replace" for existing files or "Don't copy," check the "Do this for all conflicts" checkbox and then click the "Copy and Replace" option.

If you are accessing the site with FTP, again be sure you are using a good FTP client. Using the FTP client, upload all of the files in the order listed below. When prompted to overwrite existing files, choose whichever option overwrites the existing files.

Order to Copy or Upload New Files/Folders

  1. Setup folder
  2. ClientScript folder
  3. Data folder
  4. All other files and folders

Bring the Site Online

The site was taken offline by adding the App_Offline.htm file to the root of the site. To bring the site back online, all you need to do is rename or move the file. We generally customize our App_Offline.htm files with customer logos so we simply rename the file to App_Offline.config instead of moving it elsewhere.

Run the Setup Page

The setup page runs all of the database scripts for all of the features which have database changes. It also processes all of the feature configuration files which control what settings you see on the settings page for module instances.

To run the setup page, open a web browser and go to http://www.yourwebsite.url/Setup/Default.aspx. Once all of the scripts run, you will see a summary at the bottom of the page along with a link to the site.

If you see any errors, you will need to address them. Generally, you shouldn't see any errors but we have compiled a short list of the most common errors.

Setup is disabled. To continue, please set DisableSetup to false in Web.config.
This is showing up because the DisableSetup key in the web.config or user.config file has been set to true. If you were logged in to the site prior to upgrading, you will not see this error. To get around this, open the user.config file and change the setting to false. Next, open the web.config file and add a space to the bottom of the file. Finally, reload the setup page.
The system cannot connect to the MSSQL database. Please check your connection string.
The Connection String key in the user.config file is not correct. This error is always accompanied by more detailed information to help you troubleshoot the problem. If the database server can be accessed, it will state something to the effect of "...error occurred while establishing a connection..." If the database name, username or password is incorrect, it will state something to the effect of "the login failed."

Make Skin Changes if Needed

The skins in the mojoPortal release packages are not copied over the skins used by sites (located in \Data\Sites\[sitenum]\skins). The skins located \Data\Skins are updated or appended with the updated or new files from the release package. If you are using a skin which came with mojoPortal and have not modified it, you can copy it from \Data\Skins to \Data\Sites\[sitenum]\skins.

If you are using a custom skin or you have modified a packaged skin, you should check the "Important Skin Changes" article in the mojoPortal Documentation for details on any changes you need to make to your skin to support the new release. You will want to check the details of every version between your old version and the new version you are installing. This is rather easy as the changes are listed in descending order in the article and there aren't very many.

Summary

See, it's rather simple. You don't need to worry about database scripts, different methods for minor or major versions, lots of file merging or anything like that. Really, all you need to do is create a backup and copy over the new files.

If you run into problems, check out the mojoPortal Forums. Do a search for your issue before posting because someone else may have already reported the problem and resolution has been provided by the community.

Want someone else to do it?

If you would rather have someone else handle upgrades for you, check out our Upgrade Service.

Want to learn more about mojoPortal?

If you enjoyed this guide and would like to learn more about mojoPortal, check out our Training Classes.


Joe Davis  ...]]>
https://i7media.com/ultimate-mojoportal-upgrade-guide joe@i7media.net (Joe Davis) https://i7media.com/ultimate-mojoportal-upgrade-guide https://i7media.com/ultimate-mojoportal-upgrade-guide Fri, 06 Dec 2013 00:00:00 GMT
Prettifying the mojoPortal Error Page When encountering an error on a mojoPortal site, the error.htm file is display which is a very plain page simply stating that something went wrong.

Now, it gets the job done but it's kinda plain so we revamped it on our site:

Is it better? Well, it's still an error message but at least it has some character. :-)

It's actually quite simple to accomplish as well:

  1. Create a new file in the root of your site, we'll call it Oops.htm.
  2. Add the following to it:
<!DOCTYPE HTML>
<html>
	<head>
		<title>Error</title>
		<link href='https://i7media.com//fonts.googleapis.com/css?family=Architects+Daughter' rel='stylesheet' type='text/css'>
		<style>
			html,
			body {
				width: 100%;
				height: 100%;
			}
			
			body {
				background: #f2f5f6; /* Old browsers */
				background: url();
				background: -webkit-gradient(radial, center center, 0px, center center, 100%, color-stop(0%,#f2f5f6), color-stop(37%,#e3eaed), color-stop(100%,#c8d7dc)); /* Chrome,Safari4+ */
				background: -webkit-radial-gradient(center, ellipse cover,  #f2f5f6 0%,#e3eaed 37%,#c8d7dc 100%); /* Chrome10+,Safari5.1+ */
				background:    -moz-radial-gradient(center, ellipse cover,  #f2f5f6 0%, #e3eaed 37%, #c8d7dc 100%); /* FF3.6+ */
				background:		-ms-radial-gradient(center, ellipse cover,  #f2f5f6 0%,#e3eaed 37%,#c8d7dc 100%); /* IE10+ */
				background:		 -o-radial-gradient(center, ellipse cover,  #f2f5f6 0%,#e3eaed 37%,#c8d7dc 100%); /* Opera 12+ */
				background: 		radial-gradient(ellipse at center,  #f2f5f6 0%,#e3eaed 37%,#c8d7dc 100%); /* W3C */
				display: table;
			}

			div.wrap {
				display: table-cell;
				vertical-align: middle;
			}
			
			div.inner {
				margin: 0 auto;
				width: 50%;
			}

			h1 {
				font-size: 40px;
				font-family: 'Architects Daughter', cursive;
				margin-top: 0;
				text-align: center;
			}

			p {
				font-size: large;
				font-family: Arial, Helvetica, sans-serif;
			}
		</style>
	</head>
	<body>
		<div class="wrap">
			<div class="inner">
				<h1>
					Ouch! That Hurt!
				</h1>
				<p>
					So sorry for the inconvenience but an error has occurred while trying to process your request.
				</p>
				<p>
					The error has been logged and will be reviewed by our staff as soon as possible. It's possible the error was a momentary hiccup and you may wish to use the back button to try your request again, or you can to the <a href="default.aspx">home page</a>.
				</p>
			</div>
		</div>
	</body>
</html>
  1. Open your web.config file and locate the line which looks like this:
    <customErrors mode="RemoteOnly" defaultRedirect="Error.htm">
  2. Replace Error.htm with Oops.htm
  3. Save your web.config file.

Don't forget to make this change to your web.config each time you upgrade mojoPortal.

Happy mojo-ing!


Joe Davis  ...]]>
https://i7media.com/prettifying-the-mojoportal-error-page joe@i7media.net (Joe Davis) https://i7media.com/prettifying-the-mojoportal-error-page https://i7media.com/prettifying-the-mojoportal-error-page Fri, 28 Jun 2013 19:36:00 GMT
jQuery UI + mojoPortal = happiness What is jQuery UI?

jQuery is a JavaScript library, mostly used for expediting script writing. jQuery UI is a user interface built with jQuery. In the words of jQueryUI.com:

jQuery UI is a curated set of user interface interactions, effects, widgets, and themes built on top of the jQuery JavaScript Library. Whether you're building highly interactive web applications or you just need to add a date picker to a form control, jQuery UI is the perfect choice.

Now you might think "hey, that sounds nice!", and "how do I use it on my website?". You can find instructions on how to use jQuery UI on their website, here.

But, lucky for those of us using mojoPortal, jQuery is already built in — and so is jQuery UI. This post will explain how to use it with mojoPortal.

Creation

The first thing you need before you can integrate a new UI style into mojoPortal, is a new UI style. I highly suggest using the jQuery UI Themeroller, as it is much easier than manually changing the CSS and images for an old UI theme.

Before you start, you might find it helpful to click the "gallery" tab on the left and look through the native themes to see if they have something a little closer to what you want. Once you've found one that you like, click the "edit" button under it in the gallery, and you're ready to begin making changes.

When I do this, I usually go to my mojoPortal site design and use a color-picker to pick out the primary colors from the skin, then add them to my UI theme until it matches the skin pretty well. Hint: The parts of mojoPortal that use the UI tend to use it very heavily, so you'll want to go easy on the bright colors.

Once you have the theme the way you like it, click the "download theme" button. This will bring you to a page that lets you pick what UI features you need. You can disable these as you like, but if you don't care about the file size just leave it all on the defaults and scroll to the bottom of the page, where you can name your theme and then click download again.

Encouragement

The next part can be a little confusing the first time you do it (which is why I wrote instructions), but after you get through it once you'll realize it's actually quite easy. Working for i7MEDIA, I do it on a regular basis and now the whole process only takes me 5 minutes.

I've written detailed instructions below, if you follow them it shouldn't take you too long either. Have fun!

Installation

Once you've gotten your theme downloaded, you'll need to extract the zip file into some folder on your computer. Next, navigate within that folder to the "css" folder, and then to the folder named whatever you named the theme (default is "custom-theme"). Now just follow these instructions:

  1. Inside of the "custom-theme" folder, there are two css files and a folder.
  2. Before putting them in your skin, you'll want to rename "jquery-ui-#.#.#.custom.css" to "style-jquery.css", and rename the "images" folder to "jquery-images".
  3. Copy the renamed images folder and css file into your skin.
  4. Open the "style.config" file within your skin and add a line that corresponds with the name of the new file.
    In example: <file>style-jquery.css</file> — where "style-jquery.css" is the name of the css file you copied from the folder.
  5. Now there's some slight editing you need to do within the jquery css file. Open it and do a "find-and-replace" (usually ctrl+f or ctrl+h) for the following keys:
    • Find: (images/ — Replace with: ('jquery-images/ [1].
    • Find: .png) — Replace with: .png') [2].
    • Find: (opacity — Replace with: ('opacity.
  6. Now for the next one, you can't automate the find and replace because the numbers at the end of the "opacity" rule are always different. You'll need to look for any rules like this: filter:Alpha('Opacity=#), and replace them with this: filter:Alpha('Opacity=#') — The only difference being the new apostrophe before the last parenthesis.
  7. Next, open your "layout.master" file, and search for: <portal:StyleSheetCombiner. Once you've found it, check for the following key inside of it: IncludeJQueryUI="false". If this is set for "false", you'll be okay — if it is "true", change it to "false".

Hopefully, now your new UI theme works. However, if you have a really old version of mojoPortal, or are using a really old skin, you might need to read the next section, too.

Changing mojoPortal's native jQuery version

As of this writing, the latest version of jQuery UI is 1.9.2. The latest version of mojoPortal (2.3.9.4) ships with UI version 1.9.0 — as you can imagine, this could be a problem.

Usually, your particular skin will be configured to use the version of the UI that its theme was built to use when it was created. However, if you try to upload a new UI theme as per the instructions above, but find that it is not displaying properly or certain features of the UI are buggy/broken, you might need to force the mojoPortal installation you have to use a new version of the UI.

To do this, simply follow these instructions:

  1. Open the layout.master file in your skin.
  2. Search for the following line: <portal:ScriptLoader.
  3. Make sure that the ScriptLoader has the following key: AssumejQueryUiIsLoaded="true"
  4. Once that's done, add the following line somewhere under the ScriptLoader:
    <script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.9.2/jquery-ui.min.js" type="text/javascript"></script> - [3]
  5. The numbers in that link can be changed from "1.9.2", to whatever is the latest version of jQuery UI. You can find what the latest version is and easily find the google CDN link at the bottom of this page, under "quick access".

You might also find this article helpful: http://www.mojoportal.com/self-hosting-jquery-jquery-ui-files

Help

If you've read this article, followed the instructions, and ripped out your hair trying to figure out why something is still broken… Well, you might need a psychiatrist — but you can also just try asking us for help in the comments section below!

 

[1] In this case, "jquery-images" is the name of the "images" folder that you renamed before putting it in your skin.
[2] The apostrophes are necessary to stop the StyleSheetCombiner from failing to combine the CSS properly.
[3] If your site has SSL, or if you just prefer not to call the script this way, you can call call it via the web.config.


Isaac Hall  ...]]>
https://i7media.com/jquery-ui-mojoportal-happiness isaac@i7media.net (Isaac Hall) https://i7media.com/jquery-ui-mojoportal-happiness https://i7media.com/jquery-ui-mojoportal-happiness Fri, 14 Dec 2012 18:46:00 GMT
Mocha Released Announcing the release of Mocha v1

Earlier this year we released a free skin called SwiftBlue. Now we're happy to announce that we've just released another HTML5 mojoPortal skin called Mocha. Mocha is SwiftBlue's Sister skin, and more are to come. It was designed as a contribution to the mojoPortal community and the html5mojo project. Like SwiftBlue, Mocha was created with semantics-friendly HTML5 Markup.

Check out the live demo website to see what your mojoPortal website could look like today!

Mocha Screenshot
Mocha is an HTML5 mojoPortal skin which was designed by i7MEDIA.

Features

As with all i7MEDIA Skins, Mocha has detailed style for every feature found in mojoPortal, most notably for the Event Calendar, Event Calendar Pro, Blog, Forums, Feed manager, and jPlayer Media Players.

Other features include:

  • Mocha includes support for a few basic content templates, including a fancy content slider. Making use of these templates will help you to create easy and professional content formats, so that you can spend less time worrying about layout and more time perfecting the content that your viewers came to see.
  • We've created a custom design for the dedicated Sign in and Register pages on Mocha. This way it is easier for your users to interact with the site, without having to sort through other page content.
  • Mocha utilizes a fancy User Bar based on Twitter Bootstrap. The bar includes a lot of features, links to mojoPortal, member profiles, and the ability for administrators to toggle the settings and edit links - this way you can see your site the way your users do. But mostly it's just beautiful.
  • HTML5 is an important new language that is of high interest to website owners, this is because of the implications for SEO, among other things. Mocha is HTML5 Friendly. Not sure what this means? We explain more on the live demo site.

Support

The Mocha help center is built to ensure that your time working with Mocha is successful.
The skin help center covers topics like:

  • Installation of Mocha
  • A basic introduction to CSS Classes and how they effect you in mojoPortal
  • An explanation of how to use the Mocha Content Templates
  • A FAQ to answer common questions about Mocha
  • A form so that you can request help, and get answers to questions that weren't answered on the FAQ.
  • Another form so that you can report any bugs you find. This is important because we'll be trying to keep the skin up to date. We feel that getting input from the users of the skin is the best way to make sure the skin is maintained well over the course of mojoPortal updates.

Check out the Mocha Skin-Help center now.

Mocha and SwiftBlue are just another way you can make your mojoPortal site shine with a little help from i7MEDIA. Keep your eyes out, we'll be releasing more free skins soon!
Interested? Check out the Mocha live demo site


Isaac Hall  ...]]>
https://i7media.com/mocha-released isaac@i7media.net (Isaac Hall) https://i7media.com/mocha-released https://i7media.com/mocha-released Wed, 24 Oct 2012 16:01:00 GMT
Styling the mojoPortal HTML SlideShow Pager Back in March of 2011 we added the "Pager" option to the Slide Show feature of the mojoPortal HTML Module. Since that time, we've seen some requests for styling the pager links so here's a simple style we use on this site. It can be adapted to any design and doesn't use any images. To use this CSS, just copy it to one of your skin's .css files and then apply the "prettycyclenav" class to the "Custom CSS Class" option in the HTML module settings. If you want the slide number to be shown within the navigation, add the "withnumbers" class to the "Custom CSS Class" option.

.prettycyclenav .cyclenav {
	margin: 5px 0;
	text-align: center;
}
	
.prettycyclenav .cyclenav a {
	text-indent: -9999px;
	line-height: 40px;
	background-color: #A5A5A5;
	width: 14px;
	height: 14px;
	overflow: hidden;
	display: inline-block;
	margin: 0 5px;
	text-decoration: none;
}
	
.prettycyclenav.withnumbers .cyclenav a {
	padding: 3px;
	font: 14px/1 'Rationale', Charcoal, serif;
	text-indent: 0;
	color: #fff;
}
	
.prettycyclenav .cyclenav a:focus,
.prettycyclenav .cyclenav a.activeSlide {
	background-color: #e26917;
}	

.prettycyclenav .cyclenav a:hover {
	background: #636363;
}

Joe Davis  ...]]>
https://i7media.com/styling-the-mojoportal-html-slideshow-pager joe@i7media.net (Joe Davis) https://i7media.com/styling-the-mojoportal-html-slideshow-pager https://i7media.com/styling-the-mojoportal-html-slideshow-pager Mon, 24 Sep 2012 17:17:00 GMT
SwiftBlue v1 Released Announcing the release of SwiftBlue v1

SwiftBlue is the first in a series of template skins developed by i7MEDIA for mojoPortal. It was designed as a contribution to the mojoPortal community and the html5mojo project. SwiftBlue has been created with semantics-friendly HTML5 Markup.

Check out the live demo website to see what your mojoPortal website could look like today!

SwiftBlue is an HTML5 mojoPortal skin which was designed by i7MEDIA.

Features

As with all i7MEDIA Skins, SwiftBlue has detailed style for every feature found in mojoPortal, most notably for the Event Calendar, Event Calendar Pro, Blog, Forums, Feed manager, and jPlayer Media Players.

Other features include:

  • Support for a number of content templates is included in SwiftBlue. Using these templates makes it easy to make your data appear on the page in a nice professional format. It doesn't cover everything, but it will help you with the basics so you can spend more time perfecting your content and less time worrying about basic layout.
  • SwiftBlue is HTML5 friendly. Not sure what this means? We explain more on the live demo site.
  • Custom styled dedicated Sign in and Register pages, this way potential users don't have to sort through the regular page content to find what they need to interact with the site.
  • A fancy User Bar based on Twitter Bootstrap. The bar includes a lot of features, links to mojoPortal, member profiles, and the ability for administrators to toggle the settings and edit links - this way you can see your site the way your users do. But mostly it's just beautiful.

Support

The SwiftBlue help center is built to ensure that your time working with SwiftBlue is successful.
The skin help center covers topics like:

  • Installation of SwiftBlue
  • A basic introduction to CSS Classes and how they effect you in mojoPortal
  • An explanation of how to use the SwiftBlue Content Templates
  • A FAQ to answer common questions about SwiftBlue

And if that's not enough, we've set up an easy way for you to request help or report a bug. Check out the SwiftBlue Skin-Help center now.

SwiftBlue is just another way you can make your mojoPortal site shine with a little help from i7MEDIA.
Interested? Check out the SwiftBlue live demo site


Joe Davis  ...]]>
https://i7media.com/swiftblue-v1-released joe@i7media.net (Joe Davis) https://i7media.com/swiftblue-v1-released https://i7media.com/swiftblue-v1-released Wed, 15 Aug 2012 14:26:00 GMT
Hide Module Settings and Edit Links One of the things that most of our users like the most about mojoPortal is the easy access they have to module settings and edit screens. Sometimes, people ask if they can hide these links (or icons if the skin uses those) while remaining logged into the site.

Well, here's an extremely easy way to hide the links without sacrificing the usability of mojoPortal. This solution is completely skin based so it doesn't require any additions to the mojoPortal core.

First, we add the following to our skin script (see "Optimize Your mojoPortal Skin Scripts" for more info):

function HideEditLinks() {
	$(".modulelinks").hide();
	$(".ModuleEditLink").hide();
}

function ShowEditLinks() {
	$(".modulelinks").show();
	$(".ModuleEditLink").show();
}

$(document).ready(function() {
	var editLinksState = Get_Cookie('editLinksState');
	if (editLinksState != null) {
		if (editLinksState == 'hidden') {
			HideEditLinks();
		}
		if (editLinksState == 'visible') {
			ShowEditLinks();
		}
	}

	$("a#togglemodulelinks").click(function() {
		editLinksState = Get_Cookie('editLinksState');
		if (editLinksState == null || editLinksState == 'visible') {
			HideEditLinks();
			Set_Cookie('editLinksState', 'hidden')
		} else if (editLinksState == 'hidden') {
			ShowEditLinks();
			Set_Cookie('editLinksState', 'visible')
		}
	});
});

Second, we add the following inside the AutoHidePanel in the layout.master:

<a href="#" rel="nofollow" id="togglemodulelinks">Toggle Edit Links</a>

The code above simply hides the links if they're shown and displays them if they're hidden.

Placement of the "Toggle Edit Links" link can be done with CSS but it should definitely be inside of the AutoHidePanel. The AutoHidePanel will ensure that the link isn't shown unless one of the Admin Toolbar items is shown. You could add another AutoHidePanel to the layout.master but there's no point in increasing page load if you don't have to.

Happy mojo-ing!


Joe Davis  ...]]>
https://i7media.com/hide-module-settings-and-edit-links joe@i7media.net (Joe Davis) https://i7media.com/hide-module-settings-and-edit-links https://i7media.com/hide-module-settings-and-edit-links Mon, 11 Jun 2012 03:03:00 GMT
Link mojoPortal Welcome Message to User's Profile The mojoPortal Welcome Message control can be configured to link to the logged-in user's profile. This is useful if you want to have a message like "Signed In As: USER NAME" and have USER NAME link to the user's profile settings.

Here's the code for it:

<portal:WelcomeMessage id="WelcomeMessage" runat="server"
	CssClass="greetinglink"
	RenderAsListItem="true"
	OverrideFormat="Welcome, <a id='lnkMyAccount' href='https://i7media.com/Secure/UserProfile.aspx' title='Manage your User Account'>{0}</a>" />

The {0} is where the user name will be placed.

And that's that. Happy mojo-ing!


Joe Davis  ...]]>
https://i7media.com/link-mojoportal-welcome-message-to-users-profile joe@i7media.net (Joe Davis) https://i7media.com/link-mojoportal-welcome-message-to-users-profile https://i7media.com/link-mojoportal-welcome-message-to-users-profile Tue, 05 Jun 2012 02:01:00 GMT
Optimize your mojoPortal Skin Scripts Almost every single skin we develop uses a couple JavaScript scripts, but even the addition of one script can slow the speed of a website. We use a fairly simple process to combine as many of our scripts into one file and then using a neat mojoPortal control, we add that script the combined site script. The combined site script contains most of the scripts mojoPortal uses for things like site cookies, ASP.NET CSS friendly adapters, etc… This process will result in fewer files being delivered to the browser, thus improving performance (somewhat).

Create the Skin Script and call it from the layout.master

  1. Create a new js file in your skin directory, I usually name it skinscript.js.
  2. Add your javascript to the new file. Don't use <script> tags, you don't need them in javascript files.
  3. Add the following to your layout.master. I usually add this right after the <asp:ScriptManager control.
    <portal:SkinFolderScript ID="sfs1" runat="server" ScriptFileName="skinscript.js" AddToCombinedScript="true" />

Copy all the scripts from your layout.master to the Skin Script

This is the part that can be a little bit tricky because not all scripts are going to work properly when combined with other scripts. If you copy the scripts to your new file one at a time and test the result, you'll find those pesky ones that will not cooperate. Just leave them in the layout.master, or if you're feeling froggy, rewrite them so they can be combined.

A note about SuperFish

Most of our skins use a SuperFish menu but the scripts for the SuperFishmenu come in two parts. One is the static script that is in the ClientScript directory which contains all of the SuperFish magic. The other is an initialization script that is loaded in the layout.master of the skin. Typically, these are loaded by adding the layout.master a <portal:SiteScript control to load the main SuperFish script and then a <script> element with a bit of jQuery to initialize the SuperFish menu. We decided to use the jQuery .getScript() method to load the main script from our Skin Script. Using this method allows us to initialize the SuperFish menu only if the main script is loaded properly.

A Sample Skin Script

The script below is what we use for starting our skin scripts. It includes the JavaScript for the Administration Toolbar Menu, SuperFish Menu and a neat bit of jQuery that will give the "Add File" button in the Shared Files module a hover state. The script is written out long-form so you can easily see what it does. I suggest that you minify the script before using it in production.

//  ========== 
//  = This file stores all of the scripts that would normally be placed inside the layout.master
//  = Use the following syntax for referencing this script from the layout.master.
//  = 
//  ==========

/*Standard JavaScript */

function HideMenuToolbar() {
	$("#toolbar").fadeOut();
	$("#toolbarbut").fadeIn("slow");
}

function ShowMenuToolbar() {
	$("#toolbar").fadeIn();
	$("#toolbarbut").fadeOut("slow");
}


/* jQuery Scripts */
$(document).ready(function() {

	/* Admin Toolbar */
	$("span.downarr a").click(function() {
		HideMenuToolbar();
		Set_Cookie('openstate', 'closed')
	});
	$("span.showbar a").click(function() {
		ShowMenuToolbar();
		Set_Cookie('openstate', 'open')
	});
	$("span.downarr a, span.showbar a").click(function() {
		return false;
	});
	var openState = Get_Cookie('openstate');
	if (openState != null) {
		if (openState == 'closed') {
			HideMenuToolbar();
		}
		if (openState == 'open') {
			ShowMenuToolbar();
		}
	}

	/* Superfish Menu */
	/* Get Superfish mojoPortal Script */
	$.getScript("/ClientScript/jqmojo/mojosuperfish.js", function() {
		$("ul.sf-menu").supersubs({
			minWidth: 1,
			maxWidth: 27,
			extraWidth: .2
		}).superfish({
			pathClass: 'current',
			pathLevels: 0,
			delay: 500,
			animation: {
				opacity: 'show',
				height: 'show'
			},
			speed: 200,
			dropShadows: false,
			autoArrows: true
		});
	});
	/* This will make the Shared Files "Add File" button have a hover state */
	$("div.uploadpanel > div > input + div + div").hover(
		function() {
			$("div.uploadpanel div .jqbutton").addClass("ui-state-hover")
		},
		function() {
			$("div.uploadpanel div .jqbutton").removeClass("ui-state-hover")
		});
});

Further Reading

If you're serious about optimizing the speed of your mojoPortal site, I highly suggest you read the "Improving Your YSlow or Page Speed Score" article in the mojoPortal Documentation.

Happy mojo-ing!


Joe Davis  ...]]>
https://i7media.com/optimize-your-mojoportal-skin-scripts joe@i7media.net (Joe Davis) https://i7media.com/optimize-your-mojoportal-skin-scripts https://i7media.com/optimize-your-mojoportal-skin-scripts Tue, 31 Jan 2012 16:37:00 GMT
Form Wizard Pro Templates Update 1/10/2012: Updated the download with a US State list question. All 50 states plus the District of Columbia are included.

Form Wizard Pro (FWP) is a great tool for creating ad-hoc style forms on the fly in mojoPortal. One feature that makes FWP so great is the ability to import and export Form Definitions and individual Questions.

Exporting a Question

Exporting a Question is very simple, just click the "Export Question" link next to the question in the "Edit Form" screen. The file will be named like "FWP-Instance-NameYYYYMMDDHHMMSS-q.config." This includes the name of the FWP instance, the exact date and time you clicked the export link, and a "-q" to let you know this file is a Question, not an entire form. You can of course change the name of the file without causing any problems for importing the question later.

Exporting a Form

Exporting an entire Form is also very simple, just click the "Export Form Definition" button at the bottom of the "Edit Form" screen. The file will be named like "FWP-Instance-NameYYYMMDDHHMMSS.config." This includes the name of the FWP instance and the exact date and time you clicked the export button. Again, changing the name doesn't harm anything.

 

Importing a Question or Form

Importing a Question is very straightforward. Simply click the "Browse" button and select a Question definition file from your computer and then click the "Import Question" button. You'll see the question added to the "Edit Form" screen.

You can import a Form Definition the same way you import a Question, except that you will want to select a Form definition file and click the "Import Form Definition" button. One very important thing to keep in mind is that importing a Form will erase all of the questions you already have on your form. Any data that has been submitted to the form will still be intact but the questions corresponding to the data will be gone so the data will be "orphaned" so you may not know what all of the responses mean.

Some Form Definitions For You

 

Happy mojo-ing!


Joe Davis  ...]]>
https://i7media.com/form-wizard-pro-templates joe@i7media.net (Joe Davis) https://i7media.com/form-wizard-pro-templates https://i7media.com/form-wizard-pro-templates Tue, 10 Jan 2012 14:46:00 GMT
Stand Against SOPA I don't usually write publicly about my political leanings but I feel that this topic needs as much attention as it can get. The "Stop Online Piracy Act (H.R. 3261)" or SOPA is a bill making it's way through congress which is supposed to help mitigate piracy of copyrighted material on the internet. While the overall concept is good, I take issue with the collateral damage SOPA will cause. If passed, SOPA will "reverse the protections of the Digital Millennium Copyright Act of 1998 (“DMCA”) by creating liability for Internet Service Providers (ISPs) to affirmatively block customer access to the web and specific websites claimed, but not adjudicated, to be pirating content."1

My attention was initially drawn to SOPA when I read an article on A List Apart by Jeffrey Zeldman titled "Say No to SOPA."2 Jeffrey lays out his opposition to SOPA in plain english and his article prompted me to do more research on the topic. I found that in addition to the list of organizations Jeffrey mentioned as being opposed to SOPA, the American Center for Law and Justice (ACLJ) is opposed to it as well. The ACLJ has prepared a legal analysis on SOPA which outlines the first amendment concerns with the legislation.

I highly suggest reading Jeffrey's article and the ACLJ's legal analysis. I've borrowed the following list of actions you can take to make your voice heard regarding the SOPA legislation from Jeffrey's article.

Act now!

American Censorship Day, one of several campaigns to stop SOPA, has come and gone, but you can still take action:

We urge everyone reading this to take action today. Only an overwhelming show of solidarity gives us a chance of defeating this poorly written, dangerous bill.

 

Citations:

  1. "First Amendment Concerns Posed by http://c0391070.cdn2.cloudfiles.rackspacecloud.com/pdf/first-amendment-concerns-posed-sopa.pdf SOPA" - American Center for Law and Justice, November 28, 2011 (http://c0391070.cdn2.cloudfiles.rackspacecloud.com/pdf/first-amendment-concerns-posed-sopa.pdf)
  2. "Say No to SOPA" - A List Apart, Jeffrey Zelman, November 29, 2011 (http://www.alistapart.com/articles/say-no-to-sopa)

Joe Davis  ...]]>
https://i7media.com/stand-against-sopa joe@i7media.net (Joe Davis) https://i7media.com/stand-against-sopa https://i7media.com/stand-against-sopa Fri, 02 Dec 2011 14:33:00 GMT
Using the LoginView in mojoPortal Often times clients will want to display certain text for logged in users vs anonymous users. While this is possible using the settings on individual content modules, it is sometimes necessary to add this functionality to elements in the layout.master.

For introductory information on the LoginView control, please review the MSDN Documentation for it.

An example scenario is: The client wants to display a Login control on every page and when the user is logged in, some links should be present in place of the login control. A title should be present above the control with the text "Please Sign In: " for Anonymous Users and the text "Welcome Back" for Authenticated Users.

For this scenario, the solution would be to place a LoginView control in the layout.master with the mp:Login control and "Returning Visitors ..." title inside the AnonymousTemplate. The links and the "Welcome Back" title will be placed in the LoggedInTemplate. You may recognize that the Portal:WelcomeMessage control uses the OverrideFormat property as discussed in our Customizing mojoPortal's Welcome Message for Logged In Users article.

<asp:LoginView id="lv1" runat="server">
	<AnonymousTemplate>
		<h2 class="moduletitle">Please Sign In:</h2>
		<mp:Login ID="login1" runat="server" SetRedirectUrl="false" />
	</AnonymousTemplate>
	<LoggedInTemplate>
		<h2 class="moduletitle">
			<portal:WelcomeMessage id="WelcomeMessage1" runat="server" 
				RenderAsListItem="false" 
				OverrideFormat="Welcome Back {0}" 
				CssClass=" "
			/>
		</h2>
		<ul>
			<li><asp:HyperLink id="lnk1" runat="server" NavigateUrl="~/members-only-articles.aspx" Text="Articles"/></li>
			<li><asp:HyperLink id="lnk2" runat="server" NavigateUrl="~/members-only-downloads.aspx" Text="Downloads"/></li>
			<li><asp:HyperLink id="lnk3" runat="server" NavigateUrl="~/members-only-forums.aspx" Text="Forums"/></li>
			<portal:LogoutLink id="LogoutLink1" runat="server" RenderAsListItem="true" ListItemCSS=" " CssClass=" "/>
		</ul>
	</LoggedInTemplate>
</asp:LoginView>

The result can be something like this:

Anonymous

Anonymous LoginView

 

Authenticated

Authenticated LoginView

 

Happy mojo-ing!

 


Joe Davis  ...]]>
https://i7media.com/using-the-loginview-in-mojoportal joe@i7media.net (Joe Davis) https://i7media.com/using-the-loginview-in-mojoportal https://i7media.com/using-the-loginview-in-mojoportal Mon, 08 Aug 2011 21:57:00 GMT
Customizing mojoPortal's Welcome Message for Logged In Users Have you ever wanted to change the mojoPortal WelcomeMessage text to display something besides "Signed In As: Joe Davis"?

​Well, if you have mojoPortal 2.3.6.1 or higher, it is quite easy. You can override it in your skin's layout.master file by setting a property on <portal:WelcomeMessage like this:

OverrideFormat="My name is {0}", or if you only want the user name then you could put OverrideFormat="{0}"

The {0} is replaced by the user's display name.

I prefer OverrideFormat="Welcome Back, {0}" which displays "Welcome Back, Joe Davis" very nicely.

Hope this helps you out. If it did, please spread the word through Twitter or Facebook!

Happy mojo-ing,
Joe Davis


Joe Davis  ...]]>
https://i7media.com/customizing-mojoportals-welcome-message-for-logged-in-users joe@i7media.net (Joe Davis) https://i7media.com/customizing-mojoportals-welcome-message-for-logged-in-users https://i7media.com/customizing-mojoportals-welcome-message-for-logged-in-users Sat, 06 Aug 2011 17:13:00 GMT