Products

Solutions

Resources

Partners

Community

Blog

About

QA

Ideas Test

New Community Website

Ordinarily, you'd be at the right spot, but we've recently launched a brand new community website... For the community, by the community.

Yay... Take Me to the Community!

Welcome to the DNN Community Forums, your preferred source of online community support for all things related to DNN.
In order to participate you must be a registered DNNizen

HomeHomeArchived Discus...Archived Discus...Developing Under Previous Versions of .NETDeveloping Under Previous Versions of .NETASP.Net 2.0ASP.Net 2.0Complex Module Architecture ideasComplex Module Architecture ideas
Previous
 
Next
New Post
10/23/2007 3:23 PM
 

I read this page (http://www.adefwebserver.com/DotNetNukeHELP/Misc/ModuleNavigationOptions.htm), makes lots of sense but I wanted discuss my idea with the experts here to figure a way of going about it.

I manage an intranet web application built using ASP.Net 2.0 and MS AJAX. This web app utilizes about 35 different pages and 10 user controls with ASPNET membership built in 3-tiers; UI, BLL and DAL. The DAL uses the DataProvider model. The plan is to explore building a module for DNN for the intranet.

I played around with creating a simple view module to get an idea on how to create modules. I am still not clear on how to implement the design, file locations and folder structure for a complex module that utilizes so many user controls.

How would you navigate between the different pages (DNN User controls)?
How would you structure the files in the project? The way mentioned in the building module manual or can you use a separate class library or something? I noticed something of the sort in the Blogs module.

 
New Post
10/23/2007 8:47 PM
 

Here are a few (very general) thoughts on techniques that I like to use for a complex module or several interrelated modules:

1. If each module control shares a set of common methods and/or properties, I will create a base class that inherits from PortalModuleBase and which implements the common methods and/or properties. All module controls then derive from this base class.

2. By all means use one or more class libraries for the non-UI portions of the module controls, either separately compiled if using WAP or placed in a folder under App_Code if using WSP/dynamic compilation model.  If using the latter model, be absolutely certain that your Namepace(ing) is well thought out and if necessary explicitely referenced when declaring object types, etc.

3. If the module controls use more than a few ModuleSettings or TabModuleSettings, define a Config (or what ever you would like to call it) class that encapsulates all of the settings and handles their setting to default values the first time the module(s) is/are added to a page, as well as their loading and setting in both view/edit controls and settings controls. This also makes it much easier to cache the Config class object (usually using ModuleID or UserId as part of the cachekey) and then retrieve it from the cache in a custom user control/server control.

4. I generally use the DNN NavigateUrl and EditUrl in their various overloads to switch between controls primarily for administrative users and use LoadControl to dynamically load various view controls, particularly for non-administrative users. The former is best when needing a larger, less cluttered page for editing and the later less surprising for various views of the same data which would leave the user wondering where did all the other modules on the page go if redirection to alternate view controls was done with the usual NavigateUrl or EditUrl.

5. Don't hesitate to create custom user controls or custom server controls as needed if they will be used in more than one module control.  These can be either placed in your module control (.ascx) declaritively or loaded dynamically.  I'm really getting to like using the AJAXToolKit's ExtenderControlBase to create a control extender or use ScriptControlBase as appropriate if there will be much client side code.

6. If appropriate, move some of the common processing off to a generic handler (ashx) or WebService (asmx).  I'm especially fond of the former for streaming images or other content. As for the latter, I sure wish that it was more convenient to be able to use something like PageMethods in custom server controls.  I've been working recently on an image upload and editing control which includes cropping and imagement adjustment capabilities. As one might expect, the time required to perform the image processing via a WebService is about half that of using a client callback.

7. As for folder structure, I create a folder for the module or group of modules under DesktopModules (using a company name prefix like (WESNet_EPrayer) and then create subfolders for shared images, javascript, shared resoruces, each related sub-module, etc. When installing the module, you can direct each file into the appropriate folder using the foldername and path nodes in the dnn manifest file.  The blog module (and I suspect the new forum module - but I havn't had time to look at the new code) is one of the best examples of this.  If you are using the dynamically compiled module (WSP) model, it is unfortunate that the App_Code folder is not as flexible when it comes to setting up subfolders. As much as I would like to be able to set up a folder structure like App_Code/WESNet/Module1, AppCode/WESNet/Module2, etc. I have not been able to do so.  You can, however, set up sub folders such as App_Code/Module1/Components/ImageUtilities, App_Code/Module1/Components/Configuration, etc.

8. When writing your SQL table and stored proceedure definitions, be sure to prefix all table and sproc names with your company name and the module name - something like WENet_EPrayer_GetRequests. This not only avoids name collisions with other modules database objects, but makes it much easier to extract the Create scripts from the development database when preparing your SqlDataProvider files.

Thats enough thoughts for now - let us know if you have further questions.

 [Hope this doesn't post twice as I lost my first reply during a changeover to the new forum between the time I started tiyping and hitting submit!]


Bill, WESNet Designs
Team Lead - DotNetNuke Gallery Module Project (Not Actively Being Developed)
Extensions Forge Projects . . .
Current: UserExport, ContentDeJour, ePrayer, DNN NewsTicker, By Invitation
Coming Soon: FRBO-For Rent By Owner
 
New Post
10/24/2007 10:29 AM
 

I would say that the above are all good ideas!


-Mitchel Sellers
Microsoft MVP, ASPInsider, DNN MVP
CEO/Director of Development - IowaComputerGurus Inc.
LinkedIn Profile

Visit mitchelsellers.com for my mostly DNN Blog and support forum.

Visit IowaComputerGurus.com for free DNN Modules, DNN Performance Tips, DNN Consulting Quotes, and DNN Technical Support Services
 
New Post
10/24/2007 1:49 PM
 

Bill,

Thanks a lot for the great thoughts. I enjoyed reading your ideas and all makes sense and things more clear for me.

On a different note, are you blogging about the Image upload control you are working on?

Thanks

 
Previous
 
Next
HomeHomeArchived Discus...Archived Discus...Developing Under Previous Versions of .NETDeveloping Under Previous Versions of .NETASP.Net 2.0ASP.Net 2.0Complex Module Architecture ideasComplex Module Architecture ideas


These Forums are dedicated to discussion of DNN Platform and Evoq Solutions.

For the benefit of the community and to protect the integrity of the ecosystem, please observe the following posting guidelines:

  1. No Advertising. This includes promotion of commercial and non-commercial products or services which are not directly related to DNN.
  2. No vendor trolling / poaching. If someone posts about a vendor issue, allow the vendor or other customers to respond. Any post that looks like trolling / poaching will be removed.
  3. Discussion or promotion of DNN Platform product releases under a different brand name are strictly prohibited.
  4. No Flaming or Trolling.
  5. No Profanity, Racism, or Prejudice.
  6. Site Moderators have the final word on approving / removing a thread or post or comment.
  7. English language posting only, please.
What is Liquid Content?
Find Out
What is Liquid Content?
Find Out
What is Liquid Content?
Find Out