From 67d4ca8ed819f96ee036283977b67149fdaa1dd6 Mon Sep 17 00:00:00 2001 From: Scott McCulloch Date: Thu, 20 Jul 2017 16:23:58 +1000 Subject: [PATCH] first commit --- .DS_Store | Bin 0 -> 6148 bytes API/MetaWebLog/Handler.ashx | 1 + API/MetaWebLog/Handler.ashx.vb | 514 ++ API/MetaWebLog/MetaBlogInfo.vb | 11 + API/MetaWebLog/MetaCategoryInfo.vb | 13 + API/MetaWebLog/MetaException.vb | 24 + API/MetaWebLog/MetaFaultInfo.vb | 10 + API/MetaWebLog/MetaMediaInfo.vb | 15 + API/MetaWebLog/MetaMediaUrlInfo.vb | 13 + API/MetaWebLog/MetaPostInfo.vb | 18 + API/MetaWebLog/XmlrpcRequest.vb | 223 + API/MetaWebLog/XmlrpcResponse.vb | 488 ++ API/MetaWebLog/wlwmanifest.xml | 19 + API/Rsd.ashx | 1 + API/Rsd.ashx.vb | 53 + App_LocalResources/Archives.ascx.resx | 138 + App_LocalResources/Handout.ascx.resx | 144 + App_LocalResources/HandoutDetail.ascx.resx | 171 + App_LocalResources/HandoutSettings.ascx.resx | 468 ++ App_LocalResources/LatestArticles.ascx.resx | 186 + .../LatestArticlesOptions.ascx.resx | 678 +++ App_LocalResources/LatestComments.ascx.resx | 123 + .../LatestCommentsOptions.ascx.resx | 174 + App_LocalResources/NewsArchives.ascx.resx | 109 + .../NewsArchivesOptions.ascx.resx | 249 + App_LocalResources/NewsSearch.ascx.resx | 129 + .../NewsSearchOptions.ascx.resx | 135 + App_LocalResources/PostComment.ascx.resx | 165 + App_LocalResources/PostRating.ascx.resx | 123 + App_LocalResources/SharedResources.resx | 249 + App_LocalResources/UploadFiles.ascx.resx | 147 + App_LocalResources/UploadImages.ascx.resx | 147 + App_LocalResources/ViewArchive.ascx.resx | 138 + App_LocalResources/ViewArticle.ascx.resx | 144 + App_LocalResources/ViewAuthor.ascx.resx | 126 + App_LocalResources/ViewCategory.ascx.resx | 126 + App_LocalResources/ViewSearch.ascx.resx | 129 + App_LocalResources/ViewTag.ascx.resx | 126 + App_LocalResources/ucAdminOptions.ascx.resx | 168 + .../ucApproveArticles.ascx.resx | 156 + .../ucApproveComments.ascx.resx | 153 + App_LocalResources/ucEditCategories.ascx.resx | 174 + App_LocalResources/ucEditCategory.ascx.resx | 219 + App_LocalResources/ucEditComment.ascx.resx | 159 + .../ucEditCustomField.ascx.resx | 255 + .../ucEditCustomFields.ascx.resx | 150 + App_LocalResources/ucEditPage.ascx.resx | 72 + .../ucEditPageSortOrder.ascx.resx | 60 + App_LocalResources/ucEditPages.ascx.resx | 75 + App_LocalResources/ucEditTag.ascx.resx | 150 + App_LocalResources/ucEditTags.ascx.resx | 141 + App_LocalResources/ucEmailTemplates.ascx.resx | 228 + App_LocalResources/ucImportFeed.ascx.resx | 213 + App_LocalResources/ucImportFeeds.ascx.resx | 195 + App_LocalResources/ucMyArticles.ascx.resx | 153 + .../ucNotAuthenticated.ascx.resx | 57 + App_LocalResources/ucNotAuthorized.ascx.resx | 54 + App_LocalResources/ucSubmitNews.ascx.resx | 462 ++ .../ucSubmitNewsComplete.ascx.resx | 60 + App_LocalResources/ucTemplateEditor.ascx.resx | 177 + App_LocalResources/ucViewOptions.ascx.resx | 1200 +++++ Archives.ascx | 66 + Archives.ascx.designer.vb | 152 + Archives.ascx.vb | 310 ++ Base/NewsArticleControlBase.vb | 34 + Base/NewsArticleModuleBase.vb | 409 ++ Components/Archives/ArchiveInfo.vb | 63 + Components/Archives/ArchiveModeType.vb | 17 + Components/Archives/ArchiveSettings.vb | 293 ++ Components/ArticleController.vb | 930 ++++ Components/ArticleInfo.vb | 580 ++ Components/ArticleSettings.vb | 1607 ++++++ Components/AuthorController.vb | 102 + Components/AuthorInfo.vb | 98 + Components/AuthorSortByType.vb | 19 + Components/Bitly.vb | 132 + Components/CategoryController.vb | 227 + Components/CategoryInfo.vb | 219 + Components/CategorySecurityType.vb | 22 + Components/CategorySortType.vb | 22 + Components/CommentController.vb | 96 + Components/CommentInfo.vb | 251 + Components/Common.vb | 778 +++ Components/Common/ArticleConstants.vb | 375 ++ Components/Common/ArticleUtilities.vb | 49 + Components/ContentSharingInfo.vb | 115 + Components/Controllers/PageController.vb | 53 + Components/Controllers/PageInfo.vb | 79 + .../CustomFields/CustomFieldController.vb | 61 + Components/CustomFields/CustomFieldInfo.vb | 157 + Components/CustomFields/CustomFieldType.vb | 16 + .../CustomFields/CustomFieldValidationType.vb | 15 + .../CustomFields/CustomValueController.vb | 69 + Components/CustomFields/CustomValueInfo.vb | 58 + Components/DisplayType.vb | 24 + Components/EmailTemplateController.vb | 402 ++ Components/EmailTemplateInfo.vb | 81 + Components/EmailTemplateType.vb | 26 + Components/ExpiryType.vb | 22 + Components/GroupByType.vb | 16 + Components/Handout/HandoutArticle.vb | 57 + Components/Handout/HandoutController.vb | 62 + Components/Handout/HandoutFilterType.vb | 16 + Components/Handout/HandoutInfo.vb | 80 + Components/Handout/HandoutType.vb | 17 + Components/ImageController.vb | 57 + Components/ImageInfo.vb | 153 + Components/Import/FeedController.vb | 72 + Components/Import/FeedDateMode.vb | 22 + Components/Import/FeedExpiryType.vb | 14 + Components/Import/FeedInfo.vb | 138 + Components/Import/RssImportJob.vb | 437 ++ Components/LatestArticleController.vb | 58 + Components/Layout/LatestLayoutController.vb | 160 + Components/Layout/LatestLayoutType.vb | 18 + Components/Layout/LayoutController.vb | 4683 +++++++++++++++++ Components/Layout/LayoutInfo.vb | 43 + Components/Layout/LayoutType.vb | 62 + Components/Layout/TokenProcessor.vb | 372 ++ Components/LayoutModeType.vb | 16 + Components/LinkFilterType.vb | 23 + Components/MatchOperator.vb | 22 + Components/MenuOptionType.vb | 29 + Components/MirrorArticleController.vb | 41 + Components/MirrorArticleInfo.vb | 102 + Components/RatingController.vb | 103 + Components/RatingInfo.vb | 72 + Components/RelatedType.vb | 28 + Components/Social/Journal.vb | 94 + Components/StatusType.vb | 23 + Components/SyndicationEnclosureType.vb | 22 + Components/SyndicationLinkType.vb | 22 + Components/TagController.vb | 112 + Components/TagInfo.vb | 93 + Components/TemplateConstants.vb | 36 + Components/TemplateController.vb | 80 + Components/TemplateInfo.vb | 53 + Components/ThumbnailType.vb | 20 + Components/TitleReplacementType.vb | 22 + Components/Tracking/Notification.vb | 44 + Components/Tracking/NotificationJob.vb | 58 + Components/Tracking/PingBackProxy.resx | 42 + Components/Tracking/PingBackProxy.vb | 82 + Components/Tracking/PingJob.vb | 34 + Components/Tracking/PingProxy.resx | 42 + Components/Tracking/PingProxy.vb | 39 + Components/Tracking/TrackBackProxy.vb | 114 + Components/Tracking/TrackHelper.vb | 61 + Components/Types/AuthorSelectType.vb | 22 + Components/Types/MenuPositionType.vb | 22 + Components/Types/TextEditorModeType.vb | 22 + Components/Types/UrlModeType.vb | 22 + Components/UserTime.vb | 91 + Components/Utility/LocalizationUtil.vb | 140 + .../Validators/CheckBoxListValidator.vb | 114 + Components/WatermarkPosition.vb | 14 + Components/WebControls/PagingControl.vb | 391 ++ Components/WebControls/RefreshControl.vb | 9 + Controls/Listing.ascx | 6 + Controls/Listing.ascx.designer.vb | 35 + Controls/Listing.ascx.vb | 1593 ++++++ Controls/PostComment.ascx | 40 + Controls/PostComment.ascx.designer.vb | 215 + Controls/PostComment.ascx.vb | 518 ++ Controls/PostRating.ascx | 9 + Controls/PostRating.ascx.designer.vb | 35 + Controls/PostRating.ascx.vb | 248 + Controls/SWFUploader.ashx | 1 + Controls/SWFUploader.ashx.vb | 415 ++ Controls/SWFUploaderFiles.ashx | 1 + Controls/SWFUploaderFiles.ashx.vb | 281 + Controls/UploadFiles.ascx | 183 + Controls/UploadFiles.ascx.designer.vb | 233 + Controls/UploadFiles.ascx.vb | 508 ++ Controls/UploadImages.ascx | 197 + Controls/UploadImages.ascx.designer.vb | 277 + Controls/UploadImages.ascx.vb | 606 +++ ImageHandler.ashx | 1 + ImageHandler.ashx.vb | 264 + Images/Admin/Categories.gif | Bin 0 -> 1144 bytes Images/Admin/MainOptions.gif | Bin 0 -> 1171 bytes Images/Admin/Templates.gif | Bin 0 -> 1129 bytes Images/Includes/Handout.xml | 15 + Images/Includes/Handout.xsd | 31 + Images/Includes/IIK.sps | 1 + Images/Includes/IIK_Logo.gif | Bin 0 -> 7916 bytes Images/Includes/IIK_Toddler.jpg | Bin 0 -> 5924 bytes Images/Includes/Pattern.gif | Bin 0 -> 2350 bytes Images/Includes/Template.xml | 19 + Images/Includes/Template.zip | Bin 0 -> 18257 bytes Images/Lightbox/lightbox-ico-loading.gif | Bin 0 -> 3990 bytes Images/Rating/stars-0-0.gif | Bin 0 -> 295 bytes Images/Rating/stars-0-5.gif | Bin 0 -> 408 bytes Images/Rating/stars-1-0.gif | Bin 0 -> 385 bytes Images/Rating/stars-1-5.gif | Bin 0 -> 390 bytes Images/Rating/stars-2-0.gif | Bin 0 -> 382 bytes Images/Rating/stars-2-5.gif | Bin 0 -> 391 bytes Images/Rating/stars-3-0.gif | Bin 0 -> 388 bytes Images/Rating/stars-3-5.gif | Bin 0 -> 394 bytes Images/Rating/stars-4-0.gif | Bin 0 -> 397 bytes Images/Rating/stars-4-5.gif | Bin 0 -> 403 bytes Images/Rating/stars-5-0.gif | Bin 0 -> 394 bytes Images/SmartThinker/articleadd.png | Bin 0 -> 750 bytes Images/SmartThinker/commentadd.png | Bin 0 -> 530 bytes Images/SmartThinker/rateadd.png | Bin 0 -> 260 bytes Images/Uploader/XPButtonNoText_160x22.png | Bin 0 -> 1982 bytes Images/Uploader/cancelbutton.gif | Bin 0 -> 1221 bytes Images/Uploader/error.gif | Bin 0 -> 1900 bytes Images/Uploader/toobig.gif | Bin 0 -> 3882 bytes Images/Uploader/uploadlimit.gif | Bin 0 -> 2419 bytes Images/Uploader/zerobyte.gif | Bin 0 -> 2013 bytes Images/appearance.png | Bin 0 -> 2063 bytes Images/details.png | Bin 0 -> 1859 bytes Images/left_both.gif | Bin 0 -> 330 bytes Images/linkto.png | Bin 0 -> 2012 bytes Images/publishing.png | Bin 0 -> 1966 bytes Images/right_both.gif | Bin 0 -> 949 bytes Images/rssbutton.gif | Bin 0 -> 560 bytes Images/spacer.gif | Bin 0 -> 807 bytes Images/summary.png | Bin 0 -> 1678 bytes Images/tab_background.gif | Bin 0 -> 109 bytes Includes/ColorPicker/ColorPicker.js | 357 ++ Includes/Lightbox/jquery-1.3.2.min.js | 19 + Includes/Lightbox/jquery.lightbox-0.4.js | 450 ++ Includes/Lightbox/jquery.lightbox-0.4.pack.js | 1 + Includes/Shadowbox/close.png | Bin 0 -> 255 bytes Includes/Shadowbox/loading.gif | Bin 0 -> 2545 bytes Includes/Shadowbox/next.png | Bin 0 -> 248 bytes Includes/Shadowbox/pause.png | Bin 0 -> 155 bytes Includes/Shadowbox/play.png | Bin 0 -> 211 bytes Includes/Shadowbox/previous.png | Bin 0 -> 237 bytes Includes/Shadowbox/shadowbox.css | 30 + Includes/Shadowbox/shadowbox.js | 17 + Includes/Uploader/handlers.00.07.61.js | 324 ++ Includes/Uploader/jquery-1.3.2.min.js | 19 + Includes/Uploader/swfupload.00.07.61.js | 927 ++++ Includes/Uploader/swfupload.00.07.61.swf | Bin 0 -> 11931 bytes Includes/VentrianValidators.js | 36 + Installs/NewsArticles.00.09.11.zip | Bin 0 -> 807001 bytes LatestArticles.ascx | 15 + LatestArticles.ascx.designer.vb | 35 + LatestArticles.ascx.vb | 1382 +++++ LatestArticlesOptions.ascx | 709 +++ LatestArticlesOptions.ascx.designer.vb | 1664 ++++++ LatestArticlesOptions.ascx.vb | 974 ++++ LatestComments.ascx | 8 + LatestComments.ascx.designer.vb | 44 + LatestComments.ascx.vb | 243 + LatestCommentsOptions.ascx | 67 + LatestCommentsOptions.ascx.designer.vb | 188 + LatestCommentsOptions.ascx.vb | 157 + Libraries/CookComputing.XmlRpc.dll | Bin 0 -> 114688 bytes Libraries/Joel.Net.Akismet.dll | Bin 0 -> 20480 bytes Libraries/Ventrian.NewsArticles.Secure.dll | Bin 0 -> 10752 bytes Libraries/ephtmltopdf.dll | Bin 0 -> 2013184 bytes My Project/Application.Designer.vb | 13 + My Project/Application.myapp | 10 + My Project/AssemblyInfo.vb | 34 + My Project/Resources.Designer.vb | 63 + My Project/Resources.resx | 117 + My Project/Settings.Designer.vb | 84 + My Project/Settings.settings | 9 + NewsArchives.ascx | 14 + NewsArchives.ascx.designer.vb | 44 + NewsArchives.ascx.vb | 844 +++ NewsArchivesOptions.ascx | 69 + NewsArchivesOptions.ascx.designer.vb | 206 + NewsArchivesOptions.ascx.vb | 346 ++ NewsArticles.ascx | 9 + NewsArticles.ascx.designer.vb | 26 + NewsArticles.ascx.vb | 191 + NewsArticles.dnn | 1108 ++++ NewsSearch.ascx | 11 + NewsSearch.ascx.designer.vb | 62 + NewsSearch.ascx.vb | 104 + NewsSearchOptions.ascx | 11 + NewsSearchOptions.ascx.designer.vb | 35 + NewsSearchOptions.ascx.vb | 109 + Print.aspx | 11 + Print.aspx.designer.vb | 44 + Print.aspx.vb | 312 ++ Providers/DataProvider/DataProvider.vb | 155 + .../SqlDataProvider/00.00.01.SqlDataProvider | 442 ++ .../SqlDataProvider/00.00.02.SqlDataProvider | 271 + .../SqlDataProvider/00.00.03.SqlDataProvider | 14 + .../SqlDataProvider/00.00.04.SqlDataProvider | 8 + .../SqlDataProvider/00.00.05.SqlDataProvider | 255 + .../SqlDataProvider/00.00.06.SqlDataProvider | 13 + .../SqlDataProvider/00.00.07.SqlDataProvider | 144 + .../SqlDataProvider/00.00.10.SqlDataProvider | 15 + .../SqlDataProvider/00.01.00.SqlDataProvider | 269 + .../SqlDataProvider/00.01.01.SqlDataProvider | 16 + .../SqlDataProvider/00.01.02.SqlDataProvider | 291 + .../SqlDataProvider/00.02.00.SqlDataProvider | 15 + .../SqlDataProvider/00.02.05.SqlDataProvider | 111 + .../SqlDataProvider/00.02.07.SqlDataProvider | 4 + .../SqlDataProvider/00.03.00.SqlDataProvider | 7 + .../SqlDataProvider/00.03.02.SqlDataProvider | 8 + .../SqlDataProvider/00.04.02.SqlDataProvider | 18 + .../SqlDataProvider/00.04.03.SqlDataProvider | 171 + .../SqlDataProvider/00.04.08.SqlDataProvider | 23 + .../SqlDataProvider/00.04.09.SqlDataProvider | 12 + .../SqlDataProvider/00.05.00.SqlDataProvider | 116 + .../SqlDataProvider/00.05.02.SqlDataProvider | 19 + .../SqlDataProvider/00.05.05.SqlDataProvider | 30 + .../SqlDataProvider/00.05.09.SqlDataProvider | 25 + .../SqlDataProvider/00.05.11.SqlDataProvider | 28 + .../SqlDataProvider/00.05.12.SqlDataProvider | 465 ++ .../SqlDataProvider/00.05.13.SqlDataProvider | 30 + .../SqlDataProvider/00.05.17.SqlDataProvider | 274 + .../SqlDataProvider/00.05.20.SqlDataProvider | 163 + .../SqlDataProvider/00.05.21.SqlDataProvider | 168 + .../SqlDataProvider/00.05.22.SqlDataProvider | 109 + .../SqlDataProvider/00.05.24.SqlDataProvider | 37 + .../SqlDataProvider/00.05.26.SqlDataProvider | 378 ++ .../SqlDataProvider/00.05.28.SqlDataProvider | 19 + .../SqlDataProvider/00.05.40.SqlDataProvider | 33 + .../SqlDataProvider/00.05.41.SqlDataProvider | 27 + .../SqlDataProvider/00.05.46.SqlDataProvider | 537 ++ .../SqlDataProvider/00.05.48.SqlDataProvider | 421 ++ .../SqlDataProvider/00.05.51.SqlDataProvider | 20 + .../SqlDataProvider/00.05.55.SqlDataProvider | 21 + .../SqlDataProvider/00.05.56.SqlDataProvider | 22 + .../SqlDataProvider/00.05.58.SqlDataProvider | 23 + .../SqlDataProvider/00.05.66.SqlDataProvider | 23 + .../SqlDataProvider/00.05.68.SqlDataProvider | 23 + .../SqlDataProvider/00.05.69.SqlDataProvider | 50 + .../SqlDataProvider/00.05.74.SqlDataProvider | 36 + .../SqlDataProvider/00.05.76.SqlDataProvider | 24 + .../SqlDataProvider/00.05.77.SqlDataProvider | 52 + .../SqlDataProvider/00.05.78.SqlDataProvider | 84 + .../SqlDataProvider/00.06.00.SqlDataProvider | 218 + .../SqlDataProvider/00.06.04.SqlDataProvider | 45 + .../SqlDataProvider/00.06.07.SqlDataProvider | 74 + .../SqlDataProvider/00.06.08.SqlDataProvider | 24 + .../SqlDataProvider/00.06.09.SqlDataProvider | 24 + .../SqlDataProvider/00.06.11.SqlDataProvider | 63 + .../SqlDataProvider/00.06.14.SqlDataProvider | 26 + .../SqlDataProvider/00.06.16.SqlDataProvider | 116 + .../SqlDataProvider/00.06.18.SqlDataProvider | 1 + .../SqlDataProvider/00.07.00.SqlDataProvider | 653 +++ .../SqlDataProvider/00.07.01.SqlDataProvider | 204 + .../SqlDataProvider/00.07.05.SqlDataProvider | 204 + .../SqlDataProvider/00.07.06.SqlDataProvider | 170 + .../SqlDataProvider/00.07.08.SqlDataProvider | 173 + .../SqlDataProvider/00.07.10.SqlDataProvider | 197 + .../SqlDataProvider/00.07.13.SqlDataProvider | 207 + .../SqlDataProvider/00.07.14.SqlDataProvider | 88 + .../SqlDataProvider/00.07.20.SqlDataProvider | 138 + .../SqlDataProvider/00.07.32.SqlDataProvider | 398 ++ .../SqlDataProvider/00.07.33.SqlDataProvider | 193 + .../SqlDataProvider/00.07.41.SqlDataProvider | 217 + .../SqlDataProvider/00.07.44.SqlDataProvider | 230 + .../SqlDataProvider/00.07.46.SqlDataProvider | 221 + .../SqlDataProvider/00.07.47.SqlDataProvider | 288 + .../SqlDataProvider/00.07.48.SqlDataProvider | 10 + .../SqlDataProvider/00.07.52.SqlDataProvider | 6 + .../SqlDataProvider/00.07.53.SqlDataProvider | 487 ++ .../SqlDataProvider/00.07.55.SqlDataProvider | 469 ++ .../SqlDataProvider/00.07.56.SqlDataProvider | 261 + .../SqlDataProvider/00.07.57.SqlDataProvider | 615 +++ .../SqlDataProvider/00.07.58.SqlDataProvider | 299 ++ .../SqlDataProvider/00.07.59.SqlDataProvider | 240 + .../SqlDataProvider/00.07.61.SqlDataProvider | 806 +++ .../SqlDataProvider/00.07.63.SqlDataProvider | 236 + .../SqlDataProvider/00.07.64.SqlDataProvider | 241 + .../SqlDataProvider/00.07.66.SqlDataProvider | 13 + .../SqlDataProvider/00.07.67.SqlDataProvider | 110 + .../SqlDataProvider/00.07.68.SqlDataProvider | 601 +++ .../SqlDataProvider/00.07.69.SqlDataProvider | 53 + .../SqlDataProvider/00.07.71.SqlDataProvider | 223 + .../SqlDataProvider/00.07.72.SqlDataProvider | 18 + .../SqlDataProvider/00.07.73.SqlDataProvider | 231 + .../SqlDataProvider/00.07.74.SqlDataProvider | 383 ++ .../SqlDataProvider/00.07.75.SqlDataProvider | 7 + .../SqlDataProvider/00.07.77.SqlDataProvider | 262 + .../SqlDataProvider/00.07.81.SqlDataProvider | 257 + .../SqlDataProvider/00.07.84.SqlDataProvider | 105 + .../SqlDataProvider/00.07.85.SqlDataProvider | 39 + .../SqlDataProvider/00.07.87.SqlDataProvider | 271 + .../SqlDataProvider/00.07.88.SqlDataProvider | 61 + .../SqlDataProvider/00.07.89.SqlDataProvider | 21 + .../SqlDataProvider/00.07.96.SqlDataProvider | 396 ++ .../SqlDataProvider/00.07.97.SqlDataProvider | 149 + .../SqlDataProvider/00.07.98.SqlDataProvider | 402 ++ .../SqlDataProvider/00.07.99.SqlDataProvider | 396 ++ .../SqlDataProvider/00.08.00.SqlDataProvider | 114 + .../SqlDataProvider/00.08.04.SqlDataProvider | 134 + .../SqlDataProvider/00.08.05.SqlDataProvider | 62 + .../SqlDataProvider/00.08.06.SqlDataProvider | 62 + .../SqlDataProvider/00.09.02.SqlDataProvider | 109 + .../SqlDataProvider/00.09.05.SqlDataProvider | 71 + .../SqlDataProvider/00.09.11.SqlDataProvider | 61 + .../My Project/AssemblyInfo.vb | 34 + .../SqlDataProvider/SqlDataProvider.vb | 585 ++ .../SqlDataProvider/Uninstall.SqlDataProvider | Bin 0 -> 19240 bytes .../Ventrian.NewsArticles.SqlDataProvider.sln | 20 + .../Ventrian.NewsArticles.SqlDataProvider.suo | Bin 0 -> 13312 bytes ...trian.NewsArticles.SqlDataProvider.v11.suo | Bin 0 -> 13312 bytes ...ntrian.NewsArticles.SqlDataProvider.vbproj | 267 + ...n.NewsArticles.SqlDataProvider.vbproj.user | 66 + Providers/FileProvider/CoreFileProvider.vb | 144 + Providers/FileProvider/CoreFileProvider2.vb | 144 + Providers/FileProvider/FileController.vb | 85 + Providers/FileProvider/FileInfo.vb | 129 + Providers/FileProvider/FileProvider.vb | 49 + Resources.zip | Bin 0 -> 309000 bytes Resources.zip.manifest | 860 +++ ResourcesLatestArticles.zip | Bin 0 -> 18003 bytes ResourcesLatestComments.zip | Bin 0 -> 5445 bytes ResourcesNewsArchives.zip | Bin 0 -> 5836 bytes ResourcesNewsSearch.zip | Bin 0 -> 4702 bytes Rss.aspx | 1 + Rss.aspx.designer.vb | 17 + Rss.aspx.vb | 882 ++++ RssComments.aspx | 1 + RssComments.aspx.designer.vb | 17 + RssComments.aspx.vb | 232 + Templates/Default/Comment.Footer.html | 1 + Templates/Default/Comment.Header.html | 0 Templates/Default/Comment.Item.html | 36 + Templates/Default/Images/icon_comment.gif | Bin 0 -> 148 bytes Templates/Default/Listing.Empty.html | 2 + Templates/Default/Listing.Featured.html | 50 + Templates/Default/Listing.Featured.xml | 23 + Templates/Default/Listing.Footer.html | 4 + Templates/Default/Listing.Footer.xml | 11 + Templates/Default/Listing.Header.html | 1 + Templates/Default/Listing.Item.html | 50 + Templates/Default/Listing.Item.xml | 23 + Templates/Default/Menu.Item.html | 26 + Templates/Default/Print.Footer.html | 0 Templates/Default/Print.Header.html | 0 Templates/Default/Print.Item.html | 42 + Templates/Default/Template.css | 177 + Templates/Default/View.Footer.html | 0 Templates/Default/View.Header.html | 0 Templates/Default/View.Item.html | 116 + Templates/Default/View.Item.xml | 11 + Templates/Default/View.PageHeader.Html | 0 Templates/Default/View.Title.Html | 1 + Templates/JWPlayer/Category.Child.html | 6 + Templates/JWPlayer/Category.html | 15 + Templates/JWPlayer/Comment.Item.html | 11 + Templates/JWPlayer/File.Footer.Html | 1 + Templates/JWPlayer/File.Header.Html | 1 + Templates/JWPlayer/File.Item.Html | 3 + Templates/JWPlayer/Handout.Cover.html | 10 + Templates/JWPlayer/Handout.End.html | 1 + Templates/JWPlayer/Handout.Footer.html | 1 + Templates/JWPlayer/Handout.Header.html | 9 + Templates/JWPlayer/Handout.Item.html | 19 + Templates/JWPlayer/Image.Footer.Html | 1 + Templates/JWPlayer/Image.Header.Html | 1 + Templates/JWPlayer/Image.Item.Html | 3 + Templates/JWPlayer/Images/01.gif | Bin 0 -> 1204 bytes Templates/JWPlayer/Images/02.gif | Bin 0 -> 1650 bytes Templates/JWPlayer/Images/03.gif | Bin 0 -> 1679 bytes Templates/JWPlayer/Images/04.gif | Bin 0 -> 1669 bytes Templates/JWPlayer/Images/05.gif | Bin 0 -> 1671 bytes Templates/JWPlayer/Images/06.gif | Bin 0 -> 1668 bytes Templates/JWPlayer/Images/07.gif | Bin 0 -> 1658 bytes Templates/JWPlayer/Images/08.gif | Bin 0 -> 1680 bytes Templates/JWPlayer/Images/09.gif | Bin 0 -> 1654 bytes Templates/JWPlayer/Images/10.gif | Bin 0 -> 1664 bytes Templates/JWPlayer/Images/11.gif | Bin 0 -> 1683 bytes Templates/JWPlayer/Images/12.gif | Bin 0 -> 1665 bytes Templates/JWPlayer/Images/rssbutton.gif | Bin 0 -> 560 bytes Templates/JWPlayer/Listing.Empty.html | 2 + Templates/JWPlayer/Listing.Featured.html | 1 + Templates/JWPlayer/Listing.Footer.html | 4 + Templates/JWPlayer/Listing.Header.html | 0 Templates/JWPlayer/Listing.Item.html | 32 + Templates/JWPlayer/Menu.Item.html | 35 + Templates/JWPlayer/Print.Item.html | 45 + Templates/JWPlayer/Related.Footer.html | 2 + Templates/JWPlayer/Related.Header.html | 2 + Templates/JWPlayer/Related.Item.html | 3 + Templates/JWPlayer/Rss.Comment.Footer.html | 2 + Templates/JWPlayer/Rss.Comment.Header.html | 6 + Templates/JWPlayer/Rss.Comment.Item.html | 9 + Templates/JWPlayer/Rss.Footer.html | 3 + Templates/JWPlayer/Rss.Header.html | 6 + Templates/JWPlayer/Rss.Item.html | 13 + Templates/JWPlayer/Template.css | 361 ++ Templates/JWPlayer/View.Description.html | 1 + Templates/JWPlayer/View.Item.html | 102 + Templates/JWPlayer/View.Keyword.html | 1 + Templates/JWPlayer/View.PageHeader.Html | 0 Templates/JWPlayer/View.Title.Html | 1 + Templates/Standard/Category.Child.html | 6 + Templates/Standard/Category.html | 15 + Templates/Standard/Comment.Item.html | 11 + Templates/Standard/File.Footer.Html | 1 + Templates/Standard/File.Header.Html | 1 + Templates/Standard/File.Item.Html | 3 + Templates/Standard/Handout.Cover.html | 10 + Templates/Standard/Handout.End.html | 1 + Templates/Standard/Handout.Footer.html | 1 + Templates/Standard/Handout.Header.html | 9 + Templates/Standard/Handout.Item.html | 19 + Templates/Standard/Image.Footer.Html | 1 + Templates/Standard/Image.Header.Html | 1 + Templates/Standard/Image.Item.Html | 3 + Templates/Standard/Images/01.gif | Bin 0 -> 1204 bytes Templates/Standard/Images/02.gif | Bin 0 -> 1650 bytes Templates/Standard/Images/03.gif | Bin 0 -> 1679 bytes Templates/Standard/Images/04.gif | Bin 0 -> 1669 bytes Templates/Standard/Images/05.gif | Bin 0 -> 1671 bytes Templates/Standard/Images/06.gif | Bin 0 -> 1668 bytes Templates/Standard/Images/07.gif | Bin 0 -> 1658 bytes Templates/Standard/Images/08.gif | Bin 0 -> 1680 bytes Templates/Standard/Images/09.gif | Bin 0 -> 1654 bytes Templates/Standard/Images/10.gif | Bin 0 -> 1664 bytes Templates/Standard/Images/11.gif | Bin 0 -> 1683 bytes Templates/Standard/Images/12.gif | Bin 0 -> 1665 bytes Templates/Standard/Images/rssbutton.gif | Bin 0 -> 560 bytes Templates/Standard/Listing.Empty.html | 2 + Templates/Standard/Listing.Featured.html | 1 + Templates/Standard/Listing.Footer.html | 4 + Templates/Standard/Listing.Header.html | 0 Templates/Standard/Listing.Item.html | 32 + Templates/Standard/Menu.Item.html | 35 + Templates/Standard/Print.Item.html | 45 + Templates/Standard/Related.Footer.html | 2 + Templates/Standard/Related.Header.html | 2 + Templates/Standard/Related.Item.html | 3 + Templates/Standard/Rss.Comment.Footer.html | 2 + Templates/Standard/Rss.Comment.Header.html | 6 + Templates/Standard/Rss.Comment.Item.html | 9 + Templates/Standard/Rss.Footer.html | 3 + Templates/Standard/Rss.Header.html | 6 + Templates/Standard/Rss.Item.html | 13 + Templates/Standard/Template.css | 361 ++ Templates/Standard/View.Description.html | 1 + Templates/Standard/View.Item.html | 78 + Templates/Standard/View.Keyword.html | 1 + Templates/Standard/View.PageHeader.Html | 0 Templates/Standard/View.Title.Html | 1 + Tracking/Pingback.ashx | 1 + Tracking/Trackback.aspx | 1 + Uninstall.SqlDataProvider | Bin 0 -> 20930 bytes Ventrian.NewsArticles.sln | 26 + Ventrian.NewsArticles.v11.suo | Bin 0 -> 122368 bytes Ventrian.NewsArticles.vbproj | 1006 ++++ Ventrian.NewsArticles.vbproj.user | 28 + ViewArchive.ascx | 11 + ViewArchive.ascx.designer.vb | 53 + ViewArchive.ascx.vb | 116 + ViewArticle.ascx | 17 + ViewArticle.ascx.designer.vb | 62 + ViewArticle.ascx.vb | 411 ++ ViewAuthor.ascx | 9 + ViewAuthor.ascx.designer.vb | 53 + ViewAuthor.ascx.vb | 126 + ViewCategory.ascx | 7 + ViewCategory.ascx.designer.vb | 53 + ViewCategory.ascx.vb | 1001 ++++ ViewCurrent.ascx | 6 + ViewCurrent.ascx.designer.vb | 44 + ViewCurrent.ascx.vb | 18 + ViewSearch.ascx | 13 + ViewSearch.ascx.designer.vb | 80 + ViewSearch.ascx.vb | 135 + ViewTag.ascx | 9 + ViewTag.ascx.designer.vb | 53 + ViewTag.ascx.vb | 104 + Web References/wsStoryFeed/Reference.map | 7 + Web References/wsStoryFeed/Reference.vb | 208 + Web References/wsStoryFeed/StoryFeed.disco | 6 + Web References/wsStoryFeed/StoryFeed.wsdl | 120 + icon_comment.gif | Bin 0 -> 148 bytes icon_xml.gif | Bin 0 -> 429 bytes module.css | 108 + ucAdminOptions.ascx | 92 + ucAdminOptions.ascx.designer.vb | 179 + ucAdminOptions.ascx.vb | 233 + ucApproveArticles.ascx | 60 + ucApproveArticles.ascx.designer.vb | 89 + ucApproveArticles.ascx.vb | 365 ++ ucApproveComments.ascx | 72 + ucApproveComments.ascx.designer.vb | 71 + ucApproveComments.ascx.vb | 386 ++ ucEditCategories.ascx | 85 + ucEditCategories.ascx.designer.vb | 206 + ucEditCategories.ascx.vb | 201 + ucEditCategory.ascx | 153 + ucEditCategory.ascx.designer.vb | 350 ++ ucEditCategory.ascx.vb | 366 ++ ucEditComment.ascx | 71 + ucEditComment.ascx.designer.vb | 215 + ucEditComment.ascx.vb | 192 + ucEditCustomField.ascx | 141 + ucEditCustomField.ascx.designer.vb | 404 ++ ucEditCustomField.ascx.vb | 298 ++ ucEditCustomFields.ascx | 40 + ucEditCustomFields.ascx.designer.vb | 53 + ucEditCustomFields.ascx.vb | 157 + ucEditPage.ascx | 53 + ucEditPage.ascx.designer.vb | 152 + ucEditPage.ascx.vb | 199 + ucEditPageSortOrder.ascx | 57 + ucEditPageSortOrder.ascx.designer.vb | 125 + ucEditPageSortOrder.ascx.vb | 175 + ucEditPages.ascx | 28 + ucEditPages.ascx.designer.vb | 98 + ucEditPages.ascx.vb | 215 + ucEditTag.ascx | 44 + ucEditTag.ascx.designer.vb | 116 + ucEditTag.ascx.vb | 148 + ucEditTags.ascx | 20 + ucEditTags.ascx.designer.vb | 53 + ucEditTags.ascx.vb | 60 + ucEmailTemplates.ascx | 225 + ucEmailTemplates.ascx.designer.vb | 395 ++ ucEmailTemplates.ascx.vb | 106 + ucHeader.ascx | 2 + ucHeader.ascx.designer.vb | 26 + ucHeader.ascx.vb | 104 + ucImportFeed.ascx | 120 + ucImportFeed.ascx.designer.vb | 341 ++ ucImportFeed.ascx.vb | 286 + ucImportFeeds.ascx | 147 + ucImportFeeds.ascx.designer.vb | 251 + ucImportFeeds.ascx.vb | 264 + ucMyArticles.ascx | 58 + ucMyArticles.ascx.designer.vb | 71 + ucMyArticles.ascx.vb | 292 + ucNotAuthenticated.ascx | 13 + ucNotAuthenticated.ascx.designer.vb | 62 + ucNotAuthenticated.ascx.vb | 58 + ucNotAuthorized.ascx | 10 + ucNotAuthorized.ascx.designer.vb | 53 + ucNotAuthorized.ascx.vb | 24 + ucSubmitNews.ascx | 338 ++ ucSubmitNews.ascx.designer.vb | 1124 ++++ ucSubmitNews.ascx.vb | 2213 ++++++++ ucSubmitNewsComplete.ascx | 16 + ucSubmitNewsComplete.ascx.designer.vb | 71 + ucSubmitNewsComplete.ascx.vb | 40 + ucTemplateEditor.ascx | 120 + ucTemplateEditor.ascx.designer.vb | 233 + ucTemplateEditor.ascx.vb | 219 + ucViewOptions.ascx | 1044 ++++ ucViewOptions.ascx.designer.vb | 2798 ++++++++++ ucViewOptions.ascx.vb | 1944 +++++++ web.config | 13 + 647 files changed, 91160 insertions(+) create mode 100644 .DS_Store create mode 100755 API/MetaWebLog/Handler.ashx create mode 100755 API/MetaWebLog/Handler.ashx.vb create mode 100755 API/MetaWebLog/MetaBlogInfo.vb create mode 100755 API/MetaWebLog/MetaCategoryInfo.vb create mode 100755 API/MetaWebLog/MetaException.vb create mode 100755 API/MetaWebLog/MetaFaultInfo.vb create mode 100755 API/MetaWebLog/MetaMediaInfo.vb create mode 100755 API/MetaWebLog/MetaMediaUrlInfo.vb create mode 100755 API/MetaWebLog/MetaPostInfo.vb create mode 100755 API/MetaWebLog/XmlrpcRequest.vb create mode 100755 API/MetaWebLog/XmlrpcResponse.vb create mode 100755 API/MetaWebLog/wlwmanifest.xml create mode 100755 API/Rsd.ashx create mode 100755 API/Rsd.ashx.vb create mode 100755 App_LocalResources/Archives.ascx.resx create mode 100755 App_LocalResources/Handout.ascx.resx create mode 100755 App_LocalResources/HandoutDetail.ascx.resx create mode 100755 App_LocalResources/HandoutSettings.ascx.resx create mode 100755 App_LocalResources/LatestArticles.ascx.resx create mode 100755 App_LocalResources/LatestArticlesOptions.ascx.resx create mode 100755 App_LocalResources/LatestComments.ascx.resx create mode 100755 App_LocalResources/LatestCommentsOptions.ascx.resx create mode 100755 App_LocalResources/NewsArchives.ascx.resx create mode 100755 App_LocalResources/NewsArchivesOptions.ascx.resx create mode 100755 App_LocalResources/NewsSearch.ascx.resx create mode 100755 App_LocalResources/NewsSearchOptions.ascx.resx create mode 100755 App_LocalResources/PostComment.ascx.resx create mode 100755 App_LocalResources/PostRating.ascx.resx create mode 100755 App_LocalResources/SharedResources.resx create mode 100755 App_LocalResources/UploadFiles.ascx.resx create mode 100755 App_LocalResources/UploadImages.ascx.resx create mode 100755 App_LocalResources/ViewArchive.ascx.resx create mode 100755 App_LocalResources/ViewArticle.ascx.resx create mode 100755 App_LocalResources/ViewAuthor.ascx.resx create mode 100755 App_LocalResources/ViewCategory.ascx.resx create mode 100755 App_LocalResources/ViewSearch.ascx.resx create mode 100755 App_LocalResources/ViewTag.ascx.resx create mode 100755 App_LocalResources/ucAdminOptions.ascx.resx create mode 100755 App_LocalResources/ucApproveArticles.ascx.resx create mode 100755 App_LocalResources/ucApproveComments.ascx.resx create mode 100755 App_LocalResources/ucEditCategories.ascx.resx create mode 100755 App_LocalResources/ucEditCategory.ascx.resx create mode 100755 App_LocalResources/ucEditComment.ascx.resx create mode 100755 App_LocalResources/ucEditCustomField.ascx.resx create mode 100755 App_LocalResources/ucEditCustomFields.ascx.resx create mode 100755 App_LocalResources/ucEditPage.ascx.resx create mode 100755 App_LocalResources/ucEditPageSortOrder.ascx.resx create mode 100755 App_LocalResources/ucEditPages.ascx.resx create mode 100755 App_LocalResources/ucEditTag.ascx.resx create mode 100755 App_LocalResources/ucEditTags.ascx.resx create mode 100755 App_LocalResources/ucEmailTemplates.ascx.resx create mode 100755 App_LocalResources/ucImportFeed.ascx.resx create mode 100755 App_LocalResources/ucImportFeeds.ascx.resx create mode 100755 App_LocalResources/ucMyArticles.ascx.resx create mode 100755 App_LocalResources/ucNotAuthenticated.ascx.resx create mode 100755 App_LocalResources/ucNotAuthorized.ascx.resx create mode 100755 App_LocalResources/ucSubmitNews.ascx.resx create mode 100755 App_LocalResources/ucSubmitNewsComplete.ascx.resx create mode 100755 App_LocalResources/ucTemplateEditor.ascx.resx create mode 100755 App_LocalResources/ucViewOptions.ascx.resx create mode 100755 Archives.ascx create mode 100755 Archives.ascx.designer.vb create mode 100755 Archives.ascx.vb create mode 100755 Base/NewsArticleControlBase.vb create mode 100755 Base/NewsArticleModuleBase.vb create mode 100755 Components/Archives/ArchiveInfo.vb create mode 100755 Components/Archives/ArchiveModeType.vb create mode 100755 Components/Archives/ArchiveSettings.vb create mode 100755 Components/ArticleController.vb create mode 100755 Components/ArticleInfo.vb create mode 100755 Components/ArticleSettings.vb create mode 100755 Components/AuthorController.vb create mode 100755 Components/AuthorInfo.vb create mode 100755 Components/AuthorSortByType.vb create mode 100755 Components/Bitly.vb create mode 100755 Components/CategoryController.vb create mode 100755 Components/CategoryInfo.vb create mode 100755 Components/CategorySecurityType.vb create mode 100755 Components/CategorySortType.vb create mode 100755 Components/CommentController.vb create mode 100755 Components/CommentInfo.vb create mode 100755 Components/Common.vb create mode 100755 Components/Common/ArticleConstants.vb create mode 100755 Components/Common/ArticleUtilities.vb create mode 100755 Components/ContentSharingInfo.vb create mode 100755 Components/Controllers/PageController.vb create mode 100755 Components/Controllers/PageInfo.vb create mode 100755 Components/CustomFields/CustomFieldController.vb create mode 100755 Components/CustomFields/CustomFieldInfo.vb create mode 100755 Components/CustomFields/CustomFieldType.vb create mode 100755 Components/CustomFields/CustomFieldValidationType.vb create mode 100755 Components/CustomFields/CustomValueController.vb create mode 100755 Components/CustomFields/CustomValueInfo.vb create mode 100755 Components/DisplayType.vb create mode 100755 Components/EmailTemplateController.vb create mode 100755 Components/EmailTemplateInfo.vb create mode 100755 Components/EmailTemplateType.vb create mode 100755 Components/ExpiryType.vb create mode 100755 Components/GroupByType.vb create mode 100755 Components/Handout/HandoutArticle.vb create mode 100755 Components/Handout/HandoutController.vb create mode 100755 Components/Handout/HandoutFilterType.vb create mode 100755 Components/Handout/HandoutInfo.vb create mode 100755 Components/Handout/HandoutType.vb create mode 100755 Components/ImageController.vb create mode 100755 Components/ImageInfo.vb create mode 100755 Components/Import/FeedController.vb create mode 100755 Components/Import/FeedDateMode.vb create mode 100755 Components/Import/FeedExpiryType.vb create mode 100755 Components/Import/FeedInfo.vb create mode 100755 Components/Import/RssImportJob.vb create mode 100755 Components/LatestArticleController.vb create mode 100755 Components/Layout/LatestLayoutController.vb create mode 100755 Components/Layout/LatestLayoutType.vb create mode 100755 Components/Layout/LayoutController.vb create mode 100755 Components/Layout/LayoutInfo.vb create mode 100755 Components/Layout/LayoutType.vb create mode 100755 Components/Layout/TokenProcessor.vb create mode 100755 Components/LayoutModeType.vb create mode 100755 Components/LinkFilterType.vb create mode 100755 Components/MatchOperator.vb create mode 100755 Components/MenuOptionType.vb create mode 100755 Components/MirrorArticleController.vb create mode 100755 Components/MirrorArticleInfo.vb create mode 100755 Components/RatingController.vb create mode 100755 Components/RatingInfo.vb create mode 100755 Components/RelatedType.vb create mode 100755 Components/Social/Journal.vb create mode 100755 Components/StatusType.vb create mode 100755 Components/SyndicationEnclosureType.vb create mode 100755 Components/SyndicationLinkType.vb create mode 100755 Components/TagController.vb create mode 100755 Components/TagInfo.vb create mode 100755 Components/TemplateConstants.vb create mode 100755 Components/TemplateController.vb create mode 100755 Components/TemplateInfo.vb create mode 100755 Components/ThumbnailType.vb create mode 100755 Components/TitleReplacementType.vb create mode 100755 Components/Tracking/Notification.vb create mode 100755 Components/Tracking/NotificationJob.vb create mode 100755 Components/Tracking/PingBackProxy.resx create mode 100755 Components/Tracking/PingBackProxy.vb create mode 100755 Components/Tracking/PingJob.vb create mode 100755 Components/Tracking/PingProxy.resx create mode 100755 Components/Tracking/PingProxy.vb create mode 100755 Components/Tracking/TrackBackProxy.vb create mode 100755 Components/Tracking/TrackHelper.vb create mode 100755 Components/Types/AuthorSelectType.vb create mode 100755 Components/Types/MenuPositionType.vb create mode 100755 Components/Types/TextEditorModeType.vb create mode 100755 Components/Types/UrlModeType.vb create mode 100755 Components/UserTime.vb create mode 100755 Components/Utility/LocalizationUtil.vb create mode 100755 Components/Validators/CheckBoxListValidator.vb create mode 100755 Components/WatermarkPosition.vb create mode 100755 Components/WebControls/PagingControl.vb create mode 100755 Components/WebControls/RefreshControl.vb create mode 100755 Controls/Listing.ascx create mode 100755 Controls/Listing.ascx.designer.vb create mode 100755 Controls/Listing.ascx.vb create mode 100755 Controls/PostComment.ascx create mode 100755 Controls/PostComment.ascx.designer.vb create mode 100755 Controls/PostComment.ascx.vb create mode 100755 Controls/PostRating.ascx create mode 100755 Controls/PostRating.ascx.designer.vb create mode 100755 Controls/PostRating.ascx.vb create mode 100755 Controls/SWFUploader.ashx create mode 100755 Controls/SWFUploader.ashx.vb create mode 100755 Controls/SWFUploaderFiles.ashx create mode 100755 Controls/SWFUploaderFiles.ashx.vb create mode 100755 Controls/UploadFiles.ascx create mode 100755 Controls/UploadFiles.ascx.designer.vb create mode 100755 Controls/UploadFiles.ascx.vb create mode 100755 Controls/UploadImages.ascx create mode 100755 Controls/UploadImages.ascx.designer.vb create mode 100755 Controls/UploadImages.ascx.vb create mode 100755 ImageHandler.ashx create mode 100755 ImageHandler.ashx.vb create mode 100755 Images/Admin/Categories.gif create mode 100755 Images/Admin/MainOptions.gif create mode 100755 Images/Admin/Templates.gif create mode 100755 Images/Includes/Handout.xml create mode 100755 Images/Includes/Handout.xsd create mode 100755 Images/Includes/IIK.sps create mode 100755 Images/Includes/IIK_Logo.gif create mode 100755 Images/Includes/IIK_Toddler.jpg create mode 100755 Images/Includes/Pattern.gif create mode 100755 Images/Includes/Template.xml create mode 100755 Images/Includes/Template.zip create mode 100755 Images/Lightbox/lightbox-ico-loading.gif create mode 100755 Images/Rating/stars-0-0.gif create mode 100755 Images/Rating/stars-0-5.gif create mode 100755 Images/Rating/stars-1-0.gif create mode 100755 Images/Rating/stars-1-5.gif create mode 100755 Images/Rating/stars-2-0.gif create mode 100755 Images/Rating/stars-2-5.gif create mode 100755 Images/Rating/stars-3-0.gif create mode 100755 Images/Rating/stars-3-5.gif create mode 100755 Images/Rating/stars-4-0.gif create mode 100755 Images/Rating/stars-4-5.gif create mode 100755 Images/Rating/stars-5-0.gif create mode 100755 Images/SmartThinker/articleadd.png create mode 100755 Images/SmartThinker/commentadd.png create mode 100755 Images/SmartThinker/rateadd.png create mode 100755 Images/Uploader/XPButtonNoText_160x22.png create mode 100755 Images/Uploader/cancelbutton.gif create mode 100755 Images/Uploader/error.gif create mode 100755 Images/Uploader/toobig.gif create mode 100755 Images/Uploader/uploadlimit.gif create mode 100755 Images/Uploader/zerobyte.gif create mode 100755 Images/appearance.png create mode 100755 Images/details.png create mode 100755 Images/left_both.gif create mode 100755 Images/linkto.png create mode 100755 Images/publishing.png create mode 100755 Images/right_both.gif create mode 100755 Images/rssbutton.gif create mode 100755 Images/spacer.gif create mode 100755 Images/summary.png create mode 100755 Images/tab_background.gif create mode 100755 Includes/ColorPicker/ColorPicker.js create mode 100755 Includes/Lightbox/jquery-1.3.2.min.js create mode 100755 Includes/Lightbox/jquery.lightbox-0.4.js create mode 100755 Includes/Lightbox/jquery.lightbox-0.4.pack.js create mode 100755 Includes/Shadowbox/close.png create mode 100755 Includes/Shadowbox/loading.gif create mode 100755 Includes/Shadowbox/next.png create mode 100755 Includes/Shadowbox/pause.png create mode 100755 Includes/Shadowbox/play.png create mode 100755 Includes/Shadowbox/previous.png create mode 100755 Includes/Shadowbox/shadowbox.css create mode 100755 Includes/Shadowbox/shadowbox.js create mode 100755 Includes/Uploader/handlers.00.07.61.js create mode 100755 Includes/Uploader/jquery-1.3.2.min.js create mode 100755 Includes/Uploader/swfupload.00.07.61.js create mode 100755 Includes/Uploader/swfupload.00.07.61.swf create mode 100755 Includes/VentrianValidators.js create mode 100755 Installs/NewsArticles.00.09.11.zip create mode 100755 LatestArticles.ascx create mode 100755 LatestArticles.ascx.designer.vb create mode 100755 LatestArticles.ascx.vb create mode 100755 LatestArticlesOptions.ascx create mode 100755 LatestArticlesOptions.ascx.designer.vb create mode 100755 LatestArticlesOptions.ascx.vb create mode 100755 LatestComments.ascx create mode 100755 LatestComments.ascx.designer.vb create mode 100755 LatestComments.ascx.vb create mode 100755 LatestCommentsOptions.ascx create mode 100755 LatestCommentsOptions.ascx.designer.vb create mode 100755 LatestCommentsOptions.ascx.vb create mode 100755 Libraries/CookComputing.XmlRpc.dll create mode 100755 Libraries/Joel.Net.Akismet.dll create mode 100755 Libraries/Ventrian.NewsArticles.Secure.dll create mode 100755 Libraries/ephtmltopdf.dll create mode 100755 My Project/Application.Designer.vb create mode 100755 My Project/Application.myapp create mode 100755 My Project/AssemblyInfo.vb create mode 100755 My Project/Resources.Designer.vb create mode 100755 My Project/Resources.resx create mode 100755 My Project/Settings.Designer.vb create mode 100755 My Project/Settings.settings create mode 100755 NewsArchives.ascx create mode 100755 NewsArchives.ascx.designer.vb create mode 100755 NewsArchives.ascx.vb create mode 100755 NewsArchivesOptions.ascx create mode 100755 NewsArchivesOptions.ascx.designer.vb create mode 100755 NewsArchivesOptions.ascx.vb create mode 100755 NewsArticles.ascx create mode 100755 NewsArticles.ascx.designer.vb create mode 100755 NewsArticles.ascx.vb create mode 100755 NewsArticles.dnn create mode 100755 NewsSearch.ascx create mode 100755 NewsSearch.ascx.designer.vb create mode 100755 NewsSearch.ascx.vb create mode 100755 NewsSearchOptions.ascx create mode 100755 NewsSearchOptions.ascx.designer.vb create mode 100755 NewsSearchOptions.ascx.vb create mode 100755 Print.aspx create mode 100755 Print.aspx.designer.vb create mode 100755 Print.aspx.vb create mode 100755 Providers/DataProvider/DataProvider.vb create mode 100755 Providers/DataProvider/SqlDataProvider/00.00.01.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.00.02.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.00.03.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.00.04.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.00.05.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.00.06.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.00.07.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.00.10.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.01.00.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.01.01.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.01.02.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.02.00.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.02.05.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.02.07.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.03.00.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.03.02.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.04.02.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.04.03.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.04.08.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.04.09.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.00.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.02.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.05.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.09.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.11.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.12.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.13.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.17.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.20.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.21.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.22.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.24.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.26.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.28.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.40.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.41.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.46.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.48.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.51.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.55.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.56.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.58.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.66.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.68.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.69.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.74.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.76.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.77.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.05.78.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.06.00.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.06.04.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.06.07.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.06.08.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.06.09.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.06.11.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.06.14.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.06.16.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.06.18.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.00.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.01.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.05.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.06.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.08.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.10.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.13.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.14.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.20.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.32.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.33.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.41.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.44.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.46.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.47.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.48.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.52.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.53.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.55.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.56.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.57.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.58.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.59.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.61.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.63.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.64.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.66.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.67.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.68.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.69.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.71.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.72.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.73.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.74.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.75.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.77.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.81.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.84.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.85.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.87.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.88.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.89.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.96.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.97.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.98.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.07.99.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.08.00.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.08.04.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.08.05.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.08.06.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.09.02.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.09.05.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/00.09.11.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/My Project/AssemblyInfo.vb create mode 100755 Providers/DataProvider/SqlDataProvider/SqlDataProvider.vb create mode 100755 Providers/DataProvider/SqlDataProvider/Uninstall.SqlDataProvider create mode 100755 Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.sln create mode 100755 Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.suo create mode 100755 Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.v11.suo create mode 100755 Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.vbproj create mode 100755 Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.vbproj.user create mode 100755 Providers/FileProvider/CoreFileProvider.vb create mode 100755 Providers/FileProvider/CoreFileProvider2.vb create mode 100755 Providers/FileProvider/FileController.vb create mode 100755 Providers/FileProvider/FileInfo.vb create mode 100755 Providers/FileProvider/FileProvider.vb create mode 100755 Resources.zip create mode 100755 Resources.zip.manifest create mode 100755 ResourcesLatestArticles.zip create mode 100755 ResourcesLatestComments.zip create mode 100755 ResourcesNewsArchives.zip create mode 100755 ResourcesNewsSearch.zip create mode 100755 Rss.aspx create mode 100755 Rss.aspx.designer.vb create mode 100755 Rss.aspx.vb create mode 100755 RssComments.aspx create mode 100755 RssComments.aspx.designer.vb create mode 100755 RssComments.aspx.vb create mode 100755 Templates/Default/Comment.Footer.html create mode 100755 Templates/Default/Comment.Header.html create mode 100755 Templates/Default/Comment.Item.html create mode 100755 Templates/Default/Images/icon_comment.gif create mode 100755 Templates/Default/Listing.Empty.html create mode 100755 Templates/Default/Listing.Featured.html create mode 100755 Templates/Default/Listing.Featured.xml create mode 100755 Templates/Default/Listing.Footer.html create mode 100755 Templates/Default/Listing.Footer.xml create mode 100755 Templates/Default/Listing.Header.html create mode 100755 Templates/Default/Listing.Item.html create mode 100755 Templates/Default/Listing.Item.xml create mode 100755 Templates/Default/Menu.Item.html create mode 100755 Templates/Default/Print.Footer.html create mode 100755 Templates/Default/Print.Header.html create mode 100755 Templates/Default/Print.Item.html create mode 100755 Templates/Default/Template.css create mode 100755 Templates/Default/View.Footer.html create mode 100755 Templates/Default/View.Header.html create mode 100755 Templates/Default/View.Item.html create mode 100755 Templates/Default/View.Item.xml create mode 100755 Templates/Default/View.PageHeader.Html create mode 100755 Templates/Default/View.Title.Html create mode 100755 Templates/JWPlayer/Category.Child.html create mode 100755 Templates/JWPlayer/Category.html create mode 100755 Templates/JWPlayer/Comment.Item.html create mode 100755 Templates/JWPlayer/File.Footer.Html create mode 100755 Templates/JWPlayer/File.Header.Html create mode 100755 Templates/JWPlayer/File.Item.Html create mode 100755 Templates/JWPlayer/Handout.Cover.html create mode 100755 Templates/JWPlayer/Handout.End.html create mode 100755 Templates/JWPlayer/Handout.Footer.html create mode 100755 Templates/JWPlayer/Handout.Header.html create mode 100755 Templates/JWPlayer/Handout.Item.html create mode 100755 Templates/JWPlayer/Image.Footer.Html create mode 100755 Templates/JWPlayer/Image.Header.Html create mode 100755 Templates/JWPlayer/Image.Item.Html create mode 100755 Templates/JWPlayer/Images/01.gif create mode 100755 Templates/JWPlayer/Images/02.gif create mode 100755 Templates/JWPlayer/Images/03.gif create mode 100755 Templates/JWPlayer/Images/04.gif create mode 100755 Templates/JWPlayer/Images/05.gif create mode 100755 Templates/JWPlayer/Images/06.gif create mode 100755 Templates/JWPlayer/Images/07.gif create mode 100755 Templates/JWPlayer/Images/08.gif create mode 100755 Templates/JWPlayer/Images/09.gif create mode 100755 Templates/JWPlayer/Images/10.gif create mode 100755 Templates/JWPlayer/Images/11.gif create mode 100755 Templates/JWPlayer/Images/12.gif create mode 100755 Templates/JWPlayer/Images/rssbutton.gif create mode 100755 Templates/JWPlayer/Listing.Empty.html create mode 100755 Templates/JWPlayer/Listing.Featured.html create mode 100755 Templates/JWPlayer/Listing.Footer.html create mode 100755 Templates/JWPlayer/Listing.Header.html create mode 100755 Templates/JWPlayer/Listing.Item.html create mode 100755 Templates/JWPlayer/Menu.Item.html create mode 100755 Templates/JWPlayer/Print.Item.html create mode 100755 Templates/JWPlayer/Related.Footer.html create mode 100755 Templates/JWPlayer/Related.Header.html create mode 100755 Templates/JWPlayer/Related.Item.html create mode 100755 Templates/JWPlayer/Rss.Comment.Footer.html create mode 100755 Templates/JWPlayer/Rss.Comment.Header.html create mode 100755 Templates/JWPlayer/Rss.Comment.Item.html create mode 100755 Templates/JWPlayer/Rss.Footer.html create mode 100755 Templates/JWPlayer/Rss.Header.html create mode 100755 Templates/JWPlayer/Rss.Item.html create mode 100755 Templates/JWPlayer/Template.css create mode 100755 Templates/JWPlayer/View.Description.html create mode 100755 Templates/JWPlayer/View.Item.html create mode 100755 Templates/JWPlayer/View.Keyword.html create mode 100755 Templates/JWPlayer/View.PageHeader.Html create mode 100755 Templates/JWPlayer/View.Title.Html create mode 100755 Templates/Standard/Category.Child.html create mode 100755 Templates/Standard/Category.html create mode 100755 Templates/Standard/Comment.Item.html create mode 100755 Templates/Standard/File.Footer.Html create mode 100755 Templates/Standard/File.Header.Html create mode 100755 Templates/Standard/File.Item.Html create mode 100755 Templates/Standard/Handout.Cover.html create mode 100755 Templates/Standard/Handout.End.html create mode 100755 Templates/Standard/Handout.Footer.html create mode 100755 Templates/Standard/Handout.Header.html create mode 100755 Templates/Standard/Handout.Item.html create mode 100755 Templates/Standard/Image.Footer.Html create mode 100755 Templates/Standard/Image.Header.Html create mode 100755 Templates/Standard/Image.Item.Html create mode 100755 Templates/Standard/Images/01.gif create mode 100755 Templates/Standard/Images/02.gif create mode 100755 Templates/Standard/Images/03.gif create mode 100755 Templates/Standard/Images/04.gif create mode 100755 Templates/Standard/Images/05.gif create mode 100755 Templates/Standard/Images/06.gif create mode 100755 Templates/Standard/Images/07.gif create mode 100755 Templates/Standard/Images/08.gif create mode 100755 Templates/Standard/Images/09.gif create mode 100755 Templates/Standard/Images/10.gif create mode 100755 Templates/Standard/Images/11.gif create mode 100755 Templates/Standard/Images/12.gif create mode 100755 Templates/Standard/Images/rssbutton.gif create mode 100755 Templates/Standard/Listing.Empty.html create mode 100755 Templates/Standard/Listing.Featured.html create mode 100755 Templates/Standard/Listing.Footer.html create mode 100755 Templates/Standard/Listing.Header.html create mode 100755 Templates/Standard/Listing.Item.html create mode 100755 Templates/Standard/Menu.Item.html create mode 100755 Templates/Standard/Print.Item.html create mode 100755 Templates/Standard/Related.Footer.html create mode 100755 Templates/Standard/Related.Header.html create mode 100755 Templates/Standard/Related.Item.html create mode 100755 Templates/Standard/Rss.Comment.Footer.html create mode 100755 Templates/Standard/Rss.Comment.Header.html create mode 100755 Templates/Standard/Rss.Comment.Item.html create mode 100755 Templates/Standard/Rss.Footer.html create mode 100755 Templates/Standard/Rss.Header.html create mode 100755 Templates/Standard/Rss.Item.html create mode 100755 Templates/Standard/Template.css create mode 100755 Templates/Standard/View.Description.html create mode 100755 Templates/Standard/View.Item.html create mode 100755 Templates/Standard/View.Keyword.html create mode 100755 Templates/Standard/View.PageHeader.Html create mode 100755 Templates/Standard/View.Title.Html create mode 100755 Tracking/Pingback.ashx create mode 100755 Tracking/Trackback.aspx create mode 100755 Uninstall.SqlDataProvider create mode 100755 Ventrian.NewsArticles.sln create mode 100755 Ventrian.NewsArticles.v11.suo create mode 100755 Ventrian.NewsArticles.vbproj create mode 100755 Ventrian.NewsArticles.vbproj.user create mode 100755 ViewArchive.ascx create mode 100755 ViewArchive.ascx.designer.vb create mode 100755 ViewArchive.ascx.vb create mode 100755 ViewArticle.ascx create mode 100755 ViewArticle.ascx.designer.vb create mode 100755 ViewArticle.ascx.vb create mode 100755 ViewAuthor.ascx create mode 100755 ViewAuthor.ascx.designer.vb create mode 100755 ViewAuthor.ascx.vb create mode 100755 ViewCategory.ascx create mode 100755 ViewCategory.ascx.designer.vb create mode 100755 ViewCategory.ascx.vb create mode 100755 ViewCurrent.ascx create mode 100755 ViewCurrent.ascx.designer.vb create mode 100755 ViewCurrent.ascx.vb create mode 100755 ViewSearch.ascx create mode 100755 ViewSearch.ascx.designer.vb create mode 100755 ViewSearch.ascx.vb create mode 100755 ViewTag.ascx create mode 100755 ViewTag.ascx.designer.vb create mode 100755 ViewTag.ascx.vb create mode 100755 Web References/wsStoryFeed/Reference.map create mode 100755 Web References/wsStoryFeed/Reference.vb create mode 100755 Web References/wsStoryFeed/StoryFeed.disco create mode 100755 Web References/wsStoryFeed/StoryFeed.wsdl create mode 100755 icon_comment.gif create mode 100755 icon_xml.gif create mode 100755 module.css create mode 100755 ucAdminOptions.ascx create mode 100755 ucAdminOptions.ascx.designer.vb create mode 100755 ucAdminOptions.ascx.vb create mode 100755 ucApproveArticles.ascx create mode 100755 ucApproveArticles.ascx.designer.vb create mode 100755 ucApproveArticles.ascx.vb create mode 100755 ucApproveComments.ascx create mode 100755 ucApproveComments.ascx.designer.vb create mode 100755 ucApproveComments.ascx.vb create mode 100755 ucEditCategories.ascx create mode 100755 ucEditCategories.ascx.designer.vb create mode 100755 ucEditCategories.ascx.vb create mode 100755 ucEditCategory.ascx create mode 100755 ucEditCategory.ascx.designer.vb create mode 100755 ucEditCategory.ascx.vb create mode 100755 ucEditComment.ascx create mode 100755 ucEditComment.ascx.designer.vb create mode 100755 ucEditComment.ascx.vb create mode 100755 ucEditCustomField.ascx create mode 100755 ucEditCustomField.ascx.designer.vb create mode 100755 ucEditCustomField.ascx.vb create mode 100755 ucEditCustomFields.ascx create mode 100755 ucEditCustomFields.ascx.designer.vb create mode 100755 ucEditCustomFields.ascx.vb create mode 100755 ucEditPage.ascx create mode 100755 ucEditPage.ascx.designer.vb create mode 100755 ucEditPage.ascx.vb create mode 100755 ucEditPageSortOrder.ascx create mode 100755 ucEditPageSortOrder.ascx.designer.vb create mode 100755 ucEditPageSortOrder.ascx.vb create mode 100755 ucEditPages.ascx create mode 100755 ucEditPages.ascx.designer.vb create mode 100755 ucEditPages.ascx.vb create mode 100755 ucEditTag.ascx create mode 100755 ucEditTag.ascx.designer.vb create mode 100755 ucEditTag.ascx.vb create mode 100755 ucEditTags.ascx create mode 100755 ucEditTags.ascx.designer.vb create mode 100755 ucEditTags.ascx.vb create mode 100755 ucEmailTemplates.ascx create mode 100755 ucEmailTemplates.ascx.designer.vb create mode 100755 ucEmailTemplates.ascx.vb create mode 100755 ucHeader.ascx create mode 100755 ucHeader.ascx.designer.vb create mode 100755 ucHeader.ascx.vb create mode 100755 ucImportFeed.ascx create mode 100755 ucImportFeed.ascx.designer.vb create mode 100755 ucImportFeed.ascx.vb create mode 100755 ucImportFeeds.ascx create mode 100755 ucImportFeeds.ascx.designer.vb create mode 100755 ucImportFeeds.ascx.vb create mode 100755 ucMyArticles.ascx create mode 100755 ucMyArticles.ascx.designer.vb create mode 100755 ucMyArticles.ascx.vb create mode 100755 ucNotAuthenticated.ascx create mode 100755 ucNotAuthenticated.ascx.designer.vb create mode 100755 ucNotAuthenticated.ascx.vb create mode 100755 ucNotAuthorized.ascx create mode 100755 ucNotAuthorized.ascx.designer.vb create mode 100755 ucNotAuthorized.ascx.vb create mode 100755 ucSubmitNews.ascx create mode 100755 ucSubmitNews.ascx.designer.vb create mode 100755 ucSubmitNews.ascx.vb create mode 100755 ucSubmitNewsComplete.ascx create mode 100755 ucSubmitNewsComplete.ascx.designer.vb create mode 100755 ucSubmitNewsComplete.ascx.vb create mode 100755 ucTemplateEditor.ascx create mode 100755 ucTemplateEditor.ascx.designer.vb create mode 100755 ucTemplateEditor.ascx.vb create mode 100755 ucViewOptions.ascx create mode 100755 ucViewOptions.ascx.designer.vb create mode 100755 ucViewOptions.ascx.vb create mode 100755 web.config diff --git a/.DS_Store b/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..17ed1a39327a1d0b0d4722ae1d55f414494d6ca4 GIT binary patch literal 6148 zcmeHKJ5B>J5S@V(E77E+^cD67RFF2cR*A2(RlIZ;Qeo|(IGhF5DR&D=ntT3fx+AF8BWf{xa1he;N|4P#_fe zXA1DF>$?R$%J0^T&y%}0p**3839pC)gFkr$pdshTy$;%V5+A(mSPW$r>DO>zJOosb Ks6v5XP~Zcae=QOK literal 0 HcmV?d00001 diff --git a/API/MetaWebLog/Handler.ashx b/API/MetaWebLog/Handler.ashx new file mode 100755 index 0000000..695139d --- /dev/null +++ b/API/MetaWebLog/Handler.ashx @@ -0,0 +1 @@ +<%@ WebHandler Language="VB" CodeBehind="Handler.ashx.vb" Class="Ventrian.NewsArticles.API.MetaWebLog.Handler" %> diff --git a/API/MetaWebLog/Handler.ashx.vb b/API/MetaWebLog/Handler.ashx.vb new file mode 100755 index 0000000..2cd328b --- /dev/null +++ b/API/MetaWebLog/Handler.ashx.vb @@ -0,0 +1,514 @@ +Imports System.Web +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Common.Utilities +Imports System.Linq +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Services.Log.EventLog +Imports DotNetNuke.Services.FileSystem +Imports DotNetNuke.Entities.Users +Imports System.IO +Imports DotNetNuke.Security.Membership +Imports DotNetNuke.Entities.Tabs + +Namespace Ventrian.NewsArticles.API.MetaWebLog + + Public Class Handler + Implements IHttpHandler + + ReadOnly Property IsReusable() As Boolean Implements IHttpHandler.IsReusable + Get + Return False + End Get + End Property + + Private ReadOnly Property PortalSettings() As PortalSettings + Get + Return PortalController.GetCurrentPortalSettings() + End Get + End Property + + Sub ProcessRequest(ByVal context As HttpContext) Implements IHttpHandler.ProcessRequest + + Dim methodName As String = "" + Try + Dim input As New XmlrpcRequest(context) + Dim output As New XmlrpcResponse(input.MethodName) + + Dim objLoginStatus As UserLoginStatus + UserController.ValidateUser(PortalSettings.PortalId, input.UserName, input.Password, "", PortalSettings.PortalName, context.Request.UserHostAddress, objLoginStatus) + + If (objLoginStatus = UserLoginStatus.LOGIN_SUCCESS Or objLoginStatus = UserLoginStatus.LOGIN_SUPERUSER) = False Then + Throw New MetaException("10", "Unauthorized") + End If + + methodName = input.MethodName + + Select Case methodName + Case "metaWeblog.newPost" + output.PostId = NewPost(input.BlogId, input.UserName, input.Password, input.Post, input.Publish) + Exit Select + Case "metaWeblog.editPost" + output.Completed = EditPost(input.BlogId, input.PostId, input.UserName, input.Password, input.Post, input.Publish) + Exit Select + Case "metaWeblog.getPost" + output.Post = GetPost(input.PostId, input.UserName, input.Password) + Exit Select + Case "metaWeblog.newMediaObject" + output.MediaUrlInfo = NewMediaObject(input.BlogId, input.UserName, input.Password, input.MediaObject, context) + Exit Select + Case "metaWeblog.getCategories" + output.Categories = GetCategories(input.BlogId, input.UserName, input.Password) + Exit Select + Case "metaWeblog.getRecentPosts" + output.Posts = GetRecentPosts(input.BlogId, input.UserName, input.Password, input.NumberOfPosts) + Exit Select + Case "blogger.getUsersBlogs", "metaWeblog.getUsersBlogs" + output.Blogs = GetUserBlogs(input.AppKey, input.UserName, input.Password) + Exit Select + Case "blogger.deletePost" + output.Completed = DeletePost(input.AppKey, input.PostId, input.UserName, input.Password) + Exit Select + Case "blogger.getUserInfo" + ' Not implemented. Not planned. + Throw New MetaException("10", "The method GetUserInfo is not implemented.") + Case "wp.getTags" + output.Keywords = GetKeywords(input.BlogId, input.UserName, input.Password) + Exit Select + End Select + + output.Response(context) + Catch mex As MetaException + Dim objEventLog As New EventLogController + objEventLog.AddLog(methodName, mex.Message, PortalSettings, -1, EventLogController.EventLogType.ADMIN_ALERT) + Dim output = New XmlrpcResponse("fault") + Dim fault = New MetaFaultInfo() With { _ + .FaultCode = mex.Code, _ + .FaultString = mex.Message _ + } + output.Fault = fault + output.Response(context) + Catch ex As Exception + ' Log DNN Event + Dim objEventLog As New EventLogController + objEventLog.AddLog(methodName, ex.Message + ex.StackTrace, PortalSettings, -1, EventLogController.EventLogType.ADMIN_ALERT) + + ' Raise RPC Fault + Dim outputFault = New XmlrpcResponse("fault") + Dim fault = New MetaFaultInfo() With { _ + .FaultCode = "0", _ + .FaultString = ex.StackTrace _ + } + outputFault.Fault = fault + outputFault.Response(context) + End Try + + End Sub + + Private Shared Function CheckPermission(permission As String, moduleId As Integer, user As UserInfo) + + Dim check As Boolean = False + + Dim objModuleController As New ModuleController + Dim settings As Hashtable = objModuleController.GetModuleSettings(moduleId) + + If (user.IsSuperUser) Then + Return True + End If + + If (settings.Contains(permission)) Then + + If settings(permission).ToString().Split(New Char() {";"c}).Any(Function(role) user.IsInRole(role)) Then + check = True + End If + + End If + + Return check + + End Function + + Private Shared Function IsAuthor(moduleId As Integer, user As UserInfo) + + Return CheckPermission(ArticleConstants.PERMISSION_SUBMISSION_SETTING, moduleId, user) + + End Function + + Private Shared Function IsAutoApprover(moduleId As Integer, user As UserInfo) + + Return CheckPermission(ArticleConstants.PERMISSION_AUTO_APPROVAL_SETTING, moduleId, user) + + End Function + + Private Shared Function IsApprover(moduleId As Integer, user As UserInfo) + + Return CheckPermission(ArticleConstants.PERMISSION_APPROVAL_SETTING, moduleId, user) + + End Function + + Friend Function DeletePost(appKey As String, postId As String, userName As String, password As String) As Boolean + + Try + + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = objArticleController.GetArticle(postId) + + If (objArticle Is Nothing) Then + Throw New MetaException("01", "Article Not Found") + End If + + Dim objUser As UserInfo = UserController.GetUserByName(PortalSettings.PortalId, userName) + + If (objUser Is Nothing) Then + Throw New MetaException("01", "Username not found") + End If + + If (IsAuthor(objArticle.ModuleID, objUser) = False) Then + Throw New MetaException("01", "You do not have permission to delete posts") + End If + + If (objUser.UserID <> objArticle.AuthorID) Then + If (IsApprover(objArticle.ModuleID, objUser) = False) Then + Throw New MetaException("01", "You do not have permission to delete other's posts") + End If + End If + + objArticleController.DeleteArticle(postId) + + Catch ex As Exception + Throw New MetaException("12", String.Format("DeletePost failed. Error: {0}", ex.Message)) + End Try + + Return True + + End Function + + Friend Function EditPost(blogId As Integer, postId As String, userName As String, password As String, sentPost As MetaPostInfo, publish As Boolean) As Boolean + + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = objArticleController.GetArticle(postId) + + If (objArticle Is Nothing) Then + Throw New MetaException("01", "Article Not Found") + End If + + Dim objUser As UserInfo = UserController.GetUserByName(PortalSettings.PortalId, userName) + + If (objUser Is Nothing) Then + Throw New MetaException("01", "Username not found") + End If + + If (IsAuthor(objArticle.ModuleID, objUser) = False) Then + Throw New MetaException("01", "You do not have permission to edit posts") + End If + + If (objUser.UserID <> objArticle.AuthorID) Then + If (IsApprover(objArticle.ModuleID, objUser) = False) Then + Throw New MetaException("01", "You do not have permission to edit other's posts") + End If + End If + + objArticle.Title = sentPost.Title + objArticle.LastUpdate = DateTime.Now + objArticle.LastUpdateID = objUser.UserID + + objArticleController.UpdateArticle(objArticle) + + Dim objPageController As PageController = New PageController + Dim pages As ArrayList = objPageController.GetPageList(objArticle.ArticleID) + + If (pages.Count > 0) Then + Dim objPage As PageInfo = pages(0) + objPage.PageText = sentPost.Description + objPageController.UpdatePage(objPage) + End If + + objArticleController.DeleteArticleCategories(objArticle.ArticleID) + + Dim objCategoryController As New CategoryController() + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(objArticle.ModuleID) + + For Each item As String In sentPost.Categories.Where(Function(c) c IsNot Nothing AndAlso c.Trim() <> String.Empty) + + Dim categoryId As Integer = Null.NullInteger + + For Each objCategory As CategoryInfo In objCategories + If (objCategory.Name.ToLower() = item.ToLower()) Then + categoryId = objCategory.CategoryID + Exit For + End If + Next + + If (categoryId <> Null.NullInteger) Then + objArticleController.AddArticleCategory(objArticle.ArticleID, categoryId) + End If + + Next + + Dim objTagController As New TagController + objTagController.DeleteArticleTag(objArticle.ArticleID) + + For Each itemTag As String In sentPost.Tags.Where(Function(item) item IsNot Nothing AndAlso item.Trim() <> String.Empty) + Dim objTag As TagInfo = objTagController.Get(objArticle.ModuleID, itemTag) + + If (objTag Is Nothing) Then + objTag = New TagInfo + objTag.Name = itemTag + objTag.NameLowered = itemTag.ToLower() + objTag.ModuleID = objArticle.ModuleID + objTag.TagID = objTagController.Add(objTag) + End If + + objTagController.Add(objArticle.ArticleID, objTag.TagID) + Next + + Return True + End Function + + Friend Function GetCategories(blogId As String, userName As String, password As String) As List(Of MetaCategoryInfo) + + Dim objModuleController As New ModuleController() + Dim objTabModule As ModuleInfo = objModuleController.GetTabModule(blogId) + + Dim objCategoryController As New CategoryController() + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(objTabModule.ModuleID) + Dim objMetaCategories As New List(Of MetaCategoryInfo) + + For Each objCategory As CategoryInfo In objCategories + Dim objMetaCategory As New MetaCategoryInfo + objMetaCategory.Title = objCategory.Name + objMetaCategory.Description = objCategory.Description + objMetaCategory.HtmlUrl = "#" + objMetaCategory.RssUrl = "#" + objMetaCategories.Add(objMetaCategory) + Next + + Return objMetaCategories + + End Function + + Friend Function GetKeywords(blogId As String, userName As String, password As String) As List(Of String) + + Dim objModuleController As New ModuleController() + Dim objTabModule As ModuleInfo = objModuleController.GetTabModule(blogId) + + Dim objTagController As New TagController + Dim objTags As ArrayList = objTagController.List(objTabModule.ModuleID, 1000) + + Return (From objTag As TagInfo In objTags Where (objTag.Name.Trim() <> "") Select objTag.Name).ToList() + + End Function + + Friend Function GetPost(postId As String, userName As String, password As String) As MetaPostInfo + + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = objArticleController.GetArticle(postId) + + If (objArticle Is Nothing) Then + Throw New MetaException("01", "Article Not Found") + End If + + Dim sendPost As New MetaPostInfo() + + sendPost.PostId = objArticle.ArticleID.ToString() + sendPost.PostDate = objArticle.StartDate + sendPost.Title = objArticle.Title + sendPost.Description = HttpUtility.HtmlDecode(objArticle.Body) + sendPost.Link = objArticle.Url + sendPost.Excerpt = objArticle.Summary + sendPost.Publish = (objArticle.Status = StatusType.Published) + + Dim objArticleCategories As ArrayList = objArticleController.GetArticleCategories(objArticle.ArticleID) + sendPost.Categories = (From objCategory As CategoryInfo In objArticleCategories Select objCategory.Name).ToList() + sendPost.Tags = objArticle.Tags.Split(","c).ToList() + + Return sendPost + End Function + + Friend Function GetRecentPosts(blogId As String, userName As String, password As String, numberOfPosts As Integer) As List(Of MetaPostInfo) + + Dim objUser As UserInfo = UserController.GetUserByName(PortalSettings.PortalId, userName) + + If (objUser Is Nothing) Then + Throw New MetaException("01", "Username not found") + End If + + Dim objModuleController As New ModuleController() + Dim objTabModule As ModuleInfo = objModuleController.GetTabModule(blogId) + + Dim authorId As Integer = objUser.UserID + If (IsApprover(objTabModule.ModuleID, objUser)) Then + authorId = Null.NullInteger + End If + + Dim sendPosts As New List(Of MetaPostInfo)() + + Dim objArticleController As New ArticleController + Dim objArticles As List(Of ArticleInfo) = objArticleController.GetArticleList(objTabModule.ModuleID, DateTime.Now, Null.NullDate, Nothing, False, Nothing, numberOfPosts, 1, numberOfPosts, "StartDate", "DESC", True, False, Null.NullString, authorId, False, False, False, False, False, False, Null.NullString, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, Nothing) + + For Each objArticle As ArticleInfo In objArticles + + Dim tempPost As New MetaPostInfo() With { _ + .PostId = objArticle.ArticleID, _ + .PostDate = DateTime.Now, _ + .Title = objArticle.Title, _ + .Description = objArticle.ArticleText, _ + .Link = objArticle.Url, _ + .Excerpt = objArticle.Summary, _ + .Publish = (objArticle.Status = StatusType.Published) _ + } + + Dim objArticleCategories As ArrayList = objArticleController.GetArticleCategories(objArticle.ArticleID) + tempPost.Categories = (From objCategory As CategoryInfo In objArticleCategories Select objCategory.Name).ToList() + tempPost.Tags = objArticle.Tags.Split(","c).ToList() + + sendPosts.Add(tempPost) + Next + + Return sendPosts + + End Function + + Friend Function GetUserBlogs(appKey As String, userName As String, password As String) As List(Of MetaBlogInfo) + + Dim blogs As New List(Of MetaBlogInfo)() + For Each objModule As ModuleInfo In Common.GetArticleModules(PortalSettings.PortalId) + Dim modulePath As String = objModule.ParentTab.TabPath.Replace("//", "/") + If (modulePath.Length > 1 And modulePath.Substring(0, 1) = "/") Then + modulePath = modulePath.Substring(1) + End If + Dim temp As New MetaBlogInfo() With { _ + .Url = DotNetNuke.Common.Globals.NavigateURL(objModule.TabID), _ + .BlogId = objModule.TabModuleID, _ + .BlogName = objModule.ModuleTitle + " (" + modulePath + ")" _ + } + blogs.Add(temp) + Next + + Return blogs + + End Function + + Friend Function NewMediaObject(blogId As String, userName As String, password As String, mediaObject As MetaMediaInfo, request As HttpContext) As MetaMediaUrlInfo + + Dim objUser As UserInfo = UserController.GetUserByName(PortalSettings.PortalId, userName) + + If (objUser Is Nothing) Then + Throw New MetaException("01", "Username not found") + End If + + Dim folders As IFolderManager = FolderManager.Instance() + Dim files As IFileManager = FileManager.Instance + + Dim userFolder = folders.GetUserFolder(objUser) + Dim ms As New MemoryStream(mediaObject.Bits) + Dim fileInfo As DotNetNuke.Services.FileSystem.FileInfo = files.AddFile(userFolder, mediaObject.Name.Replace(" ", "_").Replace(":", "-"), ms, True) + ms.Close() + + Dim mediaInfo As New MetaMediaUrlInfo() + mediaInfo.Url = FileManager.Instance.GetUrl(fileInfo) + + Return mediaInfo + + End Function + + Friend Function NewPost(blogId As String, userName As String, password As String, sentPost As MetaPostInfo, publish As Boolean) As String + + Dim objModuleController As New ModuleController() + Dim objTabModule As ModuleInfo = objModuleController.GetTabModule(blogId) + + If (objTabModule Is Nothing) Then + Throw New MetaException("11", "BlogID not found.") + End If + + Dim objTabController As New TabController() + Dim objTab As TabInfo = objTabController.GetTab(objTabModule.TabID, PortalSettings.PortalId, False) + + Dim objUser As UserInfo = UserController.GetUserByName(PortalSettings.PortalId, userName) + + If (objUser Is Nothing) Then + Throw New MetaException("01", "Username not found") + End If + + Dim author As Boolean = IsAuthor(objTabModule.ModuleID, objUser) + Dim autoApprove As Boolean = IsAutoApprover(objTabModule.ModuleID, objUser) + Dim approver As Boolean = IsApprover(objTabModule.ModuleID, objUser) + + If (author = False) Then + Throw New MetaException("01", "You do not have permission to post articles") + End If + + Dim objSettings As Hashtable = objModuleController.GetModuleSettings(objTabModule.ModuleID) + Dim objArticleSettings As New ArticleSettings(objSettings, PortalSettings, objTabModule) + + Dim objArticle As New ArticleInfo + + objArticle.ModuleID = objTabModule.ModuleID + objArticle.Title = sentPost.Title + objArticle.ArticleText = HttpUtility.HtmlEncode(sentPost.Description) + objArticle.AuthorID = objUser.UserID + objArticle.CreatedDate = DateTime.Now + objArticle.StartDate = Null.NullDate + objArticle.EndDate = Null.NullDate + objArticle.LastUpdate = DateTime.Now + objArticle.LastUpdateID = objUser.UserID + objArticle.Summary = HttpUtility.HtmlEncode(sentPost.Excerpt) + + objArticle.CommentCount = 0 + objArticle.RatingCount = 0 + objArticle.FileCount = 0 + objArticle.Rating = 0 + objArticle.ShortUrl = "" + + If (publish) Then + objArticle.Status = StatusType.Published + objArticle.StartDate = DateTime.Now + If (approver = False) Then + If (autoApprove = False) Then + objArticle.Status = StatusType.AwaitingApproval + + If (objSettings.Contains(ArticleConstants.NOTIFY_SUBMISSION_SETTING)) Then + If (Convert.ToBoolean(objSettings(ArticleConstants.NOTIFY_SUBMISSION_SETTING)) = True) Then + Dim objEmailTemplateController As New EmailTemplateController + Dim emails As String = objEmailTemplateController.GetApproverDistributionList(objTabModule.ModuleID) + + For Each email As String In emails.Split(Convert.ToChar(";")) + If (email <> "") Then + objEmailTemplateController.SendFormattedEmail(objTabModule.ModuleID, Common.GetArticleLink(objArticle, objTab, objArticleSettings, False), objArticle, EmailTemplateType.ArticleSubmission, email, objArticleSettings) + End If + Next + End If + End If + + If (objSettings.Contains(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL)) Then + If (objSettings(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL).ToString() <> "") Then + Dim objEmailTemplateController As New EmailTemplateController + For Each email As String In objSettings(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL).ToString().Split(","c) + objEmailTemplateController.SendFormattedEmail(objTabModule.ModuleID, Common.GetArticleLink(objArticle, objTab, objArticleSettings, False), objArticle, EmailTemplateType.ArticleSubmission, email, objArticleSettings) + Next + End If + End If + + End If + End If + Else + objArticle.Status = StatusType.Draft + End If + + Dim objArticleController As New ArticleController() + objArticle.ArticleID = objArticleController.AddArticle(objArticle) + + Dim objPage As New PageInfo + objPage.PageText = HttpUtility.HtmlEncode(sentPost.Description) + objPage.ArticleID = objArticle.ArticleID + objPage.Title = sentPost.Title + + Dim objPageController As New PageController() + objPageController.AddPage(objPage) + + Return objArticle.ArticleID.ToString() + + End Function + + End Class + +End Namespace \ No newline at end of file diff --git a/API/MetaWebLog/MetaBlogInfo.vb b/API/MetaWebLog/MetaBlogInfo.vb new file mode 100755 index 0000000..610ee64 --- /dev/null +++ b/API/MetaWebLog/MetaBlogInfo.vb @@ -0,0 +1,11 @@ +Namespace Ventrian.NewsArticles.API.MetaWebLog + + Friend Class MetaBlogInfo + + Public BlogId As String + Public BlogName As String + Public Url As String + + End Class + +End Namespace diff --git a/API/MetaWebLog/MetaCategoryInfo.vb b/API/MetaWebLog/MetaCategoryInfo.vb new file mode 100755 index 0000000..69b0926 --- /dev/null +++ b/API/MetaWebLog/MetaCategoryInfo.vb @@ -0,0 +1,13 @@ +Namespace Ventrian.NewsArticles.API.MetaWebLog + + Friend Class MetaCategoryInfo + + Public Description As String + Public HtmlUrl As String + Public Id As String + Public RssUrl As String + Public Title As String + + End Class + +End Namespace diff --git a/API/MetaWebLog/MetaException.vb b/API/MetaWebLog/MetaException.vb new file mode 100755 index 0000000..affc9b5 --- /dev/null +++ b/API/MetaWebLog/MetaException.vb @@ -0,0 +1,24 @@ +Namespace Ventrian.NewsArticles.API.MetaWebLog + + _ + Public Class MetaException + Inherits Exception + +#Region "Constructors" + + Public Sub New(code As String, message As String) + MyBase.New(message) + Me.Code = code + End Sub + +#End Region + +#Region "Properties" + + Public Property Code As String + +#End Region + + End Class + +End Namespace diff --git a/API/MetaWebLog/MetaFaultInfo.vb b/API/MetaWebLog/MetaFaultInfo.vb new file mode 100755 index 0000000..69065f7 --- /dev/null +++ b/API/MetaWebLog/MetaFaultInfo.vb @@ -0,0 +1,10 @@ +Namespace Ventrian.NewsArticles.API.MetaWebLog + + Public Class MetaFaultInfo + + Public FaultCode As String + Public FaultString As String + + End Class + +End Namespace diff --git a/API/MetaWebLog/MetaMediaInfo.vb b/API/MetaWebLog/MetaMediaInfo.vb new file mode 100755 index 0000000..aa2c9e6 --- /dev/null +++ b/API/MetaWebLog/MetaMediaInfo.vb @@ -0,0 +1,15 @@ +Namespace Ventrian.NewsArticles.API.MetaWebLog + + Friend Structure MetaMediaInfo + +#Region "Properties" + + Public Bits As Byte() + Public Name As String + Public Type As String + +#End Region + + End Structure + +End Namespace diff --git a/API/MetaWebLog/MetaMediaUrlInfo.vb b/API/MetaWebLog/MetaMediaUrlInfo.vb new file mode 100755 index 0000000..770205e --- /dev/null +++ b/API/MetaWebLog/MetaMediaUrlInfo.vb @@ -0,0 +1,13 @@ +Namespace Ventrian.NewsArticles.API.MetaWebLog + + Friend Structure MetaMediaUrlInfo + +#Region "Constants and Fields" + + Public Url As String + +#End Region + + End Structure + +End Namespace diff --git a/API/MetaWebLog/MetaPostInfo.vb b/API/MetaWebLog/MetaPostInfo.vb new file mode 100755 index 0000000..6e14d4f --- /dev/null +++ b/API/MetaWebLog/MetaPostInfo.vb @@ -0,0 +1,18 @@ +Namespace Ventrian.NewsArticles.API.MetaWebLog + + Friend Class MetaPostInfo + + Public Author As String + Public Categories As List(Of String) + Public Description As String + Public Excerpt As String + Public Link As String + Public PostDate As DateTime + Public PostId As String + Public Publish As Boolean + Public Tags As List(Of String) + Public Title As String + + End Class + +End Namespace diff --git a/API/MetaWebLog/XmlrpcRequest.vb b/API/MetaWebLog/XmlrpcRequest.vb new file mode 100755 index 0000000..4bd09a5 --- /dev/null +++ b/API/MetaWebLog/XmlrpcRequest.vb @@ -0,0 +1,223 @@ +Imports System.Xml +Imports System.Globalization +Imports System.Linq + +Namespace Ventrian.NewsArticles.API.MetaWebLog + + Friend Class XmlrpcRequest + +#Region "Private Members" + + Private _inputParams As List(Of XmlNode) + +#End Region + +#Region "Constructor" + + Public Sub New(input As HttpContext) + + Dim inputXml = ParseRequest(input) + LoadXmlRequest(inputXml) + + End Sub + +#End Region + +#Region "Properties" + + Public Property AppKey As String + Public Property BlogId As String + Public Property MediaObject As MetaMediaInfo + Public Property MethodName As String + Public Property NumberOfPosts As Integer + Public Property Password As String + Public Property Post As MetaPostInfo + Public Property PostId As String + Public Property Publish As Boolean + Public Property UserName As String + +#End Region + +#Region "Methods" + + Private Shared Function GetMediaObject(node As XmlNode) As MetaMediaInfo + Dim name = node.SelectSingleNode("value/struct/member[name='name']") + Dim type = node.SelectSingleNode("value/struct/member[name='type']") + Dim bits = node.SelectSingleNode("value/struct/member[name='bits']") + Dim temp = New MetaMediaInfo() With { _ + .name = If(name Is Nothing, String.Empty, name.LastChild.InnerText), _ + .type = If(type Is Nothing, "notsent", type.LastChild.InnerText), _ + .bits = Convert.FromBase64String(If(bits Is Nothing, String.Empty, bits.LastChild.InnerText)) _ + } + + Return temp + End Function + + Private Shared Function GetPost(node As XmlNode) As MetaPostInfo + Dim temp = New MetaPostInfo() + + ' Require Title and Description + Dim title = node.SelectSingleNode("value/struct/member[name='title']") + If title Is Nothing Then + Throw New MetaException("05", "Page Struct Element, Title, not Sent.") + End If + + temp.title = title.LastChild.InnerText + + Dim description = node.SelectSingleNode("value/struct/member[name='description']") + If description Is Nothing Then + Throw New MetaException("05", "Page Struct Element, Description, not Sent.") + End If + + temp.description = description.LastChild.InnerText + + Dim link = node.SelectSingleNode("value/struct/member[name='link']") + temp.link = If(link Is Nothing, String.Empty, link.LastChild.InnerText) + + Dim excerpt = node.SelectSingleNode("value/struct/member[name='mt_excerpt']") + temp.excerpt = If(excerpt Is Nothing, String.Empty, excerpt.LastChild.InnerText) + + Dim cats = New List(Of String)() + Dim categories = node.SelectSingleNode("value/struct/member[name='categories']") + If categories IsNot Nothing Then + Dim categoryArray = categories.LastChild + Dim categoryArrayNodes As XmlNodeList = categoryArray.SelectNodes("array/data/value/string") + If categoryArrayNodes IsNot Nothing Then + For Each objNode As XmlNode In categoryArrayNodes + cats.Add(objNode.InnerText) + Next + End If + End If + + temp.categories = cats + + ' postDate has a few different names to worry about + Dim dateCreated = node.SelectSingleNode("value/struct/member[name='dateCreated']") + Dim pubDate = node.SelectSingleNode("value/struct/member[name='pubDate']") + If dateCreated IsNot Nothing Then + Try + Dim tempDate = dateCreated.LastChild.InnerText + temp.postDate = DateTime.ParseExact(tempDate, "yyyyMMdd'T'HH':'mm':'ss", CultureInfo.InvariantCulture, DateTimeStyles.AssumeUniversal) + Catch ex As Exception + ' Ignore PubDate Error + Debug.WriteLine(ex.Message) + End Try + ElseIf pubDate IsNot Nothing Then + Try + Dim tempPubDate = pubDate.LastChild.InnerText + temp.postDate = DateTime.ParseExact(tempPubDate, "yyyyMMdd'T'HH':'mm':'ss", CultureInfo.InvariantCulture, DateTimeStyles.AssumeUniversal) + Catch ex As Exception + ' Ignore PubDate Error + Debug.WriteLine(ex.Message) + End Try + End If + + ' WLW tags implementation using mt_keywords + Dim tags = New List(Of String)() + Dim keywords = node.SelectSingleNode("value/struct/member[name='mt_keywords']") + If keywords IsNot Nothing Then + Dim tagsList = keywords.LastChild.InnerText + For Each item As String In tagsList.Split(","c) + If (item.Trim() <> "") Then + tags.Add(item.Trim()) + End If + Next + End If + + temp.tags = tags + + Return temp + End Function + + Private Sub LoadXmlRequest(xml As String) + Dim request = New XmlDocument() + Try + If Not (xml.StartsWith(" "0" AndAlso _inputParams(4).InnerText <> "false" + Exit Select + Case "metaWeblog.editPost" + PostId = _inputParams(0).InnerText + UserName = _inputParams(1).InnerText + Password = _inputParams(2).InnerText + Post = GetPost(_inputParams(3)) + Publish = _inputParams(4).InnerText <> "0" AndAlso _inputParams(4).InnerText <> "false" + Exit Select + Case "metaWeblog.getPost" + PostId = _inputParams(0).InnerText + UserName = _inputParams(1).InnerText + Password = _inputParams(2).InnerText + Exit Select + Case "metaWeblog.newMediaObject" + BlogId = _inputParams(0).InnerText + UserName = _inputParams(1).InnerText + Password = _inputParams(2).InnerText + MediaObject = GetMediaObject(_inputParams(3)) + Exit Select + Case "metaWeblog.getCategories", "wp.getTags" + BlogId = _inputParams(0).InnerText + UserName = _inputParams(1).InnerText + Password = _inputParams(2).InnerText + Exit Select + Case "metaWeblog.getRecentPosts" + BlogId = _inputParams(0).InnerText + UserName = _inputParams(1).InnerText + Password = _inputParams(2).InnerText + NumberOfPosts = Int32.Parse(_inputParams(3).InnerText, CultureInfo.InvariantCulture) + Exit Select + Case "blogger.getUsersBlogs", "metaWeblog.getUsersBlogs" + AppKey = _inputParams(0).InnerText + UserName = _inputParams(1).InnerText + Password = _inputParams(2).InnerText + Exit Select + Case "blogger.deletePost" + AppKey = _inputParams(0).InnerText + PostId = _inputParams(1).InnerText + UserName = _inputParams(2).InnerText + Password = _inputParams(3).InnerText + Publish = _inputParams(4).InnerText <> "0" AndAlso _inputParams(4).InnerText <> "false" + Exit Select + Case Else + Throw New MetaException("02", String.Format("Unknown Method. ({0})", MethodName)) + End Select + End Sub + + Private Shared Function ParseRequest(context As HttpContext) As String + Dim buffer = New Byte(context.Request.InputStream.Length - 1) {} + + context.Request.InputStream.Position = 0 + context.Request.InputStream.Read(buffer, 0, buffer.Length) + + Return Encoding.UTF8.GetString(buffer) + End Function + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/API/MetaWebLog/XmlrpcResponse.vb b/API/MetaWebLog/XmlrpcResponse.vb new file mode 100755 index 0000000..7915be5 --- /dev/null +++ b/API/MetaWebLog/XmlrpcResponse.vb @@ -0,0 +1,488 @@ +Imports System.Xml + +Namespace Ventrian.NewsArticles.API.MetaWebLog + + Friend Class XmlrpcResponse + +#Region "Private Members" + + Private ReadOnly _methodName As String + +#End Region + +#Region "Constructors and Destructors" + + Public Sub New(methodName As String) + _methodName = methodName + Blogs = New List(Of MetaBlogInfo)() + Categories = New List(Of MetaCategoryInfo)() + Keywords = New List(Of String)() + Posts = New List(Of MetaPostInfo)() + End Sub + +#End Region + +#Region "Properties" + + Public Property Blogs As List(Of MetaBlogInfo) + Public Property Categories As List(Of MetaCategoryInfo) + Public Property Completed As Boolean + Public Property Fault As MetaFaultInfo + Public Property Keywords As List(Of String) + Public Property MediaUrlInfo As MetaMediaUrlInfo + Public Property Post As MetaPostInfo + Public Property PostId As String + Public Property Posts As List(Of MetaPostInfo) + +#End Region + +#Region "Public Methods" + + Public Sub Response(context As HttpContext) + + context.Response.ContentType = "text/xml" + Using data As New XmlTextWriter(context.Response.OutputStream, Encoding.UTF8) + data.Formatting = Formatting.Indented + data.WriteStartDocument() + data.WriteStartElement("methodResponse") + data.WriteStartElement(If(_methodName = "fault", "fault", "params")) + + Select Case _methodName + Case "metaWeblog.newPost" + WriteNewPost(data) + Exit Select + Case "metaWeblog.getPost" + WritePost(data) + Exit Select + Case "metaWeblog.newMediaObject" + WriteMediaInfo(data) + Exit Select + Case "metaWeblog.getCategories" + WriteGetCategories(data) + Exit Select + Case "metaWeblog.getRecentPosts" + WritePosts(data) + Exit Select + Case "blogger.getUsersBlogs", "metaWeblog.getUsersBlogs" + WriteGetUsersBlogs(data) + Exit Select + Case "metaWeblog.editPost", "blogger.deletePost" + WriteBool(data) + Exit Select + Case "wp.getTags" + WriteKeywords(data) + Exit Select + Case "fault" + WriteFault(data) + Exit Select + End Select + + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndDocument() + End Using + + End Sub + +#End Region + +#Region "Methods" + + Private Shared Function ConvertDatetoIso8601([date] As DateTime) As String + Dim temp = String.Format("{0}{1}{2}T{3}:{4}:{5}", [date].Year, [date].Month.ToString().PadLeft(2, "0"c), [date].Day.ToString().PadLeft(2, "0"c), [date].Hour.ToString().PadLeft(2, "0"c), [date].Minute.ToString().PadLeft(2, "0"c), _ + [date].Second.ToString().PadLeft(2, "0"c)) + Return temp + End Function + + Private Sub WriteBool(data As XmlWriter) + Dim postValue = "0" + If Completed Then + postValue = "1" + End If + + data.WriteStartElement("param") + data.WriteStartElement("value") + data.WriteElementString("boolean", postValue) + data.WriteEndElement() + data.WriteEndElement() + End Sub + + Private Sub WriteFault(data As XmlWriter) + data.WriteStartElement("value") + data.WriteStartElement("struct") + + ' faultCode + data.WriteStartElement("member") + data.WriteElementString("name", "faultCode") + data.WriteElementString("value", Fault.FaultCode) + data.WriteEndElement() + + ' faultString + data.WriteStartElement("member") + data.WriteElementString("name", "faultString") + data.WriteElementString("value", Fault.FaultString) + data.WriteEndElement() + + data.WriteEndElement() + data.WriteEndElement() + End Sub + + Private Sub WriteGetCategories(data As XmlWriter) + data.WriteStartElement("param") + data.WriteStartElement("value") + data.WriteStartElement("array") + data.WriteStartElement("data") + + For Each category As MetaCategoryInfo In Categories + data.WriteStartElement("value") + data.WriteStartElement("struct") + + ' description + data.WriteStartElement("member") + data.WriteElementString("name", "description") + data.WriteElementString("value", category.Description) + data.WriteEndElement() + + ' categoryid + data.WriteStartElement("member") + data.WriteElementString("name", "categoryid") + data.WriteElementString("value", category.Id) + data.WriteEndElement() + + ' title + data.WriteStartElement("member") + data.WriteElementString("name", "title") + data.WriteElementString("value", category.Title) + data.WriteEndElement() + + ' htmlUrl + data.WriteStartElement("member") + data.WriteElementString("name", "htmlUrl") + data.WriteElementString("value", category.HtmlUrl) + data.WriteEndElement() + + ' rssUrl + data.WriteStartElement("member") + data.WriteElementString("name", "rssUrl") + data.WriteElementString("value", category.RssUrl) + data.WriteEndElement() + + data.WriteEndElement() + data.WriteEndElement() + Next + + ' Close tags + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + End Sub + + Private Sub WriteGetUsersBlogs(data As XmlWriter) + data.WriteStartElement("param") + data.WriteStartElement("value") + data.WriteStartElement("array") + data.WriteStartElement("data") + + For Each blog As MetaBlogInfo In Blogs + data.WriteStartElement("value") + data.WriteStartElement("struct") + + ' url + data.WriteStartElement("member") + data.WriteElementString("name", "url") + data.WriteElementString("value", blog.Url) + data.WriteEndElement() + + ' blogid + data.WriteStartElement("member") + data.WriteElementString("name", "blogid") + data.WriteElementString("value", blog.BlogId) + data.WriteEndElement() + + ' blogName + data.WriteStartElement("member") + data.WriteElementString("name", "blogName") + data.WriteElementString("value", blog.BlogName) + data.WriteEndElement() + + data.WriteEndElement() + data.WriteEndElement() + Next + + ' Close tags + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + End Sub + + Private Sub WriteKeywords(data As XmlWriter) + data.WriteStartElement("param") + data.WriteStartElement("value") + data.WriteStartElement("array") + data.WriteStartElement("data") + + For Each keyword As String In Keywords + data.WriteStartElement("value") + data.WriteStartElement("struct") + + ' keywordName + data.WriteStartElement("member") + data.WriteElementString("name", "name") + data.WriteElementString("value", keyword) + data.WriteEndElement() + + data.WriteEndElement() + data.WriteEndElement() + Next + + ' Close tags + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + End Sub + + Private Sub WriteMediaInfo(data As XmlWriter) + data.WriteStartElement("param") + data.WriteStartElement("value") + data.WriteStartElement("struct") + + ' url + data.WriteStartElement("member") + data.WriteElementString("name", "url") + data.WriteStartElement("value") + data.WriteElementString("string", MediaUrlInfo.Url) + data.WriteEndElement() + data.WriteEndElement() + + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + End Sub + + Private Sub WriteNewPost(data As XmlWriter) + data.WriteStartElement("param") + data.WriteStartElement("value") + data.WriteElementString("string", PostId) + data.WriteEndElement() + data.WriteEndElement() + End Sub + + Private Sub WritePost(data As XmlWriter) + data.WriteStartElement("param") + data.WriteStartElement("value") + data.WriteStartElement("struct") + + ' postid + data.WriteStartElement("member") + data.WriteElementString("name", "postid") + data.WriteStartElement("value") + data.WriteElementString("string", Post.PostId) + data.WriteEndElement() + data.WriteEndElement() + + ' title + data.WriteStartElement("member") + data.WriteElementString("name", "title") + data.WriteStartElement("value") + data.WriteElementString("string", Post.Title) + data.WriteEndElement() + data.WriteEndElement() + + ' description + data.WriteStartElement("member") + data.WriteElementString("name", "description") + data.WriteStartElement("value") + data.WriteElementString("string", Post.Description) + data.WriteEndElement() + data.WriteEndElement() + + ' link + data.WriteStartElement("member") + data.WriteElementString("name", "link") + data.WriteStartElement("value") + data.WriteElementString("string", Post.Link) + data.WriteEndElement() + data.WriteEndElement() + + ' excerpt + data.WriteStartElement("member") + data.WriteElementString("name", "mt_excerpt") + data.WriteStartElement("value") + data.WriteElementString("string", Post.Excerpt) + data.WriteEndElement() + data.WriteEndElement() + + ' dateCreated + data.WriteStartElement("member") + data.WriteElementString("name", "dateCreated") + data.WriteStartElement("value") + data.WriteElementString("dateTime.iso8601", ConvertDatetoIso8601(Post.PostDate)) + data.WriteEndElement() + data.WriteEndElement() + + ' publish + data.WriteStartElement("member") + data.WriteElementString("name", "publish") + data.WriteStartElement("value") + data.WriteElementString("boolean", If(Post.Publish, "1", "0")) + + data.WriteEndElement() + data.WriteEndElement() + + ' tags (mt_keywords) + data.WriteStartElement("member") + data.WriteElementString("name", "mt_keywords") + data.WriteStartElement("value") + Dim tags = New String(Post.Tags.Count - 1) {} + For i As Integer = 0 To Post.Tags.Count - 1 + tags(i) = Post.Tags(i) + Next + + Dim tagList = String.Join(",", tags) + data.WriteElementString("string", tagList) + data.WriteEndElement() + data.WriteEndElement() + + ' categories + If Post.Categories.Count > 0 Then + data.WriteStartElement("member") + data.WriteElementString("name", "categories") + data.WriteStartElement("value") + data.WriteStartElement("array") + data.WriteStartElement("data") + For Each cat As String In Post.Categories + data.WriteStartElement("value") + data.WriteElementString("string", cat) + data.WriteEndElement() + Next + + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + End If + + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + End Sub + + Private Sub WritePosts(data As XmlWriter) + data.WriteStartElement("param") + data.WriteStartElement("value") + data.WriteStartElement("array") + data.WriteStartElement("data") + + For Each childPost As MetaPostInfo In Posts + data.WriteStartElement("value") + data.WriteStartElement("struct") + + ' postid + data.WriteStartElement("member") + data.WriteElementString("name", "postid") + data.WriteStartElement("value") + data.WriteElementString("string", childPost.PostId) + data.WriteEndElement() + data.WriteEndElement() + + ' dateCreated + data.WriteStartElement("member") + data.WriteElementString("name", "dateCreated") + data.WriteStartElement("value") + data.WriteElementString("dateTime.iso8601", ConvertDatetoIso8601(childPost.PostDate)) + data.WriteEndElement() + data.WriteEndElement() + + ' title + data.WriteStartElement("member") + data.WriteElementString("name", "title") + data.WriteStartElement("value") + data.WriteElementString("string", childPost.Title) + data.WriteEndElement() + data.WriteEndElement() + + ' description + data.WriteStartElement("member") + data.WriteElementString("name", "description") + data.WriteStartElement("value") + data.WriteElementString("string", childPost.Description) + data.WriteEndElement() + data.WriteEndElement() + + ' link + data.WriteStartElement("member") + data.WriteElementString("name", "link") + data.WriteStartElement("value") + data.WriteElementString("string", childPost.Link) + data.WriteEndElement() + data.WriteEndElement() + + ' excerpt + data.WriteStartElement("member") + data.WriteElementString("name", "mt_excerpt") + data.WriteStartElement("value") + data.WriteElementString("string", childPost.Excerpt) + data.WriteEndElement() + data.WriteEndElement() + + ' tags (mt_keywords) + data.WriteStartElement("member") + data.WriteElementString("name", "mt_keywords") + data.WriteStartElement("value") + Dim tags = New String(childPost.Tags.Count - 1) {} + For i As Integer = 0 To childPost.Tags.Count - 1 + tags(i) = childPost.Tags(i) + Next + + Dim tagList = String.Join(",", tags) + data.WriteElementString("string", tagList) + data.WriteEndElement() + data.WriteEndElement() + + ' publish + data.WriteStartElement("member") + data.WriteElementString("name", "publish") + data.WriteStartElement("value") + data.WriteElementString("boolean", If(childPost.Publish, "1", "0")) + + data.WriteEndElement() + data.WriteEndElement() + + ' categories + If childPost.Categories.Count > 0 Then + data.WriteStartElement("member") + data.WriteElementString("name", "categories") + data.WriteStartElement("value") + data.WriteStartElement("array") + data.WriteStartElement("data") + For Each cat As String In childPost.Categories + data.WriteStartElement("value") + data.WriteElementString("string", cat) + data.WriteEndElement() + Next + + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + End If + + data.WriteEndElement() + data.WriteEndElement() + Next + + ' Close tags + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + data.WriteEndElement() + End Sub + +#End Region + + End Class + +End Namespace diff --git a/API/MetaWebLog/wlwmanifest.xml b/API/MetaWebLog/wlwmanifest.xml new file mode 100755 index 0000000..7669dee --- /dev/null +++ b/API/MetaWebLog/wlwmanifest.xml @@ -0,0 +1,19 @@ + + + + Metaweblog + Yes + Yes + No + No + No + No + Yes + No + No + No + Yes + No + {FileName} + + \ No newline at end of file diff --git a/API/Rsd.ashx b/API/Rsd.ashx new file mode 100755 index 0000000..3b2750f --- /dev/null +++ b/API/Rsd.ashx @@ -0,0 +1 @@ +<%@ WebHandler Language="VB" CodeBehind="Rsd.ashx.vb" Class="Ventrian.NewsArticles.API.Rsd" %> diff --git a/API/Rsd.ashx.vb b/API/Rsd.ashx.vb new file mode 100755 index 0000000..75438ad --- /dev/null +++ b/API/Rsd.ashx.vb @@ -0,0 +1,53 @@ +Imports System.Web +Imports System.Xml +Imports Ventrian.NewsArticles.Components.Common + +Namespace Ventrian.NewsArticles.API + + Public Class Rsd + Implements IHttpHandler + + Sub ProcessRequest(ByVal context As HttpContext) Implements IHttpHandler.ProcessRequest + + context.Response.ContentType = "text/xml" + + Using data As New XmlTextWriter(context.Response.OutputStream, Encoding.UTF8) + data.Formatting = Formatting.Indented + data.WriteStartDocument() + data.WriteStartElement("rsd") + data.WriteAttributeString("version", "1.0") + + data.WriteStartElement("service") + + data.WriteElementString("engineName", "Ventrian News Articles") + data.WriteElementString("engineLink", "http://www.ventrian.com/") + data.WriteElementString("homePageLink", context.Request("url")) + + data.WriteStartElement("apis") + + data.WriteStartElement("api") + data.WriteAttributeString("name", "MetaWeblog") + data.WriteAttributeString("preferred", "true") + data.WriteAttributeString("apiLink", ArticleUtilities.ToAbsoluteUrl("~/desktopmodules/dnnforge%20-%20newsarticles/api/metaweblog/handler.ashx")) + data.WriteAttributeString("blogID", context.Request("id")) + data.WriteEndElement() + + data.WriteEndElement() + + data.WriteEndElement() + + data.WriteEndElement() + data.WriteEndDocument() + End Using + + End Sub + + ReadOnly Property IsReusable() As Boolean Implements IHttpHandler.IsReusable + Get + Return False + End Get + End Property + + End Class + +End Namespace \ No newline at end of file diff --git a/App_LocalResources/Archives.ascx.resx b/App_LocalResources/Archives.ascx.resx new file mode 100755 index 0000000..0de79fb --- /dev/null +++ b/App_LocalResources/Archives.ascx.resx @@ -0,0 +1,138 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + articles + + + By Author + + + By Category + + + By Month + + + Archives + + + Latest 25 Articles + + \ No newline at end of file diff --git a/App_LocalResources/Handout.ascx.resx b/App_LocalResources/Handout.ascx.resx new file mode 100755 index 0000000..ef38e9f --- /dev/null +++ b/App_LocalResources/Handout.ascx.resx @@ -0,0 +1,144 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Add New Handout + + + Add New Handout + + + View/Print + + + Are You Sure You Want To Delete This Handout? + + + My Handouts + + + You must configure this module first via "Settings". + + + Suggested Handouts + + + There are no suggested handouts found. + + \ No newline at end of file diff --git a/App_LocalResources/HandoutDetail.ascx.resx b/App_LocalResources/HandoutDetail.ascx.resx new file mode 100755 index 0000000..e02a860 --- /dev/null +++ b/App_LocalResources/HandoutDetail.ascx.resx @@ -0,0 +1,171 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Add Articles + + + Selected Article List + + + Add Articles + + + Handout Details + + + There are no articles in the handout currently. + + + Select categories to add articles from. + + + Select Categories + + + Optionally specify a description for the Handout. + + + Description + + + Specify a name for the Handout. + + + Handout Name + + + You Must Enter a Name For The Handout + + + view full article... + + + Clear List + + + Save Handout + + + Are You Sure You Want To Delete This Handout? + + + Hold down ctrl to select multiple categories. + + \ No newline at end of file diff --git a/App_LocalResources/HandoutSettings.ascx.resx b/App_LocalResources/HandoutSettings.ascx.resx new file mode 100755 index 0000000..5baf3bc --- /dev/null +++ b/App_LocalResources/HandoutSettings.ascx.resx @@ -0,0 +1,468 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Article Module + + + Set the article module to link to. + + + News Handout Settings + + + A0 + + + A1 + + + A10 + + + A2 + + + A3 + + + A4 + + + A5 + + + A6 + + + A7 + + + A8 + + + A9 + + + ArchA + + + ArchB + + + ArchC + + + ArchD + + + ArchE + + + B0 + + + B1 + + + B2 + + + B3 + + + B4 + + + B5 + + + Custom + + + Flsa + + + HalfLetter + + + Ledger + + + Legal + + + Letter + + + Letter11x17 + + + Note + + + PDF Settings + + + Specify the page size for the pdf. + + + Page Size + + + Best + + + Landscape + + + No Compression + + + Normal + + + Specify a height for the footer. + + + Footer Height + + + Specify a height for the header. + + + Header Height + + + Specify a bottom margin. + + + Margin Bottom + + + Specify a left margin. + + + Margin Left + + + Specify a right margin. + + + Margin Right + + + Specify a top margin. + + + Margin Top + + + Specify the page compression for the pdf. + + + Page Compression + + + Specify the page orientation for the pdf. + + + Page Orientation + + + Pick display option for footer. + + + Footer Mode + + + Pick display option for header. + + + Header Mode + + + Suggested Handout Username + + + Portrait + + + Footer Height is Required + + + Footer Height must be a Number + + + Header Height is Required + + + Header Height must be a Number + + + Margin Bottom is Required + + + Margin Bottom must be a Number + + + Margin Left is Required + + + Margin Left must be a Number + + + Margin Right is Required + + + Margin Right must be a Number + + + Margin Top is Required + + + Margin Top must be a Number + + + Username is invalid. + + + Check to show footer on the cover page. + + + On Cover Page? + + + Check to show header on the cover page. + + + On Cover Page? + + + Footer Settings + + + Header Settings + + + Specify text to show in the footer, leave blank to use template html. + + + Footer Text + + + Specify text to show in the header, leave blank to use template html. + + + Header Text + + + Check to show page numbers. + + + Page Numbers? + + + Select the font color for the footer. + + + Font Color + + + Select the font for the footer. + + + Font Type + + + Select the font size for the footer. + + + Font Size + + + Select the font color for the header. + + + Font Color + + + Select the font for the header. + + + Font Type + + + Select the font size for the header. + + + Font Size + + + Handout.Footer.html + + + Handout.Header.html + + + Text + + + Text + + + Footer Text Size is required. + + + Footer Text Size must be a number. + + + Header Text Size is required. + + + Header Text Size must be a number. + + + Select the categories available to users for handout creation. + + + Available Categories + + + All Categories + + + Selected Categories + + + Hold down ctrl to select multiple categories. + + + Specify permissions for handouts. + + + Permissions + + + Security Settings + + + Submit + + \ No newline at end of file diff --git a/App_LocalResources/LatestArticles.ascx.resx b/App_LocalResources/LatestArticles.ascx.resx new file mode 100755 index 0000000..5f405ca --- /dev/null +++ b/App_LocalResources/LatestArticles.ascx.resx @@ -0,0 +1,186 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + You must configure this module first via "Module Settings" + + + <h1>Latest Articles</h1><p>This module allows you to display a list of latest articles.</p> + + + Expiry Date + + + Highest Rated + + + Last Update + + + Most Commented + + + Most Viewed + + + Publish Date + + + Random + + + Title + + + All Time + + + 7 Days + + + Last Year + + + -- Select Category -- + + + Three Days + + + Today + + + Yesterday + + + 90 Days + + + 30 Days + + + This Year + + + -- Select Author -- + + + -- Select {0} -- + + \ No newline at end of file diff --git a/App_LocalResources/LatestArticlesOptions.ascx.resx b/App_LocalResources/LatestArticlesOptions.ascx.resx new file mode 100755 index 0000000..4a8eba8 --- /dev/null +++ b/App_LocalResources/LatestArticlesOptions.ascx.resx @@ -0,0 +1,678 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + In this section, you can adjust the settings for the "Latest Articles" module. + + + Latest Articles Settings + + + Basic Settings + + + Article Module + + + Set the article module to link to. + + + Categories + + + Select categories to display. + + + All Categories + + + Match Any + + + Match All + + + Number of Articles + + + Number of articles to display. + + + Start Date + + + Date to begin showing articles from. + + + <br>* Leave blank to always start from the current date. + + + <br>Invalid start date! + + + Max Age + + + Maximum age of articles (days), leave blank for no filter. + + + (days), leave blank for no filter. + + + Sort By + + + Select field to sort articles by. + + + Sort Direction + + + Select direction for sort. + + + Ascending + + + Descending + + + Publish Date + + + Last Update + + + Highest Rated + + + Most Commented + + + Most Viewed + + + Title + + + Launch Links? + + + Check to launch links into page by itself (no other modules loaded). + + + Featured Only: + + + Show Featured Articles Only. + + + Not Featured Only: + + + Show Articles that are not featured only. + + + Author: + + + Optionally filter by author. + + + Select Author + + + -- All Authors -- + + + Layout Mode + + + Select a layout mode for displaying latest articles. + + + Simple + + + Advanced + + + HTML Header + + + Enter the header html for the latest articles module. + + + HTML Body + + + Enter the body html for the latest articles module. + + + HTML Footer + + + Enter the footer html for the latest articles module. + + + Items Per Row + + + Enter the number of items to display per row. + + + <br>Items Per Row Is Required. + + + <br>Items Per Row Must Be A Number. + + + Template Help + + + In this section, you can view the tags for customizing the latest articles template. + + + The ID of the article + + + The link to the actual article + + + The name of the author based on the configuration settings. + + + The email of the author + + + The username of the author + + + The first name of the author + + + The last name of the author + + + The full name of the author + + + The ID of the author + + + Comma delimited list of categories hyperlinked + + + The link to the comment section of the article. + + + The creation date of the article + + + The creation date of the article, the XXX can be replaced with a date format expression + + + The creation time of the article + + + The comment count of the article + + + Displays the details of the current page. + + + Displays a edit link to authorised users. + + + Allows the option to show a section of html if an article has categories. + + + Allows the option to show a section of html if an article has comments enabled. + + + Allows the option to show a section of html if an article has a link. + + + Allows the option to show a section of html if an article has more detail. + + + Allows the option to show a section of html if an article has multiple pages. + + + Allows the option to show a section of html if an article has ratings enabled. + + + The image of the article, displays nothing if no image selected. + + + The link to the image of the article, displays nothing if no image selected. + + + The image of the article (thumbnailed to a width of XXX), displays nothing if no image selected. + + + The link to the article image (thumbnailed to a width of XXX), displays nothing if no image selected. + + + The link to the article, url, another page or file. + + + The target of the link based on launch links. + + + The module ID of the article module. + + + The number of pages within an article. + + + The detail of the article. + + + The link to print an article. + + + The publish date of the article + + + The publish date of the article, the XXX can be replaced with a date format expression + + + The publish time of the article + + + The publish end date of the article + + + The publish end time of the article + + + The rating of the article + + + The number of the ratings on an article + + + The actual rating value of an article + + + The link to the rss feed + + + A list of pages within the article hyperlinked. If there is only 1 page, token is blank. + + + The summary of the article + + + The summary of the article restricted by number of characters, e.g. replace XXX with 50 to restrict to 50 chars. + + + The title of the article + + + The last update date of the article + + + The last update date of the article, the XXX can be replaced with a date format expression + + + The last update time of the article + + + You must specify the number of articles to display. + + + Must be a valid number. + + + Must be a valid number. + + + The view count for the article + + + Latest Articles Options + + + <h1>Latest Articles Options</h1><p>This module allows you to choose from the various admin options.</p> + + + Random + + + Filter Settings + + + Check to filter by author on the querystring parameter. + + + UserID Filter: + + + Enter the name of the parameter to filter on. + + + UserID Parameter: + + + Template + + + Latest Articles + + + Expiry Date + + + Start Point + + + (0 to start at beginning) + + + Enter a start point to begin showing articles (0 to start at beginning). + + + <br>Start Point Is Required. + + + <br>Start Point Must Be A Number. + + + Enter the text to display when no articles match filter settings. + + + HTML No Articles + + + Check to only show unsecured articles. + + + Not Secured Only + + + Check to only show secured articles. + + + Secured Only + + + Check to bring featured articles to the top of the listing. + + + Featured Articles to Top? + + + Enable Pager? + + + Check to enable a pager at the bottom fo latest articles. + + + Specify how many articles per page. + + + Pager Size + + + Page Size is Required. + + + Page Size Must Be A Number. + + + Enter a comma separated list of article IDs. + + + Article IDs + + + Hold down ctrl to select multiple. + + + Author Filter Settings + + + Check to filter by the logged in user. + + + Logged in user Filter: + + + Check to filter by username. + + + Username Filter: + + + Specify what parameter to select from. + + + Username Parameter: + + + Check to show pending articles. + + + Show Pending + + + Select categories to exclude. + + + Exclude Categories + + + Check to show related articles when viewing a category or an article. + + + Show Related + + + Filter by tags + + + Tags: + + + Separate keywords by commas e.g. Cowboy,Texas Rodeo,2009 + + + Tag Filter Settings + + + A dropdown to filter by category. + + + Header/Footer Tokens + + + Item Tokens + + + A dropdown to sort by available options. + + + A link to sort by the chosen field, valid values are PublishDate, ExpiryDate, LastUpdate, HighestRated, MostCommented, MostViewed, Random, SortTitle + + + A dropdown to filter by time periods. + + + A dropdown with the field XXX selected by default, e.g. Today, Yesterday, ThreeDays, SevenDays, ThirtyDays, NinetyDays, ThisYear, AllTime + + + Specify a custom field to filter on. + + + Custom Field Filter: + + + -- Custom Field -- + + + A dropdown to filter by author. + + + A dropdown to filter by custom field where XXX is the name of the field. This only works for dropdown lists. + + + Check to include the template stylesheet. + + + Include Stylesheet? + + + Link Filter: + + + None + + + Page + + + Url + + + Load from Template + + + Save as reusable Template + + + Select to load from template + + + Load from Template + + + Optionally save the current template for use later. + + + Save Template + + + (template name) + + + Template Saves + + \ No newline at end of file diff --git a/App_LocalResources/LatestComments.ascx.resx b/App_LocalResources/LatestComments.ascx.resx new file mode 100755 index 0000000..5d968a7 --- /dev/null +++ b/App_LocalResources/LatestComments.ascx.resx @@ -0,0 +1,123 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + You must configure this module first via "Module Settings" + + \ No newline at end of file diff --git a/App_LocalResources/LatestCommentsOptions.ascx.resx b/App_LocalResources/LatestCommentsOptions.ascx.resx new file mode 100755 index 0000000..3afd7a1 --- /dev/null +++ b/App_LocalResources/LatestCommentsOptions.ascx.resx @@ -0,0 +1,174 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Latest Comments Settings + + + Number of comments to display. + + + Comment Count + + + Enter the body html for the latest comments module. + + + HTML Body + + + Enter the footer html for the latest comments module. + + + HTML Footer + + + Enter the header html for the latest comments module. + + + HTML Header + + + Enter the text to display when no comments match filter settings. + + + HTML No Comments + + + Check to include the template stylesheet. + + + Include Stylesheet? + + + Set the article module to link to. + + + Article Module + + + Template + + + You must specify the number of comments to display. + + + Must be a valid number. + + \ No newline at end of file diff --git a/App_LocalResources/NewsArchives.ascx.resx b/App_LocalResources/NewsArchives.ascx.resx new file mode 100755 index 0000000..4e7ec90 --- /dev/null +++ b/App_LocalResources/NewsArchives.ascx.resx @@ -0,0 +1,109 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +text/microsoft-resx + + +1.3 + + +System.Resources.ResXResourceReader, System.Windows.Forms, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +System.Resources.ResXResourceWriter, System.Windows.Forms, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +You must configure this module first via "Module Settings" + + +View Options + + +<h1>Latest Articles</h1><p>This module allows you to display a list of latest articles.</p> + + \ No newline at end of file diff --git a/App_LocalResources/NewsArchivesOptions.ascx.resx b/App_LocalResources/NewsArchivesOptions.ascx.resx new file mode 100755 index 0000000..2fe2e94 --- /dev/null +++ b/App_LocalResources/NewsArchivesOptions.ascx.resx @@ -0,0 +1,249 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Archive Mode + + + Set the mode for the archives. + + + Date + + + Category + + + Author + + + Article Module + + + Set the article module to link to. + + + Layout Mode + + + Select a layout mode for displaying archives. + + + Simple + + + Advanced + + + Hide Zero Categories + + + Check to hide categories with 0 articles. + + + HTML Header + + + Enter the header html for the news archives module. + + + HTML Body + + + Enter the body html for the news archives module. + + + HTML Footer + + + Enter the footer html for the news archives module. + + + Items Per Row + + + Enter the number of items to display per row. + + + Items Per Row Is Required. + + + Items Per Row Must Be A Number + + + News Archive Options + + + <h1>News Archives Options</h1><p>This module allows you to choose from the various admin options.</p> + + + Change how date archives are grouped. + + + Group By + + + Display Name + + + First Name + + + Last Name + + + Select which field to sort authors by. + + + Sort By + + + Username + + + Optionally specify how many levels deep to show, leave blank for unlimited. + + + Max Depth + + + * Leave blank for unlimited. + + + -- No Parent Category -- + + + Select a parent category to filter by. + + + Parent Category + + + * Must be a number. + + + Basic Settings + + + Template Settings + + + Article Count + + \ No newline at end of file diff --git a/App_LocalResources/NewsSearch.ascx.resx b/App_LocalResources/NewsSearch.ascx.resx new file mode 100755 index 0000000..0114756 --- /dev/null +++ b/App_LocalResources/NewsSearch.ascx.resx @@ -0,0 +1,129 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + You must configure this module first via "Module Settings" + + + <h1>Search Articles</h1><p>This module allows you to search articles.</p> + + + Search + + \ No newline at end of file diff --git a/App_LocalResources/NewsSearchOptions.ascx.resx b/App_LocalResources/NewsSearchOptions.ascx.resx new file mode 100755 index 0000000..63cc918 --- /dev/null +++ b/App_LocalResources/NewsSearchOptions.ascx.resx @@ -0,0 +1,135 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Article Module + + + Set the article module to link to. + + + News Search Options + + + <h1>News Search Options</h1><p>This module allows you to choose from the various admin options.</p> + + + -- No Parent Category -- + + \ No newline at end of file diff --git a/App_LocalResources/PostComment.ascx.resx b/App_LocalResources/PostComment.ascx.resx new file mode 100755 index 0000000..fa4265e --- /dev/null +++ b/App_LocalResources/PostComment.ascx.resx @@ -0,0 +1,165 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Email (required) + + + Name (required) + + + Email Is Required + + + Name Is Required + + + Website + + + Add Comment + + + Notify me of followup comments via e-mail + + + Only registered users may post comments. + + + Your comment has been submitted, but requires approval. + + + <br>Comment Is Required + + + Code is invalid. + + + Invalid Email Address + + + Enter the code shown above: + + + Email (not required) + + + Name (not required) + + \ No newline at end of file diff --git a/App_LocalResources/PostRating.ascx.resx b/App_LocalResources/PostRating.ascx.resx new file mode 100755 index 0000000..7e5fee5 --- /dev/null +++ b/App_LocalResources/PostRating.ascx.resx @@ -0,0 +1,123 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Rating Saved! + + \ No newline at end of file diff --git a/App_LocalResources/SharedResources.resx b/App_LocalResources/SharedResources.resx new file mode 100755 index 0000000..da39c4b --- /dev/null +++ b/App_LocalResources/SharedResources.resx @@ -0,0 +1,249 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Current Articles + + + Archives + + + Search + + + Create Article + + + My Articles + + + Approve Articles + + + Admin Options + + + Previous Page + + + Next Page + + + Currently, there are no comments. Be the first to post one!<br> + + + <br>No Articles Found. + + + You must be logged in to post a comment. You can login <a href="{0}" class="CommandButton">here</a> + + + Click <a href="{0}" class="CommandButton">here</a> to post a comment + + + Approve Comments + + + [AUTHOR] created the article <a title='[ARTICLETITLE]' href='[ARTICLELINK]'>[ARTICLETITLE]</a> + + + [AUTHOR] created a comment on article <a title='[ARTICLETITLE]' href='[ARTICLELINK]'>[ARTICLETITLE]</a> + + + [AUTHOR] added a rating on article <a title='[ARTICLETITLE]' href='[ARTICLELINK]'>[ARTICLETITLE]</a> + + + Close + + + Image + + + Next + + + Of + + + Previous + + + All Time + + + Expiry Date + + + Highest Rated + + + Last Update + + + Most Commented + + + Most Viewed + + + 90 Days + + + Last Year + + + Publish Date + + + Random + + + -- Select Author -- + + + -- Select Category -- + + + -- Select {0} -- + + + 7 Days + + + Title + + + 30 Days + + + This Year + + + Three Days + + + Today + + + Yesterday + + + Root + + \ No newline at end of file diff --git a/App_LocalResources/UploadFiles.ascx.resx b/App_LocalResources/UploadFiles.ascx.resx new file mode 100755 index 0000000..72086ee --- /dev/null +++ b/App_LocalResources/UploadFiles.ascx.resx @@ -0,0 +1,147 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Are you sure you want to remove this file? + + + Files + + + In this section, you can associate files with articles. + + + No files are currently attached. + + + Attached Files + + + Select Existing Files + + + Select Files + + + Upload New Files + + + Add Existing File + + \ No newline at end of file diff --git a/App_LocalResources/UploadImages.ascx.resx b/App_LocalResources/UploadImages.ascx.resx new file mode 100755 index 0000000..962c71f --- /dev/null +++ b/App_LocalResources/UploadImages.ascx.resx @@ -0,0 +1,147 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Are you sure you want to delete this image? + + + External Image + + + Images + + + In this section, you can associate images with articles. + + + No images are currently attached. + + + Attached Images + + + Select Existing Images + + + Select Images + + + Upload New Images + + \ No newline at end of file diff --git a/App_LocalResources/ViewArchive.ascx.resx b/App_LocalResources/ViewArchive.ascx.resx new file mode 100755 index 0000000..eb38602 --- /dev/null +++ b/App_LocalResources/ViewArchive.ascx.resx @@ -0,0 +1,138 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Archive + + + Articles from + + + View Archive + + + <h1>About View Archive</h1><p>The module shows a articles in archive.</p> + + + Entries for {0} {1} + + + Entries for {0} + + \ No newline at end of file diff --git a/App_LocalResources/ViewArticle.ascx.resx b/App_LocalResources/ViewArticle.ascx.resx new file mode 100755 index 0000000..d39d543 --- /dev/null +++ b/App_LocalResources/ViewArticle.ascx.resx @@ -0,0 +1,144 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Anonymous + + + Anonymous + + + Anonymous User + + + Anonymous + + + View Article + + + <h1>About View Article</h1><p>The module shows a single article.</p> + + + Click to Print + + + Delete + + \ No newline at end of file diff --git a/App_LocalResources/ViewAuthor.ascx.resx b/App_LocalResources/ViewAuthor.ascx.resx new file mode 100755 index 0000000..1b7cb9f --- /dev/null +++ b/App_LocalResources/ViewAuthor.ascx.resx @@ -0,0 +1,126 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Entries for '{0}' + + + Viewing Author + + \ No newline at end of file diff --git a/App_LocalResources/ViewCategory.ascx.resx b/App_LocalResources/ViewCategory.ascx.resx new file mode 100755 index 0000000..6f85fc5 --- /dev/null +++ b/App_LocalResources/ViewCategory.ascx.resx @@ -0,0 +1,126 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Entries for the '{0}' Category + + + Viewing Category + + \ No newline at end of file diff --git a/App_LocalResources/ViewSearch.ascx.resx b/App_LocalResources/ViewSearch.ascx.resx new file mode 100755 index 0000000..e9a3baf --- /dev/null +++ b/App_LocalResources/ViewSearch.ascx.resx @@ -0,0 +1,129 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Search + + + Articles for '{0}' + + + Search Articles + + \ No newline at end of file diff --git a/App_LocalResources/ViewTag.ascx.resx b/App_LocalResources/ViewTag.ascx.resx new file mode 100755 index 0000000..fd91464 --- /dev/null +++ b/App_LocalResources/ViewTag.ascx.resx @@ -0,0 +1,126 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Viewing Tag + + + Entries for '{0}' + + \ No newline at end of file diff --git a/App_LocalResources/ucAdminOptions.ascx.resx b/App_LocalResources/ucAdminOptions.ascx.resx new file mode 100755 index 0000000..5cc773b --- /dev/null +++ b/App_LocalResources/ucAdminOptions.ascx.resx @@ -0,0 +1,168 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Main Options + + + Maintain settings for your News Articles setup. + + + Categories + + + Create, edit and delete categories.. + + + Email Templates + + + Customize the emails that are sent from this module.. + + + Site Templates + + + Customize the site templates that used in this module.. + + + Admin Options + + + <h1>Admin Options</h1><p>This module allows you to choose from the various admin options.</p> + + + Custom Fields + + + Create, edit and delete custom fields.. + + + Tags + + + Create, edit and delete tags.. + + + Import Feeds + + + Configure RSS feeds to import.. + + \ No newline at end of file diff --git a/App_LocalResources/ucApproveArticles.ascx.resx b/App_LocalResources/ucApproveArticles.ascx.resx new file mode 100755 index 0000000..9f0d18b --- /dev/null +++ b/App_LocalResources/ucApproveArticles.ascx.resx @@ -0,0 +1,156 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + <br>There are no articles awaiting approval. + + + Add New Category + + + Created Date + + + Title + + + Approve? + + + Author + + + Approve Selected Articles + + + Approve All Articles + + + Approve Articles + + + <h1>About Approve Articles</h1><p>Approvers can approve articles from this screen.</p> + + + Approve Articles + + + Publish Date + + \ No newline at end of file diff --git a/App_LocalResources/ucApproveComments.ascx.resx b/App_LocalResources/ucApproveComments.ascx.resx new file mode 100755 index 0000000..8aceef4 --- /dev/null +++ b/App_LocalResources/ucApproveComments.ascx.resx @@ -0,0 +1,153 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + <br>There are no comments awaiting approval. + + + Reject + + + Approve + + + Approve Comments + + + <h1>About Approve Comments</h1><p>Approvers can approve comments from this screen.</p> + + + Author + + + Comment + + + Date + + + Article + + + IP Address + + + Website + + \ No newline at end of file diff --git a/App_LocalResources/ucEditCategories.ascx.resx b/App_LocalResources/ucEditCategories.ascx.resx new file mode 100755 index 0000000..a972b77 --- /dev/null +++ b/App_LocalResources/ucEditCategories.ascx.resx @@ -0,0 +1,174 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + <br>There are no categories currently. + + + Add New Category + + + Edit Categories + + + <h1>About Edit Categories</h1><p>The administrator can manage the categories available for this module.</p> + + + Actions + + + Category sort order updated. + + + The child categories of the parent selection. + + + Child Categories + + + Move category down + + + Edit Category + + + Move category up + + + Update Sort Order + + + View Category + + + Move Category + + + -- No Parent Category -- + + + Select a parent category to filter on. + + + Parent Category + + + No categories exist at this level. + + \ No newline at end of file diff --git a/App_LocalResources/ucEditCategory.ascx.resx b/App_LocalResources/ucEditCategory.ascx.resx new file mode 100755 index 0000000..63c092e --- /dev/null +++ b/App_LocalResources/ucEditCategory.ascx.resx @@ -0,0 +1,219 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Category Settings + + + In this section, you can edit a category. + + + Name + + + Enter the name of the category. + + + <br>You Must Enter a Valid Title + + + Edit Category + + + <h1>About Edit Category</h1><p>The module allows you to edit a category.</p> + + + -- No Parent Category -- + + + Optionally select a parent category. + + + Parent Category + + + <br>Invalid Parent Category. Possible Loop Detected. + + + Enter the description of the category. + + + Description + + + Inherit Security? + + + Permissions + + + Submit + + + View + + + Uncheck to override security roles for categories. + + + Loose - You only have to the meet the requirement of ONE category on an article. + + + Select the permissions for these roles, view governs who can see the article and submit is for who can add to that category. + + + Restrictive - You must meet the requirements of ALL categories on an article. + + + Select the security mode for this category. + + + Security Mode + + + Meta Information + + + Optionally overrides the description for the category. + + + Description + + + Optionally overrides the keywords for the category. + + + Keywords + + + Optionally overrides the title for the category. + + + Title + + + Specify an image for a category. + + + Image + + + Security Settings + + \ No newline at end of file diff --git a/App_LocalResources/ucEditComment.ascx.resx b/App_LocalResources/ucEditComment.ascx.resx new file mode 100755 index 0000000..575cc31 --- /dev/null +++ b/App_LocalResources/ucEditComment.ascx.resx @@ -0,0 +1,159 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Specify the comment. + + + Comment + + + Edit Comment + + + Specify the email of the comment. + + + Email + + + Specify the name of the comment. + + + Name + + + Specify the url of the comment. + + + Url + + + <br>Comment Is Required + + + <br>Email Is Required + + + <br>Invalid Email Address + + + <br>Name Is Required + + \ No newline at end of file diff --git a/App_LocalResources/ucEditCustomField.ascx.resx b/App_LocalResources/ucEditCustomField.ascx.resx new file mode 100755 index 0000000..399f8ae --- /dev/null +++ b/App_LocalResources/ucEditCustomField.ascx.resx @@ -0,0 +1,255 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Enter a caption for the custom field + + + Caption + + + Enter help text for the caption. + + + Caption Help + + + Checkbox + + + Are you sure you want to delete this custom field? + + + Edit Custom Field + + + Currency + + + Custom Field Details + + + Enter the details of your custom field and then click "update". + + + Date + + + Enter a default value for the custom field + + + Default Value + + + Double + + + Drop Down List + + + Email + + + Separate values with a |, e.g. House|Land|Unit + + + Enter field elements for the custom field, separate values with a |, e.g. House|Land|Unit + + + Field Elements + + + Select a field type for the custom field + + + Field Type + + + Integer + + + <h1>Edit Custom Field</h1><p>Allows an administrator to edit or add a custom field.</p> + + + Multi Checkbox + + + Multi Line Text Box + + + Enter a name for the custom field + + + Name + + + One Line Text Box + + + Type a number for the maximum number of characters. + + + Maximum Length + + + Enter a regular expression to validate against. + + + Regular Expression + + + Radio Button + + + Regular Expression + + + Check to make the field required. + + + Required? + + + Requirement Details + + + Specify details about requirement settings. + + + Rich Text Box + + + Select a validation type for the custom field + + + Validation Type + + + Check to make the custom field visible when using the [CUSTOMFIELDS] token. + + + Visible? + + + <br>You must enter a valid caption. + + + Color Picker + + \ No newline at end of file diff --git a/App_LocalResources/ucEditCustomFields.ascx.resx b/App_LocalResources/ucEditCustomFields.ascx.resx new file mode 100755 index 0000000..1167d8e --- /dev/null +++ b/App_LocalResources/ucEditCustomFields.ascx.resx @@ -0,0 +1,150 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Add Custom Field + + + Edit Custom Fields + + + <h1>Edit Custom Fields</h1><p>Allows an administrator to edit custom fields.</p> + + + Caption + + + Field Type + + + Name + + + No custom fields currently exist. + + + Sort Order + + + Required? + + + Visible? + + \ No newline at end of file diff --git a/App_LocalResources/ucEditPage.ascx.resx b/App_LocalResources/ucEditPage.ascx.resx new file mode 100755 index 0000000..c3ce11d --- /dev/null +++ b/App_LocalResources/ucEditPage.ascx.resx @@ -0,0 +1,72 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 1.0.0.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Page Settings + + + In this section, you can edit a page settings for this article. + + + Title + + + Enter the name of the page. + + + <br>You Must Enter a Valid Title + + + Page Text + + + Enter the text for the page here. + + + Page Text Is Required + + + Edit Page + + + <h1>About Edit Page</h1><p>The module allows you to edit a page for your article.</p> + + \ No newline at end of file diff --git a/App_LocalResources/ucEditPageSortOrder.ascx.resx b/App_LocalResources/ucEditPageSortOrder.ascx.resx new file mode 100755 index 0000000..6e09b48 --- /dev/null +++ b/App_LocalResources/ucEditPageSortOrder.ascx.resx @@ -0,0 +1,60 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 1.0.0.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Edit Sort order + + + In this section, you can change the sort order for pages in an article. + + + Sort Order + + + Change the sort order for pages. + + + Edit Sort Order + + + <h1>About Edit Sort Order</h1><p>The module allows you to edit the sort order for pages in your article.</p> + + \ No newline at end of file diff --git a/App_LocalResources/ucEditPages.ascx.resx b/App_LocalResources/ucEditPages.ascx.resx new file mode 100755 index 0000000..9371ed2 --- /dev/null +++ b/App_LocalResources/ucEditPages.ascx.resx @@ -0,0 +1,75 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +text/microsoft-resx + + +1.0.0.0 + + +System.Resources.ResXResourceReader, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +System.Resources.ResXResourceWriter, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +<br>There are no pages currently associated with this article. (summary will be displayed) + + +Sort Order + + +Title + + +Editing pages of the article: {0} + + +Add Page + + +Edit Sort Order + + +Edit Summary + + +Are You Sure You Wish To Submit This Item ? (You will no longer be able to edit it if approved) + + +Submit For Approval + + +Edit Pages + + +<h1>Edit Pages</h1><p>Authors can add pages to an article. The module allows you to add new pages, modify existing pages and delete existing pages.</p> + + \ No newline at end of file diff --git a/App_LocalResources/ucEditTag.ascx.resx b/App_LocalResources/ucEditTag.ascx.resx new file mode 100755 index 0000000..82a51ae --- /dev/null +++ b/App_LocalResources/ucEditTag.ascx.resx @@ -0,0 +1,150 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Are You Sure You Wish To Delete This Item ? + + + Edit Tag + + + Edit Tag + + + Edit Tags + + + <h1>About Edit Tag</h1><p>The module allows you to edit an tag.</p> + + + Enter a name for the tag. + + + Name + + + Tag Settings + + + In this section, you can edit the tag settings. + + + <br>You Must Enter a Valid Name + + \ No newline at end of file diff --git a/App_LocalResources/ucEditTags.ascx.resx b/App_LocalResources/ucEditTags.ascx.resx new file mode 100755 index 0000000..e314440 --- /dev/null +++ b/App_LocalResources/ucEditTags.ascx.resx @@ -0,0 +1,141 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Add Tag + + + All Albums + + + Edit Tags + + + Edit Tags + + + <h1>Edit Tags</h1><p>The module allows you to add new tags, modify existing tags and delete existing tags.</p> + + + Name + + + <br>There are no tags currently. + + \ No newline at end of file diff --git a/App_LocalResources/ucEmailTemplates.ascx.resx b/App_LocalResources/ucEmailTemplates.ascx.resx new file mode 100755 index 0000000..4de2205 --- /dev/null +++ b/App_LocalResources/ucEmailTemplates.ascx.resx @@ -0,0 +1,228 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Email Templates + + + In this section, you can customize the emails that are sent by this module. + + + Name + + + Select a Template to edit. + + + Subject + + + Subject of the email. + + + <br>You Must Enter a Valid Subject + + + Template + + + Enter the template for the email here. + + + Template Text Is Required + + + Email Template Help + + + In this section, you can view the tags for customizing emails for articles (ArticleSubmission, ArticleApproval). + + + In this section, you can view the tags for customizing emails for comments (CommentNotification, CommentRequiringApproval, CommentApproved). + + + Displays the username of article's author + + + Displays the first name of article's author + + + Displays the last name of article's author + + + Displays the surname of article's author + + + Displays the name of the portal + + + Displays the date and time the article is due to be published. + + + Displays the title of the article + + + Displays the summary of the article + + + Displays the link to access the article + + + Displays the username of comment's author + + + Displays the first name of comment's author + + + Displays the last name of comment's author + + + Displays the full name of comment's author + + + Displays the date and time the comment was posted + + + Displays the details of the comment + + + Displays the link to access the comment + + + Edit Email Templates + + + <h1>About Email Templates</h1><p>The module allows you to customize the emails that are sent from this module.</p> + + + Displays the display name of article's author + + + Displays the display name of comment's author + + + Displays the email of comment's author + + + Displays the email of article's author + + + Displays the date and time the article is created. + + \ No newline at end of file diff --git a/App_LocalResources/ucImportFeed.ascx.resx b/App_LocalResources/ucImportFeed.ascx.resx new file mode 100755 index 0000000..03d889c --- /dev/null +++ b/App_LocalResources/ucImportFeed.ascx.resx @@ -0,0 +1,213 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Select the default author for the feed. + + + Default Author + + + Check to auto-feature the articles imported from this feed. + + + Auto-Feature + + + Select the default categories to associate with the feed. Hold down ctrl to select multiple. + + + Default Categories + + + <br />Hold down ctrl to select multiple categories. + + + (Change Author) + + + Are You Sure You Wish To Delete This Item ? + + + Import Feed + + + Feed Settings + + + In this section, you can edit the feed settings. + + + Check to mark the feed active. + + + Active + + + <h1>About Import Feed</h1><p>The module allows you to import RSS feeds.</p> + + + -- Select Author -- + + + Enter a title for the feed. + + + Title + + + Enter a url for the feed. + + + Feed Url + + + <br>You Must Enter a Valid Title + + + <br>You Must Enter a Valid Url + + + Article Settings + + + In this section, you can customize the imported articles. + + + (username) + + + Date Mode + + + Feed Date + + + Import Date + + + <br />Invalid author. + + + Specify whether to auto-expire articles. + + + Auto-Expire + + \ No newline at end of file diff --git a/App_LocalResources/ucImportFeeds.ascx.resx b/App_LocalResources/ucImportFeeds.ascx.resx new file mode 100755 index 0000000..6ac8772 --- /dev/null +++ b/App_LocalResources/ucImportFeeds.ascx.resx @@ -0,0 +1,195 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Add Feed + + + Import Feeds + + + Is Active? + + + <h1>Edit Feeds</h1><p>The module allows you to new feeds to import.</p> + + + <br>There are no feeds currently. + + + There is currently no history available. + + + Example: "5" and select "Minutes" to retry the task every 5 minutes after a failure. Leave blank to disable retry-timer for this task. + + + Retry Frequency + + + Check to enable the scheduler. + + + Scheduler Enabled + + + Example: "5" and select "Minutes" to run task every 5 minutes. Leave blank to disable timer for this task. + + + Time Lapse + + + Scheduler History + + + View the scheduler history for importing RSS feeds. + + + Scheduler Settings + + + Customize the settings for the scheduler to import feeds. + + + Title + + + Url + + + Description + + + Duration + + + The scheduler is not currently enabled, please contact your system administrator. + + + Start/End/Next + + + Succeeded + + + Check to delete existing articles upon import. + + + Delete Articles? + + \ No newline at end of file diff --git a/App_LocalResources/ucMyArticles.ascx.resx b/App_LocalResources/ucMyArticles.ascx.resx new file mode 100755 index 0000000..52642b0 --- /dev/null +++ b/App_LocalResources/ucMyArticles.ascx.resx @@ -0,0 +1,153 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + There are no articles matching your criteria. + + + Created Date + + + Title + + + Author + + + Draft Articles Only + + + Unapproved Articles Only + + + Approved Articles Only + + + My Articles + + + <h1>About My Articles</h1><p>Authors can view there own articles from this screen, filtered by Draft/Unapproved/Approved.</p> + + + Publish Date + + + Show all articles (from all authors) + + \ No newline at end of file diff --git a/App_LocalResources/ucNotAuthenticated.ascx.resx b/App_LocalResources/ucNotAuthenticated.ascx.resx new file mode 100755 index 0000000..ab372a2 --- /dev/null +++ b/App_LocalResources/ucNotAuthenticated.ascx.resx @@ -0,0 +1,57 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +text/microsoft-resx + + +1.0.0.0 + + +System.Resources.ResXResourceReader, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +System.Resources.ResXResourceWriter, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +You must be authenticated to use this feature. You may... + + +Login to this site + + +Go to the home page for this site + + +Not Authenticated + + + + + \ No newline at end of file diff --git a/App_LocalResources/ucNotAuthorized.ascx.resx b/App_LocalResources/ucNotAuthorized.ascx.resx new file mode 100755 index 0000000..7376e13 --- /dev/null +++ b/App_LocalResources/ucNotAuthorized.ascx.resx @@ -0,0 +1,54 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +text/microsoft-resx + + +1.0.0.0 + + +System.Resources.ResXResourceReader, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +System.Resources.ResXResourceWriter, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +You must be authorized to use this feature. You may... + + +Go to the home page for this site + + +Not Authorized + + + + + \ No newline at end of file diff --git a/App_LocalResources/ucSubmitNews.ascx.resx b/App_LocalResources/ucSubmitNews.ascx.resx new file mode 100755 index 0000000..1ce9ccc --- /dev/null +++ b/App_LocalResources/ucSubmitNews.ascx.resx @@ -0,0 +1,462 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Details + + + Appearance + + + Link to + + + Article Summary + + + Enter the details of your article including title (required), categories (if applicable) and summary text (required).<br>Once complete, you can save your article via the buttons above the form. + + + Title: + + + Enter a title for the article here. + + + Title is Required + + + Author: + + + Select author for the article. + + + (Change Author) + + + No Author + + + Categories: + + + Select categories for the article here. + + + Advanced Settings + + + Article Details + + + Enter the main body of your article (optional).<br>Once complete, you can save your article via the buttons above the form. + + + Details + + + Enter the body of your article here. + + + Article Appearance + + + Mark your article as featured or to be associated with an image.<br>Once complete, you can save your article via the buttons above the form. + + + Image: + + + You can choose an image to associate with this article. + + + Featured: + + + Optionally mark the content as featured to highlight it. + + + Secure: + + + If the article is secured, the complete article (except for summary) will only be available to the roles configured in admin options. + + + Article Link + + + Optionally link your article to another resource.<br>Once complete, you can save your article via the buttons above the form. + + + New Window? + + + Check to launch the link in a new window. + + + Article Publishing + + + Optionally specify a date & time to publish/expire your article.<br>Once complete, you can save your article via the buttons above the form. + + + Publish Date & Time: + + + Enter the start date for displaying this article. + + + Publish Date & Time is Invalid + + + Publish Date & Time is Required + + + Expiry Date & Time: + + + Enter the end date for displaying this article. + + + Expiry Date & Time is Invalid + + + Are You Sure You Wish To Delete This Item ? + + + Publish + + + Approve Article + + + Add/Edit Pages + + + Delete Article + + + Submit Article + + + <h1>Article Management</h1><p>Users allowed to submit articles can submit or edit an article on this page. This module allows you to create a new article, modify an existing article, delete an article, add pages to an article or submit an article for approval.</p> + + + Links + + + In this section, you can specify your content. + + + Enter the body of your article. + + + Body: + + + Create + + + Organize + + + In this section, you can organize your content. + + + Publish + + + In this section, you can control how and when your content is published. + + + Summary + + + Link the article to a URL/Page/File. + + + Link: + + + Body is Required + + + Action + + + In this section, you can perform actions relating to the content. + + + Awaiting Approval + + + Draft + + + Select the status for the content. + + + Status: + + + Publish + + + Published + + + Category is Required + + + Meta Information + + + Optionally overrides the description for the page. + + + Description + + + Optionally overrides the keywords for the page. + + + Keywords + + + Optionally overrides the title for the page. + + + Title + + + Enter any tags (i.e. META tags) that should be rendered in the "HEAD" tag of the HTML for this page. + + + Page Header Tags + + + Custom Fields + + + <Select [VALUE]> + + + [CUSTOMFIELD] must be a currency. + + + [CUSTOMFIELD] must be a date. + + + [CUSTOMFIELD] must be a decimal. + + + [CUSTOMFIELD] must be an email address. + + + [CUSTOMFIELD] must be a number. + + + [CUSTOMFIELD] is an invalid format. + + + [CUSTOMFIELD] is required. + + + Invalid publish date. + + + <br>Required + + + Enter tags for your article e.g. Dairy Farmer 2009 + + + Tags: + + + Separate keywords by commas e.g. Cowboy,Texas Rodeo,2009 + + + (username) + + + <br />Invalid author. + + + Specify an external image url to associate with the article. + + + Image Url: + + + -- Select Author -- + + + Attach Existing Image + + + Mirror + + + Specify if you want to mirror the article from another portal. + + + Check to mirror the article from another portal. + + + Mirror Article? + + + Select article to mirror. + + + Select Article: + + + Check to auto update article when source article is updated. + + + Auto Update? + + + Select module to pick articles from. + + + Select Module: + + + You must select an article to mirror. + + + <br />This article has been mirrored from portal {0}. + + + <br />This article has been mirrored from portal {0}. Auto-update is enabled. You are not authorized to edit this version of the article. + + + <br />This article has been mirrored from {0} portals. + + + Select the folder to upload to. + + + Upload Folder: + + \ No newline at end of file diff --git a/App_LocalResources/ucSubmitNewsComplete.ascx.resx b/App_LocalResources/ucSubmitNewsComplete.ascx.resx new file mode 100755 index 0000000..a441c37 --- /dev/null +++ b/App_LocalResources/ucSubmitNewsComplete.ascx.resx @@ -0,0 +1,60 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +text/microsoft-resx + + +1.0.0.0 + + +System.Resources.ResXResourceReader, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +System.Resources.ResXResourceWriter, System.Windows.Forms, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + +Your article has been submitted for approval. You may... + + +View My Articles + + +Submit Another Article + + +View Current Articles + + +Submit Complete + + +<h1>Submit Article Complete</h1><p>Users allowed to submit articles can submit or edit an article on this page. This module allows you to create a new article, modify an existing article, delete an article, add pages to an article or submit an article for approval.</p> + + \ No newline at end of file diff --git a/App_LocalResources/ucTemplateEditor.ascx.resx b/App_LocalResources/ucTemplateEditor.ascx.resx new file mode 100755 index 0000000..2355125 --- /dev/null +++ b/App_LocalResources/ucTemplateEditor.ascx.resx @@ -0,0 +1,177 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Site Templates + + + In this section, you can customize the templates that are sent by this module. + + + Template + + + Select a Template to edit. + + + File + + + Select a File to edit. + + + Template Text + + + Enter the text for the template here. + + + Site Template Help + + + You can find a list of tokens <a href='http://www.ventrian.com/Support/ProductForums/tabid/118/forumid/4/postid/5025/view/topic/Default.aspx' target='_blank'>here</a>. + + + Create New Template + + + Create a new template for you to customize. + + + Template Name + + + Enter a name for your template. + + + Create Template + + + Edit Site Templates + + + <h1>About Site Templates</h1><p>The module allows you to customize the templates that are used to render the module.</p> + + + Your new template has been created. + + + <br />The template has been updated. + + \ No newline at end of file diff --git a/App_LocalResources/ucViewOptions.ascx.resx b/App_LocalResources/ucViewOptions.ascx.resx new file mode 100755 index 0000000..72caad6 --- /dev/null +++ b/App_LocalResources/ucViewOptions.ascx.resx @@ -0,0 +1,1200 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + Article Settings + + + In this section, you can set up the settings that control the Article module. + + + Basic Settings + + + Allow Portal Images? + + + Check to allow portal images to be associated with articles. + + + Allow External Images? + + + Check to allow external images to be associated with articles. + + + Allow Comments? + + + Check to allow comments to be posted with articles. + + + Allow Ratings? + + + Check to allow ratings to be posted with articles. + + + Allow Anonymous Comments? + + + Check to allow comments to be posted by anonymous users. + + + Allow Anonymous Ratings? + + + Check to allow ratings to be posted by anonymous users. + + + Allow Core Search Integration? + + + Check to allow core search integration for articles. + + + Allow Syndication? + + + Check to allow syndication of articles. + + + Allow Html in Syndication? + + + Check to allow html tags in syndication. + + + Enable Notification Ping? + + + Check to notify weblogs.com (when created or updated). + + + Auto Trackback? + + + Check to scan articles for links when published and attempt to notify any linked sites. + + + Enable Incoming Trackback? + + + Check to allow incoming trackback/pings as new comments. + + + Launch Links? + + + Check to launch links into page by itself (no other modules loaded). + + + Featured Articles to Top? + + + Check to bring featured articles to the top of the listing. + + + User Display Mode + + + Set the display mode for any occurance of a user. + + + Username + + + First Name + + + Last Name + + + Display Name + + + Articles per page + + + Allows you to specify the default number of articles to page. + + + No Restriction + + + 1 + + + 2 + + + 3 + + + 4 + + + 5 + + + 10 + + + 15 + + + 20 + + + 50 + + + Article Template + + + Allows you to specify the template for displaying articles. + + + Text Editor Width + + + Enter the width of the text editor e.g. 100%, 400. + + + Server TimeZone + + + Enter the time zone of the server. + + + <br>Required + + + <br>Must be a valid value, e.g. 100%, 400 + + + Text Editor Height + + + Enter the height of the text editor e.g. 100%, 400. + + + <br>Required + + + <br>Must be a valid value, e.g. 100%, 400 + + + All Categories + + + Filter Settings + + + Max Articles + + + Enter the maximum number of articles to return in current articles. + + + Required + + + Must be a valid value, e.g. 10, 20 + + + Category Filter + + + Specify categories to only show articles from those categories. + + + Match Any + + + Match All + + + Show Featured Only? + + + Only show articles matched as 'Featured'. + + + Show Not Featured Only? + + + Only show articles not matched as 'Featured'. + + + Author + + + Optionally filter by author. + + + -- All Authors -- + + + Select Author + + + Security Settings + + + Secure Url + + + Enter the url to redirect non-secured users. + + + Notification Settings + + + Notify Approvers on Submission + + + Notify users in the approval role of an article submission. + + + Notify Email Address on Submission + + + Notify this email address of an article submission. + + + Notify Owner on Approval + + + Notify owner of the article on approval. + + + Notify Owner on Comment + + + Notify owner of the article when a comment is posted. + + + Sort By + + + Select field to sort articles by. + + + Sort Direction + + + Select direction for sort. + + + Ascending + + + Descending + + + Publish Date + + + Last Update + + + Highest Rated + + + Most Commented + + + Most Viewed + + + Title + + + Main Options + + + <h1>Main Options</h1><p>This module allows administrators to set options for the News Articles module.</p> + + + Turkish + + + Comment Settings + + + Check to use captcha validation on the post comment screen. + + + Use Captcha? + + + Check to require comments to be moderated before posting. + + + Enable Comment Moderation? + + + Notify email address(s) on comment, separate with a ; + + + Notify Email Address on Comment + + + <br>Required + + + Random + + + Approve + + + Auto-Approve + + + Auto-Feature + + + Feature + + + Secure + + + Submit + + + Enter the height of the text editor e.g. 100%, 400. + + + Text Editor Summary Height + + + Enter the width of the text editor e.g. 100%, 400. + + + Text Editor Summary Width + + + Set the basic security settings. + + + Categories + + + Summary + + + Expiry Date + + + Show/hide features on the 'Create Article' form. + + + Form Settings + + + * A role must have submit permissions to view the above items on the create article form. + + + Image + + + Link + + + 6 + + + 7 + + + 8 + + + 9 + + + Check to require a category when creating an article. + + + Require Category + + + Only show articles not marked as 'Secure'. + + + Show Not Secured Only? + + + Only show articles marked as 'Secure'. + + + Show Secured Only? + + + Category Settings + + + Check categories to auto-select them on the create article screen. + + + Default Categories + + + SEO Settings + + + Basic Text + + + Rich Text + + + Select how to render the summary text area. + + + Text Editor Summary Mode: + + + Auto-Secure + + + Hold down ctrl to select multiple. + + + Check to show authors on the archives page. + + + Show Authors? + + + Check to show categories on the archives page. + + + Show Categories? + + + Check to show current articles on the archives page. + + + Show Current Articles? + + + Check to show months on the archives page. + + + Show Months? + + + Archive Settings + + + Enter the height of the category selection listbox, e.g. 200, 400 + + + Category Selection Height + + + <br>Required + + + <br>Must be a valid value, e.g. 200, 400 + + + Check to include in the page's breadcrumb. + + + Include in breadcrumb? + + + Check to include in the page's name. + + + Include in page name? + + + Single Category (Category View) + + + Check to make the notification checkbox on by default. + + + Notify Default + + + Article + + + Article/Attachments + + + Select to always link to an article or directly to attachment/article. + + + Syndication Link Mode: + + + Check to expand summary by default. + + + Expand Summary? + + + 3rd Party Settings + + + Check to integrate with the Smart-Thinker Story Feed (Smart-Thinker UserProfile 4.3.12+) + + + Publish Group Events to Smart-Thinker Story Feed + + + - + + + Select a character to replace spaces in title with. + + + Title Replacement + + + _ + + + Optionally enter a maximum number of characters to show in RSS summary. + + + Syndication Summary Length: + + + Leave blank for unlimited. + + + Must be a valid number e.g. 100, 200 + + + Check to enable enclosures in syndication. + + + Enable Syndication Enclosures? + + + Check to show pending articles. + + + Show Pending? + + + Attachments + + + Image + + + Specify which field to use for enclosures. + + + Syndication Enclosure Type + + + Author Filter Settings + + + Check to filter by the logged in user. + + + Logged in user Filter: + + + Check to filter by author on the querystring parameter. + + + UserID Filter: + + + Enter the name of the parameter to filter on. + + + UserID Parameter: + + + Check to filter by username. + + + Username Filter: + + + Specify what parameter to select from. + + + Username Parameter: + + + Bottom + + + Specify where to place the menu. + + + Menu Position + + + Top + + + Check to always show PageID in the url. + + + Always Show PageID + + + Select the default image folder. + + + Default Image Folder: + + + Root + + + Classic + + + Shorterned + + + Specify an alias for article ID in shorterned mode. + + + Shortened Article ID + + + Select a url mode for formatting urls. + + + Url Mode + + + <br>Required + + + Check to notify approvers when a comment requires approval. + + + Notify Approvers for Comment Approval + + + Notify email address(s) when a comment requires approval, separate with a ; + + + Notify Email Address for Comment Approval + + + Check to use the canonical link in the head tag. + + + Use Canonical Link + + + Maximum age of articles (days), leave blank for no filter. + + + Max Age + + + (days), leave blank for no filter. + + + Meta + + + Specify the maximum number of items to display in an RSS feed. + + + Syndication Max Count: + + + Syndication Settings + + + <br>Required + + + <br>Must be a valid value, e.g. 50 + + + Custom Fields + + + Match Categories (All) + + + Match Categories (All) and Tags (Any) + + + Match Categories (Any) + + + Match Categories (Any) and Tags (All) + + + Match Categories (Any) and Tags (Any) + + + Match Tags (All) + + + Match Tags (Any) + + + Pick a mode to show related articles. + + + Related Mode + + + Related Settings + + + The API key for generating bit.ly urls. + + + Bit.Ly API Key + + + The login for generating bit.ly urls. + + + Bit.Ly Login + + + Your twitter username to be used in [TWITTERNAME] + + + Twitter Name + + + Twitter Settings + + + Customise the settings usually available to host only. + + + Admin Settings + + + Site Templates + + + Auto-Approve Comment + + + Image Settings + + + Specify the maximum image height to resize. + + + Maximum Image Height + + + Specify the maximum image width to resize. + + + Maximum Image Width + + + Check to resize images upon upload. + + + Resize Images? + + + <br>Required + + + <br>Image Max Height must be a number. + + + <br>Required + + + <br>Image Max Width must be a number. + + + Check to include the jquery script. + + + Include jQuery? + + + Shortened + + + By Dropdown + + + By Username + + + Specity the author selection mode for add/edit article. + + + Author Select Mode + + + Check to enable uploading of new images. + + + Enable Upload Images + + + Select how categories are ordered. + + + Category Sort Order + + + Name + + + Sort Order + + + File Settings + + + Specify the default folder to upload files. + + + Default File Folder + + + File + + + Select direction for sort. + + + Sort Direction + + + Check to publish events to the Active Social wall + + + Publish events to Active Social + + + Bottom Left + + + Bottom Right + + + Top Left + + + Top Right + + + Check to apply a watermark on uploaded images. The watermark is applied during the upload process. + + + Use Watermark? + + + Specify an image to apply as a watermark. + + + Watermark Image + + + Specify the position to place the watermark image. + + + Watermark Position + + + Specify a text string to apply as a watermark. + + + Watermark Text + + + Specify the access key for comment + + + Active Social Key - Comment + + + Specify the access key for rate + + + Active Social Key - Rate + + + Specify the access key for submission + + + Active Social Key - Submit + + + Specify thumbnail cropping algorithm. + + + Thumbnail Type + + + Proportion + + + Square (cropped) + + + Select portal/module combination to be available for sharing articles. + + + Add Article Module + + + Available modules to mirror articles. + + + Available Modules + + + Allows articles to be shared from other portals. + + + No article instances available in other portals. + + + Content Sharing Settings + + + Module + + + No modules currently linked. + + + Portal + + + Remove + + + Remove + + + Check to hide website on the comment form. + + + Hide Website? + + + Expand meta information on the submit article form. + + + Expand Meta Information + + + Check to enforce unique page titles in articles. + + + Unique Page Titles + + + Require email for anonymous users? + + + Require Email? + + + Require name for anonymous users? + + + Require Name? + + + Filter categories on submit article screen. + + + Filter Category Submit + + + -- All Groups -- + + + Specify a default author for creating articles + + + Author Default + + + Specify the path to jquery + + + jQuery Path + + + -- Select Default Author -- + + + Optionally filter roles by role group. + + + Role Group Filter + + + Optionally specify rss image path. + + + RSS Image Path + + + Specify an Akismet key to protect against comment spam. + + + Akismet Key + + + Display Name + + + Process tokens embedded in article. + + + Process Post Tokens? + + + Check to integrate Create, Comment & Rate Article into journal. + + + Journal Integration + + + Check security on categories and post to associates social groups/roles if applicable. + + + Journal Group Posting + + \ No newline at end of file diff --git a/Archives.ascx b/Archives.ascx new file mode 100755 index 0000000..6411c79 --- /dev/null +++ b/Archives.ascx @@ -0,0 +1,66 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="Archives.ascx.vb" Inherits="Ventrian.NewsArticles.Archives" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + \ No newline at end of file diff --git a/Archives.ascx.designer.vb b/Archives.ascx.designer.vb new file mode 100755 index 0000000..ff4a131 --- /dev/null +++ b/Archives.ascx.designer.vb @@ -0,0 +1,152 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class Archives + + ''' + '''Header1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Header1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''phCurrentArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phCurrentArticles As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''lblCurrentArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCurrentArticles As Global.System.Web.UI.WebControls.Label + + ''' + '''phArchives control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phArchives As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''lblLatest control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblLatest As Global.System.Web.UI.WebControls.Label + + ''' + '''phCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phCategory As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''lblByCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblByCategory As Global.System.Web.UI.WebControls.Label + + ''' + '''rptCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rptCategories As Global.System.Web.UI.WebControls.Repeater + + ''' + '''phAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phAuthor As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''lblByAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblByAuthor As Global.System.Web.UI.WebControls.Label + + ''' + '''rptAuthors control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rptAuthors As Global.System.Web.UI.WebControls.Repeater + + ''' + '''phMonth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phMonth As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''lblByMonth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblByMonth As Global.System.Web.UI.WebControls.Label + + ''' + '''rptMonth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rptMonth As Global.System.Web.UI.WebControls.Repeater + + ''' + '''Header2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Header2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/Archives.ascx.vb b/Archives.ascx.vb new file mode 100755 index 0000000..5093445 --- /dev/null +++ b/Archives.ascx.vb @@ -0,0 +1,310 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Security + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class Archives + Inherits NewsArticleModuleBase + +#Region " Protected Properties " + + Protected ReadOnly Property AuthorID() As Integer + Get + Dim id As Integer = Null.NullInteger + If (ArticleSettings.AuthorUserIDFilter) Then + If (Request.QueryString(ArticleSettings.AuthorUserIDParam) <> "") Then + Try + id = Convert.ToInt32(Request.QueryString(ArticleSettings.AuthorUserIDParam)) + Catch + End Try + End If + End If + + If (ArticleSettings.AuthorUsernameFilter) Then + If (Request.QueryString(ArticleSettings.AuthorUsernameParam) <> "") Then + Try + Dim objUser As DotNetNuke.Entities.Users.UserInfo = DotNetNuke.Entities.Users.UserController.GetUserByName(Me.PortalId, Request.QueryString(ArticleSettings.AuthorUsernameParam)) + If (objUser IsNot Nothing) Then + id = objUser.UserID + End If + Catch + End Try + End If + End If + + If (ArticleSettings.AuthorLoggedInUserFilter) Then + If (Request.IsAuthenticated) Then + id = Me.UserId + Else + id = -100 + End If + End If + + If (ArticleSettings.Author <> Null.NullInteger) Then + id = ArticleSettings.Author + End If + + Return id + End Get + End Property + + Protected ReadOnly Property AuthorIDRSS() As String + Get + If (AuthorID <> Null.NullInteger) Then + Return "&AuthorID=" & AuthorID.ToString() + End If + Return "" + End Get + End Property + +#End Region + +#Region " Protected Methods " + + Protected Function GetAuthorLink(ByVal authorID As Integer, ByVal username As String) As String + + Return Common.GetAuthorLink(Me.TabId, Me.ModuleId, authorID, username, ArticleSettings.LaunchLinks, ArticleSettings) + + End Function + + Protected Function GetAuthorLinkRss(ByVal authorID As String) As String + + Return Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/RSS.aspx?TabID=" & TabId.ToString() & "&ModuleID=" & ModuleId.ToString() & "&AuthorID=" & authorID) + + End Function + + Protected Function GetCategoryLink(ByVal categoryID As String, ByVal name As String) As String + + Return Common.GetCategoryLink(Me.TabId, Me.ModuleId, categoryID, name, ArticleSettings.LaunchLinks, ArticleSettings) + + End Function + + Protected Function GetCategoryLinkRss(ByVal categoryID As String) As String + + Return Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/RSS.aspx?TabID=" & TabId.ToString() & "&ModuleID=" & ModuleId.ToString() & "&CategoryID=" & categoryID & AuthorIDRSS) + + End Function + + Protected Function GetCurrentLinkRss() As String + + Return Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/RSS.aspx?TabID=" & TabId.ToString() & "&ModuleID=" & ModuleId.ToString() & "&MaxCount=25" & AuthorIDRSS) + + End Function + + Protected Function GetCurrentLink() As String + + Return Common.GetModuleLink(TabId, ModuleId, "", ArticleSettings) + + End Function + + Protected Function GetMonthLink(ByVal month As Integer, ByVal year As Integer) As String + + Return Common.GetModuleLink(Me.TabId, Me.ModuleId, "ArchiveView", ArticleSettings, "month=" & month.ToString(), "year=" & year.ToString()) + + End Function + + Protected Function GetMonthLinkRss(ByVal month As Integer, ByVal year As Integer) As String + + Return Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/RSS.aspx?TabID=" & TabId.ToString() & "&ModuleID=" & ModuleId.ToString() & "&Month=" & month.ToString() & "&Year=" & year.ToString() & AuthorIDRSS) + + End Function + + Protected Function GetMonthName(ByVal month As Integer) As String + + Dim dt As New DateTime(2008, month, 1) + Return dt.ToString("MMMM") + + End Function + + Protected Function GetRssPath() As String + + Return Page.ResolveUrl(ArticleSettings.SyndicationImagePath) + + End Function + + Protected Function IsSyndicationEnabled() As Boolean + + Return ArticleSettings.IsSyndicationEnabled + + End Function + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + Dim objCategoryController As New CategoryController + If (ArticleSettings.FilterSingleCategory <> Null.NullInteger) Then + Dim categoriesToDisplay(1) As Integer + categoriesToDisplay(1) = ArticleSettings.FilterSingleCategory + + rptCategories.DataSource = objCategoryController.GetCategoriesAll(Me.ModuleId, Null.NullInteger, categoriesToDisplay, AuthorID, Null.NullInteger, ArticleSettings.ShowPending, ArticleSettings.CategorySortType) + rptCategories.DataBind() + Else + Dim objCategoriesSelected As New List(Of CategoryInfo) + Dim objCategoriesDisplay As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(Me.ModuleId, Null.NullInteger, ArticleSettings.FilterCategories, AuthorID, Null.NullInteger, ArticleSettings.ShowPending, ArticleSettings.CategorySortType) + For Each objCategory As CategoryInfo In objCategoriesDisplay + If (objCategory.InheritSecurity) Then + objCategoriesSelected.Add(objCategory) + Else + If (Request.IsAuthenticated) Then + If (Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString())) Then + objCategoriesSelected.Add(objCategory) + End If + End If + End If + End If + Next + + rptCategories.DataSource = objCategoriesSelected + rptCategories.DataBind() + End If + + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(ModuleId, Null.NullInteger) + + Dim excludeCategoriesRestrictive As New List(Of Integer) + + For Each objCategory As CategoryInfo In objCategories + If (objCategory.InheritSecurity = False And objCategory.CategorySecurityType = CategorySecurityType.Restrict) Then + If (Request.IsAuthenticated) Then + If (Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString()) = False) Then + excludeCategoriesRestrictive.Add(objCategory.CategoryID) + End If + End If + Else + excludeCategoriesRestrictive.Add(objCategory.CategoryID) + End If + End If + Next + + Dim excludeCategories As New List(Of Integer) + + For Each objCategory As CategoryInfo In objCategories + If (objCategory.InheritSecurity = False And objCategory.CategorySecurityType = CategorySecurityType.Loose) Then + If (Request.IsAuthenticated) Then + If (Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString()) = False) Then + excludeCategories.Add(objCategory.CategoryID) + End If + End If + Else + excludeCategories.Add(objCategory.CategoryID) + End If + End If + Next + + Dim filterCategories As Integer() = ArticleSettings.FilterCategories + Dim includeCategories As New List(Of Integer) + + If (excludeCategories.Count > 0) Then + + For Each objCategoryToInclude As CategoryInfo In objCategories + + Dim includeCategory As Boolean = True + + For Each exclCategory As Integer In excludeCategories + If (exclCategory = objCategoryToInclude.CategoryID) Then + includeCategory = False + End If + Next + + If (ArticleSettings.FilterCategories IsNot Nothing) Then + If (ArticleSettings.FilterCategories.Length > 0) Then + Dim filter As Boolean = False + For Each cat As Integer In ArticleSettings.FilterCategories + If (cat = objCategoryToInclude.CategoryID) Then + filter = True + End If + Next + If (filter = False) Then + includeCategory = False + End If + End If + End If + + If (includeCategory) Then + includeCategories.Add(objCategoryToInclude.CategoryID) + End If + + Next + + If (includeCategories.Count > 0) Then + includeCategories.Add(-1) + End If + + filterCategories = includeCategories.ToArray() + + End If + + + If (ArticleSettings.FilterSingleCategory <> Null.NullInteger) Then + Dim categoriesToDisplay(1) As Integer + categoriesToDisplay(1) = ArticleSettings.FilterSingleCategory + + Dim objAuthorController As New AuthorController + rptAuthors.DataSource = objAuthorController.GetAuthorStatistics(Me.ModuleId, categoriesToDisplay, excludeCategoriesRestrictive.ToArray(), AuthorID, "DisplayName", ArticleSettings.ShowPending) + rptAuthors.DataBind() + Else + Dim objAuthorController As New AuthorController + rptAuthors.DataSource = objAuthorController.GetAuthorStatistics(Me.ModuleId, filterCategories, excludeCategoriesRestrictive.ToArray(), AuthorID, "DisplayName", ArticleSettings.ShowPending) + rptAuthors.DataBind() + End If + + If (ArticleSettings.FilterSingleCategory <> Null.NullInteger) Then + Dim categoriesToDisplay(1) As Integer + categoriesToDisplay(1) = ArticleSettings.FilterSingleCategory + Dim objArticleController As New ArticleController + rptMonth.DataSource = objArticleController.GetNewsArchive(Me.ModuleId, categoriesToDisplay, excludeCategoriesRestrictive.ToArray(), AuthorID, GroupByType.Month, ArticleSettings.ShowPending) + rptMonth.DataBind() + Else + Dim objArticleController As New ArticleController + rptMonth.DataSource = objArticleController.GetNewsArchive(Me.ModuleId, filterCategories, excludeCategoriesRestrictive.ToArray(), AuthorID, GroupByType.Month, ArticleSettings.ShowPending) + rptMonth.DataBind() + End If + + Me.BasePage.Title = "Archives | " & Me.BasePage.Title + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub Page_PreRender(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.PreRender + + Try + + LoadStyleSheet() + + phCurrentArticles.Visible = ArticleSettings.ArchiveCurrentArticles + phCategory.Visible = ArticleSettings.ArchiveCategories + phAuthor.Visible = ArticleSettings.ArchiveAuthor + phMonth.Visible = ArticleSettings.ArchiveMonth + + phArchives.Visible = IsSyndicationEnabled() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Base/NewsArticleControlBase.vb b/Base/NewsArticleControlBase.vb new file mode 100755 index 0000000..dd9ba27 --- /dev/null +++ b/Base/NewsArticleControlBase.vb @@ -0,0 +1,34 @@ +Namespace Ventrian.NewsArticles.Base + + Public Class NewsArticleControlBase + + Inherits UserControl + +#Region " Private Members " + + Private _articleID As Integer + +#End Region + +#Region " Public Properties " + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal value As Integer) + _articleID = value + End Set + End Property + + Protected ReadOnly Property ArticleModuleBase() As NewsArticleModuleBase + Get + Return CType(Parent, NewsArticleModuleBase) + End Get + End Property + +#End Region + + End Class + +End Namespace diff --git a/Base/NewsArticleModuleBase.vb b/Base/NewsArticleModuleBase.vb new file mode 100755 index 0000000..3b00ee9 --- /dev/null +++ b/Base/NewsArticleModuleBase.vb @@ -0,0 +1,409 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.ComponentModel +Imports System.Text.RegularExpressions +Imports System.Web +Imports System.Web.UI +Imports System.Web.UI.HtmlControls +Imports System.Xml + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Security +Imports DotNetNuke.Services.Localization + +Namespace Ventrian.NewsArticles.Base + + Public Class NewsArticleModuleBase + + Inherits PortalModuleBase + +#Region " Private Members " + + Private _articleSettings As ArticleSettings + +#End Region + +#Region " Public Properties " + + _ + Public ReadOnly Property BasePage() As DotNetNuke.Framework.CDefault + Get + Return CType(Page, DotNetNuke.Framework.CDefault) + End Get + End Property + + Public ReadOnly Property ArticleSettings() As ArticleSettings + Get + If (_articleSettings Is Nothing) Then + Try + _articleSettings = New ArticleSettings(Settings, PortalSettings, ModuleConfiguration) + Catch + Dim objModuleController As New ModuleController() + + Dim objSettings As Hashtable = objModuleController.GetModuleSettings(ModuleId) + Dim objTabSettings As Hashtable = objModuleController.GetTabModuleSettings(TabModuleId) + + For Each item As DictionaryEntry In objTabSettings + If (objSettings.ContainsKey(item.Key) = False) Then + objSettings.Add(item.Key, item.Value) + End If + Next + + _articleSettings = New ArticleSettings(objSettings, PortalSettings, ModuleConfiguration) + objModuleController.UpdateModuleSetting(ModuleId, "ResetArticleSettings", "true") + End Try + End If + Return _articleSettings + End Get + End Property + + Public ReadOnly Property ModuleKey() As String + Get + Return "NewsArticles-" & TabModuleId + End Get + End Property + +#End Region + +#Region " Protected Methods " + + Protected Function EditArticleUrl(ByVal ctl As String) As String + + If (ArticleSettings.AuthorUserIDFilter) Then + If (ArticleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(ArticleSettings.AuthorUserIDParam) <> "") Then + Return EditUrl(ArticleSettings.AuthorUserIDParam, HttpContext.Current.Request(ArticleSettings.AuthorUserIDParam), ctl) + End If + End If + End If + + If (ArticleSettings.AuthorUsernameFilter) Then + If (ArticleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(ArticleSettings.AuthorUsernameParam) <> "") Then + Return EditUrl(ArticleSettings.AuthorUsernameParam, HttpContext.Current.Request(ArticleSettings.AuthorUsernameParam), ctl) + End If + End If + End If + + Return EditUrl(ctl) + + End Function + + Protected Function EditArticleUrl(ByVal ctl As String, ByVal ParamArray params() As String) As String + + Dim parameters As New List(Of String) + + parameters.Add("mid=" & ModuleId.ToString()) + parameters.AddRange(params) + + If (ArticleSettings.AuthorUserIDFilter) Then + If (ArticleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(ArticleSettings.AuthorUserIDParam) <> "") Then + parameters.Add(ArticleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(ArticleSettings.AuthorUserIDParam)) + End If + End If + End If + + If (ArticleSettings.AuthorUsernameFilter) Then + If (ArticleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(ArticleSettings.AuthorUsernameParam) <> "") Then + parameters.Add(ArticleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(ArticleSettings.AuthorUsernameParam)) + End If + End If + End If + + Return NavigateURL(TabId, ctl, parameters.ToArray) + + End Function + + Public Sub LoadStyleSheet() + + + Dim objCSS As Control = BasePage.FindControl("CSS") + + If Not (objCSS Is Nothing) Then + Dim objLink As New HtmlLink() + objLink.ID = "Template_" & ModuleId.ToString() + objLink.Attributes("rel") = "stylesheet" + objLink.Attributes("type") = "text/css" + objLink.Href = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Templates/" & _articleSettings.Template & "/Template.css") + + objCSS.Controls.AddAt(0, objLink) + End If + + End Sub + + Public Function GetSkinAttribute(ByVal xDoc As XmlDocument, ByVal tag As String, ByVal attrib As String, ByVal defaultValue As String) As String + Dim retValue As String = defaultValue + Dim xmlSkinAttributeRoot As XmlNode = xDoc.SelectSingleNode("descendant::Object[Token='[" & tag & "]']") + ' if the token is found + If Not xmlSkinAttributeRoot Is Nothing Then + ' process each token attribute + Dim xmlSkinAttribute As XmlNode + For Each xmlSkinAttribute In xmlSkinAttributeRoot.SelectNodes(".//Settings/Setting") + If xmlSkinAttribute.SelectSingleNode("Value").InnerText <> "" Then + ' append the formatted attribute to the inner contents of the control statement + If xmlSkinAttribute.SelectSingleNode("Name").InnerText = attrib Then + retValue = xmlSkinAttribute.SelectSingleNode("Value").InnerText + End If + End If + Next + End If + Return retValue + End Function + + + Protected Function FormatImageUrl(ByVal imageUrlResolved As String) As String + + Return PortalSettings.HomeDirectory & imageUrlResolved + + End Function + + Protected Function IsRated(ByVal objArticle As ArticleInfo) As Boolean + + If (objArticle.Rating = Null.NullDouble) Then + Return False + Else + Return True + End If + + End Function + + Protected Function IsRated(ByVal objDataItem As Object) As Boolean + + Dim objArticle As ArticleInfo = CType(objDataItem, ArticleInfo) + + Return IsRated(objArticle) + + End Function + + Protected Function GetRatingImage(ByVal objArticle As ArticleInfo) As String + + If (objArticle.Rating = Null.NullDouble) Then + Return ResolveUrl("Images\Rating\stars-0-0.gif") + Else + + Select Case RoundToUnit(objArticle.Rating, 0.5, False) + + Case 1 + Return ResolveUrl("Images\Rating\stars-1-0.gif") + + Case 1.5 + Return ResolveUrl("Images\Rating\stars-1-5.gif") + + Case 2 + Return ResolveUrl("Images\Rating\stars-2-0.gif") + + Case 2.5 + Return ResolveUrl("Images\Rating\stars-2-5.gif") + + Case 3 + Return ResolveUrl("Images\Rating\stars-3-0.gif") + + Case 3.5 + Return ResolveUrl("Images\Rating\stars-3-5.gif") + + Case 4 + Return ResolveUrl("Images\Rating\stars-4-0.gif") + + Case 4.5 + Return ResolveUrl("Images\Rating\stars-4-5.gif") + + Case 5 + Return ResolveUrl("Images\Rating\stars-5-0.gif") + + End Select + + Return ResolveUrl("Images\Rating\stars-0-0.gif") + + End If + + End Function + Protected Function StripHtml(ByVal html As String) As String + + Const pattern As String = "<(.|\n)*?>" + Return Regex.Replace(html, pattern, String.Empty) + + End Function + + + Private Function RoundToUnit(ByVal d As Double, ByVal unit As Double, ByVal roundDown As Boolean) As Double + + If (roundDown) Then + Return Math.Round(Math.Round((d / unit) - 0.5, 0) * unit, 2) + Else + Return Math.Round(Math.Round((d / unit) + 0.5, 0) * unit, 2) + End If + + End Function + + Protected Function GetRatingImage(ByVal objDataItem As Object) As String + + Dim objArticle As ArticleInfo = CType(objDataItem, ArticleInfo) + + Return GetRatingImage(objArticle) + + End Function + + Protected Function GetUserName(ByVal dataItem As Object) As String + + Dim objArticle As ArticleInfo = CType(dataItem, ArticleInfo) + + If Not (objArticle Is Nothing) Then + + Select Case ArticleSettings.DisplayMode + + Case DisplayType.UserName + Return objArticle.AuthorUserName + + Case DisplayType.FirstName + Return objArticle.AuthorFirstName + + Case DisplayType.LastName + Return objArticle.AuthorLastName + + Case DisplayType.FullName + Return objArticle.AuthorFullName + + End Select + + End If + + Return Null.NullString + + End Function + + Protected Function GetUserName(ByVal dataItem As Object, ByVal type As Integer) As String + + Dim objArticle As ArticleInfo = CType(dataItem, ArticleInfo) + + If Not (objArticle Is Nothing) Then + + Select Case type + + Case 1 'Last Updated + + Select Case ArticleSettings.DisplayMode + + Case DisplayType.UserName + Return objArticle.LastUpdateUserName + + Case DisplayType.FirstName + Return objArticle.LastUpdateFirstName + + Case DisplayType.LastName + Return objArticle.LastUpdateLastName + + Case DisplayType.FullName + Return objArticle.LastUpdateDisplayName + + End Select + + Case Else + + Select Case ArticleSettings.DisplayMode + + Case DisplayType.UserName + Return objArticle.AuthorUserName + + Case DisplayType.FirstName + Return objArticle.AuthorFirstName + + Case DisplayType.LastName + Return objArticle.AuthorLastName + + Case DisplayType.FullName + Return objArticle.AuthorDisplayName + + End Select + + End Select + + End If + + Return Null.NullString + + End Function + + Protected Function HasEditRights(ByVal articleId As Integer, ByVal moduleID As Integer, ByVal tabID As Integer) As Boolean + + ' Unauthenticated User + ' + If (Request.IsAuthenticated = False) Then + + Return False + + End If + + Dim objModuleController As ModuleController = New ModuleController + + Dim objModule As ModuleInfo = objModuleController.GetModule(moduleID, tabID) + + If Not (objModule Is Nothing) Then + + ' Admin of Module + ' + If (PortalSecurity.HasEditPermissions(objModule.ModulePermissions)) Then + + Return True + + End If + + End If + + + ' Approver + ' + If (ArticleSettings.IsApprover) Then + Return True + End If + + ' Submitter of New Article + ' + If (articleId = Null.NullInteger And ArticleSettings.IsSubmitter) Then + Return True + End If + + ' Owner of Article + ' + Dim objArticleController As ArticleController = New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(articleId) + If Not (objArticle Is Nothing) Then + If (objArticle.AuthorID = UserId And (objArticle.Status = StatusType.Draft Or ArticleSettings.IsAutoApprover)) Then + Return True + End If + End If + + Return False + + End Function + + Public Function GetSharedResource(ByVal key As String) As String + + Dim path As String = "~/DesktopModules/DnnForge - NewsArticles/" & Localization.LocalResourceDirectory & "/" & Localization.LocalSharedResourceFile + Return Localization.GetString(key, path) + + End Function + +#End Region + +#Region " Shadowed Methods " + + Public Shadows Function ResolveUrl(ByVal url As String) As String + + Return MyBase.ResolveUrl(url).Replace(" ", "%20") + + End Function + +#End Region + + End Class + +End Namespace diff --git a/Components/Archives/ArchiveInfo.vb b/Components/Archives/ArchiveInfo.vb new file mode 100755 index 0000000..20fcb62 --- /dev/null +++ b/Components/Archives/ArchiveInfo.vb @@ -0,0 +1,63 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2005-2012 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Class ArchiveInfo + +#Region " Private Methods " + + ' local property declarations + Dim _day As Integer + Dim _month As Integer + Dim _year As Integer + Dim _count As Integer + +#End Region + +#Region " Public Properties " + + Public Property Day() As Integer + Get + Return _day + End Get + Set(ByVal Value As Integer) + _day = Value + End Set + End Property + + Public Property Month() As Integer + Get + Return _month + End Get + Set(ByVal Value As Integer) + _month = Value + End Set + End Property + + Public Property Year() As Integer + Get + Return _year + End Get + Set(ByVal Value As Integer) + _year = Value + End Set + End Property + + Public Property Count() As Integer + Get + Return _count + End Get + Set(ByVal Value As Integer) + _count = Value + End Set + End Property + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/Archives/ArchiveModeType.vb b/Components/Archives/ArchiveModeType.vb new file mode 100755 index 0000000..364e2d3 --- /dev/null +++ b/Components/Archives/ArchiveModeType.vb @@ -0,0 +1,17 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2005-2012 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Enum ArchiveModeType + + [Date] + Category + Author + + End Enum + +End Namespace diff --git a/Components/Archives/ArchiveSettings.vb b/Components/Archives/ArchiveSettings.vb new file mode 100755 index 0000000..d0b2a32 --- /dev/null +++ b/Components/Archives/ArchiveSettings.vb @@ -0,0 +1,293 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2005-2012 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Friend Class ArchiveSettings + +#Region " Private Properties " + + Private Property Settings As Hashtable + +#End Region + +#Region " Constructors " + + Public Sub New(ByVal moduleSettings As Hashtable) + Settings = moduleSettings + End Sub + +#End Region + +#Region " Public Properties " + + Public ReadOnly Property AuthorSortBy As AuthorSortByType + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_AUTHOR_SORT_BY)) Then + Return CType(System.Enum.Parse(GetType(AuthorSortByType), Settings(ArticleConstants.NEWS_ARCHIVES_AUTHOR_SORT_BY).ToString()), AuthorSortByType) + End If + Return ArticleConstants.NEWS_ARCHIVES_AUTHOR_SORT_BY_DEFAULT + End Get + End Property + + Public ReadOnly Property CategoryHideZeroCategories As Boolean + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_HIDE_ZERO_CATEGORIES)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.NEWS_ARCHIVES_HIDE_ZERO_CATEGORIES).ToString()) + End If + Return ArticleConstants.NEWS_ARCHIVES_HIDE_ZERO_CATEGORIES_DEFAULT + End Get + End Property + + Public ReadOnly Property CategoryMaxDepth As Integer + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_MAX_DEPTH)) Then + If (IsNumeric(Settings(ArticleConstants.NEWS_ARCHIVES_MAX_DEPTH).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.NEWS_ARCHIVES_MAX_DEPTH).ToString()) + End If + End If + Return ArticleConstants.NEWS_ARCHIVES_MAX_DEPTH_DEFAULT + End Get + End Property + + Public ReadOnly Property CategoryParent As Integer + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_PARENT_CATEGORY)) Then + If (IsNumeric(Settings(ArticleConstants.NEWS_ARCHIVES_PARENT_CATEGORY).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.NEWS_ARCHIVES_PARENT_CATEGORY).ToString()) + End If + End If + Return ArticleConstants.NEWS_ARCHIVES_PARENT_CATEGORY_DEFAULT + End Get + End Property + + Public ReadOnly Property GroupBy As GroupByType + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_GROUP_BY)) Then + Return CType(System.Enum.Parse(GetType(GroupByType), Settings(ArticleConstants.NEWS_ARCHIVES_GROUP_BY).ToString()), GroupByType) + End If + Return ArticleConstants.NEWS_ARCHIVES_GROUP_BY_DEFAULT + End Get + End Property + + Public ReadOnly Property ItemsPerRow As Integer + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_ITEMS_PER_ROW)) Then + If (IsNumeric(Settings(ArticleConstants.NEWS_ARCHIVES_ITEMS_PER_ROW).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.NEWS_ARCHIVES_ITEMS_PER_ROW).ToString()) + End If + End If + Return ArticleConstants.NEWS_ARCHIVES_ITEMS_PER_ROW_DEFAULT + End Get + End Property + + Public ReadOnly Property LayoutMode As LayoutModeType + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_LAYOUT_MODE)) Then + Return CType(System.Enum.Parse(GetType(LayoutModeType), Settings(ArticleConstants.NEWS_ARCHIVES_LAYOUT_MODE).ToString()), LayoutModeType) + End If + Return ArticleConstants.NEWS_ARCHIVES_LAYOUT_MODE_DEFAULT + End Get + End Property + + Public ReadOnly Property Mode As ArchiveModeType + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_MODE)) Then + Return CType(System.Enum.Parse(GetType(ArchiveModeType), Settings(ArticleConstants.NEWS_ARCHIVES_MODE).ToString()), ArchiveModeType) + End If + Return ArticleConstants.NEWS_ARCHIVES_MODE_DEFAULT + End Get + End Property + + Public ReadOnly Property ModuleId As Integer + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_MODULE_ID)) Then + If (IsNumeric(Settings(ArticleConstants.NEWS_ARCHIVES_MODULE_ID).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.NEWS_ARCHIVES_MODULE_ID).ToString()) + End If + End If + Return ArticleConstants.NEWS_ARCHIVES_MODULE_ID_DEFAULT + End Get + End Property + + Public ReadOnly Property TabId As Integer + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_TAB_ID)) Then + If (IsNumeric(Settings(ArticleConstants.NEWS_ARCHIVES_TAB_ID).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.NEWS_ARCHIVES_TAB_ID).ToString()) + End If + End If + Return ArticleConstants.NEWS_ARCHIVES_TAB_ID_DEFAULT + End Get + End Property + + Public ReadOnly Property TemplateAuthorAdvancedBody + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_BODY_ADVANCED)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_BODY_ADVANCED).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_BODY_ADVANCED + End Get + End Property + + Public ReadOnly Property TemplateAuthorAdvancedFooter + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_FOOTER_ADVANCED)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_FOOTER_ADVANCED).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_FOOTER_ADVANCED + End Get + End Property + + Public ReadOnly Property TemplateAuthorAdvancedHeader + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_HEADER_ADVANCED)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_HEADER_ADVANCED).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_HEADER_ADVANCED + End Get + End Property + + Public ReadOnly Property TemplateAuthorBody + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_BODY)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_BODY).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_BODY + End Get + End Property + + Public ReadOnly Property TemplateAuthorFooter + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_FOOTER)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_FOOTER).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_FOOTER + End Get + End Property + + Public ReadOnly Property TemplateAuthorHeader + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_HEADER)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_AUTHOR_HTML_HEADER).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_HEADER + End Get + End Property + + Public ReadOnly Property TemplateCategoryAdvancedBody + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_BODY_ADVANCED)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_BODY_ADVANCED).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_BODY_ADVANCED + End Get + End Property + + Public ReadOnly Property TemplateCategoryAdvancedFooter + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_FOOTER_ADVANCED)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_FOOTER_ADVANCED).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_FOOTER_ADVANCED + End Get + End Property + + Public ReadOnly Property TemplateCategoryAdvancedHeader + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_HEADER_ADVANCED)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_HEADER_ADVANCED).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_HEADER_ADVANCED + End Get + End Property + + Public ReadOnly Property TemplateCategoryBody + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_BODY)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_BODY).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_BODY + End Get + End Property + + Public ReadOnly Property TemplateCategoryFooter + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_FOOTER)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_FOOTER).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_FOOTER + End Get + End Property + + Public ReadOnly Property TemplateCategoryHeader + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_HEADER)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_CATEGORY_HTML_HEADER).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_HEADER + End Get + End Property + + Public ReadOnly Property TemplateDateAdvancedBody + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_BODY_ADVANCED)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_BODY_ADVANCED).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_HTML_BODY_ADVANCED + End Get + End Property + + Public ReadOnly Property TemplateDateAdvancedFooter + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_FOOTER_ADVANCED)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_FOOTER_ADVANCED).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_HTML_FOOTER_ADVANCED + End Get + End Property + + Public ReadOnly Property TemplateDateAdvancedHeader + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_HEADER_ADVANCED)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_HEADER_ADVANCED).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_HTML_HEADER_ADVANCED + End Get + End Property + + Public ReadOnly Property TemplateDateBody + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_BODY)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_BODY).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_HTML_BODY + End Get + End Property + + Public ReadOnly Property TemplateDateFooter + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_FOOTER)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_FOOTER).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_HTML_FOOTER + End Get + End Property + + Public ReadOnly Property TemplateDateHeader + Get + If (Settings.Contains(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_HEADER)) Then + Return Settings(ArticleConstants.NEWS_ARCHIVES_SETTING_HTML_HEADER).ToString() + End If + Return ArticleConstants.NEWS_ARCHIVES_DEFAULT_HTML_HEADER + End Get + End Property + +#End Region + + End Class + +End Namespace diff --git a/Components/ArticleController.vb b/Components/ArticleController.vb new file mode 100755 index 0000000..f007b05 --- /dev/null +++ b/Components/ArticleController.vb @@ -0,0 +1,930 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Security.Roles +Imports DotNetNuke.Services.Search +Imports System.Xml +Imports System.Security.Cryptography +Imports Ventrian.NewsArticles.Components.CustomFields + +Namespace Ventrian.NewsArticles + + Public Class ArticleController + Implements ISearchable + Implements IPortable + +#Region " Private Methods " + + Private Function FillArticleCollection(ByVal dr As IDataReader, ByRef totalRecords As Integer, ByVal maxCount As Integer) As List(Of ArticleInfo) + + Dim objArticles As New List(Of ArticleInfo) + While dr.Read + objArticles.Add(CType(CBO.FillObject(dr, GetType(ArticleInfo), False), ArticleInfo)) + End While + + Dim nextResult As Boolean = dr.NextResult() + totalRecords = 0 + + If dr.Read Then + totalRecords = Convert.ToInt32(Null.SetNull(dr("TotalRecords"), totalRecords)) + If (maxCount <> Null.NullInteger AndAlso maxCount < totalRecords) Then + totalRecords = maxCount + End If + End If + + If Not dr Is Nothing Then + dr.Close() + End If + + Return objArticles + + End Function + +#End Region + +#Region " Static Methods " + + Public Shared Sub ClearArchiveCache(ByVal moduleID As Integer) + + Dim itemsToRemove As New List(Of String)() + + If (HttpContext.Current IsNot Nothing) Then + Dim enumerator As IDictionaryEnumerator = HttpContext.Current.Cache.GetEnumerator() + While enumerator.MoveNext() + If enumerator.Key.ToString().ToLower().Contains("ventrian-newsarticles-archive-" & moduleID.ToString()) Then + itemsToRemove.Add(enumerator.Key.ToString()) + End If + End While + + For Each itemToRemove As String In itemsToRemove + DataCache.RemoveCache(itemToRemove.Replace("DNN_", "")) + Next + End If + + End Sub + + Public Shared Sub ClearArticleCache(ByVal articleID As Integer) + + Dim cacheKey As String = "ventrian-newsarticles-article-" & articleID.ToString() + DataCache.RemoveCache(cacheKey) + + + + End Sub + +#End Region + +#Region " Public Methods " + + Public Function GetArticleList(ByVal moduleID As Integer) As List(Of ArticleInfo) + + Return GetArticleList(moduleID, True) + + End Function + + Public Function GetArticleList(ByVal moduleID As Integer, ByVal isApproved As Boolean) As List(Of ArticleInfo) + + Return GetArticleList(moduleID, Null.NullDate, Null.NullDate, Nothing, Null.NullBoolean, Nothing, Null.NullInteger, Null.NullInteger, Null.NullInteger, "CreatedDate", "DESC", isApproved, Null.NullBoolean, Null.NullString, Null.NullInteger, Null.NullBoolean, Null.NullBoolean, Null.NullBoolean, Null.NullBoolean, Null.NullBoolean, Null.NullBoolean, Null.NullString, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, Null.NullInteger) + + End Function + + Public Function GetArticleList(ByVal moduleID As Integer, ByVal isApproved As Boolean, ByVal sort As String) As List(Of ArticleInfo) + + Return GetArticleList(moduleID, Null.NullDate, Null.NullDate, Nothing, Null.NullBoolean, Nothing, Null.NullInteger, Null.NullInteger, Null.NullInteger, sort, "DESC", isApproved, Null.NullBoolean, Null.NullString, Null.NullInteger, Null.NullBoolean, Null.NullBoolean, Null.NullBoolean, Null.NullBoolean, Null.NullBoolean, Null.NullBoolean, Null.NullString, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, Null.NullInteger) + + End Function + + Public Function GetArticleList(ByVal moduleID As Integer, ByVal currentDate As DateTime, ByVal agedDate As DateTime, ByVal categoryID As Integer(), ByVal matchAll As Boolean, ByVal maxCount As Integer, ByVal pageNumber As Integer, ByVal pageSize As Integer, ByVal sortBy As String, ByVal sortDirection As String, ByVal isApproved As Boolean, ByVal isDraft As Boolean, ByVal keywords As String, ByVal authorID As Integer, ByVal showPending As Boolean, ByVal showExpired As Boolean, ByVal showFeaturedOnly As Boolean, ByVal showNotFeaturedOnly As Boolean, ByVal showSecuredOnly As Boolean, ByVal showNotSecuredOnly As Boolean, ByVal articleIDs As String, ByRef totalRecords As Integer) As List(Of ArticleInfo) + + Return GetArticleList(moduleID, currentDate, agedDate, categoryID, matchAll, Nothing, maxCount, pageNumber, pageSize, sortBy, sortDirection, isApproved, isDraft, keywords, authorID, showPending, showExpired, showFeaturedOnly, showNotFeaturedOnly, showSecuredOnly, showNotSecuredOnly, articleIDs, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, totalRecords) + + End Function + + Public Function GetArticleList(ByVal moduleID As Integer, ByVal currentDate As DateTime, ByVal agedDate As DateTime, ByVal categoryID As Integer(), ByVal matchAll As Boolean, ByVal categoryIDExclude As Integer(), ByVal maxCount As Integer, ByVal pageNumber As Integer, ByVal pageSize As Integer, ByVal sortBy As String, ByVal sortDirection As String, ByVal isApproved As Boolean, ByVal isDraft As Boolean, ByVal keywords As String, ByVal authorID As Integer, ByVal showPending As Boolean, ByVal showExpired As Boolean, ByVal showFeaturedOnly As Boolean, ByVal showNotFeaturedOnly As Boolean, ByVal showSecuredOnly As Boolean, ByVal showNotSecuredOnly As Boolean, ByVal articleIDs As String, ByVal tagID As Integer(), ByVal matchAllTag As Boolean, ByVal rssGuid As String, ByVal customFieldID As Integer, ByVal customValue As String, ByVal linkFilter As String, ByRef totalRecords As Integer) As List(Of ArticleInfo) + + Return FillArticleCollection(DataProvider.Instance().GetArticleListBySearchCriteria(moduleID, currentDate, agedDate, categoryID, matchAll, categoryIDExclude, maxCount, pageNumber, pageSize, sortBy, sortDirection, isApproved, isDraft, keywords, authorID, showPending, showExpired, showFeaturedOnly, showNotFeaturedOnly, showSecuredOnly, showNotSecuredOnly, articleIDs, tagID, matchAllTag, rssGuid, customFieldID, customValue, linkFilter), totalRecords, maxCount) + + End Function + + Public Function GetArticle(ByVal articleID As Integer) As ArticleInfo + + Dim cacheKey As String = "ventrian-newsarticles-article-" & articleID.ToString() + + Dim objArticle As ArticleInfo = CType(DataCache.GetCache(cacheKey), ArticleInfo) + + If (objArticle Is Nothing) Then + objArticle = CType(CBO.FillObject(DataProvider.Instance().GetArticle(articleID), GetType(ArticleInfo)), ArticleInfo) + If (objArticle Is Nothing) Then + Return Nothing + End If + DataCache.SetCache(cacheKey, objArticle) + End If + + Return objArticle + + End Function + + Public Function GetArticleCategories(ByVal articleID As Integer) As ArrayList + + Dim objArticleCategories As ArrayList = CType(DataCache.GetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & articleID.ToString()), ArrayList) + + If (objArticleCategories Is Nothing) Then + objArticleCategories = CBO.FillCollection(DataProvider.Instance().GetArticleCategories(articleID), GetType(CategoryInfo)) + DataCache.SetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & articleID.ToString(), objArticleCategories) + End If + Return objArticleCategories + + End Function + + Public Function GetNewsArchive(ByVal moduleID As Integer, ByVal categoryID As Integer(), ByVal categoryIDExclude As Integer(), ByVal authorID As Integer, ByVal groupBy As GroupByType, ByVal showPending As Boolean) As List(Of ArchiveInfo) + + Dim categories As String = Null.NullString + + If Not (categoryID Is Nothing) Then + For Each category As Integer In categoryID + If Not (categories = Null.NullString) Then + categories = categories & "," + End If + categories = categories & category.ToString() + Next + End If + + Dim categoriesExclude As String = Null.NullString + + If Not (categoryIDExclude Is Nothing) Then + For Each category As Integer In categoryIDExclude + If Not (categoriesExclude = Null.NullString) Then + categoriesExclude = categoriesExclude & "," + End If + categoriesExclude = categoriesExclude & category.ToString() + Next + End If + + Dim hashCategories As String = "" + If (categories <> "" Or categoriesExclude <> "") Then + Dim Ue As New UnicodeEncoding() + Dim ByteSourceText() As Byte = Ue.GetBytes(categories & categoriesExclude) + Dim Md5 As New MD5CryptoServiceProvider() + Dim ByteHash() As Byte = Md5.ComputeHash(ByteSourceText) + hashCategories = Convert.ToBase64String(ByteHash) + End If + + Dim cacheKey As String = "ventrian-newsarticles-archive-" & moduleID.ToString() & "-" & hashCategories & "-" & authorID.ToString() & "-" & groupBy.ToString() & "-" & showPending.ToString() + + Dim objArchives As List(Of ArchiveInfo) = CType(DataCache.GetCache(cacheKey), List(Of ArchiveInfo)) + + If (objArchives Is Nothing) Then + objArchives = CBO.FillCollection(Of ArchiveInfo)(DataProvider.Instance().GetNewsArchive(moduleID, categoryID, categoryIDExclude, authorID, groupBy.ToString(), showPending)) + DataCache.SetCache(cacheKey, objArchives) + End If + + Return objArchives + + End Function + + Public Sub DeleteArticle(ByVal articleID As Integer) + + Dim objArticle As ArticleInfo = GetArticle(articleID) + + If (objArticle IsNot Nothing) Then + DeleteArticle(articleID, objArticle.ModuleID) + End If + + End Sub + + Public Sub DeleteArticle(ByVal articleID As Integer, ByVal moduleID As Integer) + + DataProvider.Instance().DeleteArticle(articleID) + CategoryController.ClearCache(moduleID) + AuthorController.ClearCache(moduleID) + ArticleController.ClearArchiveCache(moduleID) + ArticleController.ClearArticleCache(articleID) + + End Sub + + Public Sub DeleteArticleCategories(ByVal articleID As Integer) + + DataProvider.Instance().DeleteArticleCategories(articleID) + DataCache.RemoveCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & articleID.ToString()) + + End Sub + + Public Function AddArticle(ByVal objArticle As ArticleInfo) As Integer + + Dim articleID As Integer = CType(DataProvider.Instance().AddArticle(objArticle.AuthorID, objArticle.ApproverID, objArticle.CreatedDate, objArticle.LastUpdate, objArticle.Title, objArticle.Summary, objArticle.IsApproved, objArticle.NumberOfViews, objArticle.IsDraft, objArticle.StartDate, objArticle.EndDate, objArticle.ModuleID, objArticle.ImageUrl, objArticle.IsFeatured, objArticle.LastUpdateID, objArticle.Url, objArticle.IsSecure, objArticle.IsNewWindow, objArticle.MetaTitle, objArticle.MetaDescription, objArticle.MetaKeywords, objArticle.PageHeadText, objArticle.ShortUrl, objArticle.RssGuid), Integer) + + CategoryController.ClearCache(objArticle.ModuleID) + AuthorController.ClearCache(objArticle.ModuleID) + ArticleController.ClearArchiveCache(objArticle.ModuleID) + + Return articleID + + End Function + + Public Sub AddArticleCategory(ByVal articleID As Integer, ByVal categoryID As Integer) + + DataProvider.Instance().AddArticleCategory(articleID, categoryID) + DataCache.RemoveCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & articleID.ToString()) + + End Sub + + Public Sub UpdateArticle(ByVal objArticle As ArticleInfo) + + DataProvider.Instance().UpdateArticle(objArticle.ArticleID, objArticle.AuthorID, objArticle.ApproverID, objArticle.CreatedDate, objArticle.LastUpdate, objArticle.Title, objArticle.Summary, objArticle.IsApproved, objArticle.NumberOfViews, objArticle.IsDraft, objArticle.StartDate, objArticle.EndDate, objArticle.ModuleID, objArticle.ImageUrl, objArticle.IsFeatured, objArticle.LastUpdateID, objArticle.Url, objArticle.IsSecure, objArticle.IsNewWindow, objArticle.MetaTitle, objArticle.MetaDescription, objArticle.MetaKeywords, objArticle.PageHeadText, objArticle.ShortUrl, objArticle.RssGuid) + + CategoryController.ClearCache(objArticle.ModuleID) + AuthorController.ClearCache(objArticle.ModuleID) + ArticleController.ClearArchiveCache(objArticle.ModuleID) + ArticleController.ClearArticleCache(objArticle.ArticleID) + + End Sub + + Public Sub UpdateArticleCount(ByVal articleID As Integer, ByVal count As Integer) + + DataProvider.Instance().UpdateArticleCount(articleID, count) + + End Sub + + Public Function SecureCheck(ByVal portalID As Integer, ByVal articleID As Integer, ByVal userID As Integer) As Boolean + + Return DataProvider.Instance().SecureCheck(portalID, articleID, userID) + + End Function + +#End Region + + Private Function GetTabModuleSettings(ByVal TabModuleId As Integer, ByVal settings As Hashtable) As Hashtable + + Dim dr As IDataReader = DotNetNuke.Data.DataProvider.Instance().GetTabModuleSettings(TabModuleId) + + While dr.Read() + + If Not dr.IsDBNull(1) Then + settings(dr.GetString(0)) = dr.GetString(1) + Else + settings(dr.GetString(0)) = "" + End If + + End While + + dr.Close() + + Return settings + + End Function + +#Region " Optional Interfaces " + + Public Function GetSearchItems(ByVal ModInfo As DotNetNuke.Entities.Modules.ModuleInfo) As DotNetNuke.Services.Search.SearchItemInfoCollection Implements DotNetNuke.Entities.Modules.ISearchable.GetSearchItems + + Dim objModuleController As New ModuleController + Dim settings As Hashtable = objModuleController.GetModuleSettings(ModInfo.ModuleID) + settings = GetTabModuleSettings(ModInfo.TabModuleID, settings) + + Dim doSearch As Boolean = False + + If (settings.Contains(ArticleConstants.ENABLE_CORE_SEARCH_SETTING)) Then + doSearch = Convert.ToBoolean(settings(ArticleConstants.ENABLE_CORE_SEARCH_SETTING)) + End If + + Dim SearchItemCollection As New SearchItemInfoCollection + + If (doSearch) Then + + Dim objArticles As List(Of ArticleInfo) = GetArticleList(ModInfo.ModuleID) + + For Each objArticle As ArticleInfo In objArticles + With CType(objArticle, ArticleInfo) + + If (objArticle.IsApproved) Then + + Dim objPageController As New PageController + Dim objPages As ArrayList = objPageController.GetPageList(objArticle.ArticleID) + For i As Integer = 0 To objPages.Count - 1 + Dim SearchItem As SearchItemInfo + Dim objPage As PageInfo = CType(objPages(i), PageInfo) + Dim pageContent As String = HttpUtility.HtmlDecode(objArticle.Title) + " " + System.Web.HttpUtility.HtmlDecode(objPage.PageText) + + For Each Item As DictionaryEntry In objArticle.CustomList + If (Item.Value.ToString() <> "") Then + pageContent = pageContent & vbCrLf & Item.Value.ToString() + End If + Next + + Dim pageDescription As String = HtmlUtils.Shorten(HtmlUtils.Clean(System.Web.HttpUtility.HtmlDecode(objPage.PageText), False), 100, "...") + + Dim title As String = objArticle.Title & " - " & objPage.Title + If (objArticle.Title = objPage.Title) Then + title = objArticle.Title + End If + If (i = 0) Then + SearchItem = New SearchItemInfo(title, pageDescription, objArticle.AuthorID, objArticle.LastUpdate, ModInfo.ModuleID, ModInfo.ModuleID.ToString() & "_" & .ArticleID.ToString & "_" & objPage.PageID.ToString, pageContent, "ArticleType=ArticleView&ArticleID=" & .ArticleID.ToString) + Else + SearchItem = New SearchItemInfo(title, pageDescription, objArticle.AuthorID, objArticle.LastUpdate, ModInfo.ModuleID, ModInfo.ModuleID.ToString() & "_" & .ArticleID.ToString & "_" & objPage.PageID.ToString, pageContent, "ArticleType=ArticleView&ArticleID=" & .ArticleID.ToString & "&PageID=" + objPage.PageID.ToString()) + End If + SearchItemCollection.Add(SearchItem) + Next + + End If + + End With + Next + + End If + + Return SearchItemCollection + + End Function + + Public Function ExportModule(ByVal ModuleID As Integer) As String Implements IPortable.ExportModule + + Dim strXML As String = "" + strXML += WriteCategories(ModuleID, Null.NullInteger) + strXML += WriteTags(ModuleID) + strXML += WriteCustomFields(ModuleID) + strXML += WriteArticles(ModuleID) + Return strXML + + End Function + + Public Sub ImportModule(ByVal ModuleID As Integer, ByVal Content As String, ByVal Version As String, ByVal UserId As Integer) Implements IPortable.ImportModule + + Dim objXmlDocument As New XmlDocument() + objXmlDocument.LoadXml("" & Content & "") + + For Each xmlChildNode As XmlNode In objXmlDocument.ChildNodes(0).ChildNodes + If (xmlChildNode.Name = "categories") Then + Dim sortOrder As Integer = 0 + For Each xmlCategory As XmlNode In xmlChildNode.ChildNodes + ReadCategory(ModuleID, xmlCategory, Null.NullInteger, sortOrder) + sortOrder = sortOrder + 1 + Next + End If + + If (xmlChildNode.Name = "tags") Then + For Each xmlTag As XmlNode In xmlChildNode.ChildNodes + ReadTag(ModuleID, xmlTag) + Next + End If + + If (xmlChildNode.Name = "customfields") Then + For Each xmlCustomField As XmlNode In xmlChildNode.ChildNodes + ReadCustomField(ModuleID, xmlCustomField) + Next + End If + + If (xmlChildNode.Name = "articles") Then + For Each xmlArticle As XmlNode In xmlChildNode.ChildNodes + ReadArticle(ModuleID, xmlArticle) + Next + End If + Next + + End Sub + + Private Function WriteCategories(ByVal ModuleID As Integer, ByVal parentID As Integer) As String + + Dim strXML As String = "" + + Dim objCategoryController As New CategoryController + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategories(ModuleID, parentID) + + If objCategories.Count <> 0 Then + strXML += "" + For Each objCategory As CategoryInfo In objCategories + strXML += "" + strXML += "" & XmlUtils.XMLEncode(objCategory.Name) & "" + strXML += "" & XmlUtils.XMLEncode(objCategory.Description) & "" + strXML += "" & XmlUtils.XMLEncode(objCategory.MetaTitle) & "" + strXML += "" & XmlUtils.XMLEncode(objCategory.MetaDescription) & "" + strXML += "" & XmlUtils.XMLEncode(objCategory.MetaKeywords) & "" + strXML += WriteCategories(ModuleID, objCategory.CategoryID) + strXML += "" + Next + strXML += "" + End If + + Return strXML + + End Function + + Public Sub ReadCategory(ByVal ModuleID As Integer, ByVal xmlCategory As XmlNode, ByVal parentCategoryID As Integer, ByVal sortOrder As Integer) + + Dim objCategory As New CategoryInfo + objCategory.ParentID = parentCategoryID + objCategory.ModuleID = ModuleID + objCategory.Name = xmlCategory.Item("name").InnerText + objCategory.Description = xmlCategory.Item("description").InnerText + + objCategory.InheritSecurity = True + objCategory.CategorySecurityType = CategorySecurityType.Loose + + objCategory.MetaTitle = xmlCategory.Item("metaTitle").InnerText + objCategory.MetaDescription = xmlCategory.Item("metaDescription").InnerText + objCategory.MetaKeywords = xmlCategory.Item("metaKeywords").InnerText + + objCategory.Image = Null.NullString() + objCategory.SortOrder = sortOrder + + Dim objCategoryController As New CategoryController + objCategory.CategoryID = objCategoryController.AddCategory(objCategory) + + Dim childSortOrder As Integer = 0 + For Each xmlChildNode As XmlNode In xmlCategory.ChildNodes + If (xmlChildNode.Name.ToLower() = "categories") Then + For Each xmlChildCategory As XmlNode In xmlChildNode.ChildNodes + ReadCategory(ModuleID, xmlChildCategory, objCategory.CategoryID, childSortOrder) + Next + End If + childSortOrder = childSortOrder + 1 + Next + + End Sub + + Private Function WriteTags(ByVal ModuleID As Integer) As String + + Dim strXML As String = "" + + Dim objTagController As New TagController() + Dim objTags As ArrayList = objTagController.List(ModuleID, Null.NullInteger) + + If objTags.Count <> 0 Then + strXML += "" + For Each objTag As TagInfo In objTags + strXML += "" + strXML += "" & XmlUtils.XMLEncode(objTag.Name) & "" + strXML += "" & XmlUtils.XMLEncode(objTag.Usages.ToString()) & "" + strXML += "" + Next + strXML += "" + End If + + Return strXML + + End Function + + Public Sub ReadTag(ByVal ModuleID As Integer, ByVal xmlTag As XmlNode) + + Dim objTag As New TagInfo + + objTag.ModuleID = ModuleID + objTag.Name = xmlTag.Item("name").InnerText + objTag.NameLowered = objTag.Name.ToLower() + objTag.Usages = Convert.ToInt32(xmlTag.Item("usage").InnerText) + + Dim objTagController As New TagController + objTagController.Add(objTag) + + End Sub + + Private Function WriteCustomFields(ByVal ModuleID As Integer) As String + + Dim strXML As String = "" + + Dim objCustomFieldController As New CustomFieldController() + Dim objCustomFields = objCustomFieldController.List(ModuleID) + + If objCustomFields.Count <> 0 Then + strXML += "" + For Each objCustomField As CustomFieldInfo In objCustomFields + strXML += "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.Name) & "" + strXML += "" & XmlUtils.XMLEncode(CType(objCustomField.FieldType, Integer)) & "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.FieldElements) & "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.DefaultValue) & "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.Caption) & "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.CaptionHelp) & "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.IsRequired) & "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.IsVisible) & "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.SortOrder) & "" + strXML += "" & XmlUtils.XMLEncode(CType(objCustomField.ValidationType, Integer)) & "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.RegularExpression) & "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.Length) & "" + strXML += "" + Next + strXML += "" + End If + + Return strXML + + End Function + + Public Sub ReadCustomField(ByVal ModuleID As Integer, ByVal xmlCustomField As XmlNode) + + Dim objCustomField As New CustomFieldInfo + + objCustomField.ModuleID = ModuleID + objCustomField.Name = xmlCustomField.Item("name").InnerText + objCustomField.FieldType = [Enum].Parse(GetType(CustomFieldType), xmlCustomField.Item("fieldtype").InnerText) + objCustomField.FieldElements = xmlCustomField.Item("fieldelements").InnerText + objCustomField.DefaultValue = xmlCustomField.Item("defaultvalue").InnerText + objCustomField.Caption = xmlCustomField.Item("caption").InnerText + objCustomField.CaptionHelp = xmlCustomField.Item("captionhelp").InnerText + objCustomField.IsRequired = Convert.ToBoolean(xmlCustomField.Item("isrequired").InnerText) + objCustomField.IsVisible = Convert.ToBoolean(xmlCustomField.Item("isvisible").InnerText) + objCustomField.SortOrder = Convert.ToInt32(xmlCustomField.Item("sortorder").InnerText) + objCustomField.ValidationType = [Enum].Parse(GetType(CustomFieldValidationType), xmlCustomField.Item("validationType").InnerText) + objCustomField.RegularExpression = xmlCustomField.Item("regularexpression").InnerText + objCustomField.Length = Convert.ToInt32(xmlCustomField.Item("length").InnerText) + + Dim objCustomFieldController As New CustomFieldController + objCustomFieldController.Add(objCustomField) + + End Sub + + Private Function WriteArticles(ByVal ModuleID As Integer) As String + + Dim strXML As String = "" + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFields As ArrayList = objCustomFieldController.List(ModuleID) + + Dim objArticleController As New ArticleController + Dim objArticles As List(Of ArticleInfo) = objArticleController.GetArticleList(ModuleID, DateTime.Now, Null.NullDate, Nothing, True, 10000, 1, 10000, "CreatedDate", "DESC", True, False, Null.NullString, Null.NullInteger, True, True, False, False, False, False, Null.NullString, Nothing) + + If objArticles.Count <> 0 Then + strXML += "" + For Each objArticle As ArticleInfo In objArticles + strXML += "
" + strXML += "" & XmlUtils.XMLEncode(objArticle.CreatedDate.ToString("O")) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.LastUpdate.ToString("O")) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.Title) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.IsApproved.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.NumberOfViews.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.IsDraft.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.StartDate.ToString("O")) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.EndDate.ToString("O")) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.ImageUrl.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.IsFeatured.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.Url) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.IsSecure.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.IsNewWindow.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.CommentCount.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.PageCount.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.FileCount.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.ImageCount.ToString()) & "" + If (objArticle.Rating <> Null.NullDouble) Then + strXML += "" & XmlUtils.XMLEncode(objArticle.Rating.ToString()) & "" + End If + strXML += "" & XmlUtils.XMLEncode(objArticle.RatingCount.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.Url) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.MetaTitle) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.MetaDescription) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.MetaKeywords) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.PageHeadText) & "" + strXML += "" & XmlUtils.XMLEncode(objArticle.ShortUrl) & "" + + Dim objArticleCategories As ArrayList = objArticleController.GetArticleCategories(objArticle.ArticleID) + If (objArticleCategories.Count > 0) Then + strXML += "" + For Each objCategory As CategoryInfo In objArticleCategories + strXML += "" + strXML += "" & XmlUtils.XMLEncode(objCategory.Name) & "" + strXML += "" + Next + strXML += "" + End If + + If (objArticle.Tags <> "") Then + strXML += "" + For Each tag As String In objArticle.Tags.Split(","c) + strXML += "" + strXML += "" & XmlUtils.XMLEncode(tag) & "" + strXML += "" + Next + strXML += "" + End If + + If (objArticle.CustomList.Count > 0) Then + strXML += "" + For Each item As DictionaryEntry In objArticle.CustomList + + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.CustomFieldID = item.Key) Then + strXML += "" + strXML += "" & XmlUtils.XMLEncode(objCustomField.Name) & "" + strXML += "" & XmlUtils.XMLEncode(item.Value) & "" + strXML += "" + Exit For + End If + Next + + Next + strXML += "" + End If + + If (objArticle.PageCount > 0) Then + Dim objPageController As New PageController + Dim objPages As ArrayList = objPageController.GetPageList(objArticle.ArticleID) + + If (objPages.Count > 0) Then + strXML += "" + For Each objPage As PageInfo In objPages + strXML += "" + strXML += "" & XmlUtils.XMLEncode(objPage.Title) & "" + strXML += "" & XmlUtils.XMLEncode(objPage.PageText) & "" + strXML += "" + Next + strXML += "" + End If + End If + + If (objArticle.ImageCount > 0) Then + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString()) + + If (objImages.Count > 0) Then + strXML += "" + For Each objImage As ImageInfo In objImages + strXML += "" + strXML += "" & XmlUtils.XMLEncode(objImage.Title) & "" + strXML += "" & XmlUtils.XMLEncode(objImage.FileName) & "" + strXML += "" & XmlUtils.XMLEncode(objImage.Extension) & "" + strXML += "" & XmlUtils.XMLEncode(objImage.Size.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objImage.Width.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objImage.Height.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objImage.ContentType) & "" + strXML += "" & XmlUtils.XMLEncode(objImage.Folder) & "" + strXML += "" + Next + strXML += "" + End If + End If + + If (objArticle.FileCount > 0) Then + Dim objFileController As New FileController + Dim objFiles As List(Of FileInfo) = objFileController.GetFileList(objArticle.ArticleID, Null.NullString) + + If (objFiles.Count > 0) Then + strXML += "" + For Each objFile As FileInfo In objFiles + strXML += "" + strXML += "" & XmlUtils.XMLEncode(objFile.Title) & "" + strXML += "" & XmlUtils.XMLEncode(objFile.FileName) & "" + strXML += "" & XmlUtils.XMLEncode(objFile.Extension) & "" + strXML += "" & XmlUtils.XMLEncode(objFile.Size.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objFile.ContentType) & "" + strXML += "" & XmlUtils.XMLEncode(objFile.Folder) & "" + strXML += "" + Next + strXML += "" + End If + End If + + If (objArticle.CommentCount > 0) Then + Dim objCommentController As New CommentController + Dim objComments As List(Of CommentInfo) = objCommentController.GetCommentList(ModuleID, objArticle.ArticleID, True) + + If (objComments.Count > 0) Then + strXML += "" + For Each objComment As CommentInfo In objComments + strXML += "" + strXML += "" & XmlUtils.XMLEncode(objArticle.CreatedDate.ToString("O")) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.Comment) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.RemoteAddress) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.Type.ToString()) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.TrackbackUrl) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.TrackbackTitle) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.TrackbackBlogName) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.TrackbackExcerpt) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.AnonymousName) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.AnonymousEmail) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.AnonymousURL) & "" + strXML += "" & XmlUtils.XMLEncode(objComment.NotifyMe.ToString()) & "" + strXML += "" + Next + strXML += "" + End If + End If + + strXML += "
" + Next + strXML += "
" + End If + + Return strXML + + End Function + + Public Sub ReadArticle(ByVal ModuleID As Integer, ByVal xmlArticle As XmlNode) + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFields As ArrayList = objCustomFieldController.List(ModuleID) + + Dim objArticle As New ArticleInfo + + objArticle.ModuleID = ModuleID + + objArticle.CreatedDate = DateTime.Parse(xmlArticle.Item("createdDate").InnerText) + objArticle.LastUpdate = DateTime.Parse(xmlArticle.Item("lastUpdate").InnerText) + + objArticle.Title = xmlArticle.Item("title").InnerText + objArticle.IsApproved = Convert.ToBoolean(xmlArticle.Item("isApproved").InnerText) + objArticle.NumberOfViews = Convert.ToInt32(xmlArticle.Item("numberOfViews").InnerText) + objArticle.IsDraft = Convert.ToBoolean(xmlArticle.Item("isDraft").InnerText) + + objArticle.StartDate = DateTime.Parse(xmlArticle.Item("startDate").InnerText) + objArticle.EndDate = DateTime.Parse(xmlArticle.Item("endDate").InnerText) + + objArticle.ImageUrl = xmlArticle.Item("imageUrl").InnerText + objArticle.IsFeatured = Convert.ToBoolean(xmlArticle.Item("isFeatured").InnerText) + objArticle.Url = xmlArticle.Item("url").InnerText + objArticle.IsSecure = Convert.ToBoolean(xmlArticle.Item("isSecure").InnerText) + objArticle.IsNewWindow = Convert.ToBoolean(xmlArticle.Item("isNewWindow").InnerText) + + objArticle.CommentCount = Convert.ToInt32(xmlArticle.Item("commentCount").InnerText) + objArticle.PageCount = Convert.ToInt32(xmlArticle.Item("pageCount").InnerText) + objArticle.FileCount = Convert.ToInt32(xmlArticle.Item("fileCount").InnerText) + objArticle.ImageCount = Convert.ToInt32(xmlArticle.Item("imageCount").InnerText) + + objArticle.Rating = Null.NullInteger + objArticle.RatingCount = 0 + objArticle.Summary = xmlArticle.Item("summary").InnerText + + objArticle.MetaTitle = xmlArticle.Item("metaTitle").InnerText + objArticle.MetaDescription = xmlArticle.Item("metaDescription").InnerText + objArticle.MetaKeywords = xmlArticle.Item("metaKeywords").InnerText + objArticle.PageHeadText = xmlArticle.Item("pageHeadText").InnerText + objArticle.ShortUrl = xmlArticle.Item("shortUrl").InnerText + + Dim objArticleController As New ArticleController + objArticle.ArticleID = objArticleController.AddArticle(objArticle) + + Dim objCategoryController As New CategoryController + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(ModuleID, Null.NullInteger) + For Each xmlChildNode As XmlNode In xmlArticle.ChildNodes + + If (xmlChildNode.Name = "categories") Then + For Each xmlCategoryNode As XmlNode In xmlChildNode.ChildNodes + Dim name As String = xmlCategoryNode.Item("name").InnerText + For Each objCategory As CategoryInfo In objCategories + If (objCategory.Name.ToLower() = name.ToLower()) Then + objArticleController.AddArticleCategory(objArticle.ArticleID, objCategory.CategoryID) + Exit For + End If + Next + Next + End If + + If (xmlChildNode.Name = "tags") Then + For Each xmlTagNode As XmlNode In xmlChildNode.ChildNodes + Dim name As String = xmlTagNode.Item("name").InnerText + Dim objTagController As New TagController() + Dim objTags As ArrayList = objTagController.List(ModuleID, Null.NullInteger) + For Each objTag As TagInfo In objTags + If (objTag.Name.ToLower() = name.ToLower()) Then + objTagController.Add(objArticle.ArticleID, objTag.TagID) + Exit For + End If + Next + Next + End If + + If (xmlChildNode.Name = "customfields") Then + For Each xmlTagNode As XmlNode In xmlChildNode.ChildNodes + + Dim name As String = xmlTagNode.Item("name").InnerText + Dim value As String = xmlTagNode.Item("value").InnerText + + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.Name.ToLower() = name.ToLower()) Then + Dim objCustomValue As New CustomValueInfo + objCustomValue.CustomFieldID = objCustomField.CustomFieldID + objCustomValue.ArticleID = objArticle.ArticleID + objCustomValue.CustomValue = value + + Dim objCustomValueController As New CustomValueController() + objCustomValueController.Add(objCustomValue) + Exit For + End If + Next + Next + End If + + If (xmlChildNode.Name = "images") Then + Dim sortOrder As Integer = 0 + For Each xmlImageNode As XmlNode In xmlChildNode.ChildNodes + Dim objImage As New ImageInfo + + objImage.ArticleID = objArticle.ArticleID + objImage.Title = xmlImageNode.Item("title").InnerText + objImage.FileName = xmlImageNode.Item("filename").InnerText + objImage.Extension = xmlImageNode.Item("extension").InnerText + objImage.Size = Convert.ToInt32(xmlImageNode.Item("size").InnerText) + objImage.Width = Convert.ToInt32(xmlImageNode.Item("width").InnerText) + objImage.Height = Convert.ToInt32(xmlImageNode.Item("height").InnerText) + objImage.ContentType = xmlImageNode.Item("contentType").InnerText + objImage.Folder = xmlImageNode.Item("folder").InnerText + objImage.SortOrder = sortOrder + + Dim objImageController As New ImageController() + objImageController.Add(objImage) + + sortOrder = sortOrder + 1 + Next + If (sortOrder > 0) Then + objArticle.ImageCount = sortOrder + objArticleController.UpdateArticle(objArticle) + End If + End If + + If (xmlChildNode.Name = "files") Then + Dim sortOrder As Integer = 0 + For Each xmlImageNode As XmlNode In xmlChildNode.ChildNodes + Dim objFile As New FileInfo + + objFile.ArticleID = objArticle.ArticleID + objFile.Title = xmlImageNode.Item("title").InnerText + objFile.FileName = xmlImageNode.Item("filename").InnerText + objFile.Extension = xmlImageNode.Item("extension").InnerText + objFile.Size = Convert.ToInt32(xmlImageNode.Item("size").InnerText) + objFile.ContentType = xmlImageNode.Item("contentType").InnerText + objFile.Folder = xmlImageNode.Item("folder").InnerText + objFile.SortOrder = sortOrder + + Dim objFileController As New FileController() + objFileController.Add(objFile) + + sortOrder = sortOrder + 1 + Next + If (sortOrder > 0) Then + objArticle.FileCount = sortOrder + objArticleController.UpdateArticle(objArticle) + End If + End If + + If (xmlChildNode.Name = "pages") Then + Dim sortOrder As Integer = 0 + For Each xmlImageNode As XmlNode In xmlChildNode.ChildNodes + + Dim objPage As New PageInfo + + objPage.ArticleID = objArticle.ArticleID + objPage.Title = xmlImageNode.Item("title").InnerText + objPage.PageText = xmlImageNode.Item("pageText").InnerText + objPage.SortOrder = sortOrder + + Dim objPageController As New PageController() + objPageController.AddPage(objPage) + + sortOrder = sortOrder + 1 + Next + If (sortOrder > 0) Then + objArticle.PageCount = sortOrder + objArticleController.UpdateArticle(objArticle) + End If + End If + + If (xmlChildNode.Name = "comments") Then + Dim sortOrder As Integer = 0 + For Each xmlImageNode As XmlNode In xmlChildNode.ChildNodes + + Dim objComment As New CommentInfo + + objComment.UserID = Null.NullInteger + objComment.ArticleID = objArticle.ArticleID + objComment.CreatedDate = DateTime.Parse(xmlImageNode.Item("createdDate").InnerText) + objComment.Comment = xmlImageNode.Item("commentText").InnerText + objComment.RemoteAddress = xmlImageNode.Item("remoteAddress").InnerText + objComment.Type = Convert.ToInt32(xmlImageNode.Item("type").InnerText) + objComment.TrackbackUrl = xmlImageNode.Item("trackbackUrl").InnerText + objComment.TrackbackTitle = xmlImageNode.Item("trackbackTitle").InnerText + objComment.TrackbackBlogName = xmlImageNode.Item("trackbackBlogName").InnerText + objComment.TrackbackExcerpt = xmlImageNode.Item("trackbackExcerpt").InnerText + objComment.AnonymousName = xmlImageNode.Item("anonymousName").InnerText + objComment.AnonymousEmail = xmlImageNode.Item("anonymousEmail").InnerText + objComment.AnonymousURL = xmlImageNode.Item("anonymousUrl").InnerText + objComment.NotifyMe = Convert.ToBoolean(xmlImageNode.Item("notifyMe").InnerText) + objComment.IsApproved = True + objComment.ApprovedBy = Null.NullInteger + + Dim objCommentController As New CommentController() + objCommentController.AddComment(objComment) + + sortOrder = sortOrder + 1 + Next + If (sortOrder > 0) Then + objArticle.CommentCount = sortOrder + objArticleController.UpdateArticle(objArticle) + End If + End If + Next + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/ArticleInfo.vb b/Components/ArticleInfo.vb new file mode 100755 index 0000000..1812774 --- /dev/null +++ b/Components/ArticleInfo.vb @@ -0,0 +1,580 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Security.Roles +Imports Ventrian.NewsArticles.Components.CustomFields + +Namespace Ventrian.NewsArticles + + Public Class ArticleInfo + +#Region " Private Members " + + ' local property declarations + Dim _articleID As Integer + Dim _authorID As Integer + Dim _approverID As Integer + Dim _createdDate As DateTime + Dim _lastUpdate As DateTime + Dim _title As String + Dim _summary As String + Dim _articleText As String + Dim _isApproved As Boolean + Dim _isDraft As Boolean + Dim _numberOfViews As Integer + Dim _startDate As DateTime + Dim _endDate As DateTime + Dim _moduleID As Integer + Dim _isFeatured As Boolean + Dim _rating As Double + Dim _ratingCount As Integer + Dim _lastUpdateID As Integer + Dim _isSecure As Boolean + Dim _isNewWindow As Boolean + + Dim _metaTitle As String + Dim _metaDescription As String + Dim _metaKeywords As String + Dim _pageHeadText As String + Dim _shortUrl As String + Dim _rssGuid As String + + Dim _imageUrl As String + Dim _url As String + + Dim _authorEmail As String + Dim _authorUserName As String + Dim _authorFirstName As String + Dim _authorLastName As String + Dim _authorDisplayName As String + + Dim _lastUpdateEmail As String + Dim _lastUpdateUserName As String + Dim _lastUpdateFirstName As String + Dim _lastUpdateLastName As String + Dim _lastUpdateDisplayName As String + + Dim _body As String + Dim _pageCount As Integer + Dim _commentCount As Integer + Dim _fileCount As Integer + Dim _imageCount As Integer + Dim _imageUrlResolved As String + + Dim _customList As Hashtable + + Dim _tags As String + + Dim _approver As UserInfo + +#End Region + +#Region " Private Methods " + + Private Sub InitializePropertyList() + + ' Add Caching + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFields As ArrayList = objCustomFieldController.List(Me.ModuleID) + + Dim objCustomValueController As New CustomValueController + Dim objCustomValues As List(Of CustomValueInfo) = objCustomValueController.List(Me.ArticleID) + + _customList = New Hashtable + + For Each objCustomField As CustomFieldInfo In objCustomFields + Dim value As String = "" + For Each objCustomValue As CustomValueInfo In objCustomValues + If (objCustomValue.CustomFieldID = objCustomField.CustomFieldID) Then + value = objCustomValue.CustomValue + End If + Next + _customList.Add(objCustomField.CustomFieldID, value) + Next + + End Sub + +#End Region + +#Region " Public Properties " + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal Value As Integer) + _articleID = Value + End Set + End Property + + Public Property AuthorID() As Integer + Get + Return _authorID + End Get + Set(ByVal Value As Integer) + _authorID = Value + End Set + End Property + + Public Property ApproverID() As Integer + Get + Return _approverID + End Get + Set(ByVal Value As Integer) + _approverID = Value + End Set + End Property + + Public Property CreatedDate() As DateTime + Get + Return _createdDate + End Get + Set(ByVal Value As DateTime) + _createdDate = Value + End Set + End Property + + Public Property LastUpdate() As DateTime + Get + Return _lastUpdate + End Get + Set(ByVal Value As DateTime) + _lastUpdate = Value + End Set + End Property + + Public Property Title() As String + Get + Return _title + End Get + Set(ByVal Value As String) + _title = Value + End Set + End Property + + Public Property Summary() As String + Get + Return _summary + End Get + Set(ByVal Value As String) + _summary = Value + End Set + End Property + + Public Property ArticleText() As String + Get + Return _articleText + End Get + Set(ByVal Value As String) + _articleText = Value + End Set + End Property + + Public Property IsApproved() As Boolean + Get + Return _isApproved + End Get + Set(ByVal Value As Boolean) + _isApproved = Value + End Set + End Property + + Public Property IsDraft() As Boolean + Get + Return _isDraft + End Get + Set(ByVal Value As Boolean) + _isDraft = Value + End Set + End Property + + Public Property NumberOfViews() As Integer + Get + Return _numberOfViews + End Get + Set(ByVal Value As Integer) + _numberOfViews = Value + End Set + End Property + + Public Property StartDate() As DateTime + Get + Return _startDate + End Get + Set(ByVal Value As DateTime) + _startDate = Value + End Set + End Property + + Public Property EndDate() As DateTime + Get + Return _endDate + End Get + Set(ByVal Value As DateTime) + _endDate = Value + End Set + End Property + + Public Property ModuleID() As Integer + Get + Return _moduleID + End Get + Set(ByVal Value As Integer) + _moduleID = Value + End Set + End Property + + Public Property ImageUrl() As String + Get + Return _imageUrl + End Get + Set(ByVal Value As String) + _imageUrl = Value + End Set + End Property + + Public Property Url() As String + Get + Return _url + End Get + Set(ByVal Value As String) + _url = Value + End Set + End Property + + Public Property IsFeatured() As Boolean + Get + Return _isFeatured + End Get + Set(ByVal Value As Boolean) + _isFeatured = Value + End Set + End Property + + Public Property Rating() As Double + Get + Return _rating + End Get + Set(ByVal Value As Double) + _rating = Value + End Set + End Property + + Public Property RatingCount() As Integer + Get + Return _ratingCount + End Get + Set(ByVal Value As Integer) + _ratingCount = Value + End Set + End Property + + Public Property LastUpdateID() As Integer + Get + Return _lastUpdateID + End Get + Set(ByVal Value As Integer) + _lastUpdateID = Value + End Set + End Property + + Public Property IsSecure() As Boolean + Get + Return _isSecure + End Get + Set(ByVal Value As Boolean) + _isSecure = Value + End Set + End Property + + Public Property IsNewWindow() As Boolean + Get + Return _isNewWindow + End Get + Set(ByVal Value As Boolean) + _isNewWindow = Value + End Set + End Property + + Public Property MetaTitle() As String + Get + Return _metaTitle + End Get + Set(ByVal Value As String) + _metaTitle = Value + End Set + End Property + + Public Property MetaDescription() As String + Get + Return _metaDescription + End Get + Set(ByVal Value As String) + _metaDescription = Value + End Set + End Property + + Public Property MetaKeywords() As String + Get + Return _metaKeywords + End Get + Set(ByVal Value As String) + _metaKeywords = Value + End Set + End Property + + Public Property PageHeadText() As String + Get + Return _pageHeadText + End Get + Set(ByVal Value As String) + _pageHeadText = Value + End Set + End Property + + Public Property ShortUrl() As String + Get + Return _shortUrl + End Get + Set(ByVal Value As String) + _shortUrl = Value + End Set + End Property + + Public Property RssGuid() As String + Get + Return _rssGuid + End Get + Set(ByVal Value As String) + _rssGuid = Value + End Set + End Property + + Public Property AuthorUserName() As String + Get + Return _authorUserName + End Get + Set(ByVal Value As String) + _authorUserName = Value + End Set + End Property + + Public Property AuthorEmail() As String + Get + Return _authorEmail + End Get + Set(ByVal Value As String) + _authorEmail = Value + End Set + End Property + + Public Property AuthorFirstName() As String + Get + Return _authorFirstName + End Get + Set(ByVal Value As String) + _authorFirstName = Value + End Set + End Property + + Public Property AuthorLastName() As String + Get + Return _authorLastName + End Get + Set(ByVal Value As String) + _authorLastName = Value + End Set + End Property + + Public Property AuthorDisplayName() As String + Get + Return _authorDisplayName + End Get + Set(ByVal Value As String) + _authorDisplayName = Value + End Set + End Property + + Public Property Status() As StatusType + Get + If (IsDraft = True) Then + Return StatusType.Draft + End If + + If (IsApproved = False) Then + Return StatusType.AwaitingApproval + Else + Return StatusType.Published + End If + End Get + Set(ByVal Value As StatusType) + Select Case Value + Case StatusType.Draft + _isDraft = True + _isApproved = False + Exit Select + Case StatusType.AwaitingApproval + _isDraft = False + _isApproved = False + Exit Select + Case StatusType.Published + _isDraft = False + _isApproved = True + Exit Select + Case Else + Exit Select + End Select + End Set + End Property + + Public ReadOnly Property AuthorFullName() As String + Get + Return _authorFirstName & " " & _authorLastName + End Get + End Property + + Public Property LastUpdateUserName() As String + Get + Return _lastUpdateUserName + End Get + Set(ByVal Value As String) + _lastUpdateUserName = Value + End Set + End Property + + Public Property LastUpdateEmail() As String + Get + Return _lastUpdateEmail + End Get + Set(ByVal Value As String) + _lastUpdateEmail = Value + End Set + End Property + + Public Property LastUpdateFirstName() As String + Get + Return _lastUpdateFirstName + End Get + Set(ByVal Value As String) + _lastUpdateFirstName = Value + End Set + End Property + + Public Property LastUpdateLastName() As String + Get + Return _lastUpdateLastName + End Get + Set(ByVal Value As String) + _lastUpdateLastName = Value + End Set + End Property + + Public Property LastUpdateDisplayName() As String + Get + Return _lastUpdateDisplayName + End Get + Set(ByVal Value As String) + _lastUpdateDisplayName = Value + End Set + End Property + + Public ReadOnly Property LastUpdateFullName() As String + Get + Return _lastUpdateFirstName & " " & _lastUpdateLastName + End Get + End Property + + Public Property Body() As String + Get + Return _body + End Get + Set(ByVal Value As String) + _body = Value + End Set + End Property + + Public Property PageCount() As Integer + Get + Return _pageCount + End Get + Set(ByVal Value As Integer) + _pageCount = Value + End Set + End Property + + Public Property CommentCount() As Integer + Get + Return _commentCount + End Get + Set(ByVal Value As Integer) + _commentCount = Value + End Set + End Property + + Public Property FileCount() As Integer + Get + Return _fileCount + End Get + Set(ByVal Value As Integer) + _fileCount = Value + End Set + End Property + + Public Property ImageCount() As Integer + Get + Return _imageCount + End Get + Set(ByVal Value As Integer) + _imageCount = Value + End Set + End Property + + Public ReadOnly Property CustomList() As Hashtable + Get + If (_customList Is Nothing) Then + InitializePropertyList() + End If + Return _customList + End Get + End Property + + Public Property Tags() As String + Get + Return _tags + End Get + Set(ByVal Value As String) + _tags = Value + End Set + End Property + + Public ReadOnly Property Approver(ByVal portalID As Integer) As UserInfo + Get + If (_approver Is Nothing And ApproverID <> Null.NullInteger) Then + Dim objUserController As New UserController + _approver = objUserController.GetUser(portalID, ApproverID) + End If + Return _approver + End Get + End Property + + Public ReadOnly Property TitleAlternate() As String + Get + Return "[" & StartDate.Year.ToString() & "-" & StartDate.Month.ToString() & "-" & StartDate.Day.ToString() & "] " & Title + End Get + End Property + +#End Region + + End Class + +End Namespace diff --git a/Components/ArticleSettings.vb b/Components/ArticleSettings.vb new file mode 100755 index 0000000..adf4728 --- /dev/null +++ b/Components/ArticleSettings.vb @@ -0,0 +1,1607 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Security +Imports Ventrian.NewsArticles.Components.Types + +Namespace Ventrian.NewsArticles + + Public Class ArticleSettings + +#Region " Private Members " + + Private ReadOnly _settings As Hashtable + Private ReadOnly _portalSettings As PortalSettings + Private ReadOnly _moduleConfiguration As ModuleInfo + +#End Region + +#Region " Constructors " + + Public Sub New(ByVal settings As Hashtable, ByVal portalSettings As PortalSettings, ByVal moduleConfiguration As ModuleInfo) + _settings = settings + _portalSettings = portalSettings + _moduleConfiguration = moduleConfiguration + End Sub + +#End Region + +#Region " Private Properties " + + Public ReadOnly Property Settings() As Hashtable + Get + Return _settings + End Get + End Property + +#End Region + +#Region " Private Methods " + + Private Function IsInRoles(ByVal roles As String) As Boolean + + ' Replacement for core IsInRoles check because it doesn't auto-pass super users. + + If Not roles Is Nothing Then + Dim context As HttpContext = HttpContext.Current + Dim objUserInfo As UserInfo = UserController.GetCurrentUserInfo + Dim role As String + + For Each role In roles.Split(New Char() {";"c}) + If (role <> "" AndAlso Not role Is Nothing AndAlso _ + ((context.Request.IsAuthenticated = False And role = glbRoleUnauthUserName) Or _ + role = glbRoleAllUsersName Or _ + objUserInfo.IsInRole(role) = True _ + )) Then + Return True + End If + Next role + + End If + + Return False + + End Function + +#End Region + +#Region " Public Properties " + + Public ReadOnly Property AlwaysShowPageID() As Boolean + Get + If (Settings.Contains(ArticleConstants.SEO_ALWAYS_SHOW_PAGEID_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SEO_ALWAYS_SHOW_PAGEID_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property Author() As Integer + Get + If (Settings.Contains(ArticleConstants.AUTHOR_SETTING)) Then + If (IsNumeric(Settings(ArticleConstants.AUTHOR_SETTING).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.AUTHOR_SETTING).ToString()) + Else + Return Null.NullInteger + End If + Else + Return Null.NullInteger + End If + End Get + End Property + + Public ReadOnly Property AuthorDefault() As Integer + Get + If (Settings.Contains(ArticleConstants.AUTHOR_DEFAULT_SETTING)) Then + If (IsNumeric(Settings(ArticleConstants.AUTHOR_DEFAULT_SETTING).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.AUTHOR_DEFAULT_SETTING).ToString()) + Else + Return Null.NullInteger + End If + Else + Return Null.NullInteger + End If + End Get + End Property + + Public ReadOnly Property AuthorSelect() As AuthorSelectType + Get + If (Settings.Contains(ArticleConstants.AUTHOR_SELECT_TYPE)) Then + Return CType(System.Enum.Parse(GetType(AuthorSelectType), Settings(ArticleConstants.AUTHOR_SELECT_TYPE).ToString()), AuthorSelectType) + Else + Return AuthorSelectType.ByDropdown + End If + End Get + End Property + + Public ReadOnly Property AuthorUserIDFilter() As Boolean + Get + If (Settings.Contains(ArticleConstants.AUTHOR_USERID_FILTER_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.AUTHOR_USERID_FILTER_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property AuthorUserIDParam() As String + Get + If (Settings.Contains(ArticleConstants.AUTHOR_USERID_PARAM_SETTING)) Then + Return Settings(ArticleConstants.AUTHOR_USERID_PARAM_SETTING).ToString() + Else + Return "ID" + End If + End Get + End Property + + Public ReadOnly Property AuthorUsernameFilter() As Boolean + Get + If (Settings.Contains(ArticleConstants.AUTHOR_USERNAME_FILTER_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.AUTHOR_USERNAME_FILTER_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property AuthorUsernameParam() As String + Get + If (Settings.Contains(ArticleConstants.AUTHOR_USERNAME_PARAM_SETTING)) Then + Return Settings(ArticleConstants.AUTHOR_USERNAME_PARAM_SETTING).ToString() + Else + Return "Username" + End If + End Get + End Property + + Public ReadOnly Property AuthorLoggedInUserFilter() As Boolean + Get + If (Settings.Contains(ArticleConstants.AUTHOR_LOGGED_IN_USER_FILTER_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.AUTHOR_LOGGED_IN_USER_FILTER_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property ArchiveAuthor() As Boolean + Get + If (Settings.Contains(ArticleConstants.ARCHIVE_AUTHOR_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ARCHIVE_AUTHOR_SETTING).ToString()) + Else + Return ArticleConstants.ARCHIVE_AUTHOR_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property ArchiveCategories() As Boolean + Get + If (Settings.Contains(ArticleConstants.ARCHIVE_CATEGORIES_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ARCHIVE_CATEGORIES_SETTING).ToString()) + Else + Return ArticleConstants.ARCHIVE_CATEGORIES_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property ArchiveCurrentArticles() As Boolean + Get + If (Settings.Contains(ArticleConstants.ARCHIVE_CURRENT_ARTICLES_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ARCHIVE_CURRENT_ARTICLES_SETTING).ToString()) + Else + Return ArticleConstants.ARCHIVE_CURRENT_ARTICLES_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property ArchiveMonth() As Boolean + Get + If (Settings.Contains(ArticleConstants.ARCHIVE_MONTH_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ARCHIVE_MONTH_SETTING).ToString()) + Else + Return ArticleConstants.ARCHIVE_MONTH_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property BubbleFeatured() As Boolean + Get + If (Settings.Contains(ArticleConstants.BUBBLE_FEATURED_ARTICLES)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.BUBBLE_FEATURED_ARTICLES).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property CategoryBreadcrumb() As Boolean + Get + If (Settings.Contains(ArticleConstants.CATEGORY_BREADCRUMB_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.CATEGORY_BREADCRUMB_SETTING).ToString()) + Else + Return ArticleConstants.CATEGORY_BREADCRUMB_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property CategoryFilterSubmit() As Boolean + Get + If (Settings.Contains(ArticleConstants.CATEGORY_FILTER_SUBMIT_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.CATEGORY_FILTER_SUBMIT_SETTING).ToString()) + Else + Return ArticleConstants.CATEGORY_FILTER_SUBMIT_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property IncludeInPageName() As Boolean + Get + If (Settings.Contains(ArticleConstants.CATEGORY_NAME_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.CATEGORY_NAME_SETTING).ToString()) + Else + Return ArticleConstants.CATEGORY_NAME_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property CategorySelectionHeight() As Integer + Get + If (Settings.Contains(ArticleConstants.CATEGORY_SELECTION_HEIGHT_SETTING)) Then + Return Convert.ToInt32(Settings(ArticleConstants.CATEGORY_SELECTION_HEIGHT_SETTING).ToString()) + Else + Return ArticleConstants.CATEGORY_SELECTION_HEIGHT_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property CategorySortType() As CategorySortType + Get + If (Settings.Contains(ArticleConstants.CATEGORY_SORT_SETTING)) Then + Try + Return CType(System.Enum.Parse(GetType(CategorySortType), Settings(ArticleConstants.CATEGORY_SORT_SETTING).ToString()), CategorySortType) + Catch + Return ArticleConstants.CATEGORY_SORT_SETTING_DEFAULT + End Try + Else + Return ArticleConstants.CATEGORY_SORT_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property CommentAkismetKey() As String + Get + If (Settings.Contains(ArticleConstants.COMMENT_AKISMET_SETTING)) Then + Return Settings(ArticleConstants.COMMENT_AKISMET_SETTING).ToString() + Else + Return "" + End If + End Get + End Property + + Public ReadOnly Property CommentModeration() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_COMMENT_MODERATION_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_COMMENT_MODERATION_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property CommentRequireName() As Boolean + Get + If (Settings.Contains(ArticleConstants.COMMENT_REQUIRE_NAME_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.COMMENT_REQUIRE_NAME_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property CommentRequireEmail() As Boolean + Get + If (Settings.Contains(ArticleConstants.COMMENT_REQUIRE_EMAIL_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.COMMENT_REQUIRE_EMAIL_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property ContentSharingPortals() As String + Get + If (Settings.Contains(ArticleConstants.CONTENT_SHARING_SETTING)) Then + Return Settings(ArticleConstants.CONTENT_SHARING_SETTING).ToString() + Else + Return Null.NullString() + End If + End Get + End Property + + Public ReadOnly Property DefaultImagesFolder() As Integer + Get + If (Settings.Contains(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING)) Then + If (IsNumeric(Settings(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING).ToString()) + Else + Return Null.NullInteger + End If + Else + Return Null.NullInteger + End If + End Get + End Property + + Public ReadOnly Property DefaultFilesFolder() As Integer + Get + If (Settings.Contains(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) Then + If (IsNumeric(Settings(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING).ToString()) + Else + Return Null.NullInteger + End If + Else + Return Null.NullInteger + End If + End Get + End Property + + Public ReadOnly Property EnableActiveSocialFeed() As Boolean + Get + If (Settings.Contains(ArticleConstants.ACTIVE_SOCIAL_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ACTIVE_SOCIAL_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property JournalIntegration() As Boolean + Get + If (Settings.Contains(ArticleConstants.JOURNAL_INTEGRATION_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.JOURNAL_INTEGRATION_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property JournalIntegrationGroups() As Boolean + Get + If (Settings.Contains(ArticleConstants.JOURNAL_INTEGRATION_GROUPS_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.JOURNAL_INTEGRATION_GROUPS_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property ActiveSocialSubmitKey() As String + Get + If (Settings.Contains(ArticleConstants.ACTIVE_SOCIAL_SUBMIT_SETTING)) Then + Return Settings(ArticleConstants.ACTIVE_SOCIAL_SUBMIT_SETTING).ToString() + Else + Return "9F02B914-F565-4E5A-9194-8423431056CD" + End If + End Get + End Property + + Public ReadOnly Property ActiveSocialCommentKey() As String + Get + If (Settings.Contains(ArticleConstants.ACTIVE_SOCIAL_COMMENT_SETTING)) Then + Return Settings(ArticleConstants.ACTIVE_SOCIAL_COMMENT_SETTING).ToString() + Else + Return "" + End If + End Get + End Property + + Public ReadOnly Property ActiveSocialRateKey() As String + Get + If (Settings.Contains(ArticleConstants.ACTIVE_SOCIAL_RATE_SETTING)) Then + Return Settings(ArticleConstants.ACTIVE_SOCIAL_RATE_SETTING).ToString() + Else + Return "" + End If + End Get + End Property + + Public ReadOnly Property EnableAutoTrackback() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_AUTO_TRACKBACK_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_AUTO_TRACKBACK_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property EnableCoreSearch() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_CORE_SEARCH_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_CORE_SEARCH_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property EnableExternalImages() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_EXTERNAL_IMAGES_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_EXTERNAL_IMAGES_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property EnableNotificationPing() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_NOTIFICATION_PING_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_NOTIFICATION_PING_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property EnableImagesUpload() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_UPLOAD_IMAGES_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_UPLOAD_IMAGES_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property EnablePortalImages() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_PORTAL_IMAGES_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_PORTAL_IMAGES_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property EnableRatings() As Boolean + Get + If (EnableRatingsAnonymous Or EnableRatingsAuthenticated) Then + Return True + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property EnableRatingsAnonymous() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_RATINGS_ANONYMOUS_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_RATINGS_ANONYMOUS_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property EnableRatingsAuthenticated() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_RATINGS_AUTHENTICATED_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_RATINGS_AUTHENTICATED_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property EnableSmartThinkerStoryFeed() As Boolean + Get + If (Settings.Contains(ArticleConstants.SMART_THINKER_STORY_FEED_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SMART_THINKER_STORY_FEED_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property EnableSyndication() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_SYNDICATION_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_SYNDICATION_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property EnableSyndicationEnclosures() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_SYNDICATION_ENCLOSURES_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_SYNDICATION_ENCLOSURES_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property EnableSyndicationHtml() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_SYNDICATION_HTML_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_SYNDICATION_HTML_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property ExpandSummary() As Boolean + Get + If (Settings.Contains(ArticleConstants.EXPAND_SUMMARY_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.EXPAND_SUMMARY_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property FeaturedOnly() As Boolean + Get + If (Settings.Contains(ArticleConstants.SHOW_FEATURED_ONLY_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SHOW_FEATURED_ONLY_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property FilterCategories() As Integer() + Get + If (Settings.Contains(ArticleConstants.CATEGORIES_SETTING & _moduleConfiguration.TabID.ToString())) Then + If Not (Settings(ArticleConstants.CATEGORIES_SETTING & _moduleConfiguration.TabID.ToString()).ToString = Null.NullString Or Settings(ArticleConstants.CATEGORIES_SETTING & _moduleConfiguration.TabID.ToString()).ToString = "-1") Then + Dim categories As String() = Settings(ArticleConstants.CATEGORIES_SETTING & _moduleConfiguration.TabID.ToString()).ToString().Split(","c) + Dim cats As New List(Of Integer) + + For Each category As String In categories + If (IsNumeric(category)) Then + cats.Add(Convert.ToInt32(category)) + End If + Next + + Return cats.ToArray() + Else + Return Nothing + End If + Else + Return Nothing + End If + End Get + End Property + + Public ReadOnly Property FilterSingleCategory() As Integer + Get + If (Settings.Contains(ArticleConstants.CATEGORIES_FILTER_SINGLE_SETTING)) Then + If (IsNumeric(Settings(ArticleConstants.CATEGORIES_FILTER_SINGLE_SETTING))) Then + Return Convert.ToInt32(Settings(ArticleConstants.CATEGORIES_FILTER_SINGLE_SETTING)) + Else + Return Null.NullInteger + End If + Else + Return Null.NullInteger + End If + End Get + End Property + + Public ReadOnly Property ImageJQueryPath() As String + Get + If (Settings.Contains(ArticleConstants.IMAGE_JQUERY_PATH)) Then + Return Settings(ArticleConstants.IMAGE_JQUERY_PATH).ToString() + Else + Return "includes/fancybox/jquery.fancybox.pack.js" + End If + End Get + End Property + + Public ReadOnly Property ImageThumbnailType() As ThumbnailType + Get + If (Settings.Contains(ArticleConstants.IMAGE_THUMBNAIL_SETTING)) Then + Return CType(System.Enum.Parse(GetType(ThumbnailType), Settings(ArticleConstants.IMAGE_THUMBNAIL_SETTING).ToString()), ThumbnailType) + Else + Return ArticleConstants.DEFAULT_IMAGE_THUMBNAIL + End If + End Get + End Property + + Public ReadOnly Property IncludeJQuery() As Boolean + Get + If (Settings.Contains(ArticleConstants.INCLUDE_JQUERY_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.INCLUDE_JQUERY_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property MatchCategories() As MatchOperatorType + Get + If (Settings.Contains(ArticleConstants.MATCH_OPERATOR_SETTING)) Then + Return CType(System.Enum.Parse(GetType(MatchOperatorType), Settings(ArticleConstants.MATCH_OPERATOR_SETTING).ToString()), MatchOperatorType) + Else + Return MatchOperatorType.MatchAny + End If + End Get + End Property + + Public ReadOnly Property MaxArticles() As Integer + Get + If (Settings.Contains(ArticleConstants.MAX_ARTICLES_SETTING)) Then + If (IsNumeric(Settings(ArticleConstants.MAX_ARTICLES_SETTING).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.MAX_ARTICLES_SETTING).ToString()) + Else + Return Null.NullInteger + End If + Else + Return Null.NullInteger + End If + End Get + End Property + + Public ReadOnly Property MaxAge() As Integer + Get + If (Settings.Contains(ArticleConstants.MAX_AGE_SETTING)) Then + If (IsNumeric(Settings(ArticleConstants.MAX_AGE_SETTING).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.MAX_AGE_SETTING).ToString()) + Else + Return Null.NullInteger + End If + Else + Return Null.NullInteger + End If + End Get + End Property + + Public ReadOnly Property MaxImageHeight() As Integer + Get + If (Settings.Contains(ArticleConstants.IMAGE_MAX_HEIGHT_SETTING)) Then + If (IsNumeric(Settings(ArticleConstants.IMAGE_MAX_HEIGHT_SETTING).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.IMAGE_MAX_HEIGHT_SETTING).ToString()) + Else + Return ArticleConstants.DEFAULT_IMAGE_MAX_HEIGHT + End If + Else + Return ArticleConstants.DEFAULT_IMAGE_MAX_HEIGHT + End If + End Get + End Property + + Public ReadOnly Property MaxImageWidth() As Integer + Get + If (Settings.Contains(ArticleConstants.IMAGE_MAX_WIDTH_SETTING)) Then + If (IsNumeric(Settings(ArticleConstants.IMAGE_MAX_WIDTH_SETTING).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.IMAGE_MAX_WIDTH_SETTING).ToString()) + Else + Return ArticleConstants.DEFAULT_IMAGE_MAX_WIDTH + End If + Else + Return ArticleConstants.DEFAULT_IMAGE_MAX_WIDTH + End If + End Get + End Property + + Public ReadOnly Property MenuPosition() As MenuPositionType + Get + If (Settings.Contains(ArticleConstants.MENU_POSITION_TYPE)) Then + Return CType(System.Enum.Parse(GetType(MenuPositionType), Settings(ArticleConstants.MENU_POSITION_TYPE).ToString()), MenuPositionType) + Else + Return MenuPositionType.Top + End If + End Get + End Property + + Public ReadOnly Property NotFeaturedOnly() As Boolean + Get + If (Settings.Contains(ArticleConstants.SHOW_NOT_FEATURED_ONLY_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SHOW_NOT_FEATURED_ONLY_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property NotifyAuthorOnComment() As Boolean + Get + If (Settings.Contains(ArticleConstants.NOTIFY_COMMENT_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_COMMENT_SETTING)) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property NotifyAuthorOnApproval() As Boolean + Get + If (Settings.Contains(ArticleConstants.NOTIFY_APPROVAL_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_APPROVAL_SETTING)) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property NotifyDefault() As Boolean + Get + If (Settings.Contains(ArticleConstants.NOTIFY_DEFAULT_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_DEFAULT_SETTING)) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property NotifyEmailOnComment() As String + Get + If (Settings.Contains(ArticleConstants.NOTIFY_COMMENT_SETTING_EMAIL)) Then + Return Settings(ArticleConstants.NOTIFY_COMMENT_SETTING_EMAIL).ToString() + Else + Return "" + End If + End Get + End Property + + Public ReadOnly Property NotifyApproverForCommentApproval() As Boolean + Get + If (Settings.Contains(ArticleConstants.NOTIFY_COMMENT_APPROVAL_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_COMMENT_APPROVAL_SETTING)) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property NotifyEmailForCommentApproval() As String + Get + If (Settings.Contains(ArticleConstants.NOTIFY_COMMENT_APPROVAL_EMAIL_SETTING)) Then + Return Settings(ArticleConstants.NOTIFY_COMMENT_APPROVAL_EMAIL_SETTING).ToString() + Else + Return "" + End If + End Get + End Property + + Public ReadOnly Property NotSecuredOnly() As Boolean + Get + If (Settings.Contains(ArticleConstants.SHOW_NOT_SECURED_ONLY_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SHOW_NOT_SECURED_ONLY_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property ProcessPostTokens() As Boolean + Get + If (Settings.Contains(ArticleConstants.PROCESS_POST_TOKENS)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.PROCESS_POST_TOKENS).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property ResizeImages() As Boolean + Get + If (Settings.Contains(ArticleConstants.IMAGE_RESIZE_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.IMAGE_RESIZE_SETTING).ToString()) + Else + Return ArticleConstants.DEFAULT_IMAGE_RESIZE + End If + End Get + End Property + + Public ReadOnly Property SecuredOnly() As Boolean + Get + If (Settings.Contains(ArticleConstants.SHOW_SECURED_ONLY_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SHOW_SECURED_ONLY_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property ShortenedID() As String + Get + If (Settings.Contains(ArticleConstants.SEO_SHORTEN_ID_SETTING)) Then + Return Settings(ArticleConstants.SEO_SHORTEN_ID_SETTING).ToString() + Else + Return "ID" + End If + End Get + End Property + + Public ReadOnly Property SortBy() As String + Get + If (Settings.Contains(ArticleConstants.SORT_BY)) Then + Return Settings(ArticleConstants.SORT_BY).ToString() + Else + Return ArticleConstants.DEFAULT_SORT_BY + End If + End Get + End Property + + Public ReadOnly Property SortDirection() As String + Get + If (Settings.Contains(ArticleConstants.SORT_DIRECTION)) Then + Return Settings(ArticleConstants.SORT_DIRECTION).ToString() + Else + Return ArticleConstants.DEFAULT_SORT_DIRECTION + End If + End Get + End Property + + Public ReadOnly Property SortDirectionComments() As Integer + Get + If (Settings.Contains(ArticleConstants.COMMENT_SORT_DIRECTION_SETTING)) Then + Return Convert.ToInt32(Settings(ArticleConstants.COMMENT_SORT_DIRECTION_SETTING).ToString()) + Else + Return 0 + End If + End Get + End Property + + Public ReadOnly Property SyndicationLinkType() As SyndicationLinkType + Get + If (Settings.Contains(ArticleConstants.SYNDICATION_LINK_TYPE)) Then + Return CType(System.Enum.Parse(GetType(SyndicationLinkType), Settings(ArticleConstants.SYNDICATION_LINK_TYPE).ToString()), SyndicationLinkType) + Else + Return SyndicationLinkType.Article + End If + End Get + End Property + + Public ReadOnly Property SyndicationEnclosureType() As SyndicationEnclosureType + Get + If (Settings.Contains(ArticleConstants.SYNDICATION_ENCLOSURE_TYPE)) Then + Return CType(System.Enum.Parse(GetType(SyndicationEnclosureType), Settings(ArticleConstants.SYNDICATION_ENCLOSURE_TYPE).ToString()), SyndicationEnclosureType) + Else + Return SyndicationEnclosureType.Attachment + End If + End Get + End Property + + Public ReadOnly Property SyndicationSummaryLength() As Integer + Get + If (Settings.Contains(ArticleConstants.SYNDICATION_SUMMARY_LENGTH)) Then + Return Convert.ToInt32(Settings(ArticleConstants.SYNDICATION_SUMMARY_LENGTH).ToString()) + Else + Return Null.NullInteger + End If + End Get + End Property + + Public ReadOnly Property SyndicationMaxCount() As Integer + Get + If (Settings.Contains(ArticleConstants.SYNDICATION_MAX_COUNT)) Then + Return Convert.ToInt32(Settings(ArticleConstants.SYNDICATION_MAX_COUNT).ToString()) + Else + Return 50 + End If + End Get + End Property + + Public ReadOnly Property SyndicationImagePath() As String + Get + If (Settings.Contains(ArticleConstants.SYNDICATION_IMAGE_PATH)) Then + Return Settings(ArticleConstants.SYNDICATION_IMAGE_PATH).ToString() + Else + Return "~/DesktopModules/DnnForge - NewsArticles/Images/rssbutton.gif" + End If + End Get + End Property + + Public ReadOnly Property UseCanonicalLink() As Boolean + Get + If (Settings.Contains(ArticleConstants.SEO_USE_CANONICAL_LINK_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SEO_USE_CANONICAL_LINK_SETTING)) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property ExpandMetaInformation() As Boolean + Get + If (Settings.Contains(ArticleConstants.SEO_EXPAND_META_INFORMATION_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SEO_EXPAND_META_INFORMATION_SETTING)) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property UniquePageTitles() As Boolean + Get + If (Settings.Contains(ArticleConstants.SEO_UNIQUE_PAGE_TITLES_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SEO_UNIQUE_PAGE_TITLES_SETTING)) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property UseCaptcha() As Boolean + Get + If (Settings.Contains(ArticleConstants.USE_CAPTCHA_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.USE_CAPTCHA_SETTING)) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property UrlModeType() As UrlModeType + Get + If (Settings.Contains(ArticleConstants.SEO_URL_MODE_SETTING)) Then + Try + Return CType(System.Enum.Parse(GetType(UrlModeType), Settings(ArticleConstants.SEO_URL_MODE_SETTING).ToString()), UrlModeType) + Catch + Return UrlModeType.Shorterned + End Try + Else + Return UrlModeType.Shorterned + End If + End Get + End Property + + Public ReadOnly Property WatermarkEnabled() As Boolean + Get + If (_settings.Contains(ArticleConstants.IMAGE_WATERMARK_ENABLED_SETTING)) Then + Return Convert.ToBoolean(_settings(ArticleConstants.IMAGE_WATERMARK_ENABLED_SETTING).ToString()) + Else + Return ArticleConstants.IMAGE_WATERMARK_ENABLED_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property WatermarkText() As String + Get + If (_settings.Contains(ArticleConstants.IMAGE_WATERMARK_TEXT_SETTING)) Then + Return _settings(ArticleConstants.IMAGE_WATERMARK_TEXT_SETTING).ToString() + Else + Return ArticleConstants.IMAGE_WATERMARK_TEXT_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property WatermarkImage() As String + Get + If (_settings.Contains(ArticleConstants.IMAGE_WATERMARK_IMAGE_SETTING)) Then + Return _settings(ArticleConstants.IMAGE_WATERMARK_IMAGE_SETTING).ToString() + Else + Return ArticleConstants.IMAGE_WATERMARK_IMAGE_SETTING_DEFAULT + End If + End Get + End Property + + Public ReadOnly Property WatermarkPosition() As WatermarkPosition + Get + If (_settings.Contains(ArticleConstants.IMAGE_WATERMARK_IMAGE_POSITION_SETTING)) Then + Try + Return CType(System.Enum.Parse(GetType(WatermarkPosition), _settings(ArticleConstants.IMAGE_WATERMARK_IMAGE_POSITION_SETTING).ToString()), WatermarkPosition) + Catch + Return ArticleConstants.IMAGE_WATERMARK_IMAGE_POSITION_SETTING_DEFAULT + End Try + Else + Return ArticleConstants.IMAGE_WATERMARK_IMAGE_POSITION_SETTING_DEFAULT + End If + End Get + End Property + + + + + + + + + + + + + + + + + + + + + + + Public ReadOnly Property PageSize() As Integer + Get + If (Settings.Contains("Number")) Then + If (Convert.ToInt32(Settings("Number").ToString()) > 0) Then + Return Convert.ToInt32(Settings("Number").ToString()) + Else + If (Convert.ToInt32(Settings("Number").ToString()) = -1) Then + Return 10000 + Else + Return 10 + End If + End If + Else + Return 10 + End If + End Get + End Property + + Public ReadOnly Property IsCommentsAnonymous() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_ANONYMOUS_COMMENTS_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_ANONYMOUS_COMMENTS_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsCommentsEnabled() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_COMMENTS_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_COMMENTS_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsCommentModerationEnabled() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_COMMENT_MODERATION_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_COMMENT_MODERATION_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property IsCommentWebsiteHidden() As Boolean + Get + If (Settings.Contains(ArticleConstants.COMMENT_HIDE_WEBSITE_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.COMMENT_HIDE_WEBSITE_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property IsRateable() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated) Then + Return EnableRatingsAuthenticated + Else + Return EnableRatingsAnonymous + End If + End Get + End Property + + Public ReadOnly Property IsSyndicationEnabled() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_SYNDICATION_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_SYNDICATION_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsIncomingTrackbackEnabled() As Boolean + Get + If (Settings.Contains(ArticleConstants.ENABLE_INCOMING_TRACKBACK_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.ENABLE_INCOMING_TRACKBACK_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property LaunchLinks() As Boolean + Get + If (Settings.Contains(ArticleConstants.LAUNCH_LINKS)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.LAUNCH_LINKS).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property DisplayMode() As DisplayType + Get + If (Settings.Contains(ArticleConstants.DISPLAY_MODE)) Then + Return CType(System.Enum.Parse(GetType(DisplayType), Settings(ArticleConstants.DISPLAY_MODE).ToString()), DisplayType) + Else + Return DisplayType.FullName + End If + End Get + End Property + + Public ReadOnly Property RelatedMode() As RelatedType + Get + If (Settings.Contains(ArticleConstants.RELATED_MODE)) Then + Return CType(System.Enum.Parse(GetType(RelatedType), Settings(ArticleConstants.RELATED_MODE).ToString()), RelatedType) + Else + Return RelatedType.MatchCategoriesAnyTagsAny + End If + End Get + End Property + + Public ReadOnly Property Template() As String + Get + If (Settings.Contains(ArticleConstants.TEMPLATE_SETTING)) Then + Return Settings(ArticleConstants.TEMPLATE_SETTING).ToString() + Else + Return "Standard" + End If + End Get + End Property + + Public ReadOnly Property SEOTitleSpecified() As Boolean + Get + Return Settings.Contains(ArticleConstants.SEO_TITLE_SETTING) + End Get + End Property + + Public ReadOnly Property ShowPending() As Boolean + Get + If (Settings.Contains(ArticleConstants.SHOW_PENDING_SETTING)) Then + Return Convert.ToBoolean(Settings(ArticleConstants.SHOW_PENDING_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property TitleReplacement() As TitleReplacementType + Get + If (Settings.Contains(ArticleConstants.TITLE_REPLACEMENT_TYPE)) Then + Return CType(System.Enum.Parse(GetType(TitleReplacementType), Settings(ArticleConstants.TITLE_REPLACEMENT_TYPE).ToString()), TitleReplacementType) + Else + Return TitleReplacementType.Dash + End If + End Get + End Property + + Public ReadOnly Property TextEditorWidth() As String + Get + If (Settings.Contains(ArticleConstants.TEXT_EDITOR_WIDTH)) Then + Return Settings(ArticleConstants.TEXT_EDITOR_WIDTH).ToString() + Else + Return "100%" + End If + End Get + End Property + + Public ReadOnly Property TextEditorHeight() As String + Get + If (Settings.Contains(ArticleConstants.TEXT_EDITOR_HEIGHT)) Then + Return Settings(ArticleConstants.TEXT_EDITOR_HEIGHT).ToString() + Else + Return "400" + End If + End Get + End Property + + Public ReadOnly Property TextEditorSummaryMode() As TextEditorModeType + Get + If (Settings.Contains(ArticleConstants.TEXT_EDITOR_SUMMARY_MODE)) Then + Return CType(System.Enum.Parse(GetType(TextEditorModeType), Settings(ArticleConstants.TEXT_EDITOR_SUMMARY_MODE).ToString()), TextEditorModeType) + Else + Return TextEditorModeType.Rich + End If + End Get + End Property + + Public ReadOnly Property TextEditorSummaryWidth() As String + Get + If (Settings.Contains(ArticleConstants.TEXT_EDITOR_SUMMARY_WIDTH)) Then + Return Settings(ArticleConstants.TEXT_EDITOR_SUMMARY_WIDTH).ToString() + Else + Return "100%" + End If + End Get + End Property + + Public ReadOnly Property TextEditorSummaryHeight() As String + Get + If (Settings.Contains(ArticleConstants.TEXT_EDITOR_SUMMARY_HEIGHT)) Then + Return Settings(ArticleConstants.TEXT_EDITOR_SUMMARY_HEIGHT).ToString() + Else + Return "400" + End If + End Get + End Property + + Public ReadOnly Property TwitterName() As String + Get + If (Settings.Contains(ArticleConstants.TWITTER_USERNAME)) Then + Return Settings(ArticleConstants.TWITTER_USERNAME).ToString() + Else + Return "" + End If + End Get + End Property + + Public ReadOnly Property TwitterBitLyLogin() As String + Get + If (Settings.Contains(ArticleConstants.TWITTER_BITLY_LOGIN)) Then + Return Settings(ArticleConstants.TWITTER_BITLY_LOGIN).ToString() + Else + Return "" + End If + End Get + End Property + + Public ReadOnly Property TwitterBitLyAPIKey() As String + Get + If (Settings.Contains(ArticleConstants.TWITTER_BITLY_API_KEY)) Then + Return Settings(ArticleConstants.TWITTER_BITLY_API_KEY).ToString() + Else + Return "" + End If + End Get + End Property + + Public ReadOnly Property ServerTimeZone() As Integer + Get + If (Settings.Contains(ArticleConstants.SERVER_TIMEZONE)) Then + If (IsNumeric(Settings(ArticleConstants.SERVER_TIMEZONE).ToString())) Then + Return Convert.ToInt32(Settings(ArticleConstants.SERVER_TIMEZONE).ToString()) + Else + Return _portalSettings.TimeZoneOffset + End If + Else + Return _portalSettings.TimeZoneOffset + End If + End Get + End Property + + + + + Public ReadOnly Property TemplatePath() As String + Get + Return _portalSettings.HomeDirectoryMapPath & "DnnForge - NewsArticles/Templates/" & Template & "/" + End Get + End Property + + Public ReadOnly Property SecureUrl() As String + Get + If (Settings.Contains(ArticleConstants.PERMISSION_SECURE_URL_SETTING)) Then + Return Settings(ArticleConstants.PERMISSION_SECURE_URL_SETTING).ToString() + Else + Return "" + End If + End Get + End Property + + Public ReadOnly Property RoleGroupID() As Integer + Get + If (Settings.Contains(ArticleConstants.PERMISSION_ROLE_GROUP_ID)) Then + Return Convert.ToInt32(Settings(ArticleConstants.PERMISSION_ROLE_GROUP_ID).ToString()) + Else + Return -1 + End If + End Get + End Property + + Public ReadOnly Property IsApprover() As Boolean + Get + If (HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (IsAdmin) Then + Return True + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_APPROVAL_SETTING)) Then + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_APPROVAL_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property IsCategoriesEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_CATEGORIES_SETTING)) Then + Return IsInRoles(Settings(ArticleConstants.PERMISSION_CATEGORIES_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsExcerptEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_EXCERPT_SETTING)) Then + Return IsInRoles(Settings(ArticleConstants.PERMISSION_EXCERPT_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsImagesEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_IMAGE_SETTING)) Then + Return IsInRoles(Settings(ArticleConstants.PERMISSION_IMAGE_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsFilesEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_FILE_SETTING)) Then + Return IsInRoles(Settings(ArticleConstants.PERMISSION_FILE_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsLinkEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_LINK_SETTING)) Then + Return IsInRoles(Settings(ArticleConstants.PERMISSION_LINK_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsFeaturedEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_FEATURE_SETTING)) Then + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_FEATURE_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsSecureEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_SECURE_SETTING)) Then + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_SECURE_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsPublishEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_PUBLISH_SETTING)) Then + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_PUBLISH_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsExpiryEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_EXPIRY_SETTING)) Then + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_EXPIRY_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsMetaEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_META_SETTING)) Then + If (Settings(ArticleConstants.PERMISSION_META_SETTING).ToString() = "") Then + Return False + End If + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_META_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsCustomEnabled() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_CUSTOM_SETTING)) Then + If (Settings(ArticleConstants.PERMISSION_CUSTOM_SETTING).ToString() = "") Then + Return False + End If + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_CUSTOM_SETTING).ToString()) + Else + Return True + End If + End Get + End Property + + Public ReadOnly Property IsAutoApprover() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (IsAdmin) Then + Return True + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_APPROVAL_SETTING)) Then + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_AUTO_APPROVAL_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property IsAutoApproverComment() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (IsAdmin) Then + Return True + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_APPROVAL_COMMENT_SETTING)) Then + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_AUTO_APPROVAL_COMMENT_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property IsAutoFeatured() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_FEATURE_SETTING)) Then + + For Each role As String In Settings(ArticleConstants.PERMISSION_AUTO_FEATURE_SETTING).ToString().Split(New Char() {";"c}) + If (role <> "") Then + If (UserController.GetCurrentUserInfo.IsInRole(role)) Then + Return True + End If + End If + Next + Return False + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property IsAutoSecured() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_SECURE_SETTING)) Then + + For Each role As String In Settings(ArticleConstants.PERMISSION_AUTO_SECURE_SETTING).ToString().Split(New Char() {";"c}) + If (role <> "") Then + If (UserController.GetCurrentUserInfo.IsInRole(role)) Then + Return True + End If + End If + Next + Return False + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property IsSubmitter() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + If (IsAdmin) Then + Return True + End If + + If (Settings.Contains(ArticleConstants.PERMISSION_SUBMISSION_SETTING)) Then + Return PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_SUBMISSION_SETTING).ToString()) + Else + Return False + End If + End Get + End Property + + Public ReadOnly Property IsAdmin() As Boolean + Get + If (System.Web.HttpContext.Current.Request.IsAuthenticated = False) Then + Return False + End If + + Dim blnHasModuleEditPermissions As Boolean = PortalSecurity.IsInRoles(_moduleConfiguration.AuthorizedEditRoles) + + If (blnHasModuleEditPermissions = False) Then + blnHasModuleEditPermissions = PortalSecurity.IsInRoles(_portalSettings.ActiveTab.AdministratorRoles) + End If + + If (blnHasModuleEditPermissions = False) Then + blnHasModuleEditPermissions = PortalSecurity.IsInRoles(_portalSettings.AdministratorRoleName) + End If + + Return blnHasModuleEditPermissions + End Get + End Property + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/AuthorController.vb b/Components/AuthorController.vb new file mode 100755 index 0000000..f5aa930 --- /dev/null +++ b/Components/AuthorController.vb @@ -0,0 +1,102 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports DotNetNuke.Common.Utilities +Imports System.Security.Cryptography + +Namespace Ventrian.NewsArticles + + Public Class AuthorController + + Public Shared Sub ClearCache(ByVal moduleID As Integer) + + Dim itemsToRemove As New List(Of String)() + + If (HttpContext.Current IsNot Nothing) Then + Dim enumerator As IDictionaryEnumerator = HttpContext.Current.Cache.GetEnumerator() + While enumerator.MoveNext() + If enumerator.Key.ToString().ToLower().Contains("ventrian-newsarticles-authors-" & moduleID.ToString()) Then + itemsToRemove.Add(enumerator.Key.ToString()) + End If + End While + + For Each itemToRemove As String In itemsToRemove + DataCache.RemoveCache(itemToRemove.Replace("DNN_", "")) + Next + End If + + End Sub + + Public Function GetAuthorList(ByVal moduleID As Integer) As List(Of AuthorInfo) + + Dim cacheKey As String = "ventrian-newsarticles-authors-" & moduleID.ToString() + + Dim objAuthors As List(Of AuthorInfo) = CType(DataCache.GetCache(cacheKey), List(Of AuthorInfo)) + + If (objAuthors Is Nothing) Then + objAuthors = CBO.FillCollection(Of AuthorInfo)(DataProvider.Instance().GetAuthorList(moduleID)) + DataCache.SetCache(cacheKey, objAuthors) + End If + + Return objAuthors + + End Function + + Public Function GetAuthorStatistics(ByVal moduleID As Integer, ByVal categoryID As Integer(), ByVal categoryIDExclude As Integer(), ByVal authorID As Integer, ByVal sortBy As String, ByVal showPending As Boolean) As List(Of AuthorInfo) + + Dim categories As String = Null.NullString + + If Not (categoryID Is Nothing) Then + For Each category As Integer In categoryID + If Not (categories = Null.NullString) Then + categories = categories & "," + End If + categories = categories & category.ToString() + Next + End If + + Dim categoriesExclude As String = Null.NullString + + If Not (categoryIDExclude Is Nothing) Then + For Each category As Integer In categoryIDExclude + If Not (categoriesExclude = Null.NullString) Then + categoriesExclude = categoriesExclude & "," + End If + categoriesExclude = categoriesExclude & category.ToString() + Next + End If + + Dim hashCategories As String = "" + If (categories <> "" Or categoriesExclude <> "") Then + Dim Ue As New UnicodeEncoding() + Dim ByteSourceText() As Byte = Ue.GetBytes(categories & categoriesExclude) + Dim Md5 As New MD5CryptoServiceProvider() + Dim ByteHash() As Byte = Md5.ComputeHash(ByteSourceText) + hashCategories = Convert.ToBase64String(ByteHash) + End If + + If (sortBy = "ArticleCount") Then + sortBy = "ArticleCount DESC" + End If + + Dim cacheKey As String = "ventrian-newsarticles-authors-" & moduleID.ToString() & "-" & hashCategories & "-" & authorID.ToString() & "-" & sortBy.ToString() & "-" & showPending.ToString() + + Dim objAuthorStatistics As List(Of AuthorInfo) = CType(DataCache.GetCache(cacheKey), List(Of AuthorInfo)) + + If (objAuthorStatistics Is Nothing) Then + objAuthorStatistics = CBO.FillCollection(Of AuthorInfo)(DataProvider.Instance().GetAuthorStatistics(moduleID, categoryID, categoryIDExclude, authorID, sortBy, showPending)) + DataCache.SetCache(cacheKey, objAuthorStatistics) + End If + + Return objAuthorStatistics + + End Function + + + End Class + +End Namespace diff --git a/Components/AuthorInfo.vb b/Components/AuthorInfo.vb new file mode 100755 index 0000000..724db4b --- /dev/null +++ b/Components/AuthorInfo.vb @@ -0,0 +1,98 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Security.Roles + +Namespace Ventrian.NewsArticles + + Public Class AuthorInfo + +#Region " Private Members " + + ' local property declarations + Dim _userName As String + Dim _userID As Integer + Dim _firstName As String + Dim _lastName As String + Dim _displayName As String + Dim _articleCount As Integer + +#End Region + +#Region " Public Properties " + + Public Property UserName() As String + Get + Return _userName + End Get + Set(ByVal Value As String) + _userName = Value + End Set + End Property + + Public Property UserID() As Integer + Get + Return _userID + End Get + Set(ByVal Value As Integer) + _userID = Value + End Set + End Property + + Public Property FirstName() As String + Get + Return _firstName + End Get + Set(ByVal Value As String) + _firstName = Value + End Set + End Property + + Public Property LastName() As String + Get + Return _lastName + End Get + Set(ByVal Value As String) + _lastName = Value + End Set + End Property + + Public Property DisplayName() As String + Get + Return _displayName + End Get + Set(ByVal Value As String) + _displayName = Value + End Set + End Property + + Public ReadOnly Property FullName() As String + Get + Return FirstName & " " & LastName + End Get + End Property + + Public Property ArticleCount() As Integer + Get + Return _articleCount + End Get + Set(ByVal Value As Integer) + _articleCount = Value + End Set + End Property + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/AuthorSortByType.vb b/Components/AuthorSortByType.vb new file mode 100755 index 0000000..5bc3b23 --- /dev/null +++ b/Components/AuthorSortByType.vb @@ -0,0 +1,19 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Enum AuthorSortByType + + ArticleCount + DisplayName + FirstName + LastName + UserName + + End Enum + +End Namespace diff --git a/Components/Bitly.vb b/Components/Bitly.vb new file mode 100755 index 0000000..6365e51 --- /dev/null +++ b/Components/Bitly.vb @@ -0,0 +1,132 @@ +Imports System.Text +Imports System.Xml +Imports System.IO +Imports System.Net + +Namespace Ventrian.NewsArticles + + Public Class bitly + Private loginAccount As String + Private apiKeyForAccount As String + + Private submitPath As String = "http://api.bit.ly/shorten?version=2.0.1&format=xml" + Private errorStatus As Integer = 0 + Private errorStatusMessage As String = "" + + + ' Constructors (overloaded and chained) + Public Sub New() + Me.New("bitlyapidemo", "R_0da49e0a9118ff35f52f629d2d71bf07") + End Sub + + + Public Sub New(ByVal login As String, ByVal APIKey As String) + loginAccount = login + apiKeyForAccount = APIKey + + submitPath &= "&login=" & loginAccount & "&apiKey=" & apiKeyForAccount + End Sub + + + ' Properties to retrieve error information. + Public ReadOnly Property ErrorCode() As Integer + Get + Return errorStatus + End Get + End Property + + Public ReadOnly Property ErrorMessage() As String + Get + Return errorStatusMessage + End Get + End Property + + + ' Main shorten function which takes in the long URL and returns the bit.ly shortened URL + Public Function Shorten(ByVal url As String) As String + + errorStatus = 0 + errorStatusMessage = "" + + Dim doc As XmlDocument + doc = buildDocument(url) + + If Not doc.DocumentElement Is Nothing Then + + Dim shortenedNode As XmlNode = doc.DocumentElement.SelectSingleNode("results/nodeKeyVal/shortUrl") + + If Not shortenedNode Is Nothing Then + + Return shortenedNode.InnerText + + Else + + getErrorCode(doc) + + End If + Else + + errorStatus = -1 + errorStatusMessage = "Unable to connect to bit.ly for shortening of URL" + End If + + Return "" + + End Function + + + ' Sets error code and message in the situation we receive a response, but there was + ' something wrong with our submission. + Private Sub getErrorCode(ByVal doc As XmlDocument) + + Dim errorNode As XmlNode = doc.DocumentElement.SelectSingleNode("errorCode") + Dim errorMessageNode As XmlNode = doc.DocumentElement.SelectSingleNode("errorMessage") + + If Not errorNode Is Nothing Then + + errorStatus = Convert.ToInt32(errorNode.InnerText) + errorStatusMessage = errorMessageNode.InnerText + End If + End Sub + + + ' Builds an XmlDocument using the XML returned by bit.ly in response + ' to our URL being submitted + Private Function buildDocument(ByVal url As String) As XmlDocument + + Dim doc As New XmlDocument + + Try + + ' Load the XML response into an XML Document and return it. + doc.LoadXml(readSource(submitPath + "&longUrl=" + url)) + Return doc + + Catch e As Exception + + Return New XmlDocument() + End Try + End Function + + + ' Fetches a result from bit.ly provided the URL submitted + Private Function readSource(ByVal url As String) As String + Dim client As New WebClient + + Try + + Using reader As New StreamReader(client.OpenRead(url)) + ' Read all of the response + Return reader.ReadToEnd() + reader.Close() + End Using + + Catch e As Exception + Throw e + End Try + + End Function + + End Class + +End Namespace diff --git a/Components/CategoryController.vb b/Components/CategoryController.vb new file mode 100755 index 0000000..d547203 --- /dev/null +++ b/Components/CategoryController.vb @@ -0,0 +1,227 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class CategoryController + +#Region " Public Methods " + + Public Shared Sub ClearCache(ByVal moduleID As Integer) + + Dim itemsToRemove As New List(Of String)() + + If (HttpContext.Current IsNot Nothing) Then + Dim enumerator As IDictionaryEnumerator = HttpContext.Current.Cache.GetEnumerator() + While enumerator.MoveNext() + If enumerator.Key.ToString().ToLower().Contains("ventrian-newsarticles-categories-" & moduleID.ToString()) Then + itemsToRemove.Add(enumerator.Key.ToString()) + End If + End While + + For Each itemToRemove As String In itemsToRemove + DataCache.RemoveCache(itemToRemove.Replace("DNN_", "")) + Next + End If + + End Sub + + Public Function GetCategories(ByVal moduleID As Integer, ByVal parentID As Integer) As List(Of CategoryInfo) + + Return GetCategoriesAll(moduleID, parentID, Nothing, Null.NullInteger, 1, Null.NullBoolean, CategorySortType.Name) + + End Function + + Public Function GetCategoriesAll(ByVal moduleID As Integer) As List(Of CategoryInfo) + + Return GetCategoriesAll(moduleID, Null.NullInteger, Nothing, Null.NullInteger, Null.NullInteger, Null.NullBoolean, CategorySortType.Name) + + End Function + + Public Function GetCategoriesAll(ByVal moduleID As Integer, ByVal parentID As Integer) As List(Of CategoryInfo) + + Return GetCategoriesAll(moduleID, parentID, CategorySortType.Name) + + End Function + + Public Function GetCategoriesAll(ByVal moduleID As Integer, ByVal parentID As Integer, ByVal sortType As CategorySortType) As List(Of CategoryInfo) + + Return GetCategoriesAll(moduleID, parentID, Nothing, Null.NullInteger, Null.NullInteger, False, sortType) + + End Function + + Public Function GetCategoriesAll(ByVal moduleID As Integer, ByVal parentID As Integer, ByVal categoryIDFilter As Integer(), ByVal authorID As Integer, ByVal maxDepth As Integer, ByVal showPending As Boolean, ByVal sortType As CategorySortType) As List(Of CategoryInfo) + + Dim cacheKey As String = "Ventrian-NewsArticles-Categories-" & moduleID.ToString() & "-" & sortType.ToString() + + If (authorID <> Null.NullInteger) Then + cacheKey = cacheKey & "-a-" & authorID.ToString() + End If + + If (showPending <> Null.NullBoolean) Then + cacheKey = cacheKey & "-sp-" & showPending.ToString() + End If + + Dim objCategories As List(Of CategoryInfo) = CType(DataCache.GetCache(cacheKey), List(Of CategoryInfo)) + + If (objCategories Is Nothing) Then + objCategories = CBO.FillCollection(Of CategoryInfo)(DataProvider.Instance().GetCategoryListAll(moduleID, authorID, showPending, sortType)) + DataCache.SetCache(cacheKey, objCategories) + End If + + If (categoryIDFilter IsNot Nothing) Then + Dim objNewCategories As New List(Of CategoryInfo) + For Each id As Integer In categoryIDFilter + For Each objCategory As CategoryInfo In objCategories + If (objCategory.CategoryID = id) Then + objNewCategories.Add(objCategory) + End If + Next + Next + objCategories = objNewCategories + End If + + Dim objCategoriesCopy As New List(Of CategoryInfo)(objCategories) + + If (parentID <> Null.NullInteger) Then + Dim level As Integer = Null.NullInteger + Dim objParentIDs As New List(Of Integer) + objParentIDs.Add(parentID) + Dim objNewCategories As New List(Of CategoryInfo) + For Each objCategory As CategoryInfo In objCategoriesCopy + For Each id As Integer In objParentIDs.ToArray() + If (objCategory.ParentID = id) Then + If (level = Null.NullInteger) Then + level = objCategory.Level + End If + + If (maxDepth = Null.NullInteger Or objCategory.Level < (level + maxDepth)) Then + Dim objCategoryNew As CategoryInfo = objCategory.Clone() + objCategoryNew.Level = objCategory.Level - level + 1 + objNewCategories.Add(objCategoryNew) + If (objParentIDs.Contains(objCategory.CategoryID) = False) Then + objParentIDs.Add(objCategory.CategoryID) + End If + Exit For + End If + End If + Next + Next + objCategoriesCopy = objNewCategories + Else + If (maxDepth <> Null.NullInteger) Then + Dim objNewCategories As New List(Of CategoryInfo) + For Each objCategory As CategoryInfo In objCategoriesCopy + If (objCategory.Level <= maxDepth) Then + objNewCategories.Add(objCategory) + End If + Next + objCategoriesCopy = objNewCategories + End If + End If + + Return objCategoriesCopy + + End Function + + + + _ + Public Function GetCategoryList(ByVal moduleID As Integer, ByVal parentID As Integer) As ArrayList + + Dim objCategories As List(Of CategoryInfo) = GetCategories(moduleID, parentID) + Dim objCategoriesToReturn As New ArrayList() + + For Each objCategory As CategoryInfo In objCategories + objCategoriesToReturn.Add(objCategory) + Next + + Return objCategoriesToReturn + + End Function + + _ + Public Function GetCategoryListAll(ByVal moduleID As Integer) As ArrayList + + Return GetCategoryListAll(moduleID, Null.NullInteger, Nothing, Null.NullInteger, Null.NullInteger, Null.NullBoolean, CategorySortType.Name) + + End Function + + _ + Public Function GetCategoryListAll(ByVal moduleID As Integer, ByVal parentID As Integer) As ArrayList + + Return GetCategoryListAll(moduleID, parentID, CategorySortType.Name) + + End Function + + _ + Public Function GetCategoryListAll(ByVal moduleID As Integer, ByVal parentID As Integer, ByVal sortType As CategorySortType) As ArrayList + + Return GetCategoryListAll(moduleID, parentID, Nothing, Null.NullInteger, Null.NullInteger, False, sortType) + + End Function + + _ + Public Function GetCategoryListAll(ByVal moduleID As Integer, ByVal parentID As Integer, ByVal categoryIDFilter As Integer(), ByVal authorID As Integer, ByVal maxDepth As Integer, ByVal showPending As Boolean, ByVal sortType As CategorySortType) As ArrayList + + Dim objCategories As List(Of CategoryInfo) = GetCategoriesAll(moduleID, parentID, categoryIDFilter, authorID, maxDepth, showPending, sortType) + Dim objCategoriesToReturn As New ArrayList() + + For Each objCategory As CategoryInfo In objCategories + objCategoriesToReturn.Add(objCategory) + Next + + Return objCategoriesToReturn + + End Function + + Public Function GetCategory(ByVal categoryID As Integer, ByVal moduleID As Integer) As CategoryInfo + + Dim objCategories As List(Of CategoryInfo) = GetCategoriesAll(moduleID) + + For Each objCategory As CategoryInfo In objCategories + If (objCategory.CategoryID = categoryID) Then + Return objCategory + End If + Next + + Return CType(CBO.FillObject(DataProvider.Instance().GetCategory(categoryID), GetType(CategoryInfo)), CategoryInfo) + + End Function + + Public Sub DeleteCategory(ByVal categoryID As Integer, ByVal moduleID As Integer) + + DataProvider.Instance().DeleteCategory(categoryID) + CategoryController.ClearCache(moduleID) + + End Sub + + Public Function AddCategory(ByVal objCategory As CategoryInfo) As Integer + + Dim categoryID As Integer = CType(DataProvider.Instance().AddCategory(objCategory.ModuleID, objCategory.ParentID, objCategory.Name, objCategory.Image, objCategory.Description, objCategory.SortOrder, objCategory.InheritSecurity, objCategory.CategorySecurityType, objCategory.MetaTitle, objCategory.MetaDescription, objCategory.MetaKeywords), Integer) + CategoryController.ClearCache(objCategory.ModuleID) + Return categoryID + + End Function + + Public Sub UpdateCategory(ByVal objCategory As CategoryInfo) + + DataProvider.Instance().UpdateCategory(objCategory.CategoryID, objCategory.ModuleID, objCategory.ParentID, objCategory.Name, objCategory.Image, objCategory.Description, objCategory.SortOrder, objCategory.InheritSecurity, objCategory.CategorySecurityType, objCategory.MetaTitle, objCategory.MetaDescription, objCategory.MetaKeywords) + CategoryController.ClearCache(objCategory.ModuleID) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/CategoryInfo.vb b/Components/CategoryInfo.vb new file mode 100755 index 0000000..7af073a --- /dev/null +++ b/Components/CategoryInfo.vb @@ -0,0 +1,219 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class CategoryInfo + +#Region " Private Methods " + + ' local property declarations + Dim _categoryID As Integer + Dim _moduleID As Integer + Dim _parentID As Integer + Dim _name As String + Dim _nameIndented As String + Dim _description As String + Dim _image As String + Dim _level As Integer + Dim _sortOrder As Integer + Dim _inheritSecurity As Boolean + Dim _categorySecurityType As CategorySecurityType + + Dim _numberOfArticles As Integer + Dim _numberOfViews As Integer + + Dim _metaTitle As String + Dim _metaDescription As String + Dim _metaKeywords As String + + Dim _levelParent As Integer = Null.NullInteger + +#End Region + +#Region " Public Properties " + + Public Property CategoryID() As Integer + Get + Return _categoryID + End Get + Set(ByVal Value As Integer) + _categoryID = Value + End Set + End Property + + Public Property ModuleID() As Integer + Get + Return _moduleID + End Get + Set(ByVal Value As Integer) + _moduleID = Value + End Set + End Property + + Public Property ParentID() As Integer + Get + Return _parentID + End Get + Set(ByVal Value As Integer) + _parentID = Value + End Set + End Property + + Public Property Name() As String + Get + Return _name + End Get + Set(ByVal Value As String) + _name = Value + End Set + End Property + + Public Property Description() As String + Get + Return _description + End Get + Set(ByVal Value As String) + _description = Value + End Set + End Property + + Public Property NameIndented() As String + Get + If (Level = 1) Then + Return Name + Else + If ((Level - 1) * 2 > 0) Then + Dim a As New String("."c, (Level - 1) * 2) + Return a & Name + Else + Return Name + End If + End If + End Get + Set(ByVal Value As String) + _nameIndented = Value + End Set + End Property + + Public Property Image() As String + Get + Return _image + End Get + Set(ByVal Value As String) + _image = Value + End Set + End Property + + Public Property Level() As Integer + Get + Return _level + End Get + Set(ByVal Value As Integer) + _level = Value + End Set + End Property + + Public Property LevelParent() As Integer + Get + Return _levelParent + End Get + Set(ByVal Value As Integer) + _levelParent = Value + End Set + End Property + + Public Property SortOrder() As Integer + Get + Return _sortOrder + End Get + Set(ByVal Value As Integer) + _sortOrder = Value + End Set + End Property + + Public Property InheritSecurity() As Boolean + Get + Return _inheritSecurity + End Get + Set(ByVal Value As Boolean) + _inheritSecurity = Value + End Set + End Property + + Public Property CategorySecurityType() As CategorySecurityType + Get + Return _categorySecurityType + End Get + Set(ByVal Value As CategorySecurityType) + _categorySecurityType = Value + End Set + End Property + + Public Property NumberOfArticles() As Integer + Get + Return _numberOfArticles + End Get + Set(ByVal Value As Integer) + _numberOfArticles = Value + End Set + End Property + + Public Property NumberOfViews() As Integer + Get + Return _numberOfViews + End Get + Set(ByVal Value As Integer) + _numberOfViews = Value + End Set + End Property + + Public Property MetaTitle() As String + Get + Return _metaTitle + End Get + Set(ByVal Value As String) + _metaTitle = Value + End Set + End Property + + Public Property MetaDescription() As String + Get + Return _metaDescription + End Get + Set(ByVal Value As String) + _metaDescription = Value + End Set + End Property + + Public Property MetaKeywords() As String + Get + Return _metaKeywords + End Get + Set(ByVal Value As String) + _metaKeywords = Value + End Set + End Property + +#End Region + +#Region " Public Methods " + + Public Function Clone() As CategoryInfo + Return DirectCast(Me.MemberwiseClone(), CategoryInfo) + End Function + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/CategorySecurityType.vb b/Components/CategorySecurityType.vb new file mode 100755 index 0000000..cd5fb03 --- /dev/null +++ b/Components/CategorySecurityType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum CategorySecurityType + + Restrict = 0 + Loose = 1 + + End Enum + +End Namespace diff --git a/Components/CategorySortType.vb b/Components/CategorySortType.vb new file mode 100755 index 0000000..983f0c3 --- /dev/null +++ b/Components/CategorySortType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum CategorySortType + + SortOrder = 0 + Name = 1 + + End Enum + +End Namespace diff --git a/Components/CommentController.vb b/Components/CommentController.vb new file mode 100755 index 0000000..b355b9c --- /dev/null +++ b/Components/CommentController.vb @@ -0,0 +1,96 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class CommentController + + Public Shared Sub ClearCache(ByVal articleID As Integer) + + Dim itemsToRemove As New List(Of String)() + + Dim enumerator As IDictionaryEnumerator = HttpContext.Current.Cache.GetEnumerator() + While enumerator.MoveNext() + If enumerator.Key.ToString().ToLower().Contains("ventrian-newsarticles-comments") Then + itemsToRemove.Add(enumerator.Key.ToString()) + End If + End While + + For Each itemToRemove As String In itemsToRemove + DataCache.RemoveCache(itemToRemove.Replace("DNN_", "")) + Next + + End Sub + +#Region " Public Methods " + + Public Function GetCommentList(ByVal moduleID As Integer, ByVal articleID As Integer, ByVal isApproved As Boolean) As List(Of CommentInfo) + + Return GetCommentList(moduleID, articleID, isApproved, SortDirection.Ascending, Null.NullInteger) + + End Function + + Public Function GetCommentList(ByVal moduleID As Integer, ByVal articleID As Integer, ByVal isApproved As Boolean, ByVal direction As SortDirection, ByVal maxCount As Integer) As List(Of CommentInfo) + + Dim cacheKey As String = "ventrian-newsarticles-comments-" & moduleID.ToString() & "-" & articleID.ToString() & "-" & isApproved.ToString() & "-" & direction.ToString() & "-" & maxCount.ToString() + + Dim objComments As List(Of CommentInfo) = CType(DataCache.GetCache(cacheKey), List(Of CommentInfo)) + + If (objComments Is Nothing) Then + objComments = CBO.FillCollection(Of CommentInfo)(DataProvider.Instance().GetCommentList(moduleID, articleID, isApproved, direction, maxCount)) + DataCache.SetCache(cacheKey, objComments) + End If + + Return objComments + + End Function + + Public Function GetComment(ByVal commentID As Integer) As CommentInfo + + Return CType(CBO.FillObject(DataProvider.Instance().GetComment(commentID), GetType(CommentInfo)), CommentInfo) + + End Function + + Public Sub DeleteComment(ByVal commentID As Integer, ByVal articleID As Integer) + + DataProvider.Instance().DeleteComment(commentID) + + ArticleController.ClearArticleCache(articleID) + CommentController.ClearCache(articleID) + + End Sub + + Public Function AddComment(ByVal objComment As CommentInfo) As Integer + + Dim commentID As Integer = CType(DataProvider.Instance().AddComment(objComment.ArticleID, objComment.CreatedDate, objComment.UserID, objComment.Comment, objComment.RemoteAddress, objComment.Type, objComment.TrackbackUrl, objComment.TrackbackTitle, objComment.TrackbackBlogName, objComment.TrackbackExcerpt, objComment.AnonymousName, objComment.AnonymousEmail, objComment.AnonymousURL, objComment.NotifyMe, objComment.IsApproved, objComment.ApprovedBy), Integer) + + ArticleController.ClearArticleCache(objComment.ArticleID) + CommentController.ClearCache(objComment.ArticleID) + + Return commentID + + End Function + + Public Sub UpdateComment(ByVal objComment As CommentInfo) + + DataProvider.Instance().UpdateComment(objComment.CommentID, objComment.ArticleID, objComment.UserID, objComment.Comment, objComment.RemoteAddress, objComment.Type, objComment.TrackbackUrl, objComment.TrackbackTitle, objComment.TrackbackBlogName, objComment.TrackbackExcerpt, objComment.AnonymousName, objComment.AnonymousEmail, objComment.AnonymousURL, objComment.NotifyMe, objComment.IsApproved, objComment.ApprovedBy) + + ArticleController.ClearArticleCache(objComment.ArticleID) + CommentController.ClearCache(objComment.ArticleID) + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/CommentInfo.vb b/Components/CommentInfo.vb new file mode 100755 index 0000000..0f9c52f --- /dev/null +++ b/Components/CommentInfo.vb @@ -0,0 +1,251 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class CommentInfo + +#Region " Private Methods " + + ' local property declarations + Dim _commentID As Integer + Dim _articleID As Integer + Dim _userID As Integer + Dim _comment As String + Dim _createdDate As DateTime + Dim _remoteAddress As String + Dim _type As Integer + Dim _trackbackUrl As String + Dim _trackbackTitle As String + Dim _trackbackBlogName As String + Dim _trackbackExcerpt As String + Dim _anonymousName As String + Dim _anonymousEmail As String + Dim _anonymousURL As String + Dim _notifyMe As Boolean = Null.NullBoolean + Dim _isApproved As Boolean = Null.NullBoolean + Dim _approvedBy As Integer + + Dim _authorEmail As String + Dim _authorUserName As String + Dim _authorFirstName As String + Dim _authorLastName As String + Dim _authorDisplayName As String + +#End Region + +#Region " Public Properties " + + Public Property CommentID() As Integer + Get + Return _commentID + End Get + Set(ByVal Value As Integer) + _commentID = Value + End Set + End Property + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal Value As Integer) + _articleID = Value + End Set + End Property + + Public Property UserID() As Integer + Get + Return _userID + End Get + Set(ByVal Value As Integer) + _userID = Value + End Set + End Property + + + Public Property Comment() As String + Get + Return _comment + End Get + Set(ByVal Value As String) + _comment = Value + End Set + End Property + + Public Property CreatedDate() As DateTime + Get + Return _createdDate + End Get + Set(ByVal Value As DateTime) + _createdDate = Value + End Set + End Property + + Public Property RemoteAddress() As String + Get + Return _remoteAddress + End Get + Set(ByVal Value As String) + _remoteAddress = Value + End Set + End Property + + Public Property Type() As Integer + Get + Return _type + End Get + Set(ByVal Value As Integer) + _type = Value + End Set + End Property + + Public Property TrackbackUrl() As String + Get + Return _trackbackUrl + End Get + Set(ByVal Value As String) + _trackbackUrl = Value + End Set + End Property + + Public Property TrackbackTitle() As String + Get + Return _trackbackTitle + End Get + Set(ByVal Value As String) + _trackbackTitle = Value + End Set + End Property + + Public Property TrackbackBlogName() As String + Get + Return _trackbackBlogName + End Get + Set(ByVal Value As String) + _trackbackBlogName = Value + End Set + End Property + + Public Property TrackbackExcerpt() As String + Get + Return _trackbackExcerpt + End Get + Set(ByVal Value As String) + _trackbackExcerpt = Value + End Set + End Property + + Public Property NotifyMe() As Boolean + Get + Return _notifyMe + End Get + Set(ByVal Value As Boolean) + _notifyMe = Value + End Set + End Property + + Public Property IsApproved() As Boolean + Get + Return _isApproved + End Get + Set(ByVal Value As Boolean) + _isApproved = Value + End Set + End Property + + Public Property ApprovedBy() As Integer + Get + Return _approvedBy + End Get + Set(ByVal Value As Integer) + _approvedBy = Value + End Set + End Property + + Public Property AuthorUserName() As String + Get + Return _authorUserName + End Get + Set(ByVal Value As String) + _authorUserName = Value + End Set + End Property + + Public Property AuthorEmail() As String + Get + Return _authorEmail + End Get + Set(ByVal Value As String) + _authorEmail = Value + End Set + End Property + + Public Property AuthorFirstName() As String + Get + Return _authorFirstName + End Get + Set(ByVal Value As String) + _authorFirstName = Value + End Set + End Property + + Public Property AuthorLastName() As String + Get + Return _authorLastName + End Get + Set(ByVal Value As String) + _authorLastName = Value + End Set + End Property + + Public Property AuthorDisplayName() As String + Get + Return _authorDisplayName + End Get + Set(ByVal Value As String) + _authorDisplayName = Value + End Set + End Property + + Public Property AnonymousName() As String + Get + Return _anonymousName + End Get + Set(ByVal Value As String) + _anonymousName = Value + End Set + End Property + + Public Property AnonymousEmail() As String + Get + Return _anonymousEmail + End Get + Set(ByVal Value As String) + _anonymousEmail = Value + End Set + End Property + + Public Property AnonymousURL() As String + Get + Return _anonymousURL + End Get + Set(ByVal Value As String) + _anonymousURL = Value + End Set + End Property + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/Common.vb b/Components/Common.vb new file mode 100755 index 0000000..b3b028a --- /dev/null +++ b/Components/Common.vb @@ -0,0 +1,778 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.Globalization +Imports System.Threading +Imports System.Web + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Entities.Tabs +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Services.Localization +Imports DotNetNuke.UI.Modules + +Imports Ventrian.NewsArticles.Components.Utility +Imports DotNetNuke.Entities.Controllers +Imports DotNetNuke.Entities.Host +Imports DotNetNuke.Security + +Namespace Ventrian.NewsArticles + + Public Class Common + +#Region " Friend Shared Methods " + + Friend Shared Sub BindEnum(ByVal objListControl As ListControl, ByRef enumType As Type, ByVal resourceFile As String) + + For Each value As Integer In System.Enum.GetValues(enumType) + Dim li As New ListItem + li.Value = System.Enum.GetName(enumType, value) + li.Text = Localization.GetString(System.Enum.GetName(enumType, value), resourceFile) + objListControl.Items.Add(li) + Next + + End Sub + +#End Region + +#Region " Public Shared Methods " + + + Public Shared Function FormatTitle(ByVal title As String) As String + + If (title = "") Then + Return "Default.aspx" + End If + + Dim returnTitle As String = OnlyAlphaNumericChars(title, TitleReplacementType.Dash) + If (returnTitle = "") Then + Return "Default.aspx" + End If + + If (returnTitle.Replace("-", "").Replace("_", "") = "") Then + Return "Default.aspx" + End If + + Return returnTitle.Replace("--", "-") & ".aspx" + + End Function + + Public Shared Function FormatTitle(ByVal title As String, ByVal objArticleSettings As ArticleSettings) As String + + If (title = "") Then + Return "Default.aspx" + End If + + Dim returnTitle As String = OnlyAlphaNumericChars(title, objArticleSettings.TitleReplacement) + If (returnTitle = "") Then + Return "Default.aspx" + End If + + If (returnTitle.Replace("-", "").Replace("_", "") = "") Then + Return "Default.aspx" + End If + + Return returnTitle.Replace("--", "-") & ".aspx" + + End Function + + Public Shared Function OnlyAlphaNumericChars(ByVal OrigString As String, ByVal objReplacementType As TitleReplacementType) As String + + '*********************************************************** + 'INPUT: Any String + 'OUTPUT: The Input String with all non-alphanumeric characters + ' removed + 'EXAMPLE Debug.Print OnlyAlphaNumericChars("Hello World!") + 'output = "HelloWorld") + 'NOTES: Not optimized for speed and will run slow on long + ' strings. If you plan on using long strings, consider + ' using alternative method of appending to output string, + ' such as the method at + ' http://www.freevbcode.com/ShowCode.Asp?ID=154 + '*********************************************************** + Dim lLen As Integer + Dim sAns As String = "" + Dim lCtr As Integer + Dim sChar As String + + OrigString = RemoveDiacritics(Trim(OrigString)) + + lLen = Len(OrigString) + For lCtr = 1 To lLen + sChar = Mid(OrigString, lCtr, 1) + If IsAlphaNumeric(Mid(OrigString, lCtr, 1)) Or Mid(OrigString, lCtr, 1) = "-" Or Mid(OrigString, lCtr, 1) = "_" Then + sAns = sAns & sChar + End If + Next + + If (objReplacementType = TitleReplacementType.Dash) Then + OnlyAlphaNumericChars = Replace(sAns, " ", "-") + Else + OnlyAlphaNumericChars = Replace(sAns, " ", "_") + End If + + End Function + + Public Shared Function RemoveDiacritics(ByVal s As String) As String + s = s.Normalize(System.Text.NormalizationForm.FormD) + Dim sb As System.Text.StringBuilder = New System.Text.StringBuilder() + Dim i As Integer + For i = 0 To s.Length - 1 + If s(i) = ChrW(305) Then + sb.Append("i"c) + Else + If CharUnicodeInfo.GetUnicodeCategory(s(i)) <> UnicodeCategory.NonSpacingMark Then + sb.Append(s(i)) + End If + End If + Next + Return sb.ToString() + End Function + + Public Shared Function IsAlphaNumeric(ByVal sChr As String) As Boolean + IsAlphaNumeric = sChr Like "[0-9A-Za-z ]" + End Function + + Public Shared Function GetAdjustedUserTime(ByVal dateString As String, ByVal format As String, ByVal timeZone As Integer) As String + + Dim dateToFormat As DateTime = DateTime.Parse(dateString) + + Return dateToFormat.ToString(format) + + End Function + + Public Shared Function GetAdjustedUserTime(ByVal articleSettings As ArticleSettings, ByVal dateString As String, ByVal format As String) As String + + Return GetAdjustedUserTime(dateString, format, articleSettings.ServerTimeZone) + + End Function + + Public Shared Function GetAdjustedUserTime(ByVal articleSettings As ArticleSettings, ByVal objDateTime As DateTime) As DateTime + + Return objDateTime + + End Function + + Public Shared Function GetAdjustedServerTime(ByVal articleSettings As ArticleSettings, ByVal objDateTime As DateTime) As DateTime + + Return objDateTime + + End Function + + Public Shared Function GetArticleLink(ByVal objArticle As ArticleInfo, ByVal objTab As DotNetNuke.Entities.Tabs.TabInfo, ByVal articleSettings As ArticleSettings, ByVal includeCategory As Boolean) As String + Return GetArticleLink(objArticle, objTab, articleSettings, includeCategory, Null.NullInteger) + End Function + + Public Shared Function GetArticleLink(ByVal objArticle As ArticleInfo, ByVal objTab As DotNetNuke.Entities.Tabs.TabInfo, ByVal articleSettings As ArticleSettings, ByVal includeCategory As Boolean, ByVal pageID As Integer) As String + + If (objTab Is Nothing) Then + Return "" + End If + + If Host.UseFriendlyUrls Then + + Dim strURL As String = ApplicationURL(objTab.TabID) + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings + + If (articleSettings.LaunchLinks) Then + strURL = strURL & "&ctl=ArticleView" + strURL = strURL & "&mid=" & objArticle.ModuleID.ToString + strURL = strURL & "&articleId=" & objArticle.ArticleID + Else + If (articleSettings.UrlModeType = Components.Types.UrlModeType.Classic) Then + strURL = strURL & "&articleType=ArticleView" + strURL = strURL & "&articleId=" & objArticle.ArticleID + Else + strURL = strURL & "&" & articleSettings.ShortenedID & "=" & objArticle.ArticleID + End If + End If + + If (articleSettings.AlwaysShowPageID) Then + If (pageID <> Null.NullInteger) Then + strURL = strURL & "&PageID=" & pageID.ToString() + End If + End If + + If (includeCategory) Then + If (HttpContext.Current.Request("CategoryID") <> "") Then + strURL = strURL & "&categoryId=" & HttpContext.Current.Request("CategoryID") + End If + End If + + If (articleSettings.AuthorUserIDFilter) Then + If (articleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUserIDParam) <> "") Then + strURL = strURL & "&" & articleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUserIDParam) + End If + End If + End If + + If (articleSettings.AuthorUsernameFilter) Then + If (articleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUsernameParam) <> "") Then + strURL = strURL & "&" & articleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUsernameParam) + End If + End If + End If + + Dim title As String = FormatTitle(objArticle.Title, articleSettings) + + Dim link As String = FriendlyUrl(objTab, strURL, title, settings) + + If (link.ToLower().StartsWith("http://") Or link.ToLower().StartsWith("https://")) Then + Return link + Else + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & link) + Else + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & link) + End If + End If + Else + If (articleSettings.LaunchLinks) Then + Dim parameters As New List(Of String) + parameters.Add("mid=" & objArticle.ModuleID.ToString) + parameters.Add("ctl=ArticleView") + parameters.Add("articleId=" & objArticle.ArticleID) + + If (articleSettings.AlwaysShowPageID) Then + If (pageID <> Null.NullInteger) Then + parameters.Add("PageID=" & pageID.ToString()) + End If + End If + + If (articleSettings.AuthorUserIDFilter) Then + If (articleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUserIDParam) <> "") Then + parameters.Add(articleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUserIDParam)) + End If + End If + End If + + If (articleSettings.AuthorUsernameFilter) Then + If (articleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUsernameParam) <> "") Then + parameters.Add(articleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUsernameParam)) + End If + End If + End If + + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & NavigateURL(objTab.TabID, Null.NullString, parameters.ToArray).Replace("&", "&")) + Else + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & NavigateURL(objTab.TabID, Null.NullString, parameters.ToArray).Replace("&", "&")) + End If + Else + Dim parameters As New List(Of String) + + If (articleSettings.UrlModeType = Components.Types.UrlModeType.Classic) Then + parameters.Add("articleType=ArticleView") + parameters.Add("articleId=" & objArticle.ArticleID) + Else + parameters.Add(articleSettings.ShortenedID & "=" & objArticle.ArticleID) + End If + + If (articleSettings.AlwaysShowPageID) Then + If (pageID <> Null.NullInteger) Then + parameters.Add("PageID=" & pageID.ToString()) + End If + End If + + If (articleSettings.AuthorUserIDFilter) Then + If (articleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUserIDParam) <> "") Then + parameters.Add(articleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUserIDParam)) + End If + End If + End If + + If (articleSettings.AuthorUsernameFilter) Then + If (articleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUsernameParam) <> "") Then + parameters.Add(articleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUsernameParam)) + End If + End If + End If + + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & NavigateURL(objTab.TabID, Null.NullString, parameters.ToArray)) + Else + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & NavigateURL(objTab.TabID, Null.NullString, parameters.ToArray)) + End If + End If + + End If + + End Function + + Public Shared Function GetArticleLink(ByVal objArticle As ArticleInfo, ByVal objTab As DotNetNuke.Entities.Tabs.TabInfo, ByVal articleSettings As ArticleSettings, ByVal includeCategory As Boolean, ByVal ParamArray additionalParameters As String()) As String + Return GetArticleLink(objArticle, objTab, articleSettings, includeCategory, Null.NullInteger, additionalParameters) + End Function + + Public Shared Function GetArticleLink(ByVal objArticle As ArticleInfo, ByVal objTab As DotNetNuke.Entities.Tabs.TabInfo, ByVal articleSettings As ArticleSettings, ByVal includeCategory As Boolean, ByVal pageID As Integer, ByVal ParamArray additionalParameters As String()) As String + + If HostController.Instance.GetString("UseFriendlyUrls") = "Y" Then + + Dim strURL As String = ApplicationURL(objTab.TabID) + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings + + If (articleSettings.LaunchLinks) Then + strURL = strURL & "&ctl=ArticleView" + strURL = strURL & "&mid=" & objArticle.ModuleID.ToString + strURL = strURL & "&articleId=" & objArticle.ArticleID + + Else + If (articleSettings.UrlModeType = Components.Types.UrlModeType.Classic) Then + strURL = strURL & "&articleType=ArticleView" + strURL = strURL & "&articleId=" & objArticle.ArticleID + Else + strURL = strURL & "&" & articleSettings.ShortenedID & "=" & objArticle.ArticleID + End If + End If + + If (articleSettings.AlwaysShowPageID) Then + If (pageID <> Null.NullInteger) Then + + Dim found As Boolean = False + For Each param As String In additionalParameters + If (param.ToLower().StartsWith("pageid")) Then + found = True + End If + Next + + If (found = False) Then + strURL = strURL & "&PageID=" & pageID.ToString() + End If + + End If + End If + + For Each param As String In additionalParameters + strURL = strURL & "&" & param + Next + + If (articleSettings.AuthorUserIDFilter) Then + If (articleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUserIDParam) <> "") Then + strURL = strURL & "&" & articleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUserIDParam) + End If + End If + End If + + If (articleSettings.AuthorUsernameFilter) Then + If (articleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUsernameParam) <> "") Then + strURL = strURL & "&" & articleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUsernameParam) + End If + End If + End If + + Return FriendlyUrl(objTab, strURL, FormatTitle(objArticle.Title, articleSettings), settings) + + + Else + + If (articleSettings.LaunchLinks) Then + Dim parameters As New List(Of String) + Dim pageFound As Boolean = False + For i As Integer = 0 To additionalParameters.Length - 1 + parameters.Add(additionalParameters(i)) + If (additionalParameters(i).ToLower().StartsWith("pageid=")) Then + pageFound = True + End If + Next + parameters.Add("mid=" & objArticle.ModuleID.ToString) + parameters.Add("ctl=ArticleView") + parameters.Add("articleId=" & objArticle.ArticleID) + + If (articleSettings.AlwaysShowPageID) Then + If (pageID <> Null.NullInteger) Then + If (pageFound = False) Then + parameters.Add("PageID=" & pageID.ToString()) + End If + End If + End If + + If (articleSettings.AuthorUserIDFilter) Then + If (articleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUserIDParam) <> "") Then + parameters.Add(articleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUserIDParam)) + End If + End If + End If + + If (articleSettings.AuthorUsernameFilter) Then + If (articleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUsernameParam) <> "") Then + parameters.Add(articleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUsernameParam)) + End If + End If + End If + + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & NavigateURL(objTab.TabID, Null.NullString, parameters.ToArray)) + Else + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & NavigateURL(objTab.TabID, Null.NullString, parameters.ToArray)) + End If + Else + Dim parameters As New List(Of String) + Dim pageFound As Boolean = False + For i As Integer = 0 To additionalParameters.Length - 1 + parameters.Add(additionalParameters(i)) + If (additionalParameters(i).ToLower().StartsWith("pageid=")) Then + pageFound = True + End If + Next + + If (articleSettings.UrlModeType = Components.Types.UrlModeType.Classic) Then + parameters.Add("articleType=ArticleView") + parameters.Add("articleId=" & objArticle.ArticleID) + Else + parameters.Add(articleSettings.ShortenedID & "=" & objArticle.ArticleID) + End If + + If (articleSettings.AlwaysShowPageID) Then + If (pageID <> Null.NullInteger) Then + If (pageFound = False) Then + parameters.Add("PageID=" & pageID.ToString()) + End If + End If + End If + + If (articleSettings.AuthorUserIDFilter) Then + If (articleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUserIDParam) <> "") Then + parameters.Add(articleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUserIDParam)) + End If + End If + End If + + If (articleSettings.AuthorUsernameFilter) Then + If (articleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUsernameParam) <> "") Then + parameters.Add(articleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUsernameParam)) + End If + End If + End If + + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & NavigateURL(objTab.TabID, Null.NullString, parameters.ToArray)) + Else + Return AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & NavigateURL(objTab.TabID, Null.NullString, parameters.ToArray)) + End If + End If + + End If + + End Function + + Public Shared Function GetArticleModules(ByVal portalID As Integer) As List(Of ModuleInfo) + + Dim objModulesFound As New List(Of ModuleInfo) + + Dim objDesktopModuleController As New DesktopModuleController + Dim objDesktopModuleInfo As DesktopModuleInfo = objDesktopModuleController.GetDesktopModuleByModuleName("DnnForge - NewsArticles") + + If Not (objDesktopModuleInfo Is Nothing) Then + + Dim objTabController As New TabController() + Dim objTabs As ArrayList = objTabController.GetTabs(portalID) + For Each objTab As DotNetNuke.Entities.Tabs.TabInfo In objTabs + If Not (objTab Is Nothing) Then + If (objTab.IsDeleted = False) Then + Dim objModules As New ModuleController + For Each pair As KeyValuePair(Of Integer, ModuleInfo) In objModules.GetTabModules(objTab.TabID) + Dim objModule As ModuleInfo = pair.Value + If (objModule.IsDeleted = False) Then + If (objModule.DesktopModuleID = objDesktopModuleInfo.DesktopModuleID) Then + If objModule.IsDeleted = False Then + Dim strPath As String = objTab.TabName + Dim objTabSelected As TabInfo = objTab + While objTabSelected.ParentId <> Null.NullInteger + objTabSelected = objTabController.GetTab(objTabSelected.ParentId, objTab.PortalID, False) + If (objTabSelected Is Nothing) Then + Exit While + End If + strPath = objTabSelected.TabName & " -> " & strPath + End While + + objModulesFound.Add(objModule) + End If + End If + End If + Next + End If + End If + Next + + End If + + Return objModulesFound + + End Function + + Public Shared Function GetAuthorLink(ByVal tabID As Integer, ByVal moduleID As Integer, ByVal authorID As Integer, ByVal username As String, ByVal launchLinks As Boolean, ByVal articleSettings As ArticleSettings) As String + + Dim objTab As TabInfo = PortalController.GetCurrentPortalSettings.ActiveTab + If (tabID <> PortalController.GetCurrentPortalSettings.ActiveTab.TabID) Then + Dim objTabController As New TabController + objTab = objTabController.GetTab(tabID, PortalController.GetCurrentPortalSettings.PortalId, False) + End If + Return GetAuthorLink(tabID, moduleID, authorID, username, launchLinks, objTab, articleSettings) + + End Function + + Public Shared Function GetAuthorLink(ByVal tabID As Integer, ByVal moduleID As Integer, ByVal authorID As Integer, ByVal username As String, ByVal launchLinks As Boolean, ByVal targetTab As TabInfo, ByVal articleSettings As ArticleSettings) As String + + If Host.UseFriendlyUrls Then + + Dim strURL As String = ApplicationURL(tabID) + + If (launchLinks) Then + strURL = strURL & "&ctl=AuthorView" + strURL = strURL & "&mid=" & moduleID.ToString + Else + strURL = strURL & "&articleType=AuthorView" + End If + strURL = strURL & "&authorID=" & authorID.ToString() + + ' TODO: Remove at a later date when minimum version raised. + If Localization.GetEnabledLocales.Count > 1 AndAlso LocalizationUtil.UseLanguageInUrl Then + strURL += "&language=" & Thread.CurrentThread.CurrentCulture.Name + End If + + If (articleSettings.AuthorUserIDFilter) Then + If (articleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUserIDParam) <> "") Then + strURL = strURL & "&" & articleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUserIDParam) + End If + End If + End If + + If (articleSettings.AuthorUsernameFilter) Then + If (articleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUsernameParam) <> "") Then + strURL = strURL & "&" & articleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUsernameParam) + End If + End If + End If + + Return FriendlyUrl(targetTab, strURL, Common.FormatTitle("", articleSettings), PortalController.GetCurrentPortalSettings) + + Else + + Return Common.GetModuleLink(tabID, moduleID, "AuthorView", articleSettings, "AuthorID=" & authorID.ToString()) + + End If + + End Function + + Public Shared Function GetCategoryLink(ByVal tabID As Integer, ByVal moduleID As Integer, ByVal categoryID As String, ByVal title As String, ByVal launchLinks As Boolean, ByVal articleSettings As ArticleSettings) As String + + Dim objTab As TabInfo = PortalController.GetCurrentPortalSettings.ActiveTab + If (tabID <> PortalController.GetCurrentPortalSettings.ActiveTab.TabID) Then + Dim objTabController As New TabController + objTab = objTabController.GetTab(tabID, PortalController.GetCurrentPortalSettings.PortalId, False) + End If + Return GetCategoryLink(tabID, moduleID, categoryID, title, launchLinks, objTab, articleSettings) + + End Function + + Public Shared Function GetCategoryLink(ByVal tabID As Integer, ByVal moduleID As Integer, ByVal categoryID As String, ByVal title As String, ByVal launchLinks As Boolean, ByVal targetTab As TabInfo, ByVal articleSettings As ArticleSettings) As String + + If DotNetNuke.Entities.Host.HostSettings.GetHostSetting("UseFriendlyUrls") = "Y" Then + + Dim strURL As String = ApplicationURL(tabID) + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings + + If (launchLinks) Then + strURL = strURL & "&ctl=CategoryView" + strURL = strURL & "&mid=" & moduleID.ToString + Else + strURL = strURL & "&articleType=CategoryView" + End If + strURL = strURL & "&categoryId=" & categoryID + + ' TODO: Remove at a later date when minimum version raised. + If Localization.GetEnabledLocales.Count > 1 AndAlso LocalizationUtil.UseLanguageInUrl Then + strURL += "&language=" & Thread.CurrentThread.CurrentCulture.Name + End If + + If (articleSettings.AuthorUserIDFilter) Then + If (articleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUserIDParam) <> "") Then + strURL = strURL & "&" & articleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUserIDParam) + End If + End If + End If + + If (articleSettings.AuthorUsernameFilter) Then + If (articleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUsernameParam) <> "") Then + strURL = strURL & "&" & articleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUsernameParam) + End If + End If + End If + + Return FriendlyUrl(targetTab, strURL, Common.FormatTitle(title, articleSettings), settings) + + Else + + Return Common.GetModuleLink(tabID, moduleID, "CategoryView", articleSettings, "categoryId=" & categoryID) + + End If + + End Function + + Public Shared Function GetModuleLink(ByVal tabID As Integer, ByVal moduleID As Integer, ByVal ctl As String, ByVal articleSettings As ArticleSettings, ByVal ParamArray additionalParameters As String()) As String + + Dim parameters As New List(Of String) + For Each item As String In additionalParameters + parameters.Add(item) + Next + + If (articleSettings.AuthorUserIDFilter) Then + If (articleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUserIDParam) <> "") Then + parameters.Add(articleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUserIDParam)) + End If + End If + End If + + If (articleSettings.AuthorUsernameFilter) Then + If (articleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(articleSettings.AuthorUsernameParam) <> "") Then + parameters.Add(articleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(articleSettings.AuthorUsernameParam)) + End If + End If + End If + + Dim link As String = "" + + If (ctl <> "") Then + + If (articleSettings.LaunchLinks) Then + parameters.Insert(0, "mid=" & moduleID.ToString()) + If (ctl.ToLower() = "submitnews") Then + link = NavigateURL(tabID, "edit", parameters.ToArray()) + Else + link = NavigateURL(tabID, ctl, parameters.ToArray()) + End If + Else + parameters.Insert(0, "articleType=" & ctl) + link = NavigateURL(tabID, Null.NullString, parameters.ToArray()) + End If + + Else + + link = NavigateURL(tabID, Null.NullString, parameters.ToArray()) + + End If + + If Not (link.ToLower().StartsWith("http://") Or link.ToLower().StartsWith("https://")) Then + + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + link = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & link) + Else + link = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & link) + End If + + End If + + Return link + + End Function + + Public Shared Sub NotifyAuthor(ByVal objArticle As ArticleInfo, ByVal settings As Hashtable, ByVal moduleID As Integer, ByVal objTab As DotNetNuke.Entities.Tabs.TabInfo, ByVal portalID As Integer, ByVal articleSettings As ArticleSettings) + + If (settings.Contains(ArticleConstants.NOTIFY_APPROVAL_SETTING)) Then + If (Convert.ToBoolean(settings(ArticleConstants.NOTIFY_APPROVAL_SETTING))) Then + + Dim objUserController As New UserController + Dim objUser As UserInfo = objUserController.GetUser(portalID, objArticle.AuthorID) + + Dim objEmailTemplateController As New EmailTemplateController + If Not (objUser Is Nothing) Then + objEmailTemplateController.SendFormattedEmail(moduleID, Common.GetArticleLink(objArticle, objTab, articleSettings, False), objArticle, EmailTemplateType.ArticleApproved, objUser.Email, articleSettings) + End If + + End If + End If + + End Sub + + Public Shared Function HtmlEncode(ByVal text As String) As String + + Return System.Web.HttpUtility.HtmlEncode(text) + + End Function + + Public Shared Function HtmlDecode(ByVal text As String) As String + + Return System.Web.HttpUtility.HtmlDecode(text) + + End Function + + Public Shared Function ProcessPostTokens(ByVal content As String, ByVal objTab As TabInfo, ByVal objArticleSettings As ArticleSettings) As String + + If (objArticleSettings.ProcessPostTokens = False) Then + Return content + End If + + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + + Dim layoutArray As String() = content.Split(delimiter) + Dim formattedContent As String = "" + + For iPtr As Integer = 0 To layoutArray.Length - 1 Step 2 + + formattedContent += layoutArray(iPtr).ToString() + + If iPtr < layoutArray.Length - 1 Then + Select Case layoutArray(iPtr + 1) + Case Else + If (layoutArray(iPtr + 1).ToUpper().StartsWith("ARTICLELINK:")) Then + If (IsNumeric(layoutArray(iPtr + 1).Substring(12, layoutArray(iPtr + 1).Length - 12))) Then + Dim articleID As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(12, layoutArray(iPtr + 1).Length - 12)) + + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = objArticleController.GetArticle(articleID) + + If (objArticle IsNot Nothing) Then + Dim link As String = Common.GetArticleLink(objArticle, objTab, objArticleSettings, False) + formattedContent += "" & objArticle.Title & "" + End If + End If + Exit Select + End If + + formattedContent += "[" & layoutArray(iPtr + 1) & "]" + End Select + End If + + Next + + Return formattedContent + + End Function + + Public Shared Function StripTags(ByVal HTML As String) As String + If (HTML Is Nothing OrElse HTML.Trim() = "") Then + Return "" + End If + Dim pattern As String = "<(.|\n)*?>" + Return Regex.Replace(HTML, pattern, String.Empty) + End Function + +#End Region + + End Class + +End Namespace diff --git a/Components/Common/ArticleConstants.vb b/Components/Common/ArticleConstants.vb new file mode 100755 index 0000000..bfb22d3 --- /dev/null +++ b/Components/Common/ArticleConstants.vb @@ -0,0 +1,375 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Class ArticleConstants + +#Region " Constants " + + 'Token Settings + Public Const DEFAULT_TEMPLATE = "Standard" + + ' Basic Settings + Public Const EXPAND_SUMMARY_SETTING As String = "ExpandSummary" + + Public Const ENABLE_RATINGS_AUTHENTICATED_SETTING As String = "EnableRatings" + Public Const ENABLE_RATINGS_ANONYMOUS_SETTING As String = "EnableAnonymousRatings" + + Public Const JOURNAL_INTEGRATION_SETTING As String = "JournalIntegration" + Public Const JOURNAL_INTEGRATION_GROUPS_SETTING As String = "JournalIntegrationGroups" + + Public Const ACTIVE_SOCIAL_SETTING As String = "ActiveSocialFeed" + Public Const ACTIVE_SOCIAL_SUBMIT_SETTING As String = "ActiveSocialFeedSubmit" + Public Const ACTIVE_SOCIAL_COMMENT_SETTING As String = "ActiveSocialFeedComment" + Public Const ACTIVE_SOCIAL_RATE_SETTING As String = "ActiveSocialFeedRate" + Public Const AUTHOR_SELECT_TYPE As String = "AuthorSelectType" + Public Const ENABLE_CORE_SEARCH_SETTING As String = "EnableCoreSearch" + Public Const ENABLE_SYNDICATION_SETTING As String = "EnableSyndication" + Public Const ENABLE_SYNDICATION_ENCLOSURES_SETTING As String = "EnableSyndicationEnclosures" + Public Const ENABLE_SYNDICATION_HTML_SETTING As String = "EnableSyndicationHtml" + Public Const ENABLE_NOTIFICATION_PING_SETTING As String = "NotificationPing" + Public Const ENABLE_AUTO_TRACKBACK_SETTING As String = "AutoTrackback" + Public Const ENABLE_INCOMING_TRACKBACK_SETTING As String = "IncomingTrackback" + Public Const PAGE_SIZE_SETTING As String = "Number" + Public Const LAUNCH_LINKS As String = "LaunchLinks" + Public Const BUBBLE_FEATURED_ARTICLES As String = "BubbleFeaturedArticles" + Public Const REQUIRE_CATEGORY As String = "RequireCategory" + Public Const DISPLAY_MODE As String = "DisplayMode" + Public Const PROCESS_POST_TOKENS As String = "ProcessPostTokens" + Public Const RELATED_MODE As String = "RelatedMode" + Public Const TEMPLATE_SETTING As String = "Template" + Public Const ENABLE_SEO_TITLE_SETTING As String = "EnableSEOTitle" + Public Const SEO_TITLE_SETTING As String = "SEOTitle" + Public Const TITLE_REPLACEMENT_TYPE As String = "TitleReplacementType" + Public Const SMART_THINKER_STORY_FEED_SETTING As String = "EnableSmartThinkerStoryFeed" + Public Const TEXT_EDITOR_WIDTH As String = "TextEditorWidth" + Public Const TEXT_EDITOR_HEIGHT As String = "TextEditorHeight" + Public Const TEXT_EDITOR_SUMMARY_MODE As String = "TextEditorSummaryMode" + Public Const TEXT_EDITOR_SUMMARY_WIDTH As String = "TextEditorSummaryWidth" + Public Const TEXT_EDITOR_SUMMARY_HEIGHT As String = "TextEditorSummaryHeight" + Public Const SERVER_TIMEZONE As String = "ServerTimeZone" + Public Const SORT_BY As String = "SortBy" + Public Const SORT_DIRECTION As String = "SortDirection" + Public Const SYNDICATION_LINK_TYPE As String = "SyndicationLinkType" + Public Const SYNDICATION_SUMMARY_LENGTH As String = "SyndicationSummaryLength" + Public Const SYNDICATION_MAX_COUNT As String = "SyndicationMaxCount" + Public Const SYNDICATION_ENCLOSURE_TYPE As String = "SyndicationEnclosureType" + Public Const SYNDICATION_IMAGE_PATH As String = "SyndicationImagePath" + Public Const MENU_POSITION_TYPE As String = "MenuPositionType" + + ' Image Settings + Public Const INCLUDE_JQUERY_SETTING As String = "IncludeJQuery" + Public Const IMAGE_JQUERY_PATH As String = "JQueryPath" + Public Const ENABLE_EXTERNAL_IMAGES_SETTING As String = "EnableImagesExternal" + Public Const ENABLE_UPLOAD_IMAGES_SETTING As String = "EnableImagesUpload" + Public Const ENABLE_PORTAL_IMAGES_SETTING As String = "EnableImages" + Public Const DEFAULT_IMAGES_FOLDER_SETTING As String = "DefaultImagesFolder" + Public Const DEFAULT_FILES_FOLDER_SETTING As String = "DefaultFilesFolder" + Public Const IMAGE_RESIZE_SETTING As String = "ResizeImages" + Public Const IMAGE_THUMBNAIL_SETTING As String = "ImageThumbnailType" + Public Const IMAGE_MAX_WIDTH_SETTING As String = "ImageMaxWidth" + Public Const IMAGE_MAX_HEIGHT_SETTING As String = "ImageMaxHeight" + + Public Const IMAGE_WATERMARK_ENABLED_SETTING As String = "ImageWatermarkEnabled" + Public Const IMAGE_WATERMARK_ENABLED_SETTING_DEFAULT As Boolean = False + Public Const IMAGE_WATERMARK_TEXT_SETTING As String = "ImageWatermarkText" + Public Const IMAGE_WATERMARK_TEXT_SETTING_DEFAULT As String = "" + Public Const IMAGE_WATERMARK_IMAGE_SETTING As String = "ImageWatermarkImage" + Public Const IMAGE_WATERMARK_IMAGE_SETTING_DEFAULT As String = "" + Public Const IMAGE_WATERMARK_IMAGE_POSITION_SETTING As String = "ImageWatermarkImagePosition" + Public Const IMAGE_WATERMARK_IMAGE_POSITION_SETTING_DEFAULT As WatermarkPosition = WatermarkPosition.BottomRight + + Public Const DEFAULT_IMAGE_RESIZE As Boolean = True + Public Const DEFAULT_IMAGE_THUMBNAIL As ThumbnailType = ThumbnailType.Proportion + Public Const DEFAULT_IMAGE_MAX_WIDTH As Integer = 600 + Public Const DEFAULT_IMAGE_MAX_HEIGHT As Integer = 480 + Public Const DEFAULT_THUMBNAIL_HEIGHT As Integer = 100 + Public Const DEFAULT_THUMBNAIL_WIDTH As Integer = 100 + + ' Category Settings + Public Const ARCHIVE_CURRENT_ARTICLES_SETTING As String = "ArchiveCurrentArticles" + Public Const ARCHIVE_CURRENT_ARTICLES_SETTING_DEFAULT As Boolean = True + Public Const ARCHIVE_CATEGORIES_SETTING As String = "ArchiveCategories" + Public Const ARCHIVE_CATEGORIES_SETTING_DEFAULT As Boolean = True + Public Const ARCHIVE_AUTHOR_SETTING As String = "ArchiveAuthor" + Public Const ARCHIVE_AUTHOR_SETTING_DEFAULT As Boolean = True + Public Const ARCHIVE_MONTH_SETTING As String = "ArchiveMonth" + Public Const ARCHIVE_MONTH_SETTING_DEFAULT As Boolean = True + + ' Category Settings + Public Const DEFAULT_CATEGORIES_SETTING As String = "DefaultCategories" + Public Const CATEGORY_SELECTION_HEIGHT_SETTING As String = "CategorySelectionHeight" + Public Const CATEGORY_SELECTION_HEIGHT_DEFAULT As Integer = 150 + Public Const CATEGORY_BREADCRUMB_SETTING As String = "CategoryBreadcrumb" + Public Const CATEGORY_BREADCRUMB_SETTING_DEFAULT As Boolean = True + Public Const CATEGORY_NAME_SETTING As String = "CategoryName" + Public Const CATEGORY_NAME_SETTING_DEFAULT As Boolean = True + Public Const CATEGORY_FILTER_SUBMIT_SETTING As String = "CategoryFilterSubmit" + Public Const CATEGORY_FILTER_SUBMIT_SETTING_DEFAULT As Boolean = False + Public Const CATEGORY_SORT_SETTING As String = "CategorySortType" + Public Const CATEGORY_SORT_SETTING_DEFAULT As CategorySortType = CategorySortType.SortOrder + + ' Category Security Settings + Public Const PERMISSION_CATEGORY_VIEW_SETTING As String = "PermissionCategoryView" + Public Const PERMISSION_CATEGORY_SUBMIT_SETTING As String = "PermissionCategorySubmit" + + ' Comment Settings + Public Const ENABLE_COMMENTS_SETTING As String = "EnableComments" + Public Const ENABLE_ANONYMOUS_COMMENTS_SETTING As String = "EnableAnonymousComments" + Public Const ENABLE_COMMENT_MODERATION_SETTING As String = "EnableCommentModeration" + Public Const COMMENT_HIDE_WEBSITE_SETTING As String = "CommentHideWebsite" + Public Const COMMENT_REQUIRE_NAME_SETTING As String = "CommentRequireName" + Public Const COMMENT_REQUIRE_EMAIL_SETTING As String = "CommentRequireEmail" + Public Const USE_CAPTCHA_SETTING As String = "UseCaptcha" + Public Const NOTIFY_DEFAULT_SETTING As String = "NotifyDefault" + Public Const COMMENT_SORT_DIRECTION_SETTING As String = "CommentSortDirection" + Public Const COMMENT_AKISMET_SETTING As String = "CommentAkismet" + + ' Content Sharing Settings + Public Const CONTENT_SHARING_SETTING As String = "ContentSharingPortals" + + ' Filter Settings + Public Const MAX_ARTICLES_SETTING As String = "MaxArticles" + Public Const MAX_AGE_SETTING As String = "MaxArticlesAge" + Public Const CATEGORIES_SETTING As String = "Categories" + Public Const CATEGORIES_FILTER_SINGLE_SETTING As String = "CategoriesFilterSingle" + Public Const SHOW_PENDING_SETTING As String = "ShowPending" + Public Const SHOW_FEATURED_ONLY_SETTING As String = "ShowFeaturedOnly" + Public Const SHOW_NOT_FEATURED_ONLY_SETTING As String = "ShowNotFeaturedOnly" + Public Const SHOW_SECURED_ONLY_SETTING As String = "ShowSecuredOnly" + Public Const SHOW_NOT_SECURED_ONLY_SETTING As String = "ShowNotSecuredOnly" + Public Const AUTHOR_SETTING As String = "Author" + Public Const AUTHOR_DEFAULT_SETTING As String = "AuthorDefault" + Public Const MATCH_OPERATOR_SETTING As String = "MatchOperator" + + Public Const AUTHOR_USERID_FILTER_SETTING As String = "AuthorUserIDFilter" + Public Const AUTHOR_USERID_PARAM_SETTING As String = "AuthorUserIDParam" + Public Const AUTHOR_USERNAME_FILTER_SETTING As String = "AuthorUsernameFilter" + Public Const AUTHOR_USERNAME_PARAM_SETTING As String = "AuthorUsernameParam" + Public Const AUTHOR_LOGGED_IN_USER_FILTER_SETTING As String = "AuthorLoggedInUserFilter" + + ' Security Settings + Public Const PERMISSION_ROLE_GROUP_ID As String = "RoleGroupIDFilter" + Public Const PERMISSION_SECURE_SETTING As String = "SecureRoles" + Public Const PERMISSION_SECURE_URL_SETTING As String = "SecureUrl" + Public Const PERMISSION_AUTO_SECURE_SETTING As String = "AutoSecureRoles" + Public Const PERMISSION_SUBMISSION_SETTING As String = "SubmissionRoles" + Public Const PERMISSION_APPROVAL_SETTING As String = "ApprovalRoles" + Public Const PERMISSION_AUTO_APPROVAL_SETTING As String = "AutoApprovalRoles" + Public Const PERMISSION_AUTO_APPROVAL_COMMENT_SETTING As String = "AutoApprovalCommentRoles" + Public Const PERMISSION_FEATURE_SETTING As String = "FeatureRoles" + Public Const PERMISSION_AUTO_FEATURE_SETTING As String = "AutoFeatureRoles" + + ' Security Form Settings + Public Const PERMISSION_CATEGORIES_SETTING As String = "PermissionCategoriesRoles" + Public Const PERMISSION_EXCERPT_SETTING As String = "PermissionExcerptRoles" + Public Const PERMISSION_IMAGE_SETTING As String = "PermissionImageRoles" + Public Const PERMISSION_FILE_SETTING As String = "PermissionFileRoles" + Public Const PERMISSION_LINK_SETTING As String = "PermissionLinkRoles" + Public Const PERMISSION_PUBLISH_SETTING As String = "PermissionPublishRoles" + Public Const PERMISSION_EXPIRY_SETTING As String = "PermissionExpiryRoles" + Public Const PERMISSION_META_SETTING As String = "PermissionMetaRoles" + Public Const PERMISSION_CUSTOM_SETTING As String = "PermissionCustomRoles" + + ' Admin Settings + Public Const PERMISSION_SITE_TEMPLATES_SETTING As String = "PermissionSiteTemplates" + + ' Notification Settings + Public Const NOTIFY_SUBMISSION_SETTING As String = "NotifySubmission" + Public Const NOTIFY_SUBMISSION_SETTING_EMAIL As String = "NotifySubmissionEmail" + Public Const NOTIFY_APPROVAL_SETTING As String = "NotifyApproval" + Public Const NOTIFY_COMMENT_SETTING As String = "NotifyComment" + Public Const NOTIFY_COMMENT_SETTING_EMAIL As String = "NotifyCommentEmail" + Public Const NOTIFY_COMMENT_APPROVAL_SETTING As String = "NotifyCommentApproval" + Public Const NOTIFY_COMMENT_APPROVAL_EMAIL_SETTING As String = "NotifyCommentApprovalEmail" + + ' SEO Settings + Public Const SEO_ALWAYS_SHOW_PAGEID_SETTING As String = "AlwaysShowPageID" + Public Const SEO_URL_MODE_SETTING As String = "SEOUrlMode" + Public Const SEO_SHORTEN_ID_SETTING As String = "SEOShorternID" + Public Const SEO_USE_CANONICAL_LINK_SETTING As String = "SEOUseCanonicalLink" + Public Const SEO_EXPAND_META_INFORMATION_SETTING As String = "SEOExpandMetaInformation" + Public Const SEO_UNIQUE_PAGE_TITLES_SETTING As String = "SEOUniquePageTitles" + + ' SEO Settings + Public Const TWITTER_USERNAME As String = "NA-TwitterUsername" + Public Const TWITTER_BITLY_LOGIN As String = "NA-BitLyLogin" + Public Const TWITTER_BITLY_API_KEY As String = "NA-BitLyAPI" + + ' Latest Articles + Public Const LATEST_ARTICLES_TAB_ID As String = "LatestArticlesTabID" + Public Const LATEST_ARTICLES_MODULE_ID As String = "LatestArticlesModuleID" + Public Const LATEST_ARTICLES_CATEGORIES As String = "LatestArticlesCategories" + Public Const LATEST_ARTICLES_CATEGORIES_EXCLUDE As String = "LatestArticlesCategoriesExclude" + Public Const LATEST_ARTICLES_MATCH_OPERATOR As String = "LatestArticlesMatchOperator" + Public Const LATEST_ARTICLES_TAGS As String = "LatestArticlesTags" + Public Const LATEST_ARTICLES_TAGS_MATCH_OPERATOR As String = "LatestArticlesTagsMatchOperator" + Public Const LATEST_ARTICLES_IDS As String = "LatestArticlesIDS" + Public Const LATEST_ARTICLES_COUNT As String = "LatestArticlesCount" + Public Const LATEST_ARTICLES_START_POINT As String = "LatestArticlesStartPoint" + Public Const LATEST_ARTICLES_MAX_AGE As String = "LatestArticlesMaxAge" + Public Const LATEST_ARTICLES_START_DATE As String = "LatestArticlesStartDate" + Public Const LATEST_ARTICLES_SHOW_PENDING As String = "LatestArticlesShowPending" + Public Const LATEST_ARTICLES_SHOW_RELATED As String = "LatestArticlesShowRelated" + Public Const LATEST_ARTICLES_FEATURED_ONLY As String = "LatestArticlesFeaturedOnly" + Public Const LATEST_ARTICLES_NOT_FEATURED_ONLY As String = "LatestArticlesNotFeaturedOnly" + Public Const LATEST_ARTICLES_SECURED_ONLY As String = "LatestArticlesSecuredOnly" + Public Const LATEST_ARTICLES_NOT_SECURED_ONLY As String = "LatestArticlesNotSecuredOnly" + Public Const LATEST_ARTICLES_CUSTOM_FIELD_FILTER As String = "LatestArticlesCustomFieldFilter" + Public Const LATEST_ARTICLES_CUSTOM_FIELD_VALUE As String = "LatestArticlesCustomFieldValue" + Public Const LATEST_ARTICLES_LINK_FILTER As String = "LatestArticlesLinkFilter" + Public Const LATEST_ARTICLES_SORT_BY As String = "LatestArticlesSortBy" + Public Const LATEST_ARTICLES_SORT_DIRECTION As String = "LatestArticlesSortDirection" + Public Const LATEST_ARTICLES_ITEMS_PER_ROW As String = "ItemsPerRow" + Public Const LATEST_ARTICLES_ITEMS_PER_ROW_DEFAULT As Integer = 1 + Public Const LATEST_ARTICLES_AUTHOR As String = "LatestArticlesAuthor" + Public Const LATEST_ARTICLES_AUTHOR_DEFAULT As Integer = -1 + Public Const LATEST_ARTICLES_QUERY_STRING_FILTER As String = "LatestArticlesQueryStringFilter" + Public Const LATEST_ARTICLES_QUERY_STRING_FILTER_DEFAULT As Boolean = False + Public Const LATEST_ARTICLES_QUERY_STRING_PARAM As String = "LatestArticlesQueryStringParam" + Public Const LATEST_ARTICLES_QUERY_STRING_PARAM_DEFAULT As String = "ID" + Public Const LATEST_ARTICLES_USERNAME_FILTER As String = "LatestArticlesUsernameFilter" + Public Const LATEST_ARTICLES_USERNAME_FILTER_DEFAULT As Boolean = False + Public Const LATEST_ARTICLES_USERNAME_PARAM As String = "LatestArticlesUsernameParam" + Public Const LATEST_ARTICLES_USERNAME_PARAM_DEFAULT As String = "Username" + Public Const LATEST_ARTICLES_LOGGED_IN_USER_FILTER As String = "LatestArticlesLoggedInUserFilter" + Public Const LATEST_ARTICLES_LOGGED_IN_USER_FILTER_DEFAULT As Boolean = False + Public Const LATEST_ARTICLES_INCLUDE_STYLESHEET As String = "LatestArticlesIncludeStylesheet" + Public Const LATEST_ARTICLES_INCLUDE_STYLESHEET_DEFAULT As Boolean = False + + Public Const LATEST_ENABLE_PAGER As String = "LatestEnablePager" + Public Const LATEST_ENABLE_PAGER_DEFAULT As Boolean = False + Public Const LATEST_PAGE_SIZE As String = "LatestPageSize" + Public Const LATEST_PAGE_SIZE_DEFAULT As Integer = 10 + + Public Const LATEST_ARTICLES_LAYOUT_MODE As String = "LayoutMode" + Public Const LATEST_ARTICLES_LAYOUT_MODE_DEFAULT As LayoutModeType = LayoutModeType.Simple + + Public Const SETTING_HTML_HEADER As String = "HtmlHeader" + Public Const SETTING_HTML_BODY As String = "HtmlBody" + Public Const SETTING_HTML_FOOTER As String = "HtmlFooter" + + Public Const SETTING_HTML_HEADER_ADVANCED As String = "HtmlHeaderAdvanced" + Public Const SETTING_HTML_BODY_ADVANCED As String = "HtmlBodyAdvanced" + Public Const SETTING_HTML_FOOTER_ADVANCED As String = "HtmlFooterAdvanced" + + Public Const SETTING_HTML_NO_ARTICLES As String = "HtmlNoArticles" + + Public Const DEFAULT_HTML_HEADER As String = "" + Public Const DEFAULT_HTML_BODY As String = "" + Public Const DEFAULT_HTML_FOOTER As String = "
[EDIT][TITLE] by [AUTHORUSERNAME]
[SUMMARY]
" + Public Const DEFAULT_HTML_HEADER_ADVANCED As String = "" + Public Const DEFAULT_HTML_BODY_ADVANCED As String = "[EDIT][TITLE] by [AUTHORUSERNAME]
[SUMMARY]" + Public Const DEFAULT_HTML_FOOTER_ADVANCED As String = "" + Public Const DEFAULT_HTML_NO_ARTICLES As String = "No articles match criteria." + Public Const DEFAULT_SORT_BY As String = "StartDate" + Public Const DEFAULT_SORT_DIRECTION As String = "DESC" + + ' Latest Comments + Public Const LATEST_COMMENTS_TAB_ID As String = "LatestCommentsTabID" + Public Const LATEST_COMMENTS_MODULE_ID As String = "LatestCommentsModuleID" + Public Const LATEST_COMMENTS_COUNT As String = "LatestCommentsCount" + + Public Const LATEST_COMMENTS_HTML_HEADER As String = "HtmlHeaderLatestComments" + Public Const LATEST_COMMENTS_HTML_BODY As String = "HtmlBodyLatestComments" + Public Const LATEST_COMMENTS_HTML_FOOTER As String = "HtmlFooterLatestComments" + Public Const LATEST_COMMENTS_HTML_NO_COMMENTS As String = "HtmlNoCommentsLatestComments" + Public Const LATEST_COMMENTS_INCLUDE_STYLESHEET As String = "LatestCommentsIncludeStylesheet" + + Public Const DEFAULT_LATEST_COMMENTS_HTML_HEADER As String = "" + Public Const DEFAULT_LATEST_COMMENTS_HTML_BODY As String = "" + Public Const DEFAULT_LATEST_COMMENTS_HTML_FOOTER As String = "
[ARTICLETITLE]
[COMMENT:50] by [AUTHOR]
" + Public Const DEFAULT_LATEST_COMMENTS_HTML_NO_COMMENTS As String = "No comments match criteria." + Public Const DEFAULT_LATEST_COMMENTS_INCLUDE_STYLESHEET As Boolean = False + + ' News Archives + Public Const NEWS_ARCHIVES_TAB_ID As String = "NewsArchivesTabID" + Public Const NEWS_ARCHIVES_TAB_ID_DEFAULT As Integer = -1 + Public Const NEWS_ARCHIVES_MODULE_ID As String = "NewsArchivesModuleID" + Public Const NEWS_ARCHIVES_MODULE_ID_DEFAULT As Integer = -1 + Public Const NEWS_ARCHIVES_MODE As String = "NewsArchivesMode" + Public Const NEWS_ARCHIVES_MODE_DEFAULT As ArchiveModeType = ArchiveModeType.Date + Public Const NEWS_ARCHIVES_HIDE_ZERO_CATEGORIES As String = "NewsArchivesHideZeroCategories" + Public Const NEWS_ARCHIVES_PARENT_CATEGORY As String = "NewsArchivesParentCategory" + Public Const NEWS_ARCHIVES_PARENT_CATEGORY_DEFAULT As Integer = -1 + Public Const NEWS_ARCHIVES_MAX_DEPTH As String = "NewsArchivesMaxDepth" + Public Const NEWS_ARCHIVES_MAX_DEPTH_DEFAULT As Integer = -1 + Public Const NEWS_ARCHIVES_AUTHOR_SORT_BY As String = "NewsArchivesAuthorSortBy" + Public Const NEWS_ARCHIVES_AUTHOR_SORT_BY_DEFAULT As AuthorSortByType = AuthorSortByType.DisplayName + Public Const NEWS_ARCHIVES_HIDE_ZERO_CATEGORIES_DEFAULT As Boolean = False + Public Const NEWS_ARCHIVES_GROUP_BY As String = "GroupBy" + Public Const NEWS_ARCHIVES_GROUP_BY_DEFAULT As GroupByType = GroupByType.Month + Public Const NEWS_ARCHIVES_LAYOUT_MODE As String = "LayoutMode" + Public Const NEWS_ARCHIVES_LAYOUT_MODE_DEFAULT As LayoutModeType = LayoutModeType.Simple + Public Const NEWS_ARCHIVES_ITEMS_PER_ROW As String = "ItemsPerRow" + Public Const NEWS_ARCHIVES_ITEMS_PER_ROW_DEFAULT As Integer = 1 + + Public Const NEWS_ARCHIVES_SETTING_HTML_HEADER As String = "NewsArchivesHtmlHeader" + Public Const NEWS_ARCHIVES_SETTING_HTML_BODY As String = "NewsArchivesHtmlBody" + Public Const NEWS_ARCHIVES_SETTING_HTML_FOOTER As String = "NewsArchivesHtmlFooter" + + Public Const NEWS_ARCHIVES_SETTING_HTML_HEADER_ADVANCED As String = "NewsArchivesHtmlHeaderAdvanced" + Public Const NEWS_ARCHIVES_SETTING_HTML_BODY_ADVANCED As String = "NewsArchivesHtmlBodyAdvanced" + Public Const NEWS_ARCHIVES_SETTING_HTML_FOOTER_ADVANCED As String = "NewsArchivesHtmlFooterAdvanced" + + Public Const NEWS_ARCHIVES_SETTING_CATEGORY_HTML_HEADER As String = "NewsArchivesCategoryHtmlHeader" + Public Const NEWS_ARCHIVES_SETTING_CATEGORY_HTML_BODY As String = "NewsArchivesCategoryHtmlBody" + Public Const NEWS_ARCHIVES_SETTING_CATEGORY_HTML_FOOTER As String = "NewsArchivesCategoryHtmlFooter" + + Public Const NEWS_ARCHIVES_SETTING_CATEGORY_HTML_HEADER_ADVANCED As String = "NewsArchivesCategoryHtmlHeaderAdvanced" + Public Const NEWS_ARCHIVES_SETTING_CATEGORY_HTML_BODY_ADVANCED As String = "NewsArchivesCategoryHtmlBodyAdvanced" + Public Const NEWS_ARCHIVES_SETTING_CATEGORY_HTML_FOOTER_ADVANCED As String = "NewsArchivesCategoryHtmlFooterAdvanced" + + Public Const NEWS_ARCHIVES_SETTING_AUTHOR_HTML_HEADER As String = "NewsArchivesAuthorHtmlHeader" + Public Const NEWS_ARCHIVES_SETTING_AUTHOR_HTML_BODY As String = "NewsArchivesAuthorHtmlBody" + Public Const NEWS_ARCHIVES_SETTING_AUTHOR_HTML_FOOTER As String = "NewsArchivesAuthorHtmlFooter" + + Public Const NEWS_ARCHIVES_SETTING_AUTHOR_HTML_HEADER_ADVANCED As String = "NewsArchivesAuthorHtmlHeaderAdvanced" + Public Const NEWS_ARCHIVES_SETTING_AUTHOR_HTML_BODY_ADVANCED As String = "NewsArchivesAuthorHtmlBodyAdvanced" + Public Const NEWS_ARCHIVES_SETTING_AUTHOR_HTML_FOOTER_ADVANCED As String = "NewsArchivesAuthorHtmlFooterAdvanced" + + Public Const NEWS_ARCHIVES_DEFAULT_HTML_HEADER As String = "" + Public Const NEWS_ARCHIVES_DEFAULT_HTML_BODY As String = "" + Public Const NEWS_ARCHIVES_DEFAULT_HTML_FOOTER As String = "
[MONTH] [YEAR] ([COUNT])
" + + Public Const NEWS_ARCHIVES_DEFAULT_HTML_HEADER_ADVANCED As String = "" + Public Const NEWS_ARCHIVES_DEFAULT_HTML_BODY_ADVANCED As String = "[MONTH] [YEAR] ([COUNT])" + Public Const NEWS_ARCHIVES_DEFAULT_HTML_FOOTER_ADVANCED As String = "" + + Public Const NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_HEADER As String = "" + Public Const NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_BODY As String = "" + Public Const NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_FOOTER As String = "
[CATEGORY] ([COUNT])
" + + Public Const NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_HEADER_ADVANCED As String = "" + Public Const NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_BODY_ADVANCED As String = "[CATEGORY] ([COUNT])" + Public Const NEWS_ARCHIVES_DEFAULT_CATEGORY_HTML_FOOTER_ADVANCED As String = "" + + Public Const NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_HEADER As String = "" + Public Const NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_BODY As String = "" + Public Const NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_FOOTER As String = "
[AUTHORDISPLAYNAME] ([COUNT])
" + + Public Const NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_HEADER_ADVANCED As String = "" + Public Const NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_BODY_ADVANCED As String = "[AUTHORDISPLAYNAME] ([COUNT])" + Public Const NEWS_ARCHIVES_DEFAULT_AUTHOR_HTML_FOOTER_ADVANCED As String = "" + + ' News Search + + Public Const NEWS_SEARCH_TAB_ID As String = "NewsSearchTabID" + Public Const NEWS_SEARCH_MODULE_ID As String = "NewsSearchModuleID" + + ' Caching Constants + Public Const CACHE_CATEGORY_ARTICLE As String = "NewsCategory_Cache_" + Public Const CACHE_IMAGE_ARTICLE As String = "NewsImage_Cache_" + Public Const CACHE_CATEGORY_ARTICLE_NO_LINK As String = "NewsCategory_Cache_NoLink" + Public Const CACHE_CATEGORY_ARTICLE_LATEST As String = "NewsCategory_Cache_Latest_" + +#End Region + + End Class + +End Namespace + diff --git a/Components/Common/ArticleUtilities.vb b/Components/Common/ArticleUtilities.vb new file mode 100755 index 0000000..71e00d2 --- /dev/null +++ b/Components/Common/ArticleUtilities.vb @@ -0,0 +1,49 @@ +Namespace Ventrian.NewsArticles.Components.Common + + Public Class ArticleUtilities + + Public Shared Function MapPath(ByVal path As String) + + If (HttpContext.Current IsNot Nothing) Then + Return HttpContext.Current.Server.MapPath(path) + End If + + Return path + + End Function + + Public Shared Function ResolveUrl(ByVal path As String) + + Return SafeToAbsolute(path) + + End Function + + Public Shared Function ToAbsoluteUrl(relativeUrl As String) As String + If String.IsNullOrEmpty(relativeUrl) Then + Return relativeUrl + End If + + If HttpContext.Current Is Nothing Then + Return relativeUrl + End If + + Dim url = HttpContext.Current.Request.Url + Dim port = If(url.Port <> 80, (":" & url.Port), [String].Empty) + + If relativeUrl.StartsWith("~") Then + Return [String].Format("{0}://{1}{2}{3}", url.Scheme, url.Host, port, SafeToAbsolute(relativeUrl)) + Else + Return [String].Format("{0}://{1}{2}{3}", url.Scheme, url.Host, port, relativeUrl) + End If + End Function + + Private Shared Function SafeToAbsolute(path As String) As String + Dim madeSafe As String = path.Replace("?", "UNLIKELY_TOKEN") + Dim absolute As String = VirtualPathUtility.ToAbsolute(madeSafe) + Dim restored As String = absolute.Replace("UNLIKELY_TOKEN", "?") + Return restored + End Function + + End Class + +End Namespace diff --git a/Components/ContentSharingInfo.vb b/Components/ContentSharingInfo.vb new file mode 100755 index 0000000..bf55364 --- /dev/null +++ b/Components/ContentSharingInfo.vb @@ -0,0 +1,115 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Portals + +Namespace Ventrian.NewsArticles + + Public Class ContentSharingInfo + +#Region " Private Methods " + + ' local property declarations + Dim _linkedPortalID As Integer + Dim _portalTitle As String + Dim _linkedTabID As Integer + Dim _tabTitle As String + Dim _linkedModuleID As Integer + Dim _moduleTitle As String + +#End Region + +#Region " Public Properties " + + Public Property LinkedPortalID() As Integer + Get + Return _linkedPortalID + End Get + Set(ByVal Value As Integer) + _linkedPortalID = Value + End Set + End Property + + Public ReadOnly Property PortalTitle() As String + Get + If (_portalTitle = "") Then + Dim objPortalController As New PortalController() + Dim objPortal As PortalInfo = objPortalController.GetPortal(LinkedPortalID) + + If (objPortal IsNot Nothing) Then + _portalTitle = objPortal.PortalName + + Dim o As New PortalAliasController + Dim portalAliases As ArrayList = o.GetPortalAliasArrayByPortalID(_linkedPortalID) + + If (portalAliases.Count > 0) Then + _portalTitle = DotNetNuke.Common.AddHTTP(CType(portalAliases(0), PortalAliasInfo).HTTPAlias) + End If + End If + + End If + Return _portalTitle + End Get + End Property + + Public Property LinkedTabID() As Integer + Get + Return _linkedTabID + End Get + Set(ByVal Value As Integer) + _linkedTabID = Value + End Set + End Property + + Public Property TabTitle() As String + Get + Return _tabTitle + End Get + Set(ByVal Value As String) + _tabTitle = Value + End Set + End Property + + Public Property LinkedModuleID() As Integer + Get + Return _linkedModuleID + End Get + Set(ByVal Value As Integer) + _linkedModuleID = Value + End Set + End Property + + Public Property ModuleTitle() As String + Get + Return _moduleTitle + End Get + Set(ByVal Value As String) + _moduleTitle = Value + End Set + End Property + + Public ReadOnly Property Title() As String + Get + Return PortalTitle & " -> " & _tabTitle & " -> " & _moduleTitle + End Get + End Property + + Public ReadOnly Property LinkedID() As String + Get + Return _linkedPortalID & "-" & _linkedModuleID + End Get + End Property + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/Controllers/PageController.vb b/Components/Controllers/PageController.vb new file mode 100755 index 0000000..9e4ff43 --- /dev/null +++ b/Components/Controllers/PageController.vb @@ -0,0 +1,53 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class PageController + +#Region " Public Methods " + + Public Function GetPageList(ByVal articleId As Integer) As ArrayList + + Return CBO.FillCollection(DataProvider.Instance().GetPageList(articleId), GetType(PageInfo)) + + End Function + + Public Function GetPage(ByVal pageId As Integer) As PageInfo + + Return CType(CBO.FillObject(DataProvider.Instance().GetPage(pageId), GetType(PageInfo)), PageInfo) + + End Function + + Public Sub DeletePage(ByVal pageId As Integer) + + DataProvider.Instance().DeletePage(pageId) + + End Sub + + Public Function AddPage(ByVal objPage As PageInfo) As Integer + + Dim pageId As Integer = DataProvider.Instance().AddPage(objPage.ArticleID, objPage.Title, objPage.PageText, objPage.SortOrder) + ArticleController.ClearArticleCache(objPage.ArticleID) + Return pageId + + End Function + + Public Sub UpdatePage(ByVal objPage As PageInfo) + + DataProvider.Instance().UpdatePage(objPage.PageID, objPage.ArticleID, objPage.Title, objPage.PageText, objPage.SortOrder) + + ArticleController.ClearArticleCache(objPage.ArticleID) + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/Controllers/PageInfo.vb b/Components/Controllers/PageInfo.vb new file mode 100755 index 0000000..6437c1a --- /dev/null +++ b/Components/Controllers/PageInfo.vb @@ -0,0 +1,79 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class PageInfo + +#Region " Private Methods " + + ' local property declarations + Dim _pageID As Integer + Dim _articleID As Integer + Dim _title As String + Dim _pageText As String + Dim _sortOrder As Integer + +#End Region + +#Region " Public Properties " + + Public Property PageID() As Integer + Get + Return _pageID + End Get + Set(ByVal Value As Integer) + _pageID = Value + End Set + End Property + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal Value As Integer) + _articleID = Value + End Set + End Property + + Public Property Title() As String + Get + Return _title + End Get + Set(ByVal Value As String) + _title = Value + End Set + End Property + + Public Property PageText() As String + Get + Return _pageText + End Get + Set(ByVal Value As String) + _pageText = Value + End Set + End Property + + Public Property SortOrder() As Integer + Get + Return _sortOrder + End Get + Set(ByVal Value As Integer) + _sortOrder = Value + End Set + End Property + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/CustomFields/CustomFieldController.vb b/Components/CustomFields/CustomFieldController.vb new file mode 100755 index 0000000..ad1cbbe --- /dev/null +++ b/Components/CustomFields/CustomFieldController.vb @@ -0,0 +1,61 @@ +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles.Components.CustomFields + + Public Class CustomFieldController + +#Region " Private Members " + + Private Const CACHE_KEY As String = "-NewsArticles-CustomFields-All" + +#End Region + +#Region " Public Methods " + + Public Function [Get](ByVal customFieldID As Integer) As CustomFieldInfo + + Return CType(CBO.FillObject(DataProvider.Instance().GetCustomField(customFieldID), GetType(CustomFieldInfo)), CustomFieldInfo) + + End Function + + Public Function List(ByVal moduleID As Integer) As ArrayList + + Dim key As String = moduleID.ToString() & CACHE_KEY + + Dim objCustomFields As ArrayList = CType(DataCache.GetCache(key), ArrayList) + + If (objCustomFields Is Nothing) Then + objCustomFields = CBO.FillCollection(DataProvider.Instance().GetCustomFieldList(moduleID), GetType(CustomFieldInfo)) + DataCache.SetCache(key, objCustomFields) + End If + + Return objCustomFields + + End Function + + Public Sub Delete(ByVal moduleID As Integer, ByVal customFieldID As Integer) + + DataCache.RemoveCache(moduleID.ToString() & CACHE_KEY) + DataProvider.Instance().DeleteCustomField(customFieldID) + + End Sub + + Public Function Add(ByVal objCustomField As CustomFieldInfo) As Integer + + DataCache.RemoveCache(objCustomField.ModuleID.ToString() & CACHE_KEY) + Return CType(DataProvider.Instance().AddCustomField(objCustomField.ModuleID, objCustomField.Name, objCustomField.FieldType, objCustomField.FieldElements, objCustomField.DefaultValue, objCustomField.Caption, objCustomField.CaptionHelp, objCustomField.IsRequired, objCustomField.IsVisible, objCustomField.SortOrder, objCustomField.ValidationType, objCustomField.Length, objCustomField.RegularExpression), Integer) + + End Function + + Public Sub Update(ByVal objCustomField As CustomFieldInfo) + + DataCache.RemoveCache(objCustomField.ModuleID.ToString() & CACHE_KEY) + DataProvider.Instance().UpdateCustomField(objCustomField.CustomFieldID, objCustomField.ModuleID, objCustomField.Name, objCustomField.FieldType, objCustomField.FieldElements, objCustomField.DefaultValue, objCustomField.Caption, objCustomField.CaptionHelp, objCustomField.IsRequired, objCustomField.IsVisible, objCustomField.SortOrder, objCustomField.ValidationType, objCustomField.Length, objCustomField.RegularExpression) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/CustomFields/CustomFieldInfo.vb b/Components/CustomFields/CustomFieldInfo.vb new file mode 100755 index 0000000..9d9e7c9 --- /dev/null +++ b/Components/CustomFields/CustomFieldInfo.vb @@ -0,0 +1,157 @@ +Namespace Ventrian.NewsArticles.Components.CustomFields + + Public Class CustomFieldInfo + +#Region " Private Members " + + Dim _customFieldID As Integer + Dim _moduleID As Integer + Dim _name As String + Dim _fieldType As CustomFieldType + Dim _fieldElements As String + Dim _defaultValue As String + Dim _caption As String + Dim _captionHelp As String + Dim _isRequired As Boolean + Dim _isVisible As Boolean + Dim _sortOrder As Integer + Dim _validationType As CustomFieldValidationType + Dim _regularExpression As String + Dim _length As Integer + +#End Region + +#Region " Public Properties " + + Public Property CustomFieldID() As Integer + Get + Return _customFieldID + End Get + Set(ByVal Value As Integer) + _customFieldID = Value + End Set + End Property + + Public Property ModuleID() As Integer + Get + Return _moduleID + End Get + Set(ByVal Value As Integer) + _moduleID = Value + End Set + End Property + + Public Property Name() As String + Get + Return _name + End Get + Set(ByVal Value As String) + _name = Value + End Set + End Property + + Public Property FieldElements() As String + Get + Return _fieldElements + End Get + Set(ByVal Value As String) + _fieldElements = Value + End Set + End Property + + Public Property FieldType() As CustomFieldType + Get + Return _fieldType + End Get + Set(ByVal Value As CustomFieldType) + _fieldType = Value + End Set + End Property + + Public Property DefaultValue() As String + Get + Return _defaultValue + End Get + Set(ByVal Value As String) + _defaultValue = Value + End Set + End Property + + Public Property Caption() As String + Get + Return _caption + End Get + Set(ByVal Value As String) + _caption = Value + End Set + End Property + + Public Property CaptionHelp() As String + Get + Return _captionHelp + End Get + Set(ByVal Value As String) + _captionHelp = Value + End Set + End Property + + Public Property SortOrder() As Integer + Get + Return _sortOrder + End Get + Set(ByVal Value As Integer) + _sortOrder = Value + End Set + End Property + + Public Property IsRequired() As Boolean + Get + Return _isRequired + End Get + Set(ByVal Value As Boolean) + _isRequired = Value + End Set + End Property + + Public Property IsVisible() As Boolean + Get + Return _isVisible + End Get + Set(ByVal Value As Boolean) + _isVisible = Value + End Set + End Property + + Public Property ValidationType() As CustomFieldValidationType + Get + Return _validationType + End Get + Set(ByVal Value As CustomFieldValidationType) + _validationType = Value + End Set + End Property + + Public Property Length() As Integer + Get + Return _length + End Get + Set(ByVal Value As Integer) + _length = Value + End Set + End Property + + Public Property RegularExpression() As String + Get + Return _regularExpression + End Get + Set(ByVal Value As String) + _regularExpression = Value + End Set + End Property + +#End Region + + End Class + +End Namespace + diff --git a/Components/CustomFields/CustomFieldType.vb b/Components/CustomFields/CustomFieldType.vb new file mode 100755 index 0000000..44d872a --- /dev/null +++ b/Components/CustomFields/CustomFieldType.vb @@ -0,0 +1,16 @@ +Namespace Ventrian.NewsArticles.Components.CustomFields + + Public Enum CustomFieldType + + OneLineTextBox = 0 + MultiLineTextBox = 1 + RichTextBox = 2 + DropDownList = 3 + CheckBox = 4 + MultiCheckBox = 5 + RadioButton = 6 + ColorPicker = 7 + + End Enum + +End Namespace diff --git a/Components/CustomFields/CustomFieldValidationType.vb b/Components/CustomFields/CustomFieldValidationType.vb new file mode 100755 index 0000000..bf0c64d --- /dev/null +++ b/Components/CustomFields/CustomFieldValidationType.vb @@ -0,0 +1,15 @@ +Namespace Ventrian.NewsArticles.Components.CustomFields + + Public Enum CustomFieldValidationType + + [None] = 0 + [Currency] = 1 + [Date] = 2 + [Double] = 3 + [Integer] = 4 + [Email] = 5 + [Regex] = 6 + + End Enum + +End Namespace diff --git a/Components/CustomFields/CustomValueController.vb b/Components/CustomFields/CustomValueController.vb new file mode 100755 index 0000000..6303081 --- /dev/null +++ b/Components/CustomFields/CustomValueController.vb @@ -0,0 +1,69 @@ +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles.Components.CustomFields + + Public Class CustomValueController + +#Region " Private Members " + + Private Const CACHE_KEY As String = "-NewsArticles-CustomValues-All" + +#End Region + +#Region " Public Methods " + + Public Function GetByCustomField(ByVal articleID As Integer, ByVal customFieldID As Integer) As CustomValueInfo + + Dim objCustomValues As List(Of CustomValueInfo) = List(articleID) + + For Each objCustomValue As CustomValueInfo In objCustomValues + If (objCustomValue.CustomFieldID = customFieldID) Then + Return objCustomValue + End If + Next + + Return Nothing + + End Function + + Public Function List(ByVal articleID As Integer) As List(Of CustomValueInfo) + + Dim key As String = articleID.ToString() & CACHE_KEY + + Dim objCustomValues As List(Of CustomValueInfo) = CType(DataCache.GetCache(key), List(Of CustomValueInfo)) + + If (objCustomValues Is Nothing) Then + objCustomValues = CBO.FillCollection(Of CustomValueInfo)(DataProvider.Instance().GetCustomValueList(articleID)) + DataCache.SetCache(key, objCustomValues) + End If + + Return objCustomValues + + End Function + + Public Function Add(ByVal objCustomValue As CustomValueInfo) As Integer + + DataCache.RemoveCache(objCustomValue.ArticleID.ToString() & CACHE_KEY) + Return CType(DataProvider.Instance().AddCustomValue(objCustomValue.ArticleID, objCustomValue.CustomFieldID, objCustomValue.CustomValue), Integer) + + End Function + + Public Sub Update(ByVal objCustomValue As CustomValueInfo) + + DataCache.RemoveCache(objCustomValue.ArticleID.ToString() & CACHE_KEY) + DataProvider.Instance().UpdateCustomValue(objCustomValue.CustomValueID, objCustomValue.ArticleID, objCustomValue.CustomFieldID, objCustomValue.CustomValue) + + End Sub + + Public Sub Delete(ByVal articleID As Integer, ByVal customFieldID As Integer) + + DataCache.RemoveCache(articleID.ToString() & CACHE_KEY) + DataProvider.Instance().DeleteCustomValue(articleID, customFieldID) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/CustomFields/CustomValueInfo.vb b/Components/CustomFields/CustomValueInfo.vb new file mode 100755 index 0000000..7ea6352 --- /dev/null +++ b/Components/CustomFields/CustomValueInfo.vb @@ -0,0 +1,58 @@ +Namespace Ventrian.NewsArticles.Components.CustomFields + + Public Class CustomValueInfo + +#Region " Private Members " + + Dim _customValueID As Integer + Dim _articleID As Integer + Dim _customFieldID As Integer + Dim _customValue As String + +#End Region + +#Region " Public Properties " + + Public Property CustomValueID() As Integer + Get + Return _customValueID + End Get + Set(ByVal Value As Integer) + _customValueID = Value + End Set + End Property + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal Value As Integer) + _articleID = Value + End Set + End Property + + Public Property CustomFieldID() As Integer + Get + Return _customFieldID + End Get + Set(ByVal Value As Integer) + _customFieldID = Value + End Set + End Property + + Public Property CustomValue() As String + Get + Return _customValue + End Get + Set(ByVal Value As String) + _customValue = Value + End Set + End Property + +#End Region + + End Class + +End Namespace + + diff --git a/Components/DisplayType.vb b/Components/DisplayType.vb new file mode 100755 index 0000000..7c23590 --- /dev/null +++ b/Components/DisplayType.vb @@ -0,0 +1,24 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum DisplayType + + UserName + FirstName + LastName + FullName + + End Enum + +End Namespace diff --git a/Components/EmailTemplateController.vb b/Components/EmailTemplateController.vb new file mode 100755 index 0000000..b5a7d9f --- /dev/null +++ b/Components/EmailTemplateController.vb @@ -0,0 +1,402 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports Dotnetnuke.Entities.Portals +Imports Dotnetnuke.Entities.Users +Imports DotNetNuke.Framework +Imports DotNetNuke.Security.Roles + +Namespace Ventrian.NewsArticles + + Public Class EmailTemplateController + +#Region " Private Methods " + + Public Function FormatArticleEmail(ByVal template As String, ByVal link As String, ByVal objArticle As ArticleInfo, ByVal articleSettings As ArticleSettings) As String + + Dim formatted As String = template + + formatted = formatted.Replace("[USERNAME]", objArticle.AuthorUserName) + formatted = formatted.Replace("[FIRSTNAME]", objArticle.AuthorFirstName) + formatted = formatted.Replace("[LASTNAME]", objArticle.AuthorLastName) + formatted = formatted.Replace("[FULLNAME]", objArticle.AuthorFullName) + formatted = formatted.Replace("[EMAIL]", objArticle.AuthorEmail) + formatted = formatted.Replace("[DISPLAYNAME]", objArticle.AuthorDisplayName) + + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings() + + formatted = formatted.Replace("[PORTALNAME]", settings.PortalName) + formatted = formatted.Replace("[CREATEDATE]", objArticle.CreatedDate.ToString("d") & " " & objArticle.CreatedDate.ToString("t")) + formatted = formatted.Replace("[POSTDATE]", objArticle.StartDate.ToString("d") & " " & objArticle.CreatedDate.ToString("t")) + + formatted = formatted.Replace("[TITLE]", objArticle.Title) + formatted = formatted.Replace("[SUMMARY]", System.Web.HttpContext.Current.Server.HtmlDecode(objArticle.Summary)) + formatted = formatted.Replace("[LINK]", link) + + Return formatted + + End Function + + Public Function FormatCommentEmail(ByVal template As String, ByVal link As String, ByVal objArticle As ArticleInfo, ByVal objComment As CommentInfo, ByVal articleSettings As ArticleSettings) As String + + Dim formatted As String = template + + If (objComment.UserID = Null.NullInteger) Then + ' Anonymous Comment + formatted = formatted.Replace("[USERNAME]", objComment.AnonymousName) + formatted = formatted.Replace("[EMAIL]", objComment.AnonymousEmail) + formatted = formatted.Replace("[FIRSTNAME]", objComment.AnonymousName) + formatted = formatted.Replace("[LASTNAME]", objComment.AnonymousName) + formatted = formatted.Replace("[FULLNAME]", objComment.AnonymousName) + formatted = formatted.Replace("[DISPLAYNAME]", objComment.AnonymousName) + Else + ' Authenticated Comment + formatted = formatted.Replace("[USERNAME]", objComment.AuthorUserName) + formatted = formatted.Replace("[EMAIL]", objComment.AuthorEmail) + formatted = formatted.Replace("[FIRSTNAME]", objComment.AuthorFirstName) + formatted = formatted.Replace("[LASTNAME]", objComment.AuthorLastName) + formatted = formatted.Replace("[FULLNAME]", objComment.AuthorFirstName & " " & objComment.AuthorLastName) + formatted = formatted.Replace("[DISPLAYNAME]", objComment.AuthorDisplayName) + End If + + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings() + + formatted = formatted.Replace("[PORTALNAME]", settings.PortalName) + formatted = formatted.Replace("[POSTDATE]", DateTime.Now.ToShortDateString & " " & DateTime.Now.ToShortTimeString) + + formatted = formatted.Replace("[TITLE]", objArticle.Title) + formatted = formatted.Replace("[COMMENT]", objComment.Comment.Replace("
", vbCrLf)) + formatted = formatted.Replace("[LINK]", link) + formatted = formatted.Replace("[APPROVELINK]", Common.GetModuleLink(settings.ActiveTab.TabID, objArticle.ModuleID, "ApproveComments", articleSettings)) + + Return formatted + + End Function + + Public Function GetApproverDistributionList(ByVal moduleID As Integer) As String + + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings() + Dim moduleSettings As Hashtable = PortalSettings.GetModuleSettings(moduleID) + Dim distributionList As String = "" + + If (moduleSettings.Contains(ArticleConstants.PERMISSION_APPROVAL_SETTING)) Then + + Dim roles As String = moduleSettings(ArticleConstants.PERMISSION_APPROVAL_SETTING).ToString() + Dim rolesArray() As String = roles.Split(Convert.ToChar(";")) + Dim userList As Hashtable = New Hashtable + + For Each role As String In rolesArray + If (role.Length > 0) Then + Dim objRoleController As RoleController = New RoleController + Dim objRole As RoleInfo = objRoleController.GetRoleByName(settings.PortalId, role) + + If Not (objRole Is Nothing) Then + Dim objUsers As ArrayList = objRoleController.GetUserRolesByRoleName(settings.PortalId, objRole.RoleName) + For Each objUser As UserRoleInfo In objUsers + If (userList.Contains(objUser.UserID) = False) Then + Dim objUserController As UserController = New UserController + Dim objSelectedUser As UserInfo = objUserController.GetUser(settings.PortalId, objUser.UserID) + If Not (objSelectedUser Is Nothing) Then + If (objSelectedUser.Email.Length > 0) Then + userList.Add(objUser.UserID, objSelectedUser.Email) + End If + End If + End If + Next + End If + End If + Next + + For Each email As DictionaryEntry In userList + If (distributionList.Length > 0) Then + distributionList += "; " + End If + distributionList += email.Value.ToString() + Next + + End If + + Return distributionList + + End Function + + +#End Region + +#Region " Public Methods " + + Public Function [Get](ByVal templateID As Integer) As EmailTemplateInfo + + Return CType(CBO.FillObject(DataProvider.Instance().GetEmailTemplate(templateID), GetType(EmailTemplateInfo)), EmailTemplateInfo) + + End Function + + Public Function [Get](ByVal moduleID As Integer, ByVal type As EmailTemplateType) As EmailTemplateInfo + + Dim objEmailTemplate As EmailTemplateInfo = CType(CBO.FillObject(DataProvider.Instance().GetEmailTemplateByName(moduleID, type.ToString()), GetType(EmailTemplateInfo)), EmailTemplateInfo) + + If (objEmailTemplate Is Nothing) Then + + objEmailTemplate = New EmailTemplateInfo + objEmailTemplate.ModuleID = moduleID + objEmailTemplate.Name = type.ToString() + + Select Case type + + Case EmailTemplateType.ArticleApproved + objEmailTemplate.Subject = "[PORTALNAME]: Your Article Has Been Approved" + objEmailTemplate.Template = "" _ + & "Your article titled [TITLE] has been approved." & vbCrLf & vbCrLf _ + & "To visit the live article, please visit:" & vbCrLf _ + & "[LINK]" & vbCrLf & vbCrLf _ + & "Thank you," & vbCrLf _ + & "[PORTALNAME]" + Exit Select + + Case EmailTemplateType.ArticleSubmission + objEmailTemplate.Subject = "[PORTALNAME]: New Article Requires Approval" + objEmailTemplate.Template = "" _ + & "At [POSTDATE] an article title [TITLE] has been submitted for approval." & vbCrLf & vbCrLf _ + & "[SUMMARY]" & vbCrLf & vbCrLf _ + & "To view the complete article and approve, please visit:" & vbCrLf _ + & "[LINK]" & vbCrLf & vbCrLf _ + & "Thank you," & vbCrLf _ + & "[PORTALNAME]" + Exit Select + + Case EmailTemplateType.ArticleUpdateMirrored + objEmailTemplate.Subject = "[PORTALNAME]: An article has been updated" + objEmailTemplate.Template = "" _ + & "At [POSTDATE] an article you have mirrored '[TITLE]' was updated." & vbCrLf & vbCrLf _ + & "To visit the mirrored article, please visit:" & vbCrLf _ + & "[LINK]" & vbCrLf & vbCrLf _ + & "Thank you," & vbCrLf _ + & "[PORTALNAME]" + Exit Select + + Case EmailTemplateType.CommentNotification + objEmailTemplate.Subject = "[PORTALNAME]: Comment Notification" + objEmailTemplate.Template = "" _ + & "At [POSTDATE] a comment was posted to the article [TITLE]." & vbCrLf & vbCrLf _ + & "[COMMENT]" & vbCrLf & vbCrLf _ + & "To view the complete article and reply, please visit:" & vbCrLf _ + & "[LINK]" & vbCrLf & vbCrLf _ + & "Thank you," & vbCrLf _ + & "[PORTALNAME]" + Exit Select + + Case EmailTemplateType.CommentRequiringApproval + objEmailTemplate.Subject = "[PORTALNAME]: Comment requiring approval" + objEmailTemplate.Template = "" _ + & "At [POSTDATE], a comment requiring approval was posted to your article [TITLE]." & vbCrLf & vbCrLf _ + & "[COMMENT]" & vbCrLf & vbCrLf _ + & "To approve this comment, please visit:" & vbCrLf _ + & "[APPROVELINK]" & vbCrLf & vbCrLf _ + & "Thank you," & vbCrLf _ + & "[PORTALNAME]" + Exit Select + + Case EmailTemplateType.CommentApproved + objEmailTemplate.Subject = "[PORTALNAME]: Your Comment Has Been Approved" + objEmailTemplate.Template = "" _ + & "Your comment posted to [TITLE] has been approved." & vbCrLf & vbCrLf _ + & "To visit the live article, please visit:" & vbCrLf _ + & "[LINK]" & vbCrLf & vbCrLf _ + & "Thank you," & vbCrLf _ + & "[PORTALNAME]" + Exit Select + + End Select + + objEmailTemplate.TemplateID = Add(objEmailTemplate) + + End If + + Return objEmailTemplate + + End Function + + Public Function List(ByVal moduleID As Integer) As ArrayList + + Return CBO.FillCollection(DataProvider.Instance().ListEmailTemplate(moduleID), GetType(EmailTemplateInfo)) + + End Function + + Public Function Add(ByVal objEmailTemplate As EmailTemplateInfo) As Integer + + Return CType(DataProvider.Instance().AddEmailTemplate(objEmailTemplate.ModuleID, objEmailTemplate.Name, objEmailTemplate.Subject, objEmailTemplate.Template), Integer) + + End Function + + Public Sub Update(ByVal objEmailTemplate As EmailTemplateInfo) + + DataProvider.Instance().UpdateEmailTemplate(objEmailTemplate.TemplateID, objEmailTemplate.ModuleID, objEmailTemplate.Name, objEmailTemplate.Subject, objEmailTemplate.Template) + + End Sub + + Public Sub Delete(ByVal templateID As Integer) + + DataProvider.Instance().DeleteEmailTemplate(templateID) + + End Sub + + Public Sub SendFormattedEmail(ByVal moduleID As Integer, ByVal link As String, ByVal objArticle As ArticleInfo, ByVal type As EmailTemplateType, ByVal sendTo As String, ByVal articleSettings As ArticleSettings) + + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings() + + Dim subject As String = "" + Dim template As String = "" + + Select Case type + + Case EmailTemplateType.ArticleSubmission + Dim objTemplate As EmailTemplateInfo = Me.Get(moduleID, EmailTemplateType.ArticleSubmission) + subject = objTemplate.Subject + template = objTemplate.Template + + Exit Select + + Case EmailTemplateType.ArticleApproved + Dim objTemplate As EmailTemplateInfo = Me.Get(moduleID, EmailTemplateType.ArticleApproved) + subject = objTemplate.Subject + template = objTemplate.Template + + Exit Select + + Case EmailTemplateType.ArticleUpdateMirrored + Dim objTemplate As EmailTemplateInfo = Me.Get(moduleID, EmailTemplateType.ArticleUpdateMirrored) + subject = objTemplate.Subject + template = objTemplate.Template + + Exit Select + + Case Else + Exit Sub + + End Select + + subject = FormatArticleEmail(subject, link, objArticle, articleSettings) + template = FormatArticleEmail(template, link, objArticle, articleSettings) + + ' SendNotification(settings.Email, sendTo, Null.NullString, subject, template) + Try + DotNetNuke.Services.Mail.Mail.SendMail(settings.Email, sendTo, "", subject, template, "", "", "", "", "", "") + Catch + End Try + + End Sub + + Public Sub SendFormattedEmail(ByVal moduleID As Integer, ByVal link As String, ByVal objArticle As ArticleInfo, ByVal objComment As CommentInfo, ByVal type As EmailTemplateType, ByVal articleSettings As ArticleSettings) + + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings() + + Dim sendTo As String = "" + + Select Case type + + Case EmailTemplateType.CommentNotification + + Dim objUserController As New UserController + Dim objUser As UserInfo = objUserController.GetUser(settings.PortalId, objArticle.AuthorID) + + If Not (objUser Is Nothing) Then + sendTo = objUser.Membership.Email + SendFormattedEmail(moduleID, link, objArticle, objComment, EmailTemplateType.CommentNotification, articleSettings, sendTo) + End If + + Exit Select + + Case EmailTemplateType.CommentApproved + + If (objComment.UserID <> Null.NullInteger) Then + Dim objUserController As New UserController + Dim objUser As UserInfo = objUserController.GetUser(settings.PortalId, objComment.UserID) + + If Not (objUser Is Nothing) Then + sendTo = objUser.Membership.Email + SendFormattedEmail(moduleID, link, objArticle, objComment, EmailTemplateType.CommentApproved, articleSettings, sendTo) + End If + Else + SendFormattedEmail(moduleID, link, objArticle, objComment, EmailTemplateType.CommentApproved, articleSettings, objComment.AnonymousEmail) + End If + + Exit Select + + Case EmailTemplateType.CommentRequiringApproval + + Dim objUserController As New UserController + Dim objUser As UserInfo = objUserController.GetUser(settings.PortalId, objArticle.AuthorID) + + If Not (objUser Is Nothing) Then + sendTo = objUser.Membership.Email + SendFormattedEmail(moduleID, link, objArticle, objComment, EmailTemplateType.CommentRequiringApproval, articleSettings, sendTo) + End If + + Exit Select + + Case Else + Exit Sub + + End Select + + End Sub + + Public Sub SendFormattedEmail(ByVal moduleID As Integer, ByVal link As String, ByVal objArticle As ArticleInfo, ByVal objComment As CommentInfo, ByVal type As EmailTemplateType, ByVal articleSettings As ArticleSettings, ByVal email As String) + + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings() + + Dim subject As String = "" + Dim template As String = "" + Dim sendTo As String = email + + Select Case type + + Case EmailTemplateType.CommentNotification + Dim objTemplate As EmailTemplateInfo = Me.Get(moduleID, EmailTemplateType.CommentNotification) + subject = objTemplate.Subject + template = objTemplate.Template + + Exit Select + + Case EmailTemplateType.CommentApproved + Dim objTemplate As EmailTemplateInfo = Me.Get(moduleID, EmailTemplateType.CommentApproved) + subject = objTemplate.Subject + template = objTemplate.Template + + Exit Select + + Case EmailTemplateType.CommentRequiringApproval + Dim objTemplate As EmailTemplateInfo = Me.Get(moduleID, EmailTemplateType.CommentRequiringApproval) + subject = objTemplate.Subject + template = objTemplate.Template + + Exit Select + + Case Else + Exit Sub + + End Select + + subject = FormatCommentEmail(subject, link, objArticle, objComment, articleSettings) + template = FormatCommentEmail(template, link, objArticle, objComment, articleSettings) + + Try + DotNetNuke.Services.Mail.Mail.SendMail(settings.Email, sendTo, "", subject, template, "", "", "", "", "", "") + Catch + End Try + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/EmailTemplateInfo.vb b/Components/EmailTemplateInfo.vb new file mode 100755 index 0000000..bb8c569 --- /dev/null +++ b/Components/EmailTemplateInfo.vb @@ -0,0 +1,81 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Class EmailTemplateInfo + +#Region "Private Members" + Dim _templateID As Integer + Dim _moduleID As Integer + Dim _name As String + Dim _subject As String + Dim _template As String +#End Region + +#Region "Constructors" + Public Sub New() + End Sub + + Public Sub New(ByVal templateID As Integer, ByVal moduleID As Integer, ByVal name As String, ByVal subject As String, ByVal template As String) + Me.TemplateID = templateID + Me.ModuleID = moduleID + Me.Name = name + Me.Subject = subject + Me.Template = template + End Sub +#End Region + +#Region "Public Properties" + Public Property TemplateID() As Integer + Get + Return _templateID + End Get + Set(ByVal Value As Integer) + _templateID = Value + End Set + End Property + + Public Property ModuleID() As Integer + Get + Return _moduleID + End Get + Set(ByVal Value As Integer) + _moduleID = Value + End Set + End Property + + Public Property Name() As String + Get + Return _name + End Get + Set(ByVal Value As String) + _name = Value + End Set + End Property + + Public Property Subject() As String + Get + Return _subject + End Get + Set(ByVal Value As String) + _subject = Value + End Set + End Property + + Public Property Template() As String + Get + Return _template + End Get + Set(ByVal Value As String) + _template = Value + End Set + End Property +#End Region + + End Class + +End Namespace diff --git a/Components/EmailTemplateType.vb b/Components/EmailTemplateType.vb new file mode 100755 index 0000000..54476e1 --- /dev/null +++ b/Components/EmailTemplateType.vb @@ -0,0 +1,26 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum EmailTemplateType + + ArticleSubmission + ArticleApproved + ArticleUpdateMirrored + CommentNotification + CommentRequiringApproval + CommentApproved + + End Enum + +End Namespace diff --git a/Components/ExpiryType.vb b/Components/ExpiryType.vb new file mode 100755 index 0000000..3febcca --- /dev/null +++ b/Components/ExpiryType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum ExpiryType + + HideAll = 0 + HidePartial = 1 + + End Enum + +End Namespace diff --git a/Components/GroupByType.vb b/Components/GroupByType.vb new file mode 100755 index 0000000..1ab4d7d --- /dev/null +++ b/Components/GroupByType.vb @@ -0,0 +1,16 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Enum GroupByType + + Month + Year + + End Enum + +End Namespace diff --git a/Components/Handout/HandoutArticle.vb b/Components/Handout/HandoutArticle.vb new file mode 100755 index 0000000..3dc31f7 --- /dev/null +++ b/Components/Handout/HandoutArticle.vb @@ -0,0 +1,57 @@ +Namespace Ventrian.NewsArticles + + _ + Public Class HandoutArticle + +#Region " Private Members " + + Private _articleID As Integer + Private _title As String + Private _summary As String + Private _sortOrder As Integer + +#End Region + +#Region " Public Properties " + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal value As Integer) + _articleID = value + End Set + End Property + + Public Property Title() As String + Get + Return _title + End Get + Set(ByVal value As String) + _title = value + End Set + End Property + + Public Property Summary() As String + Get + Return _summary + End Get + Set(ByVal value As String) + _summary = value + End Set + End Property + + Public Property SortOrder() As Integer + Get + Return _sortOrder + End Get + Set(ByVal value As Integer) + _sortOrder = value + End Set + End Property + +#End Region + + End Class + +End Namespace diff --git a/Components/Handout/HandoutController.vb b/Components/Handout/HandoutController.vb new file mode 100755 index 0000000..6586525 --- /dev/null +++ b/Components/Handout/HandoutController.vb @@ -0,0 +1,62 @@ +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class HandoutController + +#Region " Public Methods " + + Public Function AddHandout(ByVal objHandout As HandoutInfo) As Integer + + Dim handoutID As Integer = CType(DataProvider.Instance().AddHandout(objHandout.ModuleID, objHandout.UserID, objHandout.Name, objHandout.Description), Integer) + + Dim i As Integer = 0 + For Each objHandoutArticle As HandoutArticle In objHandout.Articles + DataProvider.Instance().AddHandoutArticle(handoutID, objHandoutArticle.ArticleID, i) + i = i + 1 + Next + + End Function + + Public Sub DeleteHandout(ByVal handoutID As Integer) + + DataProvider.Instance().DeleteHandout(handoutID) + DataProvider.Instance().DeleteHandoutArticleList(handoutID) + + End Sub + + Public Function GetHandout(ByVal handoutID As Integer) As HandoutInfo + + Dim objHandout As HandoutInfo = CType(CBO.FillObject(DataProvider.Instance().GetHandout(handoutID), GetType(HandoutInfo)), HandoutInfo) + + objHandout.Articles = CBO.FillCollection(Of HandoutArticle)(DataProvider.Instance().GetHandoutArticleList(handoutID)) + + Return objHandout + + End Function + + Public Function ListHandout(ByVal userID As Integer) As List(Of HandoutInfo) + + Return CBO.FillCollection(Of HandoutInfo)(DataProvider.Instance().GetHandoutList(userID)) + + End Function + + Public Sub UpdateHandout(ByVal objHandout As HandoutInfo) + + DataProvider.Instance().UpdateHandout(objHandout.HandoutID, objHandout.ModuleID, objHandout.UserID, objHandout.Name, objHandout.Description) + DataProvider.Instance().DeleteHandoutArticleList(objHandout.HandoutID) + + Dim i As Integer = 0 + For Each objHandoutArticle As HandoutArticle In objHandout.Articles + DataProvider.Instance().AddHandoutArticle(objHandout.HandoutID, objHandoutArticle.ArticleID, i) + i = i + 1 + Next + + End Sub + +#End Region + + End Class + +End Namespace + diff --git a/Components/Handout/HandoutFilterType.vb b/Components/Handout/HandoutFilterType.vb new file mode 100755 index 0000000..6a7c26a --- /dev/null +++ b/Components/Handout/HandoutFilterType.vb @@ -0,0 +1,16 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Enum HandoutFilterType + + All = 0 + Selected = 1 + + End Enum + +End Namespace diff --git a/Components/Handout/HandoutInfo.vb b/Components/Handout/HandoutInfo.vb new file mode 100755 index 0000000..ea49226 --- /dev/null +++ b/Components/Handout/HandoutInfo.vb @@ -0,0 +1,80 @@ +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class HandoutInfo + +#Region " Private Members " + + Private _handoutID As Integer = Null.NullInteger + Private _moduleID As Integer = Null.NullInteger + Private _userID As Integer = Null.NullInteger + Private _name As String = Null.NullString + Private _description As String = Null.NullString + + Private _articles As List(Of HandoutArticle) + +#End Region + +#Region " Public Properties " + + Public Property HandoutID() As Integer + Get + Return _handoutID + End Get + Set(ByVal value As Integer) + _handoutID = value + End Set + End Property + + Public Property ModuleID() As Integer + Get + Return _moduleID + End Get + Set(ByVal value As Integer) + _moduleID = value + End Set + End Property + + Public Property UserID() As Integer + Get + Return _userID + End Get + Set(ByVal value As Integer) + _userID = value + End Set + End Property + + Public Property Name() As String + Get + Return _name + End Get + Set(ByVal value As String) + _name = value + End Set + End Property + + Public Property Description() As String + Get + Return _description + End Get + Set(ByVal value As String) + _description = value + End Set + End Property + + Public Property Articles() As List(Of HandoutArticle) + Get + Return _articles + End Get + Set(ByVal value As List(Of HandoutArticle)) + _articles = value + End Set + End Property + +#End Region + + End Class + +End Namespace + diff --git a/Components/Handout/HandoutType.vb b/Components/Handout/HandoutType.vb new file mode 100755 index 0000000..624341f --- /dev/null +++ b/Components/Handout/HandoutType.vb @@ -0,0 +1,17 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Enum HandoutOptionType + + None = 0 + Template = 1 + Text = 2 + + End Enum + +End Namespace diff --git a/Components/ImageController.vb b/Components/ImageController.vb new file mode 100755 index 0000000..f951782 --- /dev/null +++ b/Components/ImageController.vb @@ -0,0 +1,57 @@ +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class ImageController + +#Region " Public Methods " + + Public Function [Get](ByVal imageID As Integer) As ImageInfo + + Return CType(CBO.FillObject(DataProvider.Instance().GetImage(imageID), GetType(ImageInfo)), ImageInfo) + + End Function + + Public Function GetImageList(ByVal articleID As Integer, ByVal imageGuid As String) As List(Of ImageInfo) + + Dim objImages As List(Of ImageInfo) = CType(DataCache.GetCache(ArticleConstants.CACHE_IMAGE_ARTICLE & articleID.ToString()), List(Of ImageInfo)) + + If (objImages Is Nothing) Then + objImages = CBO.FillCollection(Of ImageInfo)(DataProvider.Instance().GetImageList(articleID, imageGuid)) + DataCache.SetCache(ArticleConstants.CACHE_IMAGE_ARTICLE & articleID.ToString() & imageGuid, objImages) + End If + Return objImages + + End Function + + Public Function Add(ByVal objImage As ImageInfo) As Integer + + DataCache.RemoveCache(ArticleConstants.CACHE_IMAGE_ARTICLE & objImage.ArticleID.ToString() & objImage.ImageGuid) + Dim imageID As Integer = CType(DataProvider.Instance().AddImage(objImage.ArticleID, objImage.Title, objImage.FileName, objImage.Extension, objImage.Size, objImage.Width, objImage.Height, objImage.ContentType, objImage.Folder, objImage.SortOrder, objImage.ImageGuid, objImage.Description), Integer) + ArticleController.ClearArticleCache(objImage.ArticleID) + Return imageID + + End Function + + Public Sub Update(ByVal objImage As ImageInfo) + + DataProvider.Instance().UpdateImage(objImage.ImageID, objImage.ArticleID, objImage.Title, objImage.FileName, objImage.Extension, objImage.Size, objImage.Width, objImage.Height, objImage.ContentType, objImage.Folder, objImage.SortOrder, objImage.ImageGuid, objImage.Description) + DataCache.RemoveCache(ArticleConstants.CACHE_IMAGE_ARTICLE & objImage.ArticleID.ToString() & objImage.ImageGuid) + DataCache.RemoveCache(ArticleConstants.CACHE_IMAGE_ARTICLE & objImage.ArticleID.ToString()) + ArticleController.ClearArticleCache(objImage.ArticleID) + + End Sub + + Public Sub Delete(ByVal imageID As Integer, ByVal articleID As Integer, ByVal imageGuid As String) + + DataProvider.Instance().DeleteImage(imageID) + DataCache.RemoveCache(ArticleConstants.CACHE_IMAGE_ARTICLE & articleID.ToString() & imageGuid) + ArticleController.ClearArticleCache(articleID) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/ImageInfo.vb b/Components/ImageInfo.vb new file mode 100755 index 0000000..3210643 --- /dev/null +++ b/Components/ImageInfo.vb @@ -0,0 +1,153 @@ +Namespace Ventrian.NewsArticles + + Public Class ImageInfo + Implements ICloneable + +#Region " Private Members " + + Dim _imageID As Integer + Dim _articleID As Integer + + Dim _title As String + + Dim _fileName As String + Dim _extension As String + Dim _size As Integer + Dim _width As Integer + Dim _height As Integer + Dim _contentType As String + Dim _folder As String + Dim _sortOrder As Integer + Dim _imageGuid As String + Dim _description As String + +#End Region + +#Region " Public Properties " + + Public Property ImageID() As Integer + Get + Return _imageID + End Get + Set(ByVal value As Integer) + _imageID = value + End Set + End Property + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal value As Integer) + _articleID = value + End Set + End Property + + Public Property Title() As String + Get + Return _title + End Get + Set(ByVal value As String) + _title = value + End Set + End Property + + Public Property FileName() As String + Get + Return _fileName + End Get + Set(ByVal value As String) + _fileName = value + End Set + End Property + + Public Property Extension() As String + Get + Return _extension + End Get + Set(ByVal value As String) + _extension = value + End Set + End Property + + Public Property Size() As Integer + Get + Return _size + End Get + Set(ByVal value As Integer) + _size = value + End Set + End Property + + Public Property Width() As Integer + Get + Return _width + End Get + Set(ByVal value As Integer) + _width = value + End Set + End Property + + Public Property Height() As Integer + Get + Return _height + End Get + Set(ByVal value As Integer) + _height = value + End Set + End Property + + Public Property ContentType() As String + Get + Return _contentType + End Get + Set(ByVal value As String) + _contentType = value + End Set + End Property + + Public Property Folder() As String + Get + Return _folder + End Get + Set(ByVal value As String) + _folder = value + End Set + End Property + + Public Property SortOrder() As Integer + Get + Return _sortOrder + End Get + Set(ByVal value As Integer) + _sortOrder = value + End Set + End Property + + Public Property ImageGuid() As String + Get + Return _imageGuid + End Get + Set(ByVal value As String) + _imageGuid = value + End Set + End Property + + Public Property Description() As String + Get + Return _description + End Get + Set(ByVal value As String) + _description = value + End Set + End Property + +#End Region + + Public Function Clone() As Object Implements System.ICloneable.Clone + Return Me.MemberwiseClone + End Function + + End Class + +End Namespace diff --git a/Components/Import/FeedController.vb b/Components/Import/FeedController.vb new file mode 100755 index 0000000..52529c5 --- /dev/null +++ b/Components/Import/FeedController.vb @@ -0,0 +1,72 @@ +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles.Import + + Public Class FeedController + +#Region " Public Methods " + + Public Function [Get](ByVal feedID As Integer) As FeedInfo + + Return CType(CBO.FillObject(DataProvider.Instance().GetFeed(feedID), GetType(FeedInfo)), FeedInfo) + + End Function + + Public Function GetFeedList(ByVal moduleID As Integer, ByVal showActiveOnly As Boolean) As List(Of FeedInfo) + + Return CBO.FillCollection(Of FeedInfo)(DataProvider.Instance().GetFeedList(moduleID, showActiveOnly)) + + End Function + + Public Function Add(ByVal objFeed As FeedInfo) As Integer + + Dim feedID As Integer = CType(DataProvider.Instance().AddFeed(objFeed.ModuleID, objFeed.Title, objFeed.Url, objFeed.UserID, objFeed.AutoFeature, objFeed.IsActive, objFeed.DateMode, objFeed.AutoExpire, objFeed.AutoExpireUnit), Integer) + + For Each objCategory As CategoryInfo In objFeed.Categories + AddFeedCategory(feedID, objCategory.CategoryID) + Next + + Return feedID + + End Function + + Public Sub Update(ByVal objFeed As FeedInfo) + + DataProvider.Instance().UpdateFeed(objFeed.FeedID, objFeed.ModuleID, objFeed.Title, objFeed.Url, objFeed.UserID, objFeed.AutoFeature, objFeed.IsActive, objFeed.DateMode, objFeed.AutoExpire, objFeed.AutoExpireUnit) + + DeleteFeedCategory(objFeed.FeedID) + For Each objCategory As CategoryInfo In objFeed.Categories + AddFeedCategory(objFeed.FeedID, objCategory.CategoryID) + Next + + End Sub + + Public Sub Delete(ByVal feedID As Integer) + + DataProvider.Instance().DeleteFeed(feedID) + + End Sub + + Public Function AddFeedCategory(ByVal feedID As Integer, ByVal categoryID As Integer) As Integer + + DataProvider.Instance().AddFeedCategory(feedID, categoryID) + + End Function + + Public Function GetFeedCategoryList(ByVal feedID As Integer) As List(Of CategoryInfo) + + Return CBO.FillCollection(Of CategoryInfo)(DataProvider.Instance().GetFeedCategoryList(feedID)) + + End Function + + Public Sub DeleteFeedCategory(ByVal feedID As Integer) + + DataProvider.Instance().DeleteFeedCategory(feedID) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/Import/FeedDateMode.vb b/Components/Import/FeedDateMode.vb new file mode 100755 index 0000000..ee102d6 --- /dev/null +++ b/Components/Import/FeedDateMode.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2010 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles.Import + + Public Enum FeedDateMode + + ImportDate = 0 + FeedDate = 1 + + End Enum + +End Namespace diff --git a/Components/Import/FeedExpiryType.vb b/Components/Import/FeedExpiryType.vb new file mode 100755 index 0000000..ab62fce --- /dev/null +++ b/Components/Import/FeedExpiryType.vb @@ -0,0 +1,14 @@ +Namespace Ventrian.NewsArticles.Import + + Public Enum FeedExpiryType + + None = -1 + Minute = 0 + Hour = 1 + Day = 2 + Month = 3 + Year = 4 + + End Enum + +End Namespace diff --git a/Components/Import/FeedInfo.vb b/Components/Import/FeedInfo.vb new file mode 100755 index 0000000..3039b9d --- /dev/null +++ b/Components/Import/FeedInfo.vb @@ -0,0 +1,138 @@ +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles.Import + + Public Class FeedInfo + +#Region " Private Members " + + Dim _feedID As Integer = Null.NullInteger + Dim _moduleID As Integer + Dim _title As String + Dim _url As String + Dim _userID As Integer + Dim _autoFeature As Boolean + Dim _isActive As Boolean + Dim _dateMode As FeedDateMode + + Dim _autoExpire As Integer + Dim _autoExpireUnit As FeedExpiryType + + Dim _categories As List(Of CategoryInfo) + +#End Region + +#Region " Private Properties " + + Public Property FeedID() As Integer + Get + Return _feedID + End Get + Set(ByVal Value As Integer) + _feedID = Value + End Set + End Property + + Public Property ModuleID() As Integer + Get + Return _moduleID + End Get + Set(ByVal Value As Integer) + _moduleID = Value + End Set + End Property + + Public Property Title() As String + Get + Return _title + End Get + Set(ByVal Value As String) + _title = Value + End Set + End Property + + Public Property Url() As String + Get + Return _url + End Get + Set(ByVal Value As String) + _url = Value + End Set + End Property + + Public Property UserID() As Integer + Get + Return _userID + End Get + Set(ByVal Value As Integer) + _userID = Value + End Set + End Property + + Public Property AutoFeature() As Boolean + Get + Return _autoFeature + End Get + Set(ByVal Value As Boolean) + _autoFeature = Value + End Set + End Property + + Public Property IsActive() As Boolean + Get + Return _isActive + End Get + Set(ByVal Value As Boolean) + _isActive = Value + End Set + End Property + + Public Property DateMode() As FeedDateMode + Get + Return _dateMode + End Get + Set(ByVal Value As FeedDateMode) + _dateMode = Value + End Set + End Property + + Public Property AutoExpire() As Integer + Get + Return _autoExpire + End Get + Set(ByVal Value As Integer) + _autoExpire = Value + End Set + End Property + + Public Property AutoExpireUnit() As FeedExpiryType + Get + Return _autoExpireUnit + End Get + Set(ByVal Value As FeedExpiryType) + _autoExpireUnit = Value + End Set + End Property + + Public Property Categories() As List(Of CategoryInfo) + Get + If (_categories Is Nothing) Then + If (_feedID = Null.NullInteger) Then + _categories = New List(Of CategoryInfo) + Else + Dim objFeedController As New FeedController + _categories = objFeedController.GetFeedCategoryList(_feedID) + End If + End If + Return _categories + End Get + Set(ByVal Value As List(Of CategoryInfo)) + _categories = Value + End Set + End Property + +#End Region + + End Class + +End Namespace diff --git a/Components/Import/RssImportJob.vb b/Components/Import/RssImportJob.vb new file mode 100755 index 0000000..67552b0 --- /dev/null +++ b/Components/Import/RssImportJob.vb @@ -0,0 +1,437 @@ +Imports System.Xml.XPath + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Scheduling +Imports System.Xml +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Portals + +Namespace Ventrian.NewsArticles.Import + + Public Class RssImportJob + Inherits SchedulerClient + +#Region " Private Methods " + + Private Sub ImportFeed(ByVal objFeed As FeedInfo) + + Dim doc As XPathDocument + Dim navigator As XPathNavigator + Dim nodes As XPathNodeIterator + Dim node As XPathNavigator + + ' Create a new XmlDocument + doc = New XPathDocument(objFeed.Url) + + ' Create navigator + navigator = doc.CreateNavigator() + + Dim mngr As New XmlNamespaceManager(navigator.NameTable) + mngr.AddNamespace("content", "http://purl.org/rss/1.0/modules/content/") + + ' Get forecast with XPath + nodes = navigator.Select("/rss/channel/item") + + If (nodes.Count = 0) Then + ImportFeedRDF(objFeed) + End If + + Dim publishedDate As DateTime = DateTime.Now + + While nodes.MoveNext() + node = nodes.Current + + Dim nodeTitle As XPathNavigator + Dim nodeDescription As XPathNavigator + Dim nodeLink As XPathNavigator + Dim nodeDate As XPathNavigator + Dim nodeGuid As XPathNavigator + Dim nodeEncoded As XPathNavigator + + nodeTitle = node.SelectSingleNode("title") + nodeDescription = node.SelectSingleNode("description") + nodeLink = node.SelectSingleNode("link") + nodeDate = node.SelectSingleNode("pubDate") + nodeGuid = node.SelectSingleNode("guid") + nodeEncoded = node.SelectSingleNode("content:encoded", mngr) + + Dim summary As String = "" + If (nodeDescription IsNot Nothing) Then + summary = nodeDescription.Value + End If + + Dim pageDetail As String = "" + If (nodeEncoded IsNot Nothing) Then + pageDetail = nodeEncoded.Value + Else + If (nodeDescription IsNot Nothing) Then + pageDetail = nodeDescription.Value + End If + End If + + Dim guid As String = "" + If (nodeGuid IsNot Nothing) Then + guid = nodeGuid.Value + Else + guid = nodeLink.Value + End If + + Dim objArticleController As New ArticleController() + Dim objArticles As List(Of ArticleInfo) = objArticleController.GetArticleList(objFeed.ModuleID, DateTime.Now, Null.NullDate, Nothing, False, Nothing, 25, 1, 25, ArticleConstants.DEFAULT_SORT_BY, ArticleConstants.DEFAULT_SORT_DIRECTION, True, False, Null.NullString, Null.NullInteger, True, True, False, False, False, False, Null.NullString, Nothing, False, guid, Null.NullInteger, Null.NullString, Null.NullString, Nothing) + + If (objArticles.Count = 0) Then + + Dim objArticle As New ArticleInfo + + objArticle.AuthorID = objFeed.UserID + objArticle.CreatedDate = DateTime.Now + objArticle.Status = StatusType.Published + objArticle.CommentCount = 0 + objArticle.RatingCount = 0 + objArticle.Rating = 0 + objArticle.ShortUrl = "" + + objArticle.Title = nodeTitle.Value + objArticle.IsFeatured = objFeed.AutoFeature + objArticle.IsSecure = False + objArticle.Summary = summary + + objArticle.LastUpdate = objArticle.CreatedDate + objArticle.LastUpdateID = objFeed.UserID + objArticle.ModuleID = objFeed.ModuleID + + objArticle.Url = nodeLink.Value + If (objFeed.DateMode = FeedDateMode.ImportDate) Then + objArticle.StartDate = publishedDate + Else + Try + Dim val As String = nodeDate.Value + + val = val.Replace("PST", "-0800") + val = val.Replace("MST", "-0700") + val = val.Replace("CST", "-0600") + val = val.Replace("EST", "-0500") + + objArticle.StartDate = DateTime.Parse(val) + Catch + objArticle.StartDate = publishedDate + End Try + End If + + objArticle.EndDate = Null.NullDate + If (objFeed.AutoExpire <> Null.NullInteger And objFeed.AutoExpireUnit <> FeedExpiryType.None) Then + Select Case objFeed.AutoExpireUnit + + Case FeedExpiryType.Minute + objArticle.EndDate = DateTime.Now.AddMinutes(objFeed.AutoExpire) + Exit Select + + Case FeedExpiryType.Hour + objArticle.EndDate = DateTime.Now.AddHours(objFeed.AutoExpire) + Exit Select + + Case FeedExpiryType.Day + objArticle.EndDate = DateTime.Now.AddDays(objFeed.AutoExpire) + Exit Select + + Case FeedExpiryType.Month + objArticle.EndDate = DateTime.Now.AddMonths(objFeed.AutoExpire) + Exit Select + + Case FeedExpiryType.Year + objArticle.EndDate = DateTime.Now.AddYears(objFeed.AutoExpire) + Exit Select + + End Select + End If + + objArticle.RssGuid = guid + + objArticle.ArticleID = objArticleController.AddArticle(objArticle) + + Dim objPage As New PageInfo + objPage.PageText = pageDetail + objPage.ArticleID = objArticle.ArticleID + objPage.Title = objArticle.Title + + Dim objPageController As New PageController() + objPageController.AddPage(objPage) + + For Each objCategory As CategoryInfo In objFeed.Categories + objArticleController.AddArticleCategory(objArticle.ArticleID, objCategory.CategoryID) + Next + + publishedDate = publishedDate.AddSeconds(-1) + + Else + + If (objArticles.Count = 1) Then + + objArticles(0).Title = nodeTitle.Value + objArticles(0).Summary = summary + objArticles(0).LastUpdate = DateTime.Now + objArticleController.UpdateArticle(objArticles(0)) + + Dim objPageController As New PageController() + Dim objPages As ArrayList = objPageController.GetPageList(objArticles(0).ArticleID) + + If (objPages.Count > 0) Then + objPages(0).PageText = pageDetail + objPageController.UpdatePage(objPages(0)) + End If + + End If + + End If + + End While + + End Sub + + Private Sub ImportFeedRDF(ByVal objFeed As FeedInfo) + + Dim doc As XPathDocument + Dim navigator As XPathNavigator + Dim nodes As XPathNodeIterator + Dim node As XPathNavigator + + ' Create a new XmlDocument + doc = New XPathDocument(objFeed.Url) + + ' Create navigator + navigator = doc.CreateNavigator() + + Dim mngr As New XmlNamespaceManager(navigator.NameTable) + mngr.AddNamespace("rdf", "http://www.w3.org/1999/02/22-rdf-syntax-ns#") + mngr.AddNamespace("dc", "http://purl.org/dc/elements/1.1/") + + ' Get forecast with XPath + nodes = navigator.Select("/rdf:RDF/*", mngr) + + While nodes.MoveNext() + node = nodes.Current + + If (node.Name.ToLower() = "item") Then + + Dim title As String = "" + Dim description As String = "" + Dim link As String = "" + Dim dateNode As String = "" + Dim guid As String = "" + + Dim objChildNodes As XPathNodeIterator = node.SelectChildren(XPathNodeType.All) + + While objChildNodes.MoveNext() + Dim objChildNode As XPathNavigator = objChildNodes.Current + + Select Case objChildNode.Name.ToLower() + + Case "title" + title = objChildNode.Value + Exit Select + + Case "description" + description = objChildNode.Value + Exit Select + + Case "link" + link = objChildNode.Value + Exit Select + + Case "date" + dateNode = objChildNode.Value + Exit Select + + Case "guid" + guid = objChildNode.Value + Exit Select + + End Select + End While + + If (title <> "" And link <> "") Then + + If (guid = "") Then + guid = link + End If + + Dim objArticleController As New ArticleController() + Dim objArticles As List(Of ArticleInfo) = objArticleController.GetArticleList(objFeed.ModuleID, DateTime.Now, Null.NullDate, Nothing, False, Nothing, 1, 1, 10, ArticleConstants.DEFAULT_SORT_BY, ArticleConstants.DEFAULT_SORT_DIRECTION, True, False, Null.NullString, Null.NullInteger, True, True, False, False, False, False, Null.NullString, Nothing, False, guid, Null.NullInteger, Null.NullString, Null.NullString, Nothing) + + If (objArticles.Count = 0) Then + + Dim publishedDate As DateTime = DateTime.Now + + Dim objArticle As New ArticleInfo + + objArticle.AuthorID = objFeed.UserID + objArticle.CreatedDate = DateTime.Now + objArticle.Status = StatusType.Published + objArticle.CommentCount = 0 + objArticle.RatingCount = 0 + objArticle.Rating = 0 + objArticle.ShortUrl = "" + + objArticle.Title = title + objArticle.IsFeatured = objFeed.AutoFeature + objArticle.IsSecure = False + objArticle.Summary = description + + objArticle.LastUpdate = publishedDate + objArticle.LastUpdateID = objFeed.UserID + objArticle.ModuleID = objFeed.ModuleID + + objArticle.Url = link + If (objFeed.DateMode = FeedDateMode.ImportDate) Then + objArticle.StartDate = publishedDate + Else + Try + Dim val As String = dateNode + + val = val.Replace("PST", "-0800") + val = val.Replace("MST", "-0700") + val = val.Replace("CST", "-0600") + val = val.Replace("EST", "-0500") + + objArticle.StartDate = DateTime.Parse(val) + Catch + objArticle.StartDate = publishedDate + End Try + End If + + objArticle.EndDate = Null.NullDate + If (objFeed.AutoExpire <> Null.NullInteger And objFeed.AutoExpireUnit <> FeedExpiryType.None) Then + Select Case objFeed.AutoExpireUnit + + Case FeedExpiryType.Minute + objArticle.EndDate = DateTime.Now.AddMinutes(objFeed.AutoExpire) + Exit Select + + Case FeedExpiryType.Hour + objArticle.EndDate = DateTime.Now.AddHours(objFeed.AutoExpire) + Exit Select + + Case FeedExpiryType.Day + objArticle.EndDate = DateTime.Now.AddDays(objFeed.AutoExpire) + Exit Select + + Case FeedExpiryType.Month + objArticle.EndDate = DateTime.Now.AddMonths(objFeed.AutoExpire) + Exit Select + + Case FeedExpiryType.Year + objArticle.EndDate = DateTime.Now.AddYears(objFeed.AutoExpire) + Exit Select + + End Select + End If + + objArticle.RssGuid = guid + + objArticle.ArticleID = objArticleController.AddArticle(objArticle) + + Dim objPage As New PageInfo + objPage.PageText = description + objPage.ArticleID = objArticle.ArticleID + objPage.Title = objArticle.Title + + Dim objPageController As New PageController() + objPageController.AddPage(objPage) + + For Each objCategory As CategoryInfo In objFeed.Categories + objArticleController.AddArticleCategory(objArticle.ArticleID, objCategory.CategoryID) + Next + + publishedDate = publishedDate.AddSeconds(-1) + + End If + + End If + + End If + + End While + + End Sub + +#End Region + +#Region " Public Methods " + + Public Sub ImportFeeds() + + Dim objFeedController As New FeedController + Dim objFeeds As List(Of FeedInfo) = objFeedController.GetFeedList(Null.NullInteger, True) + + + For Each objFeed As FeedInfo In objFeeds + If (Me.ScheduleHistoryItem.GetSetting("NewsArticles-Import-Clear-" & objFeed.ModuleID) <> "") Then + If (Convert.ToBoolean(Me.ScheduleHistoryItem.GetSetting("NewsArticles-Import-Clear-" & objFeed.ModuleID))) Then + ' Delete Articles + Dim objArticleController As New ArticleController + Dim objArticles As List(Of ArticleInfo) = objArticleController.GetArticleList(objFeed.ModuleID, DateTime.Now, Null.NullDate, Nothing, False, Nothing, 1000, 1, 1000, ArticleConstants.DEFAULT_SORT_BY, ArticleConstants.DEFAULT_SORT_DIRECTION, True, False, Null.NullString, Null.NullInteger, True, True, False, False, False, False, Null.NullString, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, Nothing) + + Me.ScheduleHistoryItem.AddLogNote(objArticles.Count.ToString()) + For Each objArticle As ArticleInfo In objArticles + objArticleController.DeleteArticleCategories(objArticle.ArticleID) + objArticleController.DeleteArticle(objArticle.ArticleID, objFeed.ModuleID) + Next + + End If + End If + Next + + For Each objFeed As FeedInfo In objFeeds + Try + Me.ScheduleHistoryItem.AddLogNote(objFeed.Url) 'OPTIONAL + ImportFeed(objFeed) + Catch ex As Exception + Me.ScheduleHistoryItem.AddLogNote("News Articles -> Failure to import feed: " + objFeed.Url + ex.ToString()) 'OPTIONAL + End Try + Next + + End Sub + +#End Region + +#Region " Constructors " + + Public Sub New(ByVal objScheduleHistoryItem As DotNetNuke.Services.Scheduling.ScheduleHistoryItem) + + MyBase.new() + Me.ScheduleHistoryItem = objScheduleHistoryItem + + End Sub + +#End Region + +#Region " Interface Methods " + + Public Overrides Sub DoWork() + + + Try + 'notification that the event is progressing + Me.Progressing() 'OPTIONAL + ImportFeeds() + Me.ScheduleHistoryItem.Succeeded = True 'REQUIRED + + Catch exc As Exception 'REQUIRED + + Me.ScheduleHistoryItem.Succeeded = False 'REQUIRED + Me.ScheduleHistoryItem.AddLogNote("News Articles -> Import RSS job failed. " + exc.ToString) 'OPTIONAL + 'notification that we have errored + Me.Errored(exc) 'REQUIRED + 'log the exception + LogException(exc) 'OPTIONAL + + End Try + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/LatestArticleController.vb b/Components/LatestArticleController.vb new file mode 100755 index 0000000..64fa536 --- /dev/null +++ b/Components/LatestArticleController.vb @@ -0,0 +1,58 @@ +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Common.Utilities +Imports System.Xml + +Namespace Ventrian.NewsArticles + + Public Class LatestArticleController + Implements IPortable + + Public Function ExportModule(ByVal ModuleID As Integer) As String Implements IPortable.ExportModule + + Dim objModuleController As New ModuleController + Dim settings As Hashtable = objModuleController.GetModuleSettings(ModuleID) + + Dim objLatestLayoutController As New LatestLayoutController() + + Dim objLayoutHeader As LayoutInfo = objLatestLayoutController.GetLayout(LatestLayoutType.Listing_Header_Html, ModuleID, settings) + Dim objLayoutItem As LayoutInfo = objLatestLayoutController.GetLayout(LatestLayoutType.Listing_Item_Html, ModuleID, settings) + Dim objLayoutFooter As LayoutInfo = objLatestLayoutController.GetLayout(LatestLayoutType.Listing_Footer_Html, ModuleID, settings) + Dim objLayoutEmpty As LayoutInfo = objLatestLayoutController.GetLayout(LatestLayoutType.Listing_Empty_Html, ModuleID, settings) + + Dim strXML As String = "" + + strXML += "" & XmlUtils.XMLEncode(objLayoutHeader.Template) & "" + strXML += "" & XmlUtils.XMLEncode(objLayoutItem.Template) & "" + strXML += "" & XmlUtils.XMLEncode(objLayoutFooter.Template) & "" + strXML += "" & XmlUtils.XMLEncode(objLayoutEmpty.Template) & "" + + Return strXML + + End Function + + Public Sub ImportModule(ByVal ModuleID As Integer, ByVal Content As String, ByVal Version As String, ByVal UserId As Integer) Implements IPortable.ImportModule + + Dim objXmlDocument As New XmlDocument() + objXmlDocument.LoadXml("" & Content & "") + + Dim objLatestLayoutController As New LatestLayoutController() + For Each xmlChildNode As XmlNode In objXmlDocument.ChildNodes(0).ChildNodes + If (xmlChildNode.Name = "layoutHeader") Then + objLatestLayoutController.UpdateLayout(LatestLayoutType.Listing_Header_Html, ModuleID, xmlChildNode.InnerText) + End If + If (xmlChildNode.Name = "layoutItem") Then + objLatestLayoutController.UpdateLayout(LatestLayoutType.Listing_Item_Html, ModuleID, xmlChildNode.InnerText) + End If + If (xmlChildNode.Name = "layoutFooter") Then + objLatestLayoutController.UpdateLayout(LatestLayoutType.Listing_Footer_Html, ModuleID, xmlChildNode.InnerText) + End If + If (xmlChildNode.Name = "layoutEmpty") Then + objLatestLayoutController.UpdateLayout(LatestLayoutType.Listing_Empty_Html, ModuleID, xmlChildNode.InnerText) + End If + Next + + End Sub + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/Layout/LatestLayoutController.vb b/Components/Layout/LatestLayoutController.vb new file mode 100755 index 0000000..590dbd0 --- /dev/null +++ b/Components/Layout/LatestLayoutController.vb @@ -0,0 +1,160 @@ +Imports System.IO + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class LatestLayoutController + +#Region " Public Methods " + + Public Function GetLayout(ByVal type As LatestLayoutType, ByVal moduleID As Integer, ByVal settings As Hashtable) As LayoutInfo + + Dim cacheKey As String = "LatestArticles-" & moduleID.ToString() & "-" & type.ToString() + Dim objLayout As LayoutInfo = CType(DataCache.GetCache(cacheKey), LayoutInfo) + + If (objLayout Is Nothing) Then + + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + + objLayout = New LayoutInfo + Dim folderPath As String = HttpContext.Current.Server.MapPath("~\DesktopModules\DnnForge - LatestArticles\Templates\" & moduleID.ToString()) + Dim filePath As String = HttpContext.Current.Server.MapPath("~\DesktopModules\DnnForge - LatestArticles\Templates\" & moduleID.ToString() & "\" & type.ToString().Replace("_", ".")) + + If (File.Exists(filePath) = False) Then + ' Load from settings... + + Dim _layoutMode As LayoutModeType = ArticleConstants.LATEST_ARTICLES_LAYOUT_MODE_DEFAULT + If (settings.Contains(ArticleConstants.LATEST_ARTICLES_LAYOUT_MODE)) Then + _layoutMode = CType(System.Enum.Parse(GetType(LayoutModeType), settings(ArticleConstants.LATEST_ARTICLES_LAYOUT_MODE).ToString()), LayoutModeType) + End If + + Select Case type + + Case LatestLayoutType.Listing_Header_Html + + Dim layoutHeader As String + + If (_layoutMode = LayoutModeType.Simple) Then + If (settings.Contains(ArticleConstants.SETTING_HTML_HEADER)) Then + layoutHeader = settings(ArticleConstants.SETTING_HTML_HEADER).ToString() + Else + layoutHeader = ArticleConstants.DEFAULT_HTML_HEADER + End If + Else + If (settings.Contains(ArticleConstants.SETTING_HTML_HEADER_ADVANCED)) Then + layoutHeader = settings(ArticleConstants.SETTING_HTML_HEADER_ADVANCED).ToString() + Else + layoutHeader = ArticleConstants.DEFAULT_HTML_HEADER_ADVANCED + End If + End If + + If Not (Directory.Exists(folderPath)) Then + Directory.CreateDirectory(folderPath) + End If + + File.WriteAllText(filePath, layoutHeader) + Exit Select + + Case LatestLayoutType.Listing_Item_Html + + Dim layoutItem As String + + If (_layoutMode = LayoutModeType.Simple) Then + If (settings.Contains(ArticleConstants.SETTING_HTML_BODY)) Then + layoutItem = settings(ArticleConstants.SETTING_HTML_BODY).ToString() + Else + layoutItem = ArticleConstants.DEFAULT_HTML_BODY + End If + Else + If (settings.Contains(ArticleConstants.SETTING_HTML_BODY_ADVANCED)) Then + layoutItem = settings(ArticleConstants.SETTING_HTML_BODY_ADVANCED).ToString() + Else + layoutItem = ArticleConstants.DEFAULT_HTML_BODY_ADVANCED + End If + End If + + If Not (Directory.Exists(folderPath)) Then + Directory.CreateDirectory(folderPath) + End If + + File.WriteAllText(filePath, layoutItem) + Exit Select + + Case LatestLayoutType.Listing_Footer_Html + + Dim layoutFooter As String + + If (_layoutMode = LayoutModeType.Simple) Then + If (settings.Contains(ArticleConstants.SETTING_HTML_FOOTER)) Then + layoutFooter = settings(ArticleConstants.SETTING_HTML_FOOTER).ToString() + Else + layoutFooter = ArticleConstants.DEFAULT_HTML_FOOTER + End If + Else + If (settings.Contains(ArticleConstants.SETTING_HTML_FOOTER_ADVANCED)) Then + layoutFooter = settings(ArticleConstants.SETTING_HTML_FOOTER_ADVANCED).ToString() + Else + layoutFooter = ArticleConstants.DEFAULT_HTML_FOOTER_ADVANCED + End If + End If + + If Not (Directory.Exists(folderPath)) Then + Directory.CreateDirectory(folderPath) + End If + + File.WriteAllText(filePath, layoutFooter) + Exit Select + + Case LatestLayoutType.Listing_Empty_Html + + Dim noArticles As String = ArticleConstants.SETTING_HTML_NO_ARTICLES + If (settings.Contains(ArticleConstants.SETTING_HTML_NO_ARTICLES)) Then + noArticles = settings(ArticleConstants.SETTING_HTML_NO_ARTICLES).ToString() + End If + noArticles = "
" & noArticles & "
" + + If Not (Directory.Exists(folderPath)) Then + Directory.CreateDirectory(folderPath) + End If + + File.WriteAllText(filePath, noArticles) + Exit Select + + End Select + + End If + + objLayout.Template = File.ReadAllText(filePath) + objLayout.Tokens = objLayout.Template.Split(delimiter) + + DataCache.SetCache(cacheKey, objLayout, New CacheDependency(filePath)) + + End If + + Return objLayout + + End Function + + Public Sub UpdateLayout(ByVal type As LatestLayoutType, ByVal moduleID As Integer, ByVal content As String) + + Dim folderPath As String = HttpContext.Current.Server.MapPath("~\DesktopModules\DnnForge - LatestArticles\Templates\" & moduleID.ToString()) + Dim filePath As String = HttpContext.Current.Server.MapPath("~\DesktopModules\DnnForge - LatestArticles\Templates\" & moduleID.ToString() & "\" & type.ToString().Replace("_", ".")) + + If Not (Directory.Exists(folderPath)) Then + Directory.CreateDirectory(folderPath) + End If + + File.WriteAllText(filePath, content) + + Dim cacheKey As String = "LatestArticles-" & moduleID.ToString() & "-" & type.ToString() + DataCache.RemoveCache(cacheKey) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/Layout/LatestLayoutType.vb b/Components/Layout/LatestLayoutType.vb new file mode 100755 index 0000000..6b576d9 --- /dev/null +++ b/Components/Layout/LatestLayoutType.vb @@ -0,0 +1,18 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Enum LatestLayoutType + + Listing_Header_Html + Listing_Item_Html + Listing_Footer_Html + Listing_Empty_Html + + End Enum + +End Namespace diff --git a/Components/Layout/LayoutController.vb b/Components/Layout/LayoutController.vb new file mode 100755 index 0000000..504f4f5 --- /dev/null +++ b/Components/Layout/LayoutController.vb @@ -0,0 +1,4683 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.IO +Imports System.Text.RegularExpressions +Imports System.Web +Imports System.Web.UI +Imports System.Web.UI.WebControls +Imports Ventrian.NewsArticles.Components.Common + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Services.Localization +Imports DotNetNuke.Security +Imports DotNetNuke.Entities.Profile +Imports DotNetNuke.Common.Lists +Imports DotNetNuke.Entities.Portals +Imports Ventrian.NewsArticles.Components.CustomFields + +Imports Ventrian.NewsArticles.Base +Imports DotNetNuke.Web.Client.ClientResourceManagement +Imports DotNetNuke.Web.Client +Imports DotNetNuke.Services.Cache + +Namespace Ventrian.NewsArticles + + Public Class LayoutController + +#Region " Constructors " + + Public Sub New(ByVal portalSettings As PortalSettings, ByVal articleSettings As ArticleSettings, ByVal objModule As ModuleInfo, ByVal objPage As Page) + + _portalSettings = portalSettings + _articleSettings = articleSettings + _articleModule = objModule + _page = objPage + + End Sub + + Public Sub New(ByVal moduleContext As NewsArticleModuleBase) + + _portalSettings = moduleContext.PortalSettings + _articleSettings = moduleContext.ArticleSettings + _articleModule = moduleContext.ModuleContext.Configuration + _page = moduleContext.Page + + End Sub + + Public Sub New(ByVal moduleContext As NewsArticleModuleBase, ByVal pageId As Integer) + + _portalSettings = moduleContext.PortalSettings + _articleSettings = moduleContext.ArticleSettings + _articleModule = moduleContext.ModuleContext.Configuration + _page = moduleContext.Page + _pageId = pageId + + End Sub + +#End Region + +#Region " Private Members " + + Private ReadOnly _portalSettings As PortalSettings + Private ReadOnly _articleSettings As ArticleSettings + Private ReadOnly _articleModule As ModuleInfo + Private ReadOnly _page As Page + + Private _pageId As Integer = Null.NullInteger + Private _tab As DotNetNuke.Entities.Tabs.TabInfo + + Private _objPages As ArrayList + Private _objRelatedArticles As List(Of ArticleInfo) + + Dim _author As UserInfo + + Dim _includeCategory As Boolean = False + + Dim _profileProperties As ProfilePropertyDefinitionCollection + +#End Region + +#Region " Private Properties " + + Private ReadOnly Property PortalSettings() As PortalSettings + Get + Return _portalSettings + End Get + End Property + + Private ReadOnly Property ArticleSettings() As ArticleSettings + Get + Return _articleSettings + End Get + End Property + + Private ReadOnly Property ArticleModule() As ModuleInfo + Get + Return _articleModule + End Get + End Property + + Private ReadOnly Property Page() As Page + Get + Return _page + End Get + End Property + + Private ReadOnly Property Pages(ByVal articleId As Integer) As ArrayList + Get + If (_objPages Is Nothing) Then + Dim objPageController As New PageController + _objPages = objPageController.GetPageList(articleId) + End If + Return _objPages + End Get + End Property + + Private ReadOnly Property Server() As HttpServerUtility + Get + Return _page.Server + End Get + End Property + + Private ReadOnly Property Request() As HttpRequest + Get + Return _page.Request + End Get + End Property + + Private ReadOnly Property UserId() As Integer + Get + Return UserController.GetCurrentUserInfo().UserID + End Get + End Property + + Private ReadOnly Property Tab() As DotNetNuke.Entities.Tabs.TabInfo + Get + If (_tab Is Nothing) Then + Dim objTabController As New DotNetNuke.Entities.Tabs.TabController() + _tab = objTabController.GetTab(ArticleModule.TabID, PortalSettings.PortalId, False) + End If + + Return _tab + End Get + End Property + + Private ReadOnly Property IsEditable() As Boolean + Get + If (Permissions.ModulePermissionController.CanEditModuleContent(ArticleModule)) Then + Return True + End If + Return False + End Get + End Property + +#End Region + +#Region " Public Properties " + + + Public Property IncludeCategory() As Boolean + Get + Return _includeCategory + End Get + Set(ByVal value As Boolean) + _includeCategory = value + End Set + End Property + +#End Region + +#Region " Private Methods " + + Private Function Author(ByVal authorID As Integer) As UserInfo + + If (authorID = Null.NullInteger) Then + Return Nothing + End If + + If (_author Is Nothing) Then + _author = UserController.GetUserById(PortalSettings.PortalId, authorID) + Else + If (_author.UserID = authorID) Then + Return _author + Else + _author = UserController.GetUserById(PortalSettings.PortalId, authorID) + End If + End If + + Return _author + + End Function + + Public Function BBCode(ByVal strTextToReplace As String) As String + + '//Define regex + Dim regExp As Regex + + '//Regex for URL tag without anchor + regExp = New Regex("\[url\]([^\]]+)\[\/url\]", RegexOptions.IgnoreCase) + Dim m As Match = regExp.Match(strTextToReplace) + Do While m.Success + strTextToReplace = strTextToReplace.Replace(m.Value, "" & m.Groups(1).Value & "") + m = m.NextMatch() + Loop + + '//Regex for URL with anchor + regExp = New Regex("\[url=([^\]]+)\]([^\]]+)\[\/url\]", RegexOptions.IgnoreCase) + m = regExp.Match(strTextToReplace) + Do While m.Success + strTextToReplace = strTextToReplace.Replace(m.Value, "" & m.Groups(2).Value & "") + m = m.NextMatch() + Loop + + '//Quote text + regExp = New Regex("\[quote\](.+?)\[\/quote\]", RegexOptions.IgnoreCase) + strTextToReplace = regExp.Replace(strTextToReplace, "$1") + + '//Bold text + regExp = New Regex("\[b\](.+?)\[\/b\]", RegexOptions.IgnoreCase) + strTextToReplace = regExp.Replace(strTextToReplace, "$1") + + '//Italic text + regExp = New Regex("\[i\](.+?)\[\/i\]", RegexOptions.IgnoreCase) + strTextToReplace = regExp.Replace(strTextToReplace, "$1") + + '//Underline text + regExp = New Regex("\[u\](.+?)\[\/u\]", RegexOptions.IgnoreCase) + strTextToReplace = regExp.Replace(strTextToReplace, "$1") + + Return strTextToReplace + + End Function + + ' utility function to convert a byte array into a hex string + Private Function ByteArrayToString(ByVal arrInput() As Byte) As String + + Dim strOutput As New System.Text.StringBuilder(arrInput.Length) + + For i As Integer = 0 To arrInput.Length - 1 + strOutput.Append(arrInput(i).ToString("X2")) + Next + + Return strOutput.ToString().ToLower + + End Function + + Protected Function EncodeComment(ByVal objComment As CommentInfo) As String + + If (objComment.Type = 0) Then + Dim body As String = objComment.Comment + Return BBCode(body) + Else + Return objComment.Comment + End If + + End Function + + ' Returns string with binary notation of b bytes, + ' rounded to 2 decimal places , eg + ' 123="123 Bytes", 2345="2.29 KB", + ' 1234567="1.18 MB", etc + ' b : double : numeric to convert + Function Numeric2Bytes(ByVal b As Double) As String + Dim bSize(8) As String + Dim i As Integer + + bSize(0) = "Bytes" + bSize(1) = "KB" 'Kilobytes + bSize(2) = "MB" 'Megabytes + bSize(3) = "GB" 'Gigabytes + bSize(4) = "TB" 'Terabytes + bSize(5) = "PB" 'Petabytes + bSize(6) = "EB" 'Exabytes + bSize(7) = "ZB" 'Zettabytes + bSize(8) = "YB" 'Yottabytes + + b = CDbl(b) ' Make sure var is a Double (not just + ' variant) + For i = UBound(bSize) To 0 Step -1 + If b >= (1024 ^ i) Then + Numeric2Bytes = ThreeNonZeroDigits(b / (1024 ^ _ + i)) & " " & bSize(i) + Return Numeric2Bytes + End If + Next + + Return "" + End Function + + ' Return the value formatted to include at most three + ' non-zero digits and at most two digits after the + ' decimal point. Examples: + ' 1 + ' 123 + ' 12.3 + ' 1.23 + ' 0.12 + Private Function ThreeNonZeroDigits(ByVal value As Double) _ + As String + If value >= 100 Then + ' No digits after the decimal. + Return Format$(CInt(value)) + ElseIf value >= 10 Then + ' One digit after the decimal. + Return Format$(value, "0.0") + Else + ' Two digits after the decimal. + Return Format$(value, "0.00") + End If + End Function + + Private Function FormatImageUrl(ByVal imageUrl As String) As String + + If (imageUrl.ToLower().StartsWith("http://") Or imageUrl.ToLower().StartsWith("https://")) Then + Return imageUrl + Else + If (imageUrl.ToLower().StartsWith("fileid=")) Then + Dim objFileController As DotNetNuke.Services.FileSystem.FileController = New DotNetNuke.Services.FileSystem.FileController + Dim objFile As DotNetNuke.Services.FileSystem.FileInfo = objFileController.GetFileById(Convert.ToInt32(UrlUtils.GetParameterValue(imageUrl)), PortalSettings.PortalId) + If Not (objFile Is Nothing) Then + If (objFile.StorageLocation = 1) Then + ' Secure Url + Dim url As String = LinkClick(imageUrl, ArticleModule.TabID, ArticleModule.ModuleID) + + If (HttpContext.Current.Request.Url.Port = 80) Then + Return AddHTTP(HttpContext.Current.Request.Url.Host & url) + Else + Return AddHTTP(HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & url) + End If + Else + If (HttpContext.Current.Request.Url.Port = 80) Then + Return AddHTTP(HttpContext.Current.Request.Url.Host & PortalSettings.HomeDirectory & objFile.Folder & objFile.FileName) + Else + Return AddHTTP(HttpContext.Current.Request.Url.Host & ":" & HttpContext.Current.Request.Url.Port.ToString() & PortalSettings.HomeDirectory & objFile.Folder & objFile.FileName) + End If + End If + End If + End If + End If + + Return "" + + End Function + + Public Function GetArticleResource(ByVal key As String) As String + + Dim path As String = "~/DesktopModules/DnnForge - NewsArticles/" & Localization.LocalResourceDirectory & "/ViewArticle.ascx.resx" + Return Localization.GetString(key, path) + + End Function + + Private Function GetFieldValue(ByVal objCustomField As CustomFieldInfo, ByVal objArticle As ArticleInfo, ByVal showCaption As Boolean) As String + + Dim value As String = objArticle.CustomList(objCustomField.CustomFieldID).ToString() + If (objCustomField.FieldType = CustomFieldType.RichTextBox) Then + value = Server.HtmlDecode(objArticle.CustomList(objCustomField.CustomFieldID).ToString()) + + Else + If (objCustomField.FieldType = CustomFieldType.MultiCheckBox) Then + value = objArticle.CustomList(objCustomField.CustomFieldID).ToString().Replace("|", ", ") + End If + If (objCustomField.FieldType = CustomFieldType.MultiLineTextBox) Then + value = objArticle.CustomList(objCustomField.CustomFieldID).ToString().Replace(vbCrLf, "
") + End If + If (value <> "" And objCustomField.ValidationType = CustomFieldValidationType.Date) Then + Try + value = DateTime.Parse(value).ToShortDateString() + Catch + value = objArticle.CustomList(objCustomField.CustomFieldID).ToString() + End Try + End If + + If (value <> "" And objCustomField.ValidationType = CustomFieldValidationType.Currency) Then + Try + Dim culture As String = "en-US" + + Dim portalFormat As System.Globalization.CultureInfo = New System.Globalization.CultureInfo(culture) + Dim format As String = "{0:C2}" + value = String.Format(portalFormat.NumberFormat, format, Double.Parse(value)) + + Catch + value = objArticle.CustomList(objCustomField.CustomFieldID).ToString() + End Try + End If + End If + + If (showCaption) Then + value = "" & objCustomField.Caption & ": " & value + End If + + Return value + + End Function + + Private Function GetRelatedArticles(ByVal objArticle As ArticleInfo, ByVal count As Integer) As List(Of ArticleInfo) + + If (_objRelatedArticles IsNot Nothing) Then + Return _objRelatedArticles + End If + + Dim matchAllCategories As Boolean = False + If (ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAll Or ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAllTagsAny) Then + matchAllCategories = True + End If + + Dim matchAllTags As Boolean = False + If (ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAnyTagsAll Or ArticleSettings.RelatedMode = RelatedType.MatchTagsAll) Then + matchAllTags = True + End If + + Dim objArticleController As New ArticleController() + + Dim categoriesArray() As Integer = Nothing + If (ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAll Or ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAllTagsAny Or ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAny Or ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAnyTagsAll Or ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAnyTagsAny) Then + Dim categories As ArrayList = objArticleController.GetArticleCategories(objArticle.ArticleID) + Dim categoriesRelated As New List(Of Integer) + For Each objCategory As CategoryInfo In categories + categoriesRelated.Add(objCategory.CategoryID) + Next + If (categories.Count = 0) Then + categoriesRelated.Add(-1) + End If + categoriesArray = categoriesRelated.ToArray() + End If + + Dim tagsArray() As Integer = Nothing + If (ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAllTagsAny Or ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAnyTagsAll Or ArticleSettings.RelatedMode = RelatedType.MatchCategoriesAnyTagsAny Or ArticleSettings.RelatedMode = RelatedType.MatchTagsAll Or ArticleSettings.RelatedMode = RelatedType.MatchTagsAny) Then + Dim tagsRelated As New List(Of Integer) + If (objArticle.Tags <> "") Then + Dim objTagController As New TagController() + For Each tag As String In objArticle.Tags.Split(","c) + Dim objTag As TagInfo = objTagController.Get(objArticle.ModuleID, tag.ToLower().Trim()) + If (objTag IsNot Nothing) Then + tagsRelated.Add(objTag.TagID) + End If + Next + End If + If (tagsRelated.Count = 0) Then + tagsRelated.Add(-1) + End If + tagsArray = tagsRelated.ToArray() + End If + + _objRelatedArticles = objArticleController.GetArticleList(objArticle.ModuleID, DateTime.Now, Null.NullDate, categoriesArray, matchAllCategories, Nothing, (count + 1), 1, (count + 1), ArticleSettings.SortBy, ArticleSettings.SortDirection, True, False, Null.NullString, Null.NullInteger, ArticleSettings.ShowPending, True, False, False, False, False, Null.NullString, tagsArray, matchAllTags, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, Nothing) + + Dim positionToRemove As Integer = Null.NullInteger + + Dim i As Integer = 0 + For Each objRelatedArticle As ArticleInfo In _objRelatedArticles + If (objArticle.ArticleID = objRelatedArticle.ArticleID) Then + positionToRemove = i + End If + i = i + 1 + Next + + If (positionToRemove <> Null.NullInteger) Then + _objRelatedArticles.RemoveAt(positionToRemove) + End If + + If (_objRelatedArticles.Count = (count + 1)) Then + _objRelatedArticles.RemoveAt(count) + End If + + Return _objRelatedArticles + + End Function + + Private Function GetRatingImage(ByVal objArticle As ArticleInfo) As String + + If (objArticle.Rating = Null.NullDouble) Then + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-0-0.gif") + Else + + Select Case RoundToUnit(objArticle.Rating, 0.5, False) + + Case 1 + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-1-0.gif") + + Case 1.5 + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-1-5.gif") + + Case 2 + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-2-0.gif") + + Case 2.5 + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-2-5.gif") + + Case 3 + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-3-0.gif") + + Case 3.5 + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-3-5.gif") + + Case 4 + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-4-0.gif") + + Case 4.5 + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-4-5.gif") + + Case 5 + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-5-0.gif") + + End Select + + Return ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images/Rating/stars-0-0.gif") + + End If + + End Function + + Public Function GetSharedResource(ByVal key As String) As String + + Dim path As String = "~/DesktopModules/DnnForge - NewsArticles/" & Localization.LocalResourceDirectory & "/" & Localization.LocalSharedResourceFile + Return Localization.GetString(key, path) + + End Function + + ' calculate the MD5 hash of a given string + ' the string is first converted to a byte array + Public Function MD5CalcString(ByVal strData As String) As String + + Dim objMD5 As New System.Security.Cryptography.MD5CryptoServiceProvider + Dim arrData() As Byte + Dim arrHash() As Byte + + ' first convert the string to bytes (using UTF8 encoding for unicode characters) + arrData = Text.Encoding.UTF8.GetBytes(strData) + + ' hash contents of this byte array + arrHash = objMD5.ComputeHash(arrData) + + ' thanks objects + objMD5 = Nothing + + ' return formatted hash + Return ByteArrayToString(arrHash) + + End Function + + Private Function ProcessPostTokens(ByVal content As String, ByVal objArticle As ArticleInfo, ByRef generator As System.Random, ByVal objArticleSettings As ArticleSettings) As String + + If (objArticleSettings.ProcessPostTokens = False) Then + Return content + End If + + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + + Dim layoutArray As String() = content.Split(delimiter) + Dim formattedContent As String = "" + + For iPtr As Integer = 0 To layoutArray.Length - 1 Step 2 + + formattedContent += layoutArray(iPtr).ToString() + + If iPtr < layoutArray.Length - 1 Then + Select Case layoutArray(iPtr + 1) + Case Else + If (layoutArray(iPtr + 1).ToUpper().StartsWith("ARTICLELINK:")) Then + If (IsNumeric(layoutArray(iPtr + 1).Substring(12, layoutArray(iPtr + 1).Length - 12))) Then + Dim articleID As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(12, layoutArray(iPtr + 1).Length - 12)) + + Dim objArticleController As New ArticleController + Dim objArticleTarget As ArticleInfo = objArticleController.GetArticle(articleID) + + If (objArticleTarget IsNot Nothing) Then + Dim link As String = Common.GetArticleLink(objArticleTarget, Tab, ArticleSettings, False) + formattedContent += "" & objArticleTarget.Title & "" + End If + End If + Exit Select + End If + + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("IMAGETHUMBRANDOM:")) Then + + If (objArticle.ImageCount > 0) Then + + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString) + If (objImages.Count > 0) Then + + Dim randomImage As ImageInfo = objImages(generator.Next(0, objImages.Count - 1)) + + Dim val As String = layoutArray(iPtr + 1).Substring(17, layoutArray(iPtr + 1).Length - 17) + If (val.IndexOf(":"c) = -1) Then + Dim length As Integer = Convert.ToInt32(val) + + Dim objImage As New Image + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(randomImage.Folder & randomImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + + formattedContent += RenderControlAsString(objImage) + Else + + Dim arr() As String = val.Split(":"c) + + If (arr.Length = 2) Then + Dim width As Integer = Convert.ToInt32(val.Split(":"c)(0)) + Dim height As Integer = Convert.ToInt32(val.Split(":"c)(1)) + + Dim objImage As New Image + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(randomImage.Folder & randomImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + + formattedContent += RenderControlAsString(objImage) + End If + End If + + End If + + End If + Exit Select + End If + + formattedContent += "[" & layoutArray(iPtr + 1) & "]" + End Select + End If + + Next + + Return formattedContent + + End Function + + Private ReadOnly Property ProfileProperties() As ProfilePropertyDefinitionCollection + Get + If (_profileProperties Is Nothing) Then + _profileProperties = ProfileController.GetPropertyDefinitionsByPortal(PortalSettings.PortalId) + End If + Return _profileProperties + End Get + End Property + + Private Function RenderControlAsString(ByVal objControl As Control) As String + + Dim sb As New StringBuilder + Dim tw As New StringWriter(sb) + Dim hw As New HtmlTextWriter(tw) + + objControl.RenderControl(hw) + + Return sb.ToString() + + End Function + + Private Function RoundToUnit(ByVal d As Double, ByVal unit As Double, ByVal roundDown As Boolean) As Double + + If (roundDown) Then + Return Math.Round(Math.Round((d / unit) - 0.5, 0) * unit, 2) + Else + Return Math.Round(Math.Round((d / unit) + 0.5, 0) * unit, 2) + End If + + End Function + + Private Function StripHtml(ByVal html As String) As String + + Dim pattern As String = "<(.|\n)*?>" + Return Regex.Replace(html, pattern, String.Empty) + + End Function + +#End Region + + + Public Shared Function GetLayout(ByVal moduleContext As NewsArticleModuleBase, ByVal type As LayoutType) As LayoutInfo + + Return GetLayout(moduleContext.ArticleSettings, moduleContext.ModuleConfiguration, moduleContext.Page, type) + + End Function + + Public Shared Function GetLayout(ByVal articleSettings As ArticleSettings, ByVal articleModule As ModuleInfo, ByVal page As Page, ByVal type As LayoutType) As LayoutInfo + + Dim cacheKey As String = "NewsArticles-" & articleModule.TabModuleID.ToString() & type.ToString() + Dim objLayout As LayoutInfo = CType(DataCache.GetCache(cacheKey), LayoutInfo) + + If (objLayout Is Nothing) Then + + Const delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + + objLayout = New LayoutInfo + Dim path As String = page.MapPath("~\DesktopModules\DnnForge - NewsArticles\Templates\" & articleSettings.Template & "\" & type.ToString().Replace("_", ".")) + + If (File.Exists(path) = False) Then + ' Need to find a default... + path = page.MapPath("~\DesktopModules\DnnForge - NewsArticles\Templates\" & ArticleConstants.DEFAULT_TEMPLATE & "\" & type.ToString().Replace("_", ".")) + End If + + objLayout.Template = File.ReadAllText(path) + objLayout.Tokens = objLayout.Template.Split(delimiter) + + DataCache.SetCache(cacheKey, objLayout, New DNNCacheDependency(path)) + + End If + + Return objLayout + + End Function + + Public Shared Sub ClearCache(ByVal moduleContext As NewsArticleModuleBase) + + For Each type As String In System.Enum.GetNames(GetType(LayoutType)) + Dim cacheKey As String = "NewsArticles-" & moduleContext.TabModuleId.ToString() & type.ToString() + DataCache.RemoveCache(cacheKey) + Next + + End Sub + +#Region " Public Methods " + + Public Function GetLayoutObject(ByVal templateData As String) As LayoutInfo + + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + Dim objLayout As New LayoutInfo + + objLayout.Template = templateData + objLayout.Tokens = objLayout.Template.Split(delimiter) + + Return objLayout + + End Function + + Public Function GetStylesheet(ByVal template As String) As String + + Dim value As String = "" + + Dim path As String = ArticleUtilities.MapPath("~\DnnForge - NewsArticles\Templates\" & template & "\Template.css") + + If (File.Exists(path) = False) Then + ' Need to find a default... + End If + + File.ReadAllText(path) + + Return value + + End Function + + Public Sub UpdateStylesheet(ByVal template As String, ByVal text As String) + + Dim path As String = ArticleUtilities.MapPath("~\DnnForge - NewsArticles\Templates\" & template & "\Template.css") + File.WriteAllText(path, text) + + End Sub + + Public Sub UpdateLayout(ByVal template As String, ByVal type As LayoutType, ByVal text As String) + + Dim path As String = ArticleUtilities.MapPath("~\DnnForge - NewsArticles\Templates\" & template & "\" & type.ToString().Replace("_", ".")) + File.WriteAllText(path, text) + + End Sub + + Public Sub LoadStyleSheet(ByVal template As String) + + ClientResourceManager.RegisterStyleSheet(Page, ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Templates/" & template & "/Template.css"), FileOrder.Css.ModuleCss) + + End Sub + + Public Function ProcessImages(ByVal html As String) As String + + If (html.ToLower().Contains("src=""images/") Or html.ToLower().Contains("src=""~/images/")) Then + html = html.Replace("src=""images/", "src=""" & ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Templates/" & ArticleSettings.Template & "/Images/")) + html = html.Replace("src=""Images/", "src=""" & ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Templates/" & ArticleSettings.Template & "/Images/")) + html = html.Replace("src=""~/images/", "src=""" & ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images") & "/") + html = html.Replace("src=""~/Images/", "src=""" & ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Images") & "/") + End If + + Return html + + End Function + +#Region " Process Article Item " + + + Public Sub ProcessHeaderFooter(ByRef objPlaceHolder As ControlCollection, ByVal layoutArray As String(), ByVal objArticle As ArticleInfo) + + For iPtr As Integer = 0 To layoutArray.Length - 1 Step 2 + objPlaceHolder.Add(New LiteralControl(ProcessImages(layoutArray(iPtr).ToString()))) + Next + + End Sub + + Private articleItemIndex As Integer = 0 + Public Sub ProcessArticleItem(ByRef objPlaceHolder As ControlCollection, ByVal layoutArray As String(), ByVal objArticle As ArticleInfo) + + articleItemIndex = articleItemIndex + 1 + _objRelatedArticles = Nothing + + Static Generator As System.Random = New System.Random() + + For iPtr As Integer = 0 To layoutArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(ProcessImages(layoutArray(iPtr).ToString()))) + + If iPtr < layoutArray.Length - 1 Then + Select Case layoutArray(iPtr + 1) + + Case "APPROVERDISPLAYNAME" + If (objArticle.Approver(PortalSettings.PortalId) IsNot Nothing) Then + Dim objLiteral As New Literal + objLiteral.Text = objArticle.Approver(PortalSettings.PortalId).DisplayName + objPlaceHolder.Add(objLiteral) + End If + + Case "APPROVERFIRSTNAME" + If (objArticle.Approver(PortalSettings.PortalId) IsNot Nothing) Then + Dim objLiteral As New Literal + objLiteral.Text = objArticle.Approver(PortalSettings.PortalId).FirstName + objPlaceHolder.Add(objLiteral) + End If + + Case "APPROVERLASTNAME" + If (objArticle.Approver(PortalSettings.PortalId) IsNot Nothing) Then + Dim objLiteral As New Literal + objLiteral.Text = objArticle.Approver(PortalSettings.PortalId).LastName + objPlaceHolder.Add(objLiteral) + End If + + Case "APPROVERUSERNAME" + If (objArticle.Approver(PortalSettings.PortalId) IsNot Nothing) Then + Dim objLiteral As New Literal + objLiteral.Text = objArticle.Approver(PortalSettings.PortalId).Username + objPlaceHolder.Add(objLiteral) + End If + + Case "ARTICLEID" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.ArticleID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "ARTICLELINK" + Dim objLiteral As New Literal + Dim pageID As Integer = Null.NullInteger + If (ArticleSettings.AlwaysShowPageID) Then + If (Pages(objArticle.ArticleID).Count > 0) Then + pageID = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID + End If + End If + objLiteral.Text = Common.GetArticleLink(objArticle, Tab, ArticleSettings, IncludeCategory, pageID) + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "AUTHOR" + Dim objLiteral As New Literal + Select Case ArticleSettings.DisplayMode + Case DisplayType.FirstName + objLiteral.Text = objArticle.AuthorFirstName + Exit Select + Case DisplayType.LastName + objLiteral.Text = objArticle.AuthorLastName + Exit Select + Case DisplayType.UserName + objLiteral.Text = objArticle.AuthorUserName + Exit Select + Case DisplayType.FullName + objLiteral.Text = objArticle.AuthorDisplayName + Exit Select + Case Else + objLiteral.Text = objArticle.AuthorUserName + Exit Select + End Select + objPlaceHolder.Add(objLiteral) + + Case "AUTHORDISPLAYNAME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.AuthorDisplayName + objPlaceHolder.Add(objLiteral) + + Case "AUTHOREMAIL" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.AuthorEmail.ToString() + objPlaceHolder.Add(objLiteral) + + Case "AUTHORFIRSTNAME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.AuthorFirstName + objPlaceHolder.Add(objLiteral) + + Case "AUTHORFULLNAME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.AuthorFullName + objPlaceHolder.Add(objLiteral) + + Case "AUTHORID" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.AuthorID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "AUTHORLASTNAME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.AuthorLastName + objPlaceHolder.Add(objLiteral) + + Case "AUTHORLINK" + Dim objLiteral As New Literal + objLiteral.Text = Common.GetAuthorLink(ArticleModule.TabID, ArticleModule.ModuleID, objArticle.AuthorID, objArticle.AuthorUserName, ArticleSettings.LaunchLinks, ArticleSettings) + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "AUTHORUSERNAME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.AuthorUserName.ToString() + objPlaceHolder.Add(objLiteral) + + Case "CATEGORIES" + Dim objLiteral As New Literal + + Dim objArticleCategories As ArrayList = CType(DataCache.GetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString()), ArrayList) + If (objArticleCategories Is Nothing) Then + Dim objArticleController As New ArticleController + objArticleCategories = objArticleController.GetArticleCategories(objArticle.ArticleID) + For Each objCategory As CategoryInfo In objArticleCategories + If (objCategory.InheritSecurity) Then + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name & "" + Else + objLiteral.Text = " " & objCategory.Name & "" + End If + Else + If (ArticleSettings.Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(ArticleSettings.Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString())) Then + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name & "" + Else + objLiteral.Text = " " & objCategory.Name & "" + End If + End If + End If + End If + Next + DataCache.SetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString(), objArticleCategories) + Else + For Each objCategory As CategoryInfo In objArticleCategories + If (objCategory.InheritSecurity) Then + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name & "" + Else + objLiteral.Text = " " & objCategory.Name & "" + End If + Else + + If (ArticleSettings.Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(ArticleSettings.Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString())) Then + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name & "" + Else + objLiteral.Text = " " & objCategory.Name & "" + End If + End If + End If + End If + Next + End If + objPlaceHolder.Add(objLiteral) + + Case "CATEGORIESNOLINK" + Dim objLiteral As New Literal + Dim objArticleCategories As ArrayList = CType(DataCache.GetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString()), ArrayList) + If (objArticleCategories Is Nothing) Then + Dim objArticleController As New ArticleController + objArticleCategories = (objArticleController.GetArticleCategories(objArticle.ArticleID)) + For Each objCategory As CategoryInfo In objArticleCategories + If (objCategory.InheritSecurity) Then + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name + Else + objLiteral.Text = objCategory.Name + End If + Else + If (ArticleSettings.Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(ArticleSettings.Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString())) Then + + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name + Else + objLiteral.Text = objCategory.Name + End If + End If + End If + End If + Next + DataCache.SetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE_NO_LINK & objArticle.ArticleID.ToString(), objArticleCategories) + Else + For Each objCategory As CategoryInfo In objArticleCategories + If (objCategory.InheritSecurity) Then + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name + Else + objLiteral.Text = objCategory.Name + End If + Else + If (ArticleSettings.Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(ArticleSettings.Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString())) Then + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name + Else + objLiteral.Text = objCategory.Name + End If + End If + End If + End If + Next + End If + objPlaceHolder.Add(objLiteral) + + Case "COMMENTCOUNT" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.CommentCount.ToString() + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "COMMENTLINK" + Dim objLiteral As New Literal + objLiteral.Text = Common.GetArticleLink(objArticle, Tab, ArticleSettings, IncludeCategory) & "#Comments" + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "COMMENTRSS" + Dim objLiteral As New Literal + objLiteral.Text = AddHTTP(Request.Url.Host & ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/RssComments.aspx?TabID=" & ArticleModule.TabID.ToString() & "&ModuleID=" & ArticleModule.ModuleID.ToString() & "&ArticleID=" & objArticle.ArticleID.ToString()).Replace(" ", "%20")) + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "COMMENTS" + commentItemIndex = 0 + + Dim phComments As New PlaceHolder + Dim objLayoutCommentItem As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Comment_Item_Html) + + Dim direction As SortDirection = SortDirection.Ascending + If (ArticleSettings.SortDirectionComments = 1) Then + direction = SortDirection.Descending + End If + Dim objCommentController As New CommentController + Dim objComments As List(Of CommentInfo) = objCommentController.GetCommentList(objArticle.ModuleID, objArticle.ArticleID, True, direction, Null.NullInteger) + + For Each objComment As CommentInfo In objComments + ProcessComment(phComments.Controls, objArticle, objComment, objLayoutCommentItem.Tokens) + Next + + objPlaceHolder.Add(phComments) + + Case "CREATEDATE" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.CreatedDate.ToString("D") + objPlaceHolder.Add(objLiteral) + + Case "CREATETIME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.CreatedDate.ToString("t") + objPlaceHolder.Add(objLiteral) + + Case "CURRENTPAGE" + Dim objLiteral As New Literal + If (objArticle.PageCount <= 1) Then + objLiteral.Text = "1" + Else + Dim pageID As Integer = Null.NullInteger + If (Request("PageID") <> "" AndAlso IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + If (pageID = Null.NullInteger) Then + pageID = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID + End If + For i As Integer = 0 To Pages(objArticle.ArticleID).Count - 1 + Dim objPage As PageInfo = CType(Pages(objArticle.ArticleID)(i), PageInfo) + If (pageID = objPage.PageID) Then + objLiteral.Text = (i + 1).ToString() + Exit For + End If + Next + If (objLiteral.Text = Null.NullString) Then + objLiteral.Text = "1" + End If + End If + objPlaceHolder.Add(objLiteral) + + Case "CUSTOMFIELDS" + Dim objCustomFieldController As New CustomFieldController() + Dim objCustomFields As ArrayList = objCustomFieldController.List(objArticle.ModuleID) + Dim i As Integer = 0 + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.IsVisible = True) Then + Dim objLiteral As New Literal + objLiteral.Text = GetFieldValue(objCustomField, objArticle, True) & "
" + If (objLiteral.Text <> "") Then + objPlaceHolder.Add(objLiteral) + End If + i = i + 1 + End If + Next + + Case "DETAILS" + Dim objLiteral As New Literal + If (objArticle.PageCount > 0) Then + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + If (pageID = Null.NullInteger) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Body), objArticle, Generator, ArticleSettings) + Else + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objPage.PageText), objArticle, Generator, ArticleSettings) + Exit For + End If + Next + If (objLiteral.Text = Null.NullString) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Body), objArticle, Generator, ArticleSettings) + End If + End If + End If + objPlaceHolder.Add(objLiteral) + + Case "DETAILSDATA" + Dim objLiteral As New Literal + If (objArticle.PageCount > 0) Then + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + If (pageID = Null.NullInteger) Then + objLiteral.Text = "" + Else + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID) Then + objLiteral.Text = "" + Exit For + End If + Next + If (objLiteral.Text = Null.NullString) Then + objLiteral.Text = "" + End If + End If + End If + objPlaceHolder.Add(objLiteral) + + Case "EDIT" + If IsEditable OrElse (ArticleSettings.IsApprover) OrElse (objArticle.AuthorID = UserId And ArticleSettings.IsAutoApprover) Then + Dim objHyperLink As New HyperLink + objHyperLink.NavigateUrl = Common.GetModuleLink(ArticleModule.TabID, ArticleModule.ModuleID, "SubmitNews", ArticleSettings, "ArticleID=" & objArticle.ArticleID.ToString(), "ReturnUrl=" & Server.UrlEncode(Request.RawUrl)) + objHyperLink.ImageUrl = "~/images/edit.gif" + objHyperLink.ToolTip = "Click to edit" + objHyperLink.EnableViewState = False + objPlaceHolder.Add(objHyperLink) + End If + + Case "FILECOUNT" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.FileCount.ToString() + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "FILELINK" + If (objArticle.FileCount > 0) Then + Dim objFiles As List(Of FileInfo) = FileProvider.Instance().GetFiles(objArticle.ArticleID) + + If (objFiles.Count > 0) Then + Dim objLiteral As New Literal + objLiteral.Text = CType(objFiles(0), FileInfo).Link + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + + End If + + Case "FILES" + ' File Count Check + If (objArticle.FileCount > 0) Then + ' Dim objFileController As New FileController + Dim objFiles As List(Of FileInfo) = FileProvider.Instance().GetFiles(objArticle.ArticleID) + + If (objFiles.Count > 0) Then + Dim objLayoutFileHeader As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.File_Header_Html) + Dim objLayoutFileItem As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.File_Item_Html) + Dim objLayoutFileFooter As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.File_Footer_Html) + + ProcessHeaderFooter(objPlaceHolder, objLayoutFileHeader.Tokens, objArticle) + For Each objFile As FileInfo In objFiles + ProcessFile(objPlaceHolder, objArticle, objFile, objLayoutFileItem.Tokens) + Next + ProcessHeaderFooter(objPlaceHolder, objLayoutFileFooter.Tokens, objArticle) + End If + End If + + Case "GRAVATARURL" + If (objArticle.AuthorEmail <> "") Then + Dim objLiteral As New Literal + If Request.IsSecureConnection Then + objLiteral.Text = AddHTTP("secure.gravatar.com/avatar/" & MD5CalcString(objArticle.AuthorEmail.ToLower())) + Else + objLiteral.Text = AddHTTP("www.gravatar.com/avatar/" & MD5CalcString(objArticle.AuthorEmail.ToLower())) + End If + objPlaceHolder.Add(objLiteral) + End If + + Case "HASAUTHOR" + If (objArticle.AuthorID = Null.NullInteger) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASAUTHOR") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASAUTHOR" + ' Do Nothing + + Case "HASNOAUTHOR" + If (objArticle.AuthorID <> Null.NullInteger) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNOAUTHOR") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOAUTHOR" + ' Do Nothing + + Case "HASCATEGORIES" + Dim objLiteral As New Literal + If (DataCache.GetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString()) Is Nothing) Then + Dim objArticleController As New ArticleController + Dim objArticleCategories As ArrayList = objArticleController.GetArticleCategories(objArticle.ArticleID) + For Each objCategory As CategoryInfo In objArticleCategories + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name & "" + Else + objLiteral.Text = " " & objCategory.Name & "" + End If + Next + DataCache.SetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString(), objArticleCategories) + Else + Dim objArticleCategories As ArrayList = CType(DataCache.GetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString()), ArrayList) + For Each objCategory As CategoryInfo In objArticleCategories + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name & "" + Else + objLiteral.Text = " " & objCategory.Name & "" + End If + Next + End If + If (objLiteral.Text = "") Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASCATEGORIES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASCATEGORIES" + ' Do Nothing + + Case "HASCOMMENTS" + If (objArticle.CommentCount = 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASCOMMENTS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASCOMMENTS" + ' Do Nothing + + Case "HASCOMMENTSENABLED" + If (ArticleSettings.IsCommentsEnabled = False) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASCOMMENTSENABLED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASCOMMENTSENABLED" + ' Do Nothing + + Case "HASCUSTOMFIELDS" + Dim objCustomFieldController As New CustomFieldController() + Dim objCustomFields As ArrayList = objCustomFieldController.List(objArticle.ModuleID) + + If (objCustomFields.Count = 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASCUSTOMFIELDS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASCUSTOMFIELDS" + ' Do Nothing + + Case "HASDETAILS" + Dim objLiteral As New Literal + objLiteral.Text = "" + If (objArticle.PageCount > 0) Then + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + If (pageID = Null.NullInteger) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Body), objArticle, Generator, ArticleSettings) + Else + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objPage.PageText), objArticle, Generator, ArticleSettings) + Exit For + End If + Next + If (objLiteral.Text = Null.NullString) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Body), objArticle, Generator, ArticleSettings) + End If + End If + End If + + If (objLiteral.Text.Replace("

 

", "").Trim() = "") Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASDETAILS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASDETAILS" + ' Do Nothing + + Case "HASNODETAILS" + Dim objLiteral As New Literal + objLiteral.Text = "" + If (objArticle.PageCount > 0) Then + Dim pageId As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageId = Convert.ToInt32(Request("PageID")) + End If + If (pageId = Null.NullInteger) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Body), objArticle, Generator, ArticleSettings) + Else + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageId) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objPage.PageText), objArticle, Generator, ArticleSettings) + Exit For + End If + Next + If (objLiteral.Text = Null.NullString) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Body), objArticle, Generator, ArticleSettings) + End If + End If + End If + + If (objLiteral.Text.Replace("

 

", "").Trim() <> "") Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNODETAILS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNODETAILS" + ' Do Nothing + + Case "HASFILES" + If (objArticle.FileCount = 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASFILES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASFILES" + ' Do Nothing + + Case "HASIMAGE" + If (objArticle.ImageUrl = "" And objArticle.ImageCount = 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASIMAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASIMAGE" + ' Do Nothing + + Case "HASIMAGES" + If (objArticle.ImageCount = 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASIMAGES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASIMAGES" + ' Do Nothing + + Case "HASLINK" + If (objArticle.Url = Null.NullString()) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASLINK") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASLINK" + ' Do Nothing + + Case "HASMOREDETAIL" + If (objArticle.Url = Null.NullString() And StripHtml(objArticle.Summary.Trim()) = "") Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASMOREDETAIL") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASMOREDETAIL" + ' Do Nothing + + Case "HASMULTIPLEIMAGES" + If (objArticle.ImageCount <= 1) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASMULTIPLEIMAGES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASMULTIPLEIMAGES" + ' Do Nothing + + Case "HASMULTIPLEPAGES" + If (objArticle.PageCount <= 1) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASMULTIPLEPAGES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASMULTIPLEPAGES" + ' Do Nothing + + Case "HASNEXTPAGE" + If (Pages(objArticle.ArticleID).Count <= 1) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNEXTPAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + Else + If (_pageId = Null.NullInteger) Then + _pageId = Pages(objArticle.ArticleID)(0).PageID + End If + If (_pageId = Pages(objArticle.ArticleID)(Pages(objArticle.ArticleID).Count - 1).PageID) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNEXTPAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + Case "/HASNEXTPAGE" + ' Do Nothing + + Case "HASNOCOMMENTS" + If (objArticle.CommentCount > 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNOCOMMENTS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOCOMMENTS" + ' Do Nothing + + Case "HASNOFILES" + If (objArticle.FileCount > 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNOFILES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOFILES" + ' Do Nothing + + Case "HASNOIMAGE" + If (objArticle.ImageUrl <> "" Or objArticle.ImageCount > 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNOIMAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOIMAGE" + ' Do Nothing + + Case "HASNOIMAGES" + If (objArticle.ImageCount > 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNOIMAGES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOIMAGES" + ' Do Nothing + + Case "HASNOLINK" + If (objArticle.Url <> Null.NullString()) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNOLINK") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOLINK" + ' Do Nothing + + Case "HASPREVPAGE" + If (objArticle.PageCount <= 1) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASPREVPAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + Else + If (_pageId = Null.NullInteger) Then + _pageId = Pages(objArticle.ArticleID)(0).PageID + End If + If (_pageId = Pages(objArticle.ArticleID)(0).PageID) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASPREVPAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + Case "/HASPREVPAGE" + ' Do Nothing + + Case "HASRATING" + If (ArticleSettings.EnableRatings = False OrElse objArticle.RatingCount = 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASRATING") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASRATING" + ' Do Nothing + + Case "HASRATINGSENABLED" + If (ArticleSettings.EnableRatings = False) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASRATINGSENABLED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASRATINGSENABLED" + ' Do Nothing + + Case "HASRELATED" + Dim objRelatedArticles As List(Of ArticleInfo) = GetRelatedArticles(objArticle, 5) + If (objRelatedArticles.Count = 0) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASRELATED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASRELATED" + ' Do Nothing + + Case "HASSUMMARY" + If (StripHtml(objArticle.Summary.Trim()) = "") Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASSUMMARY") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASSUMMARY" + ' Do Nothing + + Case "HASNOSUMMARY" + If (StripHtml(objArticle.Summary.Trim()) <> "") Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNOSUMMARY") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOSUMMARY" + ' Do Nothing + + Case "HASTAGS" + If (objArticle.Tags = "") Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASTAGS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASTAGS" + ' Do Nothing + + Case "HASNOTAGS" + If (objArticle.Tags <> "") Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/HASNOTAGS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOTAGS" + ' Do Nothing + + Case "IMAGE" + If (objArticle.ImageUrl <> "") Then + Dim objImage As New Image + objImage.ImageUrl = FormatImageUrl(objArticle.ImageUrl) + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + Else + If (objArticle.ImageCount > 0) Then + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString()) + + If (objImages.Count > 0) Then + Dim objImage As New Image + objImage.ImageUrl = PortalSettings.HomeDirectory & objImages(0).Folder & objImages(0).FileName + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + End If + + End If + End If + + Case "IMAGECOUNT" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.ImageCount.ToString() + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "IMAGELINK" + If (objArticle.ImageUrl <> "") Then + Dim objLiteral As New Literal + objLiteral.Text = FormatImageUrl(objArticle.ImageUrl) + objPlaceHolder.Add(objLiteral) + Else + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString()) + + If (objImages.Count > 0) Then + Dim objLiteral As New Literal + objLiteral.Text = PortalSettings.HomeDirectory & objImages(0).Folder & objImages(0).FileName + objPlaceHolder.Add(objLiteral) + End If + End If + + Case "IMAGES" + + ' Image Count Check + If (objArticle.ImageCount > 0) Then + imageIndex = 0 + + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString()) + + If (objImages.Count > 0) Then + Dim objLayoutImageHeader As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Image_Header_Html) + Dim objLayoutImageItem As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Image_Item_Html) + Dim objLayoutImageFooter As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Image_Footer_Html) + + ProcessHeaderFooter(objPlaceHolder, objLayoutImageHeader.Tokens, objArticle) + For Each objImage As ImageInfo In objImages + ProcessImage(objPlaceHolder, objArticle, objImage, objLayoutImageItem.Tokens) + Next + ProcessHeaderFooter(objPlaceHolder, objLayoutImageFooter.Tokens, objArticle) + End If + + 'Dim script As String = "" _ + '& "" & vbCrLf + + 'Dim objScript As New Literal + 'objScript.Text = script + 'objPlaceHolder.AddAt(0, objScript) + End If + + Case "ISAUTHOR" + Dim isAuthor As Boolean = False + + If (Request.IsAuthenticated) Then + Dim objUser As UserInfo = UserController.GetCurrentUserInfo() + If (objUser IsNot Nothing) Then + If (objUser.UserID = objArticle.AuthorID) Then + isAuthor = True + End If + End If + End If + + If (isAuthor = False) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISAUTHOR") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISAUTHOR" + ' Do Nothing + + Case "ISANONYMOUS" + If (Request.IsAuthenticated) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISANONYMOUS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISANONYMOUS" + ' Do Nothing + + Case "ISDRAFT" + If (objArticle.Status <> StatusType.Draft) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISDRAFT") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISDRAFT" + ' Do Nothing + + Case "ISFEATURED" + If (objArticle.IsFeatured = False) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISFEATURED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISFEATURED" + ' Do Nothing + + Case "ISNOTFEATURED" + If (objArticle.IsFeatured) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISNOTFEATURED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISNOTFEATURED" + ' Do Nothing + + Case "ISFIRST" + If (articleItemIndex > 1) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISFIRST") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISFIRST" + ' Do Nothing + + Case "ISFIRST2" + If (articleItemIndex > 1 Or (Request("currentpage") <> "" And Request("currentpage") <> "1")) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISFIRST2") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISFIRST2" + ' Do Nothing + + Case "ISNOTFIRST" + If (articleItemIndex = 1) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISNOTFIRST") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISNOTFIRST" + ' Do Nothing + + Case "ISNOTFIRST2" + If (articleItemIndex = 1 And (Request("currentpage") = "" Or Request("currentpage") = "1")) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISNOTFIRST2") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISNOTFIRST2" + ' Do Nothing + + Case "ISSECOND" + If (articleItemIndex <> 2) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISSECOND") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSECOND" + ' Do Nothing + + Case "ISNOTSECOND" + If (articleItemIndex = 2) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISNOTSECOND") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISNOTSECOND" + ' Do Nothing + + Case "ISNOTANONYMOUS" + If (Request.IsAuthenticated = False) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISNOTANONYMOUS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISNOTANONYMOUS" + ' Do Nothing + + Case "ISNOTSECURE" + If (objArticle.IsSecure) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISNOTSECURE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISNOTSECURE" + ' Do Nothing + + Case "ISPUBLISHED" + If (objArticle.Status <> StatusType.Published) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISPUBLISHED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISPUBLISHED" + ' Do Nothing + + Case "ISRATEABLE" + If (ArticleSettings.IsRateable = False) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISRATEABLE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISRATEABLE" + ' Do Nothing + + Case "ISRSSITEM" + If (objArticle.RssGuid = Null.NullString) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISRSSITEM") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISRSSITEM" + ' Do Nothing + + Case "ISNOTRSSITEM" + If (objArticle.RssGuid <> Null.NullString) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISNOTRSSITEM") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISNOTRSSITEM" + ' Do Nothing + + Case "ISSECURE" + If (objArticle.IsSecure = False) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISSECURE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSECURE" + ' Do Nothing + + Case "ISSYNDICATIONENABLED" + If (ArticleSettings.IsSyndicationEnabled = False) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISSYNDICATIONENABLED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSYNDICATIONENABLED" + ' Do Nothing + + Case "ITEMINDEX" + Dim objLiteral As New Literal + objLiteral.Text = articleItemIndex.ToString() + objPlaceHolder.Add(objLiteral) + + Case "LASTUPDATEDATE" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.LastUpdate.ToString("D") + objPlaceHolder.Add(objLiteral) + + Case "LASTUPDATEEMAIL" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.LastUpdateEmail.ToString() + objPlaceHolder.Add(objLiteral) + + Case "LASTUPDATEFIRSTNAME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.LastUpdateFirstName.ToString() + objPlaceHolder.Add(objLiteral) + + Case "LASTUPDATELASTNAME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.LastUpdateLastName.ToString() + objPlaceHolder.Add(objLiteral) + + Case "LASTUPDATEUSERNAME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.LastUpdateUserName.ToString() + objPlaceHolder.Add(objLiteral) + + Case "LASTUPDATEFULLNAME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.LastUpdateFullName.ToString() + objPlaceHolder.Add(objLiteral) + + Case "LASTUPDATEID" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.LastUpdateID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "LINK" + Dim objLiteral As New Literal + If objArticle.Url = "" Then + Dim pageID As Integer = Null.NullInteger + If (ArticleSettings.AlwaysShowPageID) Then + If (Pages(objArticle.ArticleID).Count > 0) Then + pageID = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID + End If + End If + objLiteral.Text = Common.GetArticleLink(objArticle, Tab, ArticleSettings, IncludeCategory, pageID) + Else + objLiteral.Text = Globals.LinkClick(objArticle.Url, Tab.TabID, objArticle.ModuleID, False) + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "LINKNEXT" + Dim objLink As New HyperLink + objLink.CssClass = "CommandButton" + If (Pages(objArticle.ArticleID).Count <= 1) Then + objLink.Enabled = False + Else + If (_pageId = Null.NullInteger) Then + _pageId = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID + End If + If (_pageId = CType(Pages(objArticle.ArticleID)(Pages(objArticle.ArticleID).Count - 1), PageInfo).PageID) Then + objLink.Enabled = False + Else + objLink.Enabled = True + End If + End If + If (objLink.Enabled = True) Then + If (_pageId = Null.NullInteger) Then + _pageId = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID + End If + For i As Integer = 0 To Pages(objArticle.ArticleID).Count - 1 + Dim objPage As PageInfo = CType(Pages(objArticle.ArticleID)(i), PageInfo) + If (_pageId = objPage.PageID) Then + objLink.NavigateUrl = Common.GetArticleLink(objArticle, Tab, ArticleSettings, IncludeCategory, "PageID=" + CType(Pages(objArticle.ArticleID)(i + 1), PageInfo).PageID.ToString()) + End If + Next + End If + objLink.Text = GetSharedResource("NextPage") + objPlaceHolder.Add(objLink) + + Case "LINKPREVIOUS" + Dim objLink As New HyperLink + objLink.CssClass = "CommandButton" + If (Pages(objArticle.ArticleID).Count <= 1) Then + objLink.Enabled = False + Else + If (_pageId = Null.NullInteger) Then + _pageId = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID + End If + If (_pageId = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID) Then + objLink.Enabled = False + Else + objLink.Enabled = True + End If + End If + If (objLink.Enabled = True) Then + For i As Integer = 0 To Pages(objArticle.ArticleID).Count - 1 + Dim objPage As PageInfo = CType(Pages(objArticle.ArticleID)(i), PageInfo) + If (_pageId = objPage.PageID) Then + If (CType(Pages(objArticle.ArticleID)(i - 1), PageInfo).PageID.ToString() = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID.ToString()) Then + objLink.NavigateUrl = Common.GetArticleLink(objArticle, Tab, ArticleSettings, IncludeCategory) + Else + objLink.NavigateUrl = Common.GetArticleLink(objArticle, Tab, ArticleSettings, IncludeCategory, "PageID=" + CType(Pages(objArticle.ArticleID)(i - 1), PageInfo).PageID.ToString()) + End If + Exit For + End If + Next + End If + objLink.Text = GetSharedResource("PreviousPage") + objPlaceHolder.Add(objLink) + + Case "LINKTARGET" + If (objArticle.Url <> "") Then + Dim objLiteral As New Literal + If (objArticle.IsNewWindow) Then + objLiteral.Text = "_blank" + Else + objLiteral.Text = "_self" + End If + objPlaceHolder.Add(objLiteral) + End If + + Case "MODULEID" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.ModuleID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "PAGECOUNT" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.PageCount.ToString() + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "PAGETEXT" + Dim objLiteral As New Literal + If (objArticle.PageCount > 0) Then + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + If (pageID = Null.NullInteger) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Body), objArticle, Generator, ArticleSettings) + Else + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objPage.PageText), objArticle, Generator, ArticleSettings) + Exit For + End If + Next + If (objLiteral.Text = Null.NullString) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Body), objArticle, Generator, ArticleSettings) + End If + End If + Else + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Summary), objArticle, Generator, ArticleSettings) + End If + objPlaceHolder.Add(objLiteral) + + Case "PAGETITLE" + Dim objLiteral As New Literal + If (objArticle.PageCount > 0) Then + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + If (pageID = Null.NullInteger) Then + objLiteral.Text = CType(pageList(0), PageInfo).Title + Else + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID) Then + objLiteral.Text = objPage.Title + Exit For + End If + Next + If (objLiteral.Text = Null.NullString) Then + objLiteral.Text = CType(pageList(0), PageInfo).Title + End If + End If + Else + objLiteral.Text = objArticle.Title + End If + objPlaceHolder.Add(objLiteral) + + Case "PAGETITLENEXT" + Dim objLiteral As New Literal + If (Pages(objArticle.ArticleID).Count <= 1) Then + objLiteral.Visible = False + Else + If (_pageId = Null.NullInteger) Then + _pageId = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID + End If + If (_pageId = CType(Pages(objArticle.ArticleID)(Pages(objArticle.ArticleID).Count - 1), PageInfo).PageID) Then + objLiteral.Visible = False + Else + objLiteral.Visible = True + End If + End If + If (objLiteral.Visible = True) Then + If (_pageId = Null.NullInteger) Then + _pageId = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID + End If + For i As Integer = 0 To Pages(objArticle.ArticleID).Count - 1 + Dim objPage As PageInfo = CType(Pages(objArticle.ArticleID)(i), PageInfo) + If (_pageId = objPage.PageID) Then + objLiteral.Text = CType(Pages(objArticle.ArticleID)(i + 1), PageInfo).Title + End If + Next + End If + If (objLiteral.Visible = True And objLiteral.Text <> "") Then + objPlaceHolder.Add(objLiteral) + End If + + Case "PAGETITLEPREV" + Dim objLiteral As New Literal + If (Pages(objArticle.ArticleID).Count <= 1) Then + objLiteral.Visible = False + Else + If (_pageId = Null.NullInteger) Then + _pageId = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID + End If + If (_pageId = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID) Then + objLiteral.Visible = False + Else + objLiteral.Visible = True + End If + End If + If (objLiteral.Visible = True) Then + For i As Integer = 0 To Pages(objArticle.ArticleID).Count - 1 + Dim objPage As PageInfo = CType(Pages(objArticle.ArticleID)(i), PageInfo) + If (_pageId = objPage.PageID) Then + If (CType(Pages(objArticle.ArticleID)(i - 1), PageInfo).PageID.ToString() = CType(Pages(objArticle.ArticleID)(0), PageInfo).PageID.ToString()) Then + objLiteral.Text = objArticle.Title + Else + objLiteral.Text = CType(Pages(objArticle.ArticleID)(i - 1), PageInfo).Title + End If + Exit For + End If + Next + End If + If (objLiteral.Visible And objLiteral.Text <> "") Then + objPlaceHolder.Add(objLiteral) + End If + + + Case "PAGES" + Dim drpPages As New DropDownList + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + drpPages.Attributes.Add("onChange", "window.location.href=this.options[this.selectedIndex].value;") + drpPages.CssClass = "Normal" + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + For Each objPage As PageInfo In pageList + Dim item As New ListItem + + item.Value = Common.GetModuleLink(ArticleModule.TabID, ArticleModule.ModuleID, "ArticleView", ArticleSettings, "ArticleID=" & objArticle.ArticleID.ToString(), "PageID=" + objPage.PageID.ToString()) + item.Text = objPage.Title + + If (objPage.PageID = pageID) Then + item.Selected = True + End If + drpPages.Items.Add(item) + Next + If (drpPages.Items.Count > 1) Then + objPlaceHolder.Add(drpPages) + End If + + Case "PAGER" + + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + + Dim pager As String = "" _ + & "" _ + & "" _ + & "" + + Dim pageNo As Integer = 1 + + Dim y As Integer = 1 + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID) Then + pageNo = y + Exit For + End If + y = y + 1 + Next + + pager = pager & "" _ + & "" _ + & "" _ + & "" _ + & "
" & GetSharedResource("Page") & " " & pageNo.ToString() & " " & GetSharedResource("Of") & " " & pageList.Count.ToString() & "" + + If (pageList.Count > 1) Then + If (pageNo = 1) Then + pager = pager & "" & GetSharedResource("First") & "  " + Else + pager = pager & "" & GetSharedResource("First") & "  " + End If + Else + pager = pager & "" & GetSharedResource("First") & "  " + End If + + If (pageList.Count > 1) Then + If (pageNo = 1) Then + pager = pager & "" & GetSharedResource("Previous") & "  " + Else + Dim x As Integer = 0 + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID) Then + pager = pager & "" & GetSharedResource("Previous") & "  " + Exit For + End If + x = x + 1 + Next + End If + Else + pager = pager & "" & GetSharedResource("Previous") & "  " + End If + + Dim i As Integer = 1 + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID Or (pageID = Null.NullInteger And i = 1)) Then + pager = pager & "" & i.ToString() & "  " + Else + pager = pager & "" & i.ToString() & "  " + End If + i = i + 1 + Next + + If (pageList.Count > 1) Then + If (pageID <> Null.NullInteger) Then + If (CType(pageList(pageList.Count - 1), PageInfo).PageID = pageID) Then + pager = pager & "" & GetSharedResource("Next") & "  " + Else + Dim x As Integer = 0 + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID) Then + pager = pager & "" & GetSharedResource("Next") & "  " + Exit For + End If + x = x + 1 + Next + End If + Else + pager = pager & "" & GetSharedResource("Next") & "  " + End If + Else + pager = pager & "" & GetSharedResource("Next") & "  " + End If + + If (pageList.Count > 1) Then + If (CType(pageList(pageList.Count - 1), PageInfo).PageID = pageID) Then + pager = pager & "" & GetSharedResource("Last") & "  " + Else + pager = pager & "" & GetSharedResource("Last") & "  " + End If + Else + pager = pager & "" & GetSharedResource("Last") & "  " + End If + + pager = pager & "" _ + & "
" + + Dim objLiteral As New Literal + objLiteral.Text = pager + objPlaceHolder.Add(objLiteral) + + Case "PAGESLIST" + Dim pages As String = "" + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + + pages = "
    " + For Each objPage As PageInfo In pageList + pages = pages & "
  • " & objPage.Title & "
  • " + Next + pages = pages & "
" + + If (pageList.Count > 1) Then + Dim objLiteral As New Literal + objLiteral.Text = pages + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + + Case "PAGESLIST2" + Dim pages As String = "" + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + + pages = "
    " + Dim isFirst As Boolean = True + For Each objPage As PageInfo In pageList + If (pageID = objPage.PageID Or (pageID = Null.NullInteger And isFirst)) Then + pages = pages & "
  • " & objPage.Title & "
  • " + Else + pages = pages & "
  • " & objPage.Title & "
  • " + End If + isFirst = False + Next + pages = pages & "
" + + If (pageList.Count > 1) Then + Dim objLiteral As New Literal + objLiteral.Text = pages + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + + Case "PORTALROOT" + Dim objLiteral As New Literal + objLiteral.Text = PortalSettings.HomeDirectory + objPlaceHolder.Add(objLiteral) + + Case "POSTCOMMENT" + If (ArticleSettings.IsCommentsEnabled) Then + Dim objControl As Control = Page.LoadControl("~/DesktopModules/DnnForge - NewsArticles/Controls/PostComment.ascx") + CType(objControl, NewsArticleControlBase).ArticleID = objArticle.ArticleID + objPlaceHolder.Add(objControl) + End If + + Case "POSTRATING" + Dim objControl As Control = Page.LoadControl("~/DesktopModules/DnnForge - NewsArticles/Controls/PostRating.ascx") + objPlaceHolder.Add(objControl) + + Case "PRINT" + Dim objHyperLink As New HyperLink + If (_pageId <> Null.NullInteger) Then + objHyperLink.NavigateUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Print.aspx?tabid=" & ArticleModule.TabID.ToString() & "&tabmoduleid=" & ArticleModule.TabModuleID.ToString() & "&articleId=" & objArticle.ArticleID.ToString() & "&moduleId=" & objArticle.ModuleID.ToString() & "&PortalID=" & PortalSettings.PortalId.ToString() & "&PageID=" & _pageId.ToString()) + Else + objHyperLink.NavigateUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Print.aspx?tabid=" & ArticleModule.TabID.ToString() & "&tabmoduleid=" & ArticleModule.TabModuleID.ToString() & "&articleId=" & objArticle.ArticleID.ToString() & "&moduleId=" & objArticle.ModuleID.ToString() & "&PortalID=" & PortalSettings.PortalId.ToString()) + End If + objHyperLink.ImageUrl = "~/images/print.gif" + objHyperLink.ToolTip = GetArticleResource("ClickPrint") + objHyperLink.EnableViewState = False + objHyperLink.Target = "_blank" + objHyperLink.Attributes.Add("rel", "nofollow") + objPlaceHolder.Add(objHyperLink) + + Case "PRINTLINK" + Dim objLiteral As New Literal + If (_pageId <> Null.NullInteger) Then + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Print.aspx?tabid=" & ArticleModule.TabID.ToString() & "&tabmoduleid=" & ArticleModule.TabModuleID.ToString() & "&articleId=" & objArticle.ArticleID.ToString() & "&moduleId=" & objArticle.ModuleID.ToString() & "&PortalID=" & PortalSettings.PortalId.ToString() & "&PageID=" & _pageId.ToString()) + Else + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Print.aspx?tabid=" & ArticleModule.TabID.ToString() & "&tabmoduleid=" & ArticleModule.TabModuleID.ToString() & "&articleId=" & objArticle.ArticleID.ToString() & "&moduleId=" & objArticle.ModuleID.ToString() & "&PortalID=" & PortalSettings.PortalId.ToString()) + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "PUBLISHDATE" + Dim objLiteral As New Literal + If (objArticle.StartDate = Null.NullDate) Then + objLiteral.Text = objArticle.CreatedDate.ToString("D") + Else + objLiteral.Text = objArticle.StartDate.ToString("D") + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "PUBLISHSTARTDATE" + Dim objLiteral As New Literal + If (objArticle.StartDate = Null.NullDate) Then + objLiteral.Text = objArticle.CreatedDate.ToString("D") + Else + objLiteral.Text = objArticle.StartDate.ToString("D") + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "PUBLISHTIME" + Dim objLiteral As New Literal + If (objArticle.StartDate = Null.NullDate) Then + objLiteral.Text = objArticle.CreatedDate.ToString("t") + Else + objLiteral.Text = objArticle.StartDate.ToString("t") + End If + objLiteral.EnableViewState = False + + Case "PUBLISHSTARTTIME" + Dim objLiteral As New Literal + If (objArticle.StartDate = Null.NullDate) Then + objLiteral.Text = objArticle.CreatedDate.ToString("t") + Else + objLiteral.Text = objArticle.StartDate.ToString("t") + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "PUBLISHENDDATE" + Dim objLiteral As New Literal + If (objArticle.EndDate = Null.NullDate) Then + objLiteral.Text = "" + Else + objLiteral.Text = objArticle.EndDate.ToString("D") + End If + objPlaceHolder.Add(objLiteral) + + Case "PUBLISHENDTIME" + Dim objLiteral As New Literal + If (objArticle.EndDate = Null.NullDate) Then + objLiteral.Text = "" + Else + objLiteral.Text = objArticle.EndDate.ToString("t") + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "RATING" + Dim objImage As New Image + objImage.ImageUrl = GetRatingImage(objArticle) + objImage.EnableViewState = False + objImage.ToolTip = "Article Rating" + objImage.AlternateText = "Article Rating" + objPlaceHolder.Add(objImage) + + Case "RATINGCOUNT" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.RatingCount.ToString() + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "RATINGDETAIL" + If (objArticle.Rating <> Null.NullDouble) Then + Dim objLiteral As New Literal + objLiteral.Text = objArticle.Rating.ToString("R1") + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + + Case "RELATED" + If (ArticleSettings.RelatedMode <> RelatedType.None) Then + Dim phRelated As New PlaceHolder + + Dim objArticles As List(Of ArticleInfo) = GetRelatedArticles(objArticle, 5) + + If (objArticles.Count > 0) Then + Dim _objLayoutRelatedHeader As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Related_Header_Html) + Dim _objLayoutRelatedItem As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Related_Item_Html) + Dim _objLayoutRelatedFooter As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Related_Footer_Html) + + ProcessArticleItem(phRelated.Controls, _objLayoutRelatedHeader.Tokens, objArticle) + For Each objRelatedArticle As ArticleInfo In objArticles + ProcessArticleItem(phRelated.Controls, _objLayoutRelatedItem.Tokens, objRelatedArticle) + Next + ProcessArticleItem(phRelated.Controls, _objLayoutRelatedFooter.Tokens, objArticle) + + objPlaceHolder.Add(phRelated) + End If + End If + + Case "SITEROOT" + Dim objLiteral As New Literal + objLiteral.Text = ArticleUtilities.ResolveUrl("~/") + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "SITETITLE" + Dim objLiteral As New Literal + objLiteral.Text = PortalSettings.PortalName + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "SHORTLINK" + If (objArticle.ShortUrl <> "") Then + Dim objLiteral As New Literal + objLiteral.Text = objArticle.ShortUrl + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Else + If (ArticleSettings.TwitterBitLyAPIKey <> "" And ArticleSettings.TwitterBitLyLogin <> "") Then + Dim link As String = Common.GetArticleLink(objArticle, Tab, ArticleSettings, False) + Dim b As New bitly(ArticleSettings.TwitterBitLyLogin, ArticleSettings.TwitterBitLyAPIKey) + Dim shortUrl As String = b.Shorten(link) + + If (shortUrl <> "") Then + Dim objLiteral As New Literal + objLiteral.Text = shortUrl + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + objArticle.ShortUrl = shortUrl + Dim objArticleController As New ArticleController() + objArticleController.UpdateArticle(objArticle) + End If + End If + End If + + Case "SUMMARY" + Dim objLiteral As New Literal + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(objArticle.Summary), objArticle, Generator, ArticleSettings) + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "TABID" + Dim objLiteral As New Literal + objLiteral.Text = ArticleModule.TabID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "TABTITLE" + Dim objLiteral As New Literal + If (PortalSettings.ActiveTab.Title.Length = 0) Then + objLiteral.Text = PortalSettings.ActiveTab.TabName + Else + objLiteral.Text = PortalSettings.ActiveTab.Title + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "TAGS" + If (objArticle.Tags.Trim() <> "") Then + Dim objLiteral As New Literal + For Each tag As String In objArticle.Tags.Split(","c) + If (objLiteral.Text = "") Then + objLiteral.Text = "" + tag + "" + Else + objLiteral.Text = objLiteral.Text + ", " + "" + tag + "" + End If + Next + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + + Case "TAGSNOLINK" + If (objArticle.Tags.Trim() <> "") Then + Dim objLiteral As New Literal + For Each tag As String In objArticle.Tags.Split(","c) + If (objLiteral.Text = "") Then + objLiteral.Text = tag + Else + objLiteral.Text = objLiteral.Text + ", " + tag + End If + Next + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + + Case "TEMPLATEPATH" + Dim objLiteral As New Literal + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DnnForge - NewsArticles/Templates/" & ArticleSettings.Template & "/") + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "TITLE" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.Title + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "TITLESAFEJS" + If (objArticle.Title <> "") Then + Dim objLiteral As New Literal + objLiteral.Text = objArticle.Title.Replace("""", "") + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + + Case "TITLEURLENCODED" + Dim objLiteral As New Literal + objLiteral.Text = Server.UrlEncode(objArticle.Title) + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "TWITTERNAME" + Dim objLiteral As New Literal + objLiteral.Text = ArticleSettings.TwitterName + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "UPDATEDATE" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.LastUpdate.ToString("D") + objPlaceHolder.Add(objLiteral) + + Case "UPDATETIME" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.LastUpdate.ToString("t") + objPlaceHolder.Add(objLiteral) + + Case "VIEWCOUNT" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.NumberOfViews.ToString() + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case Else + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("AUTHOR:")) Then + If Author(objArticle.AuthorID) IsNot Nothing Then + ' token to be processed + Dim field As String = layoutArray(iPtr + 1).Substring(7, layoutArray(iPtr + 1).Length - 7).ToLower().Trim() + + 'Gets the DNN profile property named like the token (field) + Dim profilePropertyFound As Boolean = False + Dim profilePropertyDataType As String = String.Empty + Dim profilePropertyName As String = String.Empty + Dim profilePropertyValue As String = String.Empty + + For Each objProfilePropertyDefinition As ProfilePropertyDefinition In ProfileProperties + If (objProfilePropertyDefinition.PropertyName.ToLower().Trim() = field) Then + + 'Gets the dnn profile property's datatype + Dim objListController As New ListController + Dim definitionEntry As ListEntryInfo = objListController.GetListEntryInfo(objProfilePropertyDefinition.DataType) + If Not definitionEntry Is Nothing Then + profilePropertyDataType = definitionEntry.Value + Else + profilePropertyDataType = "Unknown" + End If + + 'Gets the dnn profile property's name and current value for the given user (Agent = AuthorID) + profilePropertyName = objProfilePropertyDefinition.PropertyName + profilePropertyValue = Author(objArticle.AuthorID).Profile.GetPropertyValue(profilePropertyName) + + profilePropertyFound = True + + End If + Next + + If profilePropertyFound Then + + Select Case profilePropertyDataType.ToLower() + Case "truefalse" + Dim objTrueFalse As New CheckBox + If profilePropertyValue = String.Empty Then + objTrueFalse.Checked = False + Else + objTrueFalse.Checked = CType(profilePropertyValue, Boolean) + End If + objTrueFalse.Enabled = False + objTrueFalse.EnableViewState = False + objPlaceHolder.Add(objTrueFalse) + + Case "richtext" + Dim objLiteral As New Literal + If profilePropertyValue = String.Empty Then + objLiteral.Text = String.Empty + Else + objLiteral.Text = Server.HtmlDecode(profilePropertyValue) + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "list" + Dim objLiteral As New Literal + objLiteral.Text = profilePropertyValue + Dim objListController As New ListController + Dim objListEntryInfoCollection As ListEntryInfoCollection = objListController.GetListEntryInfoCollection(profilePropertyName) + For Each objListEntryInfo As ListEntryInfo In objListEntryInfoCollection + If objListEntryInfo.Value = profilePropertyValue Then + objLiteral.Text = objListEntryInfo.Text + Exit For + End If + Next + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case Else + Dim objLiteral As New Literal + If profilePropertyValue = String.Empty Then + objLiteral.Text = String.Empty + Else + If profilePropertyName.ToLower() = "website" Then + Dim url As String = profilePropertyValue + If url.ToLower.StartsWith("http://") Then + url = url.Substring(7) ' removes the "http://" + End If + objLiteral.Text = url + Else + objLiteral.Text = profilePropertyValue + End If + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End Select 'profilePropertyDataType + + End If ' DNN Profile property processing + End If + Exit Select + End If ' "AUTHOR:" token + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("CAPTION:")) Then + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFields As ArrayList = objCustomFieldController.List(objArticle.ModuleID) + + Dim field As String = layoutArray(iPtr + 1).Substring(8, layoutArray(iPtr + 1).Length - 8) + + Dim i As Integer = 0 + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.Name.ToLower() = field.ToLower()) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID)) Then + Dim objLiteral As New Literal + objLiteral.Text = objCustomField.Caption + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + i = i + 1 + End If + End If + Next + + Exit Select + + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("CATEGORIESSUB:")) Then + Dim values As String = layoutArray(iPtr + 1).Substring(14, layoutArray(iPtr + 1).Length - 14) + + Dim splitValues As String() = values.Split(":"c) + + If (splitValues.Length = 2) Then + + Dim category As String = splitValues(0) + Dim number As String = splitValues(1) + + If (IsNumeric(number)) Then + If (Convert.ToInt32(number) > 0) Then + + ' Find category + + Dim objCategoryController As New CategoryController + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(ArticleModule.ModuleID, Null.NullInteger) + + Dim categoryID As Integer = Null.NullInteger + For Each objCategory As CategoryInfo In objCategories + + If (objCategory.Name.ToLower() = category.ToLower()) Then + categoryID = objCategory.CategoryID + Exit For + End If + + Next + + If (categoryID <> Null.NullInteger) Then + + Dim objCategoriesSelected As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(ArticleModule.ModuleID, categoryID, Nothing, Null.NullInteger, Convert.ToInt32(number), False, CategorySortType.Name) + + Dim objArticleCategories As ArrayList = CType(DataCache.GetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString()), ArrayList) + If (objArticleCategories Is Nothing) Then + Dim objArticleController As New ArticleController + objArticleCategories = objArticleController.GetArticleCategories(objArticle.ArticleID) + DataCache.SetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString(), objArticleCategories) + End If + + + Dim objLiteral As New Literal + For Each objCategory As CategoryInfo In objArticleCategories + + For Each objCategorySel As CategoryInfo In objCategoriesSelected + If (objCategory.CategoryID = objCategorySel.CategoryID) Then + If (objLiteral.Text <> "") Then + objLiteral.Text = objLiteral.Text & ", " & objCategory.Name & "" + Else + objLiteral.Text = " " & objCategory.Name & "" + End If + End If + Next + + Next + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + + End If + End If + + End If + + End If + + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("CREATEDATE:")) Then + Dim formatExpression As String = layoutArray(iPtr + 1).Substring(11, layoutArray(iPtr + 1).Length - 11) + + Dim objLiteral As New Literal + + Try + If (objArticle.CreatedDate = Null.NullDate) Then + objLiteral.Text = "" + Else + objLiteral.Text = objArticle.CreatedDate.ToString(formatExpression) + End If + Catch + If (objArticle.CreatedDate = Null.NullDate) Then + objLiteral.Text = "" + Else + objLiteral.Text = objArticle.CreatedDate.ToString("D") + End If + End Try + + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("CREATEDATELESSTHAN:")) Then + Dim length As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(19, layoutArray(iPtr + 1).Length - 19)) + + If (objArticle.CreatedDate < DateTime.Now.AddDays(length * -1)) Then + Dim endVal As String = layoutArray(iPtr + 1).ToUpper() + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = ("/" & endVal)) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/CREATEDATELESSTHAN:")) Then + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("CUSTOM:")) Then + Dim field As String = layoutArray(iPtr + 1).Substring(7, layoutArray(iPtr + 1).Length - 7).ToLower() + + Dim customFieldID As Integer = Null.NullInteger + Dim objCustomFieldSelected As New CustomFieldInfo + Dim isLink As Boolean = False + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFields As ArrayList = objCustomFieldController.List(objArticle.ModuleID) + + Dim maxLength As Integer = Null.NullInteger + If (field.IndexOf(":"c) <> -1) Then + Try + maxLength = Convert.ToInt32(field.Split(":"c)(1)) + Catch + maxLength = Null.NullInteger + End Try + field = field.Split(":"c)(0) + End If + If (customFieldID = Null.NullInteger) Then + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.Name.ToLower() = field.ToLower()) Then + customFieldID = objCustomField.CustomFieldID + objCustomFieldSelected = objCustomField + End If + Next + End If + + If (customFieldID <> Null.NullInteger) Then + + Dim i As Integer = 0 + If (objArticle.CustomList.Contains(customFieldID)) Then + Dim objLiteral As New Literal + Dim fieldValue As String = GetFieldValue(objCustomFieldSelected, objArticle, False) + If (maxLength <> Null.NullInteger) Then + If (fieldValue.Length > maxLength) Then + fieldValue = fieldValue.Substring(0, maxLength) + End If + End If + objLiteral.Text = fieldValue.TrimStart("#"c) + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + i = i + 1 + End If + End If + Exit Select + End If + + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("DETAILS:")) Then + Dim length As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(8, layoutArray(iPtr + 1).Length - 8)) + + Dim objLiteral As New Literal + If (StripHtml(Server.HtmlDecode(objArticle.Body)).TrimStart().Length > length) Then + objLiteral.Text = ProcessPostTokens(Left(StripHtml(Server.HtmlDecode(objArticle.Body)).TrimStart(), length), objArticle, Generator, ArticleSettings) & "..." + Else + objLiteral.Text = ProcessPostTokens(Left(StripHtml(Server.HtmlDecode(objArticle.Body)).TrimStart(), length), objArticle, Generator, ArticleSettings) + End If + + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("EXPRESSION:")) Then + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFields As ArrayList = objCustomFieldController.List(objArticle.ModuleID) + + Dim field As String = layoutArray(iPtr + 1).Substring(11, layoutArray(iPtr + 1).Length - 11) + + Dim params As String() = field.Split(":"c) + + If (params.Length <> 3) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + Exit Select + End If + + Dim customField As String = params(0) + Dim customExpression As String = params(1) + Dim customValue As String = params(2) + + Dim fieldValue As String = "" + + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.Name.ToLower() = customField.ToLower()) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID)) Then + fieldValue = GetFieldValue(objCustomField, objArticle, False) + End If + End If + Next + + Dim isValid As Boolean = False + Select Case customExpression + Case "=" + If (customValue.ToLower() = fieldValue.ToLower()) Then + isValid = True + End If + Exit Select + + Case "!=" + If (customValue.ToLower() <> fieldValue.ToLower()) Then + isValid = True + End If + Exit Select + + Case "<" + If (IsNumeric(customValue) AndAlso IsNumeric(fieldValue)) Then + If (Convert.ToInt32(fieldValue) < Convert.ToInt32(customValue)) Then + isValid = True + End If + End If + Exit Select + + Case "<=" + If (IsNumeric(customValue) AndAlso IsNumeric(fieldValue)) Then + If (Convert.ToInt32(fieldValue) <= Convert.ToInt32(customValue)) Then + isValid = True + End If + End If + Exit Select + + Case ">" + If (IsNumeric(customValue) AndAlso IsNumeric(fieldValue)) Then + If (Convert.ToInt32(fieldValue) > Convert.ToInt32(customValue)) Then + isValid = True + End If + End If + Exit Select + + Case ">=" + If (IsNumeric(customValue) AndAlso IsNumeric(fieldValue)) Then + If (Convert.ToInt32(fieldValue) >= Convert.ToInt32(customValue)) Then + isValid = True + End If + End If + Exit Select + + End Select + + If (isValid = False) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Exit Select + + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/EXPRESSION:")) Then + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("HASIMAGES:")) Then + + Dim field As String = layoutArray(iPtr + 1).Substring(10, layoutArray(iPtr + 1).Length - 10) + + If (IsNumeric(field)) Then + + If (objArticle.ImageCount < Convert.ToInt32(field)) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + End If + + Exit Select + + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/HASIMAGES:")) Then + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("HASMOREDETAIL:")) Then + Dim length As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(14, layoutArray(iPtr + 1).Length - 14)) + Dim endToken As String = "/" & layoutArray(iPtr + 1) + + If (objArticle.Url = Null.NullString() And StripHtml(objArticle.Summary.Trim()) = "" And StripHtml(Server.HtmlDecode(objArticle.Body)).TrimStart().Length <= length) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/HASMOREDETAIL:")) Then + ' Do Nothing + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("HASNOVALUE:")) Then + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFields As ArrayList = objCustomFieldController.List(objArticle.ModuleID) + + Dim field As String = layoutArray(iPtr + 1).Substring(11, layoutArray(iPtr + 1).Length - 11) + + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.Name.ToLower() = field.ToLower()) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID)) Then + Dim fieldValue As String = GetFieldValue(objCustomField, objArticle, False) + If (fieldValue.Trim() <> "") Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + End If + Next + + Exit Select + + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/HASNOVALUE:")) Then + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("HASVALUE:")) Then + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFields As ArrayList = objCustomFieldController.List(objArticle.ModuleID) + + Dim field As String = layoutArray(iPtr + 1).Substring(9, layoutArray(iPtr + 1).Length - 9) + + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.Name.ToLower() = field.ToLower()) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID)) Then + Dim fieldValue As String = GetFieldValue(objCustomField, objArticle, False) + If (fieldValue.Trim() = "") Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + End If + Next + + Exit Select + + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/HASVALUE:")) Then + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("HASAUTHORVALUE:")) Then + + Dim field As String = layoutArray(iPtr + 1).Substring(15, layoutArray(iPtr + 1).Length - 15).ToLower().Trim() + + 'Gets the DNN profile property named like the token (field) + Dim profilePropertyName As String = String.Empty + Dim profilePropertyValue As String = String.Empty + + For Each objProfilePropertyDefinition As ProfilePropertyDefinition In ProfileProperties + If (objProfilePropertyDefinition.PropertyName.ToLower().Trim() = field) Then + + 'Gets the dnn profile property's datatype + Dim objListController As New ListController + Dim definitionEntry As ListEntryInfo = objListController.GetListEntryInfo(objProfilePropertyDefinition.DataType) + If Not definitionEntry Is Nothing Then + Else + End If + + 'Gets the dnn profile property's name and current value for the given user (Agent = AuthorID) + profilePropertyName = objProfilePropertyDefinition.PropertyName + If (Author(objArticle.AuthorID) IsNot Nothing) Then + profilePropertyValue = Author(objArticle.AuthorID).Profile.GetPropertyValue(profilePropertyName) + Exit For + End If + + End If + Next + + If (profilePropertyValue = "") Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Exit Select + + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/HASAUTHORVALUE:")) Then + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("IMAGE:")) Then + If (objArticle.ImageCount > 0) Then + Dim val As String = layoutArray(iPtr + 1).Substring(6, layoutArray(iPtr + 1).Length - 6) + + If (IsNumeric(val)) Then + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString()) + + If (objImages.Count > 0) Then + Dim count As Integer = 1 + For Each objChildImage As ImageInfo In objImages + If (count = Convert.ToInt32(val)) Then + Dim objImage As New Image + objImage.ImageUrl = PortalSettings.HomeDirectory & objChildImage.Folder & objChildImage.FileName + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + End If + count = count + 1 + Next + End If + End If + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("IMAGETHUMB:")) Then + + If (objArticle.ImageUrl <> "") Then + Dim objImage As New Image + objImage.ImageUrl = objArticle.ImageUrl + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + Else + If (objArticle.ImageCount > 0) Then + + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString) + If (objImages.Count > 0) Then + + Dim val As String = layoutArray(iPtr + 1).Substring(11, layoutArray(iPtr + 1).Length - 11) + If (val.IndexOf(":"c) = -1) Then + Dim length As Integer = Convert.ToInt32(val) + + Dim objImage As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImages(0).Folder & objImages(0).FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + Else + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImages(0).Folder & objImages(0).FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1&s=1") + End If + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + Else + + Dim arr() As String = val.Split(":"c) + + If (arr.Length = 2) Then + Dim width As Integer = Convert.ToInt32(val.Split(":"c)(0)) + Dim height As Integer = Convert.ToInt32(val.Split(":"c)(1)) + + Dim objImage As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImages(0).Folder & objImages(0).FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + Else + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImages(0).Folder & objImages(0).FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1&s=1") + End If + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + Else + If (arr.Length = 3) Then + Dim width As Integer = Convert.ToInt32(val.Split(":"c)(0)) + Dim height As Integer = Convert.ToInt32(val.Split(":"c)(1)) + Dim item As Integer = Convert.ToInt32(val.Split(":"c)(2)) + + If (objImages.Count > 0) Then + Dim count As Integer = 1 + For Each objChildImage As ImageInfo In objImages + If (count = item) Then + Dim objImage As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objChildImage.Folder & objChildImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + Else + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objChildImage.Folder & objChildImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1&s=1") + End If + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + End If + count = count + 1 + Next + End If + + End If + End If + End If + + End If + + End If + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("IMAGETHUMBLINK:")) Then + + If (objArticle.ImageUrl <> "") Then + Dim objImage As New Image + objImage.ImageUrl = objArticle.ImageUrl + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + Else + If (objArticle.ImageCount > 0) Then + + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString) + + If (objImages.Count > 0) Then + + Dim val As String = layoutArray(iPtr + 1).Substring(15, layoutArray(iPtr + 1).Length - 15) + If (val.IndexOf(":"c) = -1) Then + Dim length As Integer = Convert.ToInt32(val) + + Dim objLiteral As New Literal + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImages(0).Folder & objImages(0).FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + Else + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImages(0).Folder & objImages(0).FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1&s=1") + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Else + Dim arr() As String = val.Split(":"c) + + If (arr.Length = 2) Then + Dim width As Integer = Convert.ToInt32(val.Split(":"c)(0)) + Dim height As Integer = Convert.ToInt32(val.Split(":"c)(1)) + + Dim objLiteral As New Literal + If (objArticle.ImageUrl.ToLower().StartsWith("http://") Or objArticle.ImageUrl.ToLower().StartsWith("https://")) Then + objLiteral.Text = objArticle.ImageUrl + Else + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImages(0).Folder & objImages(0).FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + Else + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImages(0).Folder & objImages(0).FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1&s=1") + End If + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Else + If (arr.Length = 3) Then + Dim width As Integer = Convert.ToInt32(val.Split(":"c)(0)) + Dim height As Integer = Convert.ToInt32(val.Split(":"c)(1)) + Dim item As Integer = Convert.ToInt32(val.Split(":"c)(2)) + + If (objImages.Count > 0) Then + Dim count As Integer = 1 + For Each objChildImage As ImageInfo In objImages + If (count = item) Then + Dim objLiteral As New Literal + If (objArticle.ImageUrl.ToLower().StartsWith("http://") Or objArticle.ImageUrl.ToLower().StartsWith("https://")) Then + objLiteral.Text = objArticle.ImageUrl + Else + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objChildImage.Folder & objChildImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + Else + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objChildImage.Folder & objChildImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1&s=1") + End If + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + count = count + 1 + Next + End If + + End If + End If + + End If + End If + End If + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("IMAGETHUMBRANDOM:")) Then + + If (objArticle.ImageCount > 0) Then + + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString) + If (objImages.Count > 0) Then + + Dim randomImage As ImageInfo = objImages(Generator.Next(0, objImages.Count - 1)) + + Dim val As String = layoutArray(iPtr + 1).Substring(17, layoutArray(iPtr + 1).Length - 17) + If (val.IndexOf(":"c) = -1) Then + Dim length As Integer = Convert.ToInt32(val) + + Dim objImage As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(randomImage.Folder & randomImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + Else + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(randomImage.Folder & randomImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1&s=1") + End If + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + Else + + Dim arr() As String = val.Split(":"c) + + If (arr.Length = 2) Then + Dim width As Integer = Convert.ToInt32(val.Split(":"c)(0)) + Dim height As Integer = Convert.ToInt32(val.Split(":"c)(1)) + + Dim objImage As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(randomImage.Folder & randomImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + Else + objImage.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(randomImage.Folder & randomImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1&s=1") + End If + objImage.EnableViewState = False + objImage.AlternateText = objArticle.Title + objPlaceHolder.Add(objImage) + End If + End If + + End If + + End If + Exit Select + End If + + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("ISINROLE:")) Then + Dim field As String = layoutArray(iPtr + 1).Substring(9, layoutArray(iPtr + 1).Length - 9) + If (PortalSecurity.IsInRole(field) = False) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/ISINROLE:")) Then + ' Do Nothing + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("ISITEMINDEX:")) Then + Dim field As String = layoutArray(iPtr + 1).Substring(12, layoutArray(iPtr + 1).Length - 12) + Try + If (Convert.ToInt32(field) <> articleItemIndex) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Catch + End Try + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/ISITEMINDEX:")) Then + ' Do Nothing + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("ISPAGE:")) Then + Dim page As String = layoutArray(iPtr + 1).Substring(7, layoutArray(iPtr + 1).Length - 7) + If (IsNumeric(page)) Then + If (Convert.ToInt32(page) = 1) Then + If (Request("PageID") <> "") Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Else + Dim objPageController As New PageController() + Dim objPages As ArrayList = objPageController.GetPageList(objArticle.ArticleID) + + Dim found As Boolean = False + If (Request("PageID") <> "") Then + Dim pageNumber As Integer = 1 + For Each objPage As PageInfo In objPages + If (Convert.ToInt32(page) = pageNumber) Then + If (Request("PageID") = objPage.PageID.ToString()) Then + found = True + End If + Exit For + End If + pageNumber = pageNumber + 1 + Next + End If + + If (found = False) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/ISPAGE:")) Then + ' Do Nothing + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("ISNOTPAGE:")) Then + Dim page As String = layoutArray(iPtr + 1).Substring(10, layoutArray(iPtr + 1).Length - 10) + If (IsNumeric(page)) Then + If (Convert.ToInt32(page) = 1) Then + If (Request("PageID") = "") Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Else + Dim objPageController As New PageController() + Dim objPages As ArrayList = objPageController.GetPageList(objArticle.ArticleID) + + Dim found As Boolean = False + If (Request("PageID") <> "") Then + Dim pageNumber As Integer = 1 + For Each objPage As PageInfo In objPages + If (Convert.ToInt32(page) = pageNumber) Then + If (Request("PageID") = objPage.PageID.ToString()) Then + found = True + End If + Exit For + End If + pageNumber = pageNumber + 1 + Next + End If + + If (found = True) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/ISNOTPAGE:")) Then + ' Do Nothing + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("HASCATEGORY:")) Then + Dim category As String = layoutArray(iPtr + 1).Substring(12, layoutArray(iPtr + 1).Length - 12) + + Dim objArticleCategories As ArrayList = CType(DataCache.GetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString()), ArrayList) + If (objArticleCategories Is Nothing) Then + Dim objArticleController As New ArticleController + objArticleCategories = objArticleController.GetArticleCategories(objArticle.ArticleID) + DataCache.SetCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & objArticle.ArticleID.ToString(), objArticleCategories) + End If + + Dim found As Boolean = False + If (category <> "") Then + For Each objCategory As CategoryInfo In objArticleCategories + If (category.ToLower() = objCategory.Name.ToLower()) Then + found = True + End If + Next + End If + + If (found = False) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/HASCATEGORY:")) Then + ' Do Nothing + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("HASTAG:")) Then + + Dim tagSelected As String = layoutArray(iPtr + 1).Substring(7, layoutArray(iPtr + 1).Length - 7) + + Dim found As Boolean = False + If (objArticle.Tags.Trim() <> "") Then + For Each tag As String In objArticle.Tags.Split(","c) + If (tag.ToLower() = tagSelected.ToLower()) Then + found = True + End If + Next + End If + + If (found = False) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/HASTAG:")) Then + ' Do Nothing + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("ISLOCALE:")) Then + Dim field As String = layoutArray(iPtr + 1).Substring(9, layoutArray(iPtr + 1).Length - 9) + + If (CType(Page, DotNetNuke.Framework.PageBase).PageCulture.Name.ToLower() <> field.ToLower()) Then + Dim endToken As String = "/" & layoutArray(iPtr + 1) + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/ISLOCALE:")) Then + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("PAGE:")) Then + If (IsNumeric(layoutArray(iPtr + 1).Substring(5, layoutArray(iPtr + 1).Length - 5))) Then + Dim pageNumber As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(5, layoutArray(iPtr + 1).Length - 5)) + + Dim objLiteral As New Literal + If (pageNumber > 0) Then + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + + If (pageList.Count >= pageNumber) Then + objLiteral.Text = ProcessPostTokens(Server.HtmlDecode(CType(pageList(pageNumber - 1), PageInfo).PageText), objArticle, Generator, ArticleSettings) + End If + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("PUBLISHENDDATE:")) Then + Dim formatExpression As String = layoutArray(iPtr + 1).Substring(15, layoutArray(iPtr + 1).Length - 15) + + Dim objLiteral As New Literal + + Try + If (objArticle.EndDate = Null.NullDate) Then + objLiteral.Text = "" + Else + objLiteral.Text = objArticle.EndDate.ToString(formatExpression) + End If + Catch + If (objArticle.EndDate = Null.NullDate) Then + objLiteral.Text = "" + Else + objLiteral.Text = objArticle.EndDate.ToString("D") + End If + End Try + + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("PUBLISHDATE:")) Then + Dim formatExpression As String = layoutArray(iPtr + 1).Substring(12, layoutArray(iPtr + 1).Length - 12) + + Dim objLiteral As New Literal + + Try + If (objArticle.StartDate = Null.NullDate) Then + objLiteral.Text = objArticle.CreatedDate.ToString(formatExpression) + Else + objLiteral.Text = objArticle.StartDate.ToString(formatExpression) + End If + Catch + If (objArticle.StartDate = Null.NullDate) Then + objLiteral.Text = objArticle.CreatedDate.ToString("D") + Else + objLiteral.Text = objArticle.StartDate.ToString("D") + End If + End Try + + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("PUBLISHSTARTDATE:")) Then + Dim formatExpression As String = layoutArray(iPtr + 1).Substring(17, layoutArray(iPtr + 1).Length - 17) + + Dim objLiteral As New Literal + + Try + If (objArticle.StartDate = Null.NullDate) Then + objLiteral.Text = objArticle.CreatedDate.ToString(formatExpression) + Else + objLiteral.Text = objArticle.StartDate.ToString(formatExpression) + End If + Catch + If (objArticle.StartDate = Null.NullDate) Then + objLiteral.Text = objArticle.CreatedDate.ToString("D") + Else + objLiteral.Text = objArticle.StartDate.ToString("D") + End If + End Try + + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("QUERYSTRING:")) Then + Dim variable As String = layoutArray(iPtr + 1).Substring(12, layoutArray(iPtr + 1).Length - 12) + + Dim objLiteral As New Literal + objLiteral.Text = Request.QueryString(variable) + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("RELATED:")) Then + _objRelatedArticles = Nothing + If (IsNumeric(layoutArray(iPtr + 1).Substring(8, layoutArray(iPtr + 1).Length - 8))) Then + Dim count As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(8, layoutArray(iPtr + 1).Length - 8)) + If (count > 0) Then + If (ArticleSettings.RelatedMode <> RelatedType.None) Then + Dim phRelated As New PlaceHolder + Dim objArticles As List(Of ArticleInfo) = GetRelatedArticles(objArticle, count) + If (objArticles.Count > 0) Then + Dim _objLayoutRelatedHeader As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Related_Header_Html) + Dim _objLayoutRelatedItem As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Related_Item_Html) + Dim _objLayoutRelatedFooter As LayoutInfo = GetLayout(ArticleSettings, ArticleModule, Page, LayoutType.Related_Footer_Html) + + ProcessArticleItem(phRelated.Controls, _objLayoutRelatedHeader.Tokens, objArticle) + For Each objRelatedArticle As ArticleInfo In objArticles + ProcessArticleItem(phRelated.Controls, _objLayoutRelatedItem.Tokens, objRelatedArticle) + Next + ProcessArticleItem(phRelated.Controls, _objLayoutRelatedFooter.Tokens, objArticle) + + objPlaceHolder.Add(phRelated) + End If + End If + End If + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("SUMMARY:")) Then + Dim summary As String = objArticle.Summary + If (IsNumeric(layoutArray(iPtr + 1).Substring(8, layoutArray(iPtr + 1).Length - 8))) Then + Dim length As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(8, layoutArray(iPtr + 1).Length - 8)) + If (StripHtml(Server.HtmlDecode(objArticle.Summary)).TrimStart().Length > length) Then + summary = ProcessPostTokens(Left(StripHtml(Server.HtmlDecode(objArticle.Summary)).TrimStart(), length), objArticle, Generator, ArticleSettings) & "..." + Else + summary = ProcessPostTokens(Left(StripHtml(Server.HtmlDecode(objArticle.Summary)).TrimStart(), length), objArticle, Generator, ArticleSettings) + End If + End If + + Dim objLiteral As New Literal + objLiteral.Text = summary + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("TITLE:")) Then + Dim title As String = objArticle.Title + If (IsNumeric(layoutArray(iPtr + 1).Substring(6, layoutArray(iPtr + 1).Length - 6))) Then + Dim length As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(6, layoutArray(iPtr + 1).Length - 6)) + If (objArticle.Title.Length > length) Then + title = Left(objArticle.Title, length) & "..." + Else + title = Left(objArticle.Title, length) + End If + End If + + Dim objLiteral As New Literal + objLiteral.Text = title + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("UPDATEDATE:")) Then + Dim formatExpression As String = layoutArray(iPtr + 1).Substring(11, layoutArray(iPtr + 1).Length - 11) + + Dim objLiteral As New Literal + + Try + If (objArticle.CreatedDate = Null.NullDate) Then + objLiteral.Text = "" + Else + objLiteral.Text = objArticle.LastUpdate.ToString(formatExpression) + End If + Catch + If (objArticle.CreatedDate = Null.NullDate) Then + objLiteral.Text = "" + Else + objLiteral.Text = objArticle.LastUpdate.ToString("D") + End If + End Try + + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("UPDATEDATELESSTHAN:")) Then + Dim length As Integer = Convert.ToInt32(layoutArray(iPtr + 1).Substring(19, layoutArray(iPtr + 1).Length - 19)) + + If (objArticle.LastUpdate < DateTime.Now.AddDays(length * -1)) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/UPDATEDATELESSTHAN") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Exit Select + End If + + If (layoutArray(iPtr + 1).ToUpper().StartsWith("/UPDATEDATELESSTHAN:")) Then + Exit Select + End If + + Dim objLiteralOther As New Literal + objLiteralOther.Text = "[" & layoutArray(iPtr + 1) & "]" + objLiteralOther.EnableViewState = False + objPlaceHolder.Add(objLiteralOther) + + End Select + End If + + Next + + End Sub + +#End Region + +#Region " Process Comment Item " + + Dim commentItemIndex As Integer = 0 + Public Sub ProcessComment(ByRef objPlaceHolder As ControlCollection, ByVal objArticle As ArticleInfo, ByVal objComment As CommentInfo, ByVal templateArray As String()) + + commentItemIndex = commentItemIndex + 1 + Dim isAnonymous As Boolean = Null.IsNull(objComment.UserID) + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(ProcessImages(templateArray(iPtr).ToString()))) + + If iPtr < templateArray.Length - 1 Then + Select Case templateArray(iPtr + 1) + Case "ANONYMOUSURL" + Dim objLiteral As New Literal + objLiteral.Text = AddHTTP(objComment.AnonymousURL) + objPlaceHolder.Add(objLiteral) + Case "ARTICLETITLE" + Dim objLiteral As New Literal + objLiteral.Text = objArticle.Title + objPlaceHolder.Add(objLiteral) + Case "AUTHOREMAIL" + Dim objLiteral As New Literal + If (objComment.UserID = Null.NullInteger) Then + objLiteral.Text = objComment.AnonymousEmail.ToString() + Else + objLiteral.Text = objComment.AuthorEmail.ToString() + End If + objPlaceHolder.Add(objLiteral) + Case "AUTHOR" + Dim objLiteral As New Literal + Select Case ArticleSettings.DisplayMode + Case DisplayType.FirstName + If (isAnonymous) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousFirstName") + End If + Else + objLiteral.Text = objComment.AuthorFirstName + End If + Exit Select + Case DisplayType.LastName + If (isAnonymous) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousLastName") + End If + Else + objLiteral.Text = objComment.AuthorLastName + End If + Exit Select + Case DisplayType.UserName + If (isAnonymous) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousUserName") + End If + Else + objLiteral.Text = objComment.AuthorUserName + End If + Exit Select + Case DisplayType.FullName + If (isAnonymous) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousFullName") + End If + Else + objLiteral.Text = objComment.AuthorDisplayName + End If + Exit Select + Case Else + If (isAnonymous) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousUserName") + End If + Else + objLiteral.Text = objComment.AuthorUserName + End If + Exit Select + End Select + objPlaceHolder.Add(objLiteral) + Case "AUTHORID" + Dim objLiteral As New Literal + objLiteral.Text = objComment.UserID.ToString() + objPlaceHolder.Add(objLiteral) + Case "AUTHORUSERNAME" + Dim objLiteral As New Literal + If (objComment.UserID = Null.NullInteger) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousUserName") + End If + Else + objLiteral.Text = objComment.AuthorUserName.ToString() + End If + objPlaceHolder.Add(objLiteral) + Case "AUTHORDISPLAYNAME" + Dim objLiteral As New Literal + If (objComment.UserID = Null.NullInteger) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousFullName") + End If + Else + objLiteral.Text = objComment.AuthorDisplayName.ToString() + End If + objPlaceHolder.Add(objLiteral) + Case "AUTHORFIRSTNAME" + Dim objLiteral As New Literal + If (objComment.UserID = Null.NullInteger) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousFirstName") + End If + Else + objLiteral.Text = objComment.AuthorFirstName.ToString() + End If + objPlaceHolder.Add(objLiteral) + Case "AUTHORLASTNAME" + Dim objLiteral As New Literal + If (objComment.UserID = Null.NullInteger) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousLastName") + End If + Else + objLiteral.Text = objComment.AuthorLastName.ToString() + End If + objPlaceHolder.Add(objLiteral) + Case "AUTHORFULLNAME" + Dim objLiteral As New Literal + If (objComment.UserID = Null.NullInteger) Then + If (objComment.AnonymousName <> "") Then + objLiteral.Text = objComment.AnonymousName + Else + objLiteral.Text = GetArticleResource("AnonymousFullName") + End If + Else + objLiteral.Text = objComment.AuthorFirstName.ToString() & " " & objComment.AuthorLastName.ToString() + End If + objPlaceHolder.Add(objLiteral) + Case "COMMENTID" + Dim objLiteral As New Literal + objLiteral.Text = objComment.CommentID.ToString() + objPlaceHolder.Add(objLiteral) + Case "COMMENT" + Dim objLiteral As New Literal + objLiteral.Text = ProcessPostTokens(EncodeComment(objComment), objArticle, Nothing, ArticleSettings) + objPlaceHolder.Add(objLiteral) + Case "COMMENTLINK" + Dim objLiteral As New Literal + objLiteral.Text = Common.GetArticleLink(objArticle, Tab, ArticleSettings, IncludeCategory) & "#Comments" + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Case "CREATEDATE" + Dim objLiteral As New Literal + objLiteral.Text = objComment.CreatedDate.ToString("D") + objPlaceHolder.Add(objLiteral) + Case "CREATETIME" + Dim objLiteral As New Literal + objLiteral.Text = objComment.CreatedDate.ToString("t") + objPlaceHolder.Add(objLiteral) + Case "DELETE" + If (ArticleSettings.IsAdmin() Or ArticleSettings.IsApprover() Or (UserId = objArticle.AuthorID And objArticle.AuthorID <> Null.NullInteger)) Then + Dim cmdDelete As New LinkButton + cmdDelete.CssClass = "CommandButton" + cmdDelete.Text = GetArticleResource("Delete") + cmdDelete.Attributes.Add("onClick", "javascript:return confirm('Are You Sure You Wish To Delete This Item ?');") + cmdDelete.CommandArgument = objComment.CommentID.ToString() + cmdDelete.CommandName = "DeleteComment" + Dim objHandler As New System.Web.UI.WebControls.CommandEventHandler(AddressOf Comment_Command) + AddHandler cmdDelete.Command, objHandler + objPlaceHolder.Add(cmdDelete) + End If + Case "EDIT" + If (ArticleSettings.IsAdmin() Or ArticleSettings.IsApprover() Or (UserId = objArticle.AuthorID And objArticle.AuthorID <> Null.NullInteger)) Then + Dim objHyperLink As New HyperLink + objHyperLink.CssClass = "CommandButton" + objHyperLink.Text = GetArticleResource("Edit") + objHyperLink.NavigateUrl = Common.GetModuleLink(ArticleModule.TabID, ArticleModule.ModuleID, "EditComment", ArticleSettings, "CommentID=" & objComment.CommentID.ToString(), "ReturnUrl=" & Server.UrlEncode(Request.RawUrl)) + objHyperLink.EnableViewState = False + objPlaceHolder.Add(objHyperLink) + End If + Case "GRAVATARURL" + Dim objLiteral As New Literal + If Request.IsSecureConnection Then + If (objComment.UserID = Null.NullInteger) Then + objLiteral.Text = AddHTTP("secure.gravatar.com/avatar/" & MD5CalcString(objComment.AnonymousEmail.ToLower())) + Else + objLiteral.Text = AddHTTP("secure.gravatar.com/avatar/" & MD5CalcString(objComment.AuthorEmail.ToLower())) + End If + Else + If (objComment.UserID = Null.NullInteger) Then + objLiteral.Text = AddHTTP("www.gravatar.com/avatar/" & MD5CalcString(objComment.AnonymousEmail.ToLower())) + Else + objLiteral.Text = AddHTTP("www.gravatar.com/avatar/" & MD5CalcString(objComment.AuthorEmail.ToLower())) + End If + End If + objPlaceHolder.Add(objLiteral) + Case "HASANONYMOUSURL" + If (objComment.AnonymousURL = "") Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASANONYMOUSURL") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Case "/HASANONYMOUSURL" + ' Do Nothing + Case "IPADDRESS" + Dim objLiteral As New Literal + objLiteral.Text = objComment.RemoteAddress + objPlaceHolder.Add(objLiteral) + Case "ISANONYMOUS" + If (objComment.UserID <> -1) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISANONYMOUS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Case "/ISANONYMOUS" + ' Do Nothing + Case "ISNOTANONYMOUS" + If (objComment.UserID = -1) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISNOTANONYMOUS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Case "/ISNOTANONYMOUS" + ' Do Nothing + Case "ISCOMMENT" + If (objComment.Type <> 0) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISCOMMENT") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Case "/ISCOMMENT" + ' Do Nothing + Case "ISPINGBACK" + If (objComment.Type <> 2) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISPINGBACK") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Case "/ISTRACKBACK" + ' Do Nothing + Case "ISTRACKBACK" + If (objComment.Type <> 1) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISTRACKBACK") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Case "/ISTRACKBACK" + ' Do Nothing + Case "ISAUTHOR" + If (objComment.UserID = Null.NullInteger Or (objComment.UserID <> objArticle.AuthorID)) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISAUTHOR") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Case "/ISAUTHOR" + ' Do Nothing + Case "ITEMINDEX" + Dim objLiteral As New Literal + objLiteral.Text = Me.commentItemIndex.ToString() + objPlaceHolder.Add(objLiteral) + Case "MODULEID" + Dim objLiteral As New Literal + objLiteral.Text = ArticleModule.ModuleID + objPlaceHolder.Add(objLiteral) + Case "PINGBACKURL" + Dim objLiteral As New Literal + objLiteral.Text = objComment.TrackbackUrl + objPlaceHolder.Add(objLiteral) + Case "TRACKBACKBLOGNAME" + Dim objLiteral As New Literal + objLiteral.Text = objComment.TrackbackBlogName + objPlaceHolder.Add(objLiteral) + Case "TRACKBACKEXCERPT" + Dim objLiteral As New Literal + objLiteral.Text = objComment.TrackbackExcerpt + objPlaceHolder.Add(objLiteral) + Case "TRACKBACKTITLE" + Dim objLiteral As New Literal + objLiteral.Text = objComment.TrackbackTitle + objPlaceHolder.Add(objLiteral) + Case "TRACKBACKURL" + Dim objLiteral As New Literal + objLiteral.Text = objComment.TrackbackUrl + objPlaceHolder.Add(objLiteral) + + Case Else + If (templateArray(iPtr + 1).ToUpper().StartsWith("AUTHOR:")) Then + If Author(objComment.UserID) IsNot Nothing Then + ' token to be processed + Dim field As String = templateArray(iPtr + 1).Substring(7, templateArray(iPtr + 1).Length - 7).ToLower().Trim() + + 'Gets the DNN profile property named like the token (field) + Dim profilePropertyFound As Boolean = False + Dim profilePropertyDataType As String = String.Empty + Dim profilePropertyName As String = String.Empty + Dim profilePropertyValue As String = String.Empty + + For Each objProfilePropertyDefinition As ProfilePropertyDefinition In ProfileProperties + If (objProfilePropertyDefinition.PropertyName.ToLower().Trim() = field) Then + + 'Gets the dnn profile property's datatype + Dim objListController As New ListController + Dim definitionEntry As ListEntryInfo = objListController.GetListEntryInfo(objProfilePropertyDefinition.DataType) + If Not definitionEntry Is Nothing Then + profilePropertyDataType = definitionEntry.Value + Else + profilePropertyDataType = "Unknown" + End If + + 'Gets the dnn profile property's name and current value for the given user (Agent = AuthorID) + profilePropertyName = objProfilePropertyDefinition.PropertyName + profilePropertyValue = Author(objComment.UserID).Profile.GetPropertyValue(profilePropertyName) + + profilePropertyFound = True + + End If + Next + + If profilePropertyFound Then + + Select Case profilePropertyDataType.ToLower() + Case "truefalse" + Dim objTrueFalse As New CheckBox + If profilePropertyValue = String.Empty Then + objTrueFalse.Checked = False + Else + objTrueFalse.Checked = CType(profilePropertyValue, Boolean) + End If + objTrueFalse.Enabled = False + objTrueFalse.EnableViewState = False + objPlaceHolder.Add(objTrueFalse) + + Case "richtext" + Dim objLiteral As New Literal + If profilePropertyValue = String.Empty Then + objLiteral.Text = String.Empty + Else + objLiteral.Text = Page.Server.HtmlDecode(profilePropertyValue) + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "list" + Dim objLiteral As New Literal + objLiteral.Text = profilePropertyValue + Dim objListController As New ListController + Dim objListEntryInfoCollection As ListEntryInfoCollection = objListController.GetListEntryInfoCollection(profilePropertyName) + For Each objListEntryInfo As ListEntryInfo In objListEntryInfoCollection + If objListEntryInfo.Value = profilePropertyValue Then + objLiteral.Text = objListEntryInfo.Text + Exit For + End If + Next + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case Else + Dim objLiteral As New Literal + If profilePropertyValue = String.Empty Then + objLiteral.Text = String.Empty + Else + If profilePropertyName.ToLower() = "website" Then + Dim url As String = profilePropertyValue + If url.ToLower.StartsWith("http://") Then + url = url.Substring(7) ' removes the "http://" + End If + objLiteral.Text = url + Else + objLiteral.Text = profilePropertyValue + End If + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End Select 'profilePropertyDataType + + End If ' DNN Profile property processing + End If + Exit Select + End If ' "AUTHOR:" token + + If (templateArray(iPtr + 1).ToUpper().StartsWith("CREATEDATE:")) Then + Dim formatExpression As String = templateArray(iPtr + 1).Substring(11, templateArray(iPtr + 1).Length - 11) + Dim objLiteral As New Literal + objLiteral.Text = objComment.CreatedDate.ToString(formatExpression) + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("COMMENT:")) Then + Dim count As String = templateArray(iPtr + 1).Substring(8, templateArray(iPtr + 1).Length - 8) + If (IsNumeric(count)) Then + Dim comment As String = objComment.Comment + If (StripHtml(objComment.Comment).TrimStart().Length > Convert.ToInt32(count)) Then + comment = Left(StripHtml(Server.HtmlDecode(objComment.Comment)).TrimStart(), Convert.ToInt32(count)) & "..." + End If + Dim objLiteral As New Literal + objLiteral.Text = comment + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + End If + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISINROLE:")) Then + Dim field As String = templateArray(iPtr + 1).Substring(9, templateArray(iPtr + 1).Length - 9) + If (PortalSecurity.IsInRole(field) = False) Then + Dim endToken As String = "/" & templateArray(iPtr + 1) + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + End Select + End If + + Next + + End Sub + + Public Sub ProcessFile(ByRef objPlaceHolder As ControlCollection, ByVal objArticle As ArticleInfo, ByVal objFile As FileInfo, ByVal templateArray As String()) + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(ProcessImages(templateArray(iPtr).ToString()))) + + If iPtr < templateArray.Length - 1 Then + Select Case templateArray(iPtr + 1) + + Case "ARTICLEID" + Dim objLiteral As New Literal + objLiteral.Text = objFile.ArticleID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "FILEID" + Dim objLiteral As New Literal + objLiteral.Text = objFile.FileID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "FILENAME" + Dim objLiteral As New Literal + objLiteral.Text = objFile.FileName.ToString() + objPlaceHolder.Add(objLiteral) + + Case "FILELINK" + Dim objLiteral As New Literal + objLiteral.Text = objFile.Link + objPlaceHolder.Add(objLiteral) + + Case "SIZE" + Dim objLiteral As New Literal + objLiteral.Text = Numeric2Bytes(objFile.Size) + objPlaceHolder.Add(objLiteral) + + Case "SORTORDER" + Dim objLiteral As New Literal + objLiteral.Text = objFile.SortOrder.ToString() + objPlaceHolder.Add(objLiteral) + + Case "TITLE" + Dim objLiteral As New Literal + objLiteral.Text = objFile.Title + objPlaceHolder.Add(objLiteral) + + Case Else + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISEXTENSION:")) Then + Dim field As String = templateArray(iPtr + 1).Substring(12, templateArray(iPtr + 1).Length - 12) + + If (objFile.FileName.ToUpper().EndsWith(field.ToUpper()) = False) Then + Dim endToken As String = "/" & templateArray(iPtr + 1) + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISNOTEXTENSION:")) Then + Dim field As String = templateArray(iPtr + 1).Substring(15, templateArray(iPtr + 1).Length - 15) + + If (objFile.FileName.ToUpper().EndsWith(field.ToUpper()) = True) Then + Dim endToken As String = "/" & templateArray(iPtr + 1) + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + End Select + End If + + Next + + End Sub + + Private imageIndex As Integer = 0 + Public Sub ProcessImage(ByRef objPlaceHolder As ControlCollection, ByVal objArticle As ArticleInfo, ByVal objImage As ImageInfo, ByVal templateArray As String()) + + imageIndex = imageIndex + 1 + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(ProcessImages(templateArray(iPtr).ToString()).Replace("{|", "[").Replace("|}", "]"))) + + If iPtr < templateArray.Length - 1 Then + Select Case templateArray(iPtr + 1) + + Case "ARTICLEID" + Dim objLiteral As New Literal + objLiteral.Text = objImage.ArticleID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "DESCRIPTION" + Dim objLiteral As New Literal + objLiteral.Text = objImage.Description + objPlaceHolder.Add(objLiteral) + + Case "FILENAME" + Dim objLiteral As New Literal + objLiteral.Text = objImage.FileName.ToString() + objPlaceHolder.Add(objLiteral) + + Case "HEIGHT" + Dim objLiteral As New Literal + objLiteral.Text = objImage.Height.ToString() + objPlaceHolder.Add(objLiteral) + + Case "IMAGEID" + Dim objLiteral As New Literal + objLiteral.Text = objImage.ImageID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "IMAGELINK" + Dim objLiteral As New Literal + objLiteral.Text = PortalSettings.HomeDirectory & objImage.Folder & objImage.FileName + objPlaceHolder.Add(objLiteral) + + Case "ITEMINDEX" + Dim objLiteral As New Literal + objLiteral.Text = imageIndex.ToString() + objPlaceHolder.Add(objLiteral) + + Case "SIZE" + Dim objLiteral As New Literal + objLiteral.Text = objImage.Size.ToString() + objPlaceHolder.Add(objLiteral) + + Case "SORTORDER" + Dim objLiteral As New Literal + objLiteral.Text = objImage.SortOrder.ToString() + objPlaceHolder.Add(objLiteral) + + Case "TITLE" + Dim objLiteral As New Literal + objLiteral.Text = objImage.Title + objPlaceHolder.Add(objLiteral) + + Case "WIDTH" + Dim objLiteral As New Literal + objLiteral.Text = objImage.Width.ToString() + objPlaceHolder.Add(objLiteral) + + Case Else + + If (templateArray(iPtr + 1).ToUpper().StartsWith("IMAGETHUMB:")) Then + Dim val As String = templateArray(iPtr + 1).Substring(11, templateArray(iPtr + 1).Length - 11) + If (val.IndexOf(":"c) <> -1) Then + Dim width As Integer = Convert.ToInt32(val.Split(":"c)(0)) + Dim height As Integer = Convert.ToInt32(val.Split(":"c)(1)) + + Dim objImageItem As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImageItem.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImage.Folder & objImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1") + Else + objImageItem.ImageUrl = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & width.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImage.Folder & objImage.FileName) & "&PortalID=" & PortalSettings.PortalId.ToString() & "&q=1&s=1") + End If + objImageItem.EnableViewState = False + objImageItem.AlternateText = objArticle.Title + objPlaceHolder.Add(objImageItem) + End If + Exit Select + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISITEMINDEX:")) Then + Dim field As String = templateArray(iPtr + 1).Substring(12, templateArray(iPtr + 1).Length - 12) + If (field <> imageIndex.ToString()) Then + Dim endToken As String = "/" & templateArray(iPtr + 1) + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Exit Select + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("/ISITEMINDEX:")) Then + Exit Select + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISNOTITEMINDEX:")) Then + Dim field As String = templateArray(iPtr + 1).Substring(15, templateArray(iPtr + 1).Length - 15) + If (field = imageIndex.ToString()) Then + Dim endToken As String = "/" & templateArray(iPtr + 1) + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + Exit Select + End If + + + If (templateArray(iPtr + 1).ToUpper().StartsWith("/ISNOTITEMINDEX:")) Then + Exit Select + End If + + Dim objLiteralOther As New Literal + objLiteralOther.Text = "[" & templateArray(iPtr + 1) & "]" + objLiteralOther.EnableViewState = False + objPlaceHolder.Add(objLiteralOther) + + End Select + End If + + Next + + End Sub + +#End Region + +#End Region + +#Region " Event Handlers " + + Private Sub Comment_Command(ByVal sender As Object, ByVal e As CommandEventArgs) + + Select Case e.CommandName.ToLower() + + Case "deletecomment" + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = objArticleController.GetArticle(Convert.ToInt32(Request("ArticleID"))) + + If (objArticle IsNot Nothing) Then + Dim objCommentController As New CommentController + objCommentController.DeleteComment(Convert.ToInt32(e.CommandArgument), objArticle.ArticleID) + End If + + HttpContext.Current.Response.Redirect(Request.RawUrl, True) + + End Select + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/Layout/LayoutInfo.vb b/Components/Layout/LayoutInfo.vb new file mode 100755 index 0000000..066ec5b --- /dev/null +++ b/Components/Layout/LayoutInfo.vb @@ -0,0 +1,43 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Class LayoutInfo + +#Region " Private Members " + + Dim _template As String + Dim _tokens As String() + +#End Region + +#Region " Public Properties " + + Public Property Template() As String + Get + Return _template + End Get + Set(ByVal Value As String) + _template = Value + End Set + End Property + + + Public Property Tokens() As String() + Get + Return _tokens + End Get + Set(ByVal Value As String()) + _tokens = Value + End Set + End Property + +#End Region + + End Class + +End Namespace diff --git a/Components/Layout/LayoutType.vb b/Components/Layout/LayoutType.vb new file mode 100755 index 0000000..b6414c8 --- /dev/null +++ b/Components/Layout/LayoutType.vb @@ -0,0 +1,62 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Enum LayoutType + + Category_Html + Category_Child_Html + + Comment_Item_Html + + Handout_Cover_Html + Handout_Header_Html + Handout_Item_Html + Handout_Footer_Html + Handout_End_Html + + File_Header_Html + File_Item_Html + File_Footer_Html + + Image_Header_Html + Image_Item_Html + Image_Footer_Html + + Listing_Header_Html + Listing_Item_Html + Listing_Featured_Html + Listing_Footer_Html + Listing_Empty_Html + + Menu_Item_Html + + Print_Header_Html + Print_Item_Html + Print_Footer_Html + + Related_Header_Html + Related_Item_Html + Related_Footer_Html + + Rss_Header_Html + Rss_Item_Html + Rss_Footer_Html + + Rss_Comment_Header_Html + Rss_Comment_Item_Html + Rss_Comment_Footer_Html + + View_Item_Html + View_Title_Html + View_Description_Html + View_Keyword_Html + View_PageHeader_Html + + End Enum + +End Namespace diff --git a/Components/Layout/TokenProcessor.vb b/Components/Layout/TokenProcessor.vb new file mode 100755 index 0000000..6330cfe --- /dev/null +++ b/Components/Layout/TokenProcessor.vb @@ -0,0 +1,372 @@ + + +Imports System.Web.UI +Imports System.Web.UI.WebControls +Imports Ventrian.NewsArticles.Components.Common + +Imports DotNetNuke +Imports DotNetNuke.Common +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Public Class TokenProcessor + +#Region " Private Methods " + + Private Shared Function GetModuleLink(ByVal key As String, ByVal moduleContext As NewsArticleModuleBase) As String + Return Common.GetModuleLink(moduleContext.TabId, moduleContext.ModuleId, key, moduleContext.ArticleSettings) + End Function + +#End Region + +#Region " Process Menu " + + Public Shared Sub ProcessMenu(ByRef placeHolder As ControlCollection, ByRef moduleContext As NewsArticleModuleBase, ByVal selectedMenu As MenuOptionType) + + Dim objLayoutController As New LayoutController(moduleContext) + Dim objLayout As LayoutInfo = LayoutController.GetLayout(moduleContext, LayoutType.Menu_Item_Html) + + For iPtr As Integer = 0 To objLayout.Tokens.Length - 1 Step 2 + + placeHolder.Add(New LiteralControl(objLayoutController.ProcessImages(objLayout.Tokens(iPtr).ToString()))) + + If iPtr < objLayout.Tokens.Length - 1 Then + ProcessMenuItem(objLayout.Tokens(iPtr + 1), placeHolder, objLayoutController, moduleContext, iPtr, objLayout.Tokens, selectedMenu) + End If + + Next + + End Sub + + Public Shared Sub ProcessMenuItem(ByVal token As String, ByRef objPlaceHolder As ControlCollection, ByVal objLayoutController As LayoutController, ByVal moduleContext As NewsArticleModuleBase, ByRef iPtr As Integer, ByVal templateArray As String(), ByVal selectedMenu As MenuOptionType) + + 'Dim path As String = objPage.TemplateSourceDirectory & "/DesktopModules/DnnForge - NewsArticles/" & Localization.LocalResourceDirectory & "/" & Localization.LocalSharedResourceFile + 'path = "~" & path.Substring(path.IndexOf("/DesktopModules/"), path.Length - path.IndexOf("/DesktopModules/")) + + Dim path As String = "~/DesktopModules/DnnForge - NewsArticles/" & Localization.LocalResourceDirectory & "/" & Localization.LocalSharedResourceFile + + Select Case token + + Case "ADMINLINK" + Dim objLiteral As New Literal + + Dim parameters As New List(Of String) + parameters.Add("mid=" & moduleContext.ModuleId) + + If (moduleContext.ArticleSettings.AuthorUserIDFilter) Then + If (moduleContext.ArticleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(moduleContext.ArticleSettings.AuthorUserIDParam) <> "") Then + parameters.Add(moduleContext.ArticleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(moduleContext.ArticleSettings.AuthorUserIDParam)) + End If + End If + End If + + If (moduleContext.ArticleSettings.AuthorUsernameFilter) Then + If (moduleContext.ArticleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(moduleContext.ArticleSettings.AuthorUsernameParam) <> "") Then + parameters.Add(moduleContext.ArticleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(moduleContext.ArticleSettings.AuthorUsernameParam)) + End If + End If + End If + + objLiteral.Text = NavigateURL(moduleContext.TabId, "AdminOptions", parameters.ToArray()) + objPlaceHolder.Add(objLiteral) + + Case "ARCHIVESLINK" + Dim objLiteral As New Literal + objLiteral.Text = GetModuleLink("Archives", moduleContext) + objPlaceHolder.Add(objLiteral) + + Case "APPROVEARTICLESLINK" + Dim objLiteral As New Literal + objLiteral.Text = GetModuleLink("ApproveArticles", moduleContext) + objPlaceHolder.Add(objLiteral) + + Case "APPROVECOMMENTSLINK" + Dim objLiteral As New Literal + objLiteral.Text = GetModuleLink("ApproveComments", moduleContext) + objPlaceHolder.Add(objLiteral) + + Case "CATEGORIESLINK" + Dim objLiteral As New Literal + objLiteral.Text = GetModuleLink("Archives", moduleContext) + objPlaceHolder.Add(objLiteral) + + Case "CURRENTARTICLESLINK" + Dim objLiteral As New Literal + objLiteral.Text = GetModuleLink("", moduleContext) + objPlaceHolder.Add(objLiteral) + + Case "HASCOMMENTSENABLED" + If (moduleContext.ArticleSettings.IsCommentsEnabled = False Or moduleContext.ArticleSettings.IsCommentModerationEnabled = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASCOMMENTSENABLED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASCOMMENTSENABLED" + ' Do Nothing + + Case "ISADMIN" + If (moduleContext.ArticleSettings.IsAdmin = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISADMIN") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISADMIN" + ' Do Nothing + + Case "ISAPPROVER" + If (moduleContext.ArticleSettings.IsApprover = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISAPPROVER") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISAPPROVER" + ' Do Nothing + + Case "ISSELECTEDADMIN" + If (selectedMenu <> MenuOptionType.AdminOptions) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSELECTEDADMIN") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSELECTEDADMIN" + ' Do Nothing + + Case "ISSELECTEDAPPROVEARTICLES" + If (selectedMenu <> MenuOptionType.ApproveArticles) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSELECTEDAPPROVEARTICLES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSELECTEDAPPROVEARTICLES" + ' Do Nothing + + Case "ISSELECTEDAPPROVECOMMENTS" + If (selectedMenu <> MenuOptionType.ApproveComments) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSELECTEDAPPROVECOMMENTS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSELECTEDAPPROVECOMMENTS" + ' Do Nothing + + Case "ISSELECTEDCATEGORIES" + If (selectedMenu <> MenuOptionType.Categories) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSELECTEDCATEGORIES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSELECTEDCATEGORIES" + ' Do Nothing + + Case "ISSELECTEDCURRENTARTICLES" + If (selectedMenu <> MenuOptionType.CurrentArticles) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSELECTEDCURRENTARTICLES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSELECTEDCURRENTARTICLES" + ' Do Nothing + + Case "ISSELECTEDMYARTICLES" + If (selectedMenu <> MenuOptionType.MyArticles) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSELECTEDMYARTICLES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSELECTEDMYARTICLES" + ' Do Nothing + + Case "ISSELECTEDSEARCH" + If (selectedMenu <> MenuOptionType.Search) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSELECTEDSEARCH") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSELECTEDSEARCH" + ' Do Nothing + + Case "ISSELECTEDSYNDICATION" + If (selectedMenu <> MenuOptionType.Syndication) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSELECTEDSYNDICATION") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSELECTEDSYNDICATION" + ' Do Nothing + + Case "ISSELECTEDSUBMITARTICLE" + If (selectedMenu <> MenuOptionType.SubmitArticle) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSELECTEDSUBMITARTICLE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSELECTEDSUBMITARTICLE" + ' Do Nothing + + Case "ISSYNDICATIONENABLED" + If (moduleContext.ArticleSettings.IsSyndicationEnabled = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSYNDICATIONENABLED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSYNDICATIONENABLED" + ' Do Nothing + + Case "ISSUBMITTER" + If (moduleContext.ArticleSettings.IsSubmitter = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/ISSUBMITTER") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISSUBMITTER" + ' Do Nothing + + Case "MYARTICLESLINK" + Dim objLiteral As New Literal + objLiteral.Text = GetModuleLink("MyArticles", moduleContext) + objPlaceHolder.Add(objLiteral) + + Case "RSSLATESTLINK" + Dim objLiteral As New Literal + Dim authorIDParam As String = "" + If (moduleContext.ArticleSettings.AuthorUserIDFilter) Then + If (moduleContext.ArticleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(moduleContext.ArticleSettings.AuthorUserIDParam) <> "") Then + authorIDParam = "&AuthorID=" & HttpContext.Current.Request(moduleContext.ArticleSettings.AuthorUserIDParam) + End If + End If + End If + + If (moduleContext.ArticleSettings.AuthorUsernameFilter) Then + If (moduleContext.ArticleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(moduleContext.ArticleSettings.AuthorUsernameParam) <> "") Then + Try + Dim objUser As Entities.Users.UserInfo = Entities.Users.UserController.GetUserByName(PortalController.GetCurrentPortalSettings().PortalId, HttpContext.Current.Request.QueryString(moduleContext.ArticleSettings.AuthorUsernameParam)) + If (objUser IsNot Nothing) Then + authorIDParam = "&AuthorID=" & objUser.UserID.ToString() + End If + Catch + End Try + End If + End If + End If + objLiteral.Text = ArticleUtilities.ResolveUrl("~/DesktopModules/DnnForge%20-%20NewsArticles/Rss.aspx") & "?TabID=" & moduleContext.TabId & "&ModuleID=" & moduleContext.ModuleId & "&MaxCount=25" & authorIDParam + objPlaceHolder.Add(objLiteral) + + Case "SEARCHLINK" + Dim objLiteral As New Literal + objLiteral.Text = GetModuleLink("Search", moduleContext) + objPlaceHolder.Add(objLiteral) + + Case "SUBMITARTICLELINK" + Dim objLiteral As New Literal + If (moduleContext.ArticleSettings.LaunchLinks) Then + objLiteral.Text = GetModuleLink("Edit", moduleContext) + Else + objLiteral.Text = GetModuleLink("SubmitNews", moduleContext) + End If + objPlaceHolder.Add(objLiteral) + + Case "SYNDICATIONLINK" + Dim objLiteral As New Literal + objLiteral.Text = GetModuleLink("Syndication", moduleContext) + objPlaceHolder.Add(objLiteral) + + Case Else + Dim isRendered As Boolean = False + + If (templateArray(iPtr + 1).ToUpper().StartsWith("RESX:")) Then + Dim key As String = templateArray(iPtr + 1).Substring(5, templateArray(iPtr + 1).Length - 5) + Dim objLiteral As New Literal + Try + objLiteral.Text = Localization.GetString(key & ".Text", path) + If (objLiteral.Text = "") Then + objLiteral.Text = templateArray(iPtr + 1).Substring(5, templateArray(iPtr + 1).Length - 5) + End If + Catch + objLiteral.Text = templateArray(iPtr + 1).Substring(5, templateArray(iPtr + 1).Length - 5) + End Try + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + isRendered = True + End If + + If (isRendered = False) Then + Dim objLiteralOther As New Literal + objLiteralOther.Text = "[" & templateArray(iPtr + 1) & "]" + objLiteralOther.EnableViewState = False + objPlaceHolder.Add(objLiteralOther) + End If + + End Select + + End Sub + + +#End Region + + End Class + +End Namespace diff --git a/Components/LayoutModeType.vb b/Components/LayoutModeType.vb new file mode 100755 index 0000000..80e7385 --- /dev/null +++ b/Components/LayoutModeType.vb @@ -0,0 +1,16 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Enum LayoutModeType + + Simple + Advanced + + End Enum + +End Namespace diff --git a/Components/LinkFilterType.vb b/Components/LinkFilterType.vb new file mode 100755 index 0000000..cd7d710 --- /dev/null +++ b/Components/LinkFilterType.vb @@ -0,0 +1,23 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum LinkFilterType + + None + Url + Page + + End Enum + +End Namespace diff --git a/Components/MatchOperator.vb b/Components/MatchOperator.vb new file mode 100755 index 0000000..be9f9b4 --- /dev/null +++ b/Components/MatchOperator.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum MatchOperatorType + + MatchAny + MatchAll + + End Enum + +End Namespace diff --git a/Components/MenuOptionType.vb b/Components/MenuOptionType.vb new file mode 100755 index 0000000..55505c2 --- /dev/null +++ b/Components/MenuOptionType.vb @@ -0,0 +1,29 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum MenuOptionType + + CurrentArticles + Categories + Search + Syndication + MyArticles + SubmitArticle + ApproveArticles + ApproveComments + AdminOptions + + End Enum + +End Namespace diff --git a/Components/MirrorArticleController.vb b/Components/MirrorArticleController.vb new file mode 100755 index 0000000..fc5fcd0 --- /dev/null +++ b/Components/MirrorArticleController.vb @@ -0,0 +1,41 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class MirrorArticleController + +#Region " Public Methods " + + Public Sub AddMirrorArticle(ByVal objMirrorArticle As MirrorArticleInfo) + + DataProvider.Instance().AddMirrorArticle(objMirrorArticle.ArticleID, objMirrorArticle.LinkedArticleID, objMirrorArticle.LinkedPortalID, objMirrorArticle.AutoUpdate) + + End Sub + + Public Function GetMirrorArticle(ByVal articleID As Integer) As MirrorArticleInfo + + Return CType(CBO.FillObject(DataProvider.Instance().GetMirrorArticle(articleID), GetType(MirrorArticleInfo)), MirrorArticleInfo) + + End Function + + Public Function GetMirrorArticleList(ByVal linkedArticleID As Integer) As ArrayList + + Return CBO.FillCollection(DataProvider.Instance().GetMirrorArticleList(linkedArticleID), GetType(MirrorArticleInfo)) + + End Function + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/MirrorArticleInfo.vb b/Components/MirrorArticleInfo.vb new file mode 100755 index 0000000..3a647b1 --- /dev/null +++ b/Components/MirrorArticleInfo.vb @@ -0,0 +1,102 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Portals + +Namespace Ventrian.NewsArticles + + Public Class MirrorArticleInfo + +#Region " Private Methods " + + ' local property declarations + Dim _articleID As Integer + Dim _linkedArticleID As Integer + Dim _linkedPortalID As Integer + Dim _autoUpdate As Boolean + Dim _portalName As String = "" + Dim _portalID As Integer + +#End Region + +#Region " Public Properties " + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal Value As Integer) + _articleID = Value + End Set + End Property + + Public Property PortalID() As Integer + Get + Return _portalID + End Get + Set(ByVal Value As Integer) + _portalID = Value + End Set + End Property + + Public Property LinkedArticleID() As Integer + Get + Return _linkedArticleID + End Get + Set(ByVal Value As Integer) + _linkedArticleID = Value + End Set + End Property + + Public Property LinkedPortalID() As Integer + Get + Return _linkedPortalID + End Get + Set(ByVal Value As Integer) + _linkedPortalID = Value + End Set + End Property + + Public Property AutoUpdate() As Boolean + Get + Return _autoUpdate + End Get + Set(ByVal Value As Boolean) + _autoUpdate = Value + End Set + End Property + + Public ReadOnly Property PortalName() As String + Get + If (_portalName = "") Then + Dim objPortalController As New PortalController() + Dim objPortal As PortalInfo = objPortalController.GetPortal(LinkedPortalID) + + If (objPortal IsNot Nothing) Then + _portalName = objPortal.PortalName + + Dim o As New PortalAliasController + Dim portalAliases As ArrayList = o.GetPortalAliasArrayByPortalID(_linkedPortalID) + + If (portalAliases.Count > 0) Then + _portalName = DotNetNuke.Common.AddHTTP(CType(portalAliases(0), PortalAliasInfo).HTTPAlias) + End If + End If + End If + Return _portalName + End Get + End Property + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/RatingController.vb b/Components/RatingController.vb new file mode 100755 index 0000000..621344c --- /dev/null +++ b/Components/RatingController.vb @@ -0,0 +1,103 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Framework + +Namespace Ventrian.NewsArticles + + Public Class RatingController + +#Region " Static Methods " + + Public Shared Sub ClearCache(ByVal moduleID As Integer) + + Dim itemsToRemove As New List(Of String)() + + Dim enumerator As IDictionaryEnumerator = HttpContext.Current.Cache.GetEnumerator() + While enumerator.MoveNext() + If enumerator.Key.ToString().ToLower().StartsWith("ventrian-newsarticles-rating-" & moduleID.ToString()) Then + itemsToRemove.Add(enumerator.Key.ToString()) + End If + End While + + For Each itemToRemove As String In itemsToRemove + DataCache.RemoveCache(itemToRemove.Replace("DNN_", "")) + Next + + End Sub + +#End Region + +#Region " Public Methods " + + Public Function Add(ByVal objRating As RatingInfo, ByVal moduleID As Integer) As Integer + + Dim ratingID As Integer = CType(DataProvider.Instance().AddRating(objRating.ArticleID, objRating.UserID, objRating.CreatedDate, objRating.Rating), Integer) + + ArticleController.ClearArticleCache(objRating.ArticleID) + + Dim cacheKey As String = "ventrian-newsarticles-rating-" & moduleID.ToString() & "-aid-" & objRating.ArticleID.ToString() & "-" & objRating.UserID.ToString() + DataCache.RemoveCache(cacheKey) + + Return ratingID + + End Function + + Public Function [Get](ByVal articleID As Integer, ByVal userID As Integer, ByVal moduleID As Integer) As RatingInfo + + Dim cacheKey As String = "ventrian-newsarticles-rating-" & moduleID.ToString() & "-aid-" & articleID.ToString() & "-" & userID.ToString() + + Dim objRating As RatingInfo = CType(DataCache.GetCache(cacheKey), RatingInfo) + + If (objRating Is Nothing) Then + objRating = CType(CBO.FillObject(DataProvider.Instance().GetRating(articleID, userID), GetType(RatingInfo)), RatingInfo) + If (objRating IsNot Nothing) Then + DataCache.SetCache(cacheKey, objRating) + Else + objRating = New RatingInfo() + objRating.RatingID = Null.NullInteger + DataCache.SetCache(cacheKey, objRating) + End If + End If + + Return objRating + + End Function + + Public Function [GetByID](ByVal ratingID As Integer, ByVal articleID As Integer, ByVal moduleID As Integer) As RatingInfo + + Dim cacheKey As String = "ventrian-newsarticles-rating-" & moduleID.ToString() & "-id-" & ratingID.ToString() + + Dim objRating As RatingInfo = CType(DataCache.GetCache(cacheKey), RatingInfo) + + If (objRating Is Nothing) Then + objRating = CType(CBO.FillObject(DataProvider.Instance().GetRatingByID(ratingID), GetType(RatingInfo)), RatingInfo) + DataCache.SetCache(cacheKey, objRating) + End If + + Return objRating + + End Function + + Public Sub Delete(ByVal ratingID As Integer, ByVal articleID As Integer, ByVal moduleID As Integer) + + DataProvider.Instance().DeleteRating(ratingID) + + ArticleController.ClearArticleCache(articleID) + + Dim cacheKey As String = "ventrian-newsarticles-rating-" & moduleID.ToString() & "-id-" & ratingID.ToString() + DataCache.RemoveCache(cacheKey) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/RatingInfo.vb b/Components/RatingInfo.vb new file mode 100755 index 0000000..64ac867 --- /dev/null +++ b/Components/RatingInfo.vb @@ -0,0 +1,72 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Class RatingInfo + +#Region " Private Members " + + Dim _ratingID As Integer + Dim _articleID As Integer + Dim _userID As Integer + Dim _createdDate As DateTime + Dim _rating As Double + +#End Region + +#Region " Public Properties " + + Public Property RatingID() As Integer + Get + Return _ratingID + End Get + Set(ByVal Value As Integer) + _ratingID = Value + End Set + End Property + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal Value As Integer) + _articleID = Value + End Set + End Property + + Public Property UserID() As Integer + Get + Return _userID + End Get + Set(ByVal Value As Integer) + _userID = Value + End Set + End Property + + Public Property CreatedDate() As DateTime + Get + Return _createdDate + End Get + Set(ByVal Value As DateTime) + _createdDate = Value + End Set + End Property + + Public Property Rating() As Double + Get + Return _rating + End Get + Set(ByVal Value As Double) + _rating = Value + End Set + End Property + +#End Region + + End Class + +End Namespace diff --git a/Components/RelatedType.vb b/Components/RelatedType.vb new file mode 100755 index 0000000..3fbba3f --- /dev/null +++ b/Components/RelatedType.vb @@ -0,0 +1,28 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum RelatedType + + None + MatchCategoriesAny + MatchCategoriesAll + MatchTagsAny + MatchTagsAll + MatchCategoriesAnyTagsAny + MatchCategoriesAllTagsAny + MatchCategoriesAnyTagsAll + + End Enum + +End Namespace diff --git a/Components/Social/Journal.vb b/Components/Social/Journal.vb new file mode 100755 index 0000000..d5a5232 --- /dev/null +++ b/Components/Social/Journal.vb @@ -0,0 +1,94 @@ +Imports DotNetNuke.Services.Journal + +Namespace Ventrian.NewsArticles.Components.Social + + Public Class Journal + + Public Const ContentTypeName As String = "Ventrian_Article_" + +#Region "Internal Methods" + + Friend Sub AddArticleToJournal(ByVal objArticle As ArticleInfo, ByVal portalId As Integer, ByVal tabId As Integer, ByVal journalUserId As Integer, ByVal journalGroupID As Integer, ByVal url As String) + Dim objectKey As String = "Ventrian_Article_" + objArticle.ArticleID.ToString() + "_" + journalGroupID.ToString() + Dim ji As JournalItem = JournalController.Instance.GetJournalItemByKey(portalId, objectKey) + + If Not ji Is Nothing Then + JournalController.Instance.DeleteJournalItemByKey(portalId, objectKey) + End If + + ji = New JournalItem + + ji.PortalId = portalId + ji.ProfileId = journalUserId + ji.UserId = journalUserId + ji.ContentItemId = objArticle.ArticleID + ji.Title = objArticle.Title + ji.ItemData = New ItemData() + ji.ItemData.Url = url + ji.Summary = objArticle.Summary + ji.Body = Nothing + ji.JournalTypeId = 15 + ji.ObjectKey = objectKey + ji.SecuritySet = "E," + ji.SocialGroupId = journalGroupID + + JournalController.Instance.SaveJournalItem(ji, tabId) + End Sub + + Friend Sub AddCommentToJournal(ByVal objArticle As ArticleInfo, ByVal objComment As CommentInfo, ByVal portalId As Integer, ByVal tabId As Integer, ByVal journalUserId As Integer, ByVal url As String) + Dim objectKey As String = "Ventrian_Article_Comment_" + objArticle.ArticleID.ToString() + ":" + objComment.CommentID.ToString() + Dim ji As JournalItem = JournalController.Instance.GetJournalItemByKey(portalId, objectKey) + + If Not ji Is Nothing Then + JournalController.Instance.DeleteJournalItemByKey(portalId, objectKey) + End If + + ji = New JournalItem + + ji.PortalId = portalId + ji.ProfileId = journalUserId + ji.UserId = journalUserId + ji.ContentItemId = objComment.CommentID + ji.Title = objArticle.Title + ji.ItemData = New ItemData() + ji.ItemData.Url = url + ji.Summary = objComment.Comment + ji.Body = Nothing + ji.JournalTypeId = 18 + ji.ObjectKey = objectKey + ji.SecuritySet = "E," + + JournalController.Instance.SaveJournalItem(ji, tabId) + End Sub + + Friend Sub AddRatingToJournal(ByVal objArticle As ArticleInfo, ByVal objRating As RatingInfo, ByVal portalId As Integer, ByVal tabId As Integer, ByVal journalUserId As Integer, ByVal url As String) + Dim objectKey As String = "Ventrian_Article_Rating_" + objArticle.ArticleID.ToString() + ":" + objRating.RatingID.ToString() + Dim ji As JournalItem = JournalController.Instance.GetJournalItemByKey(portalId, objectKey) + + If Not ji Is Nothing Then + JournalController.Instance.DeleteJournalItemByKey(portalId, objectKey) + End If + + ji = New JournalItem + + ji.PortalId = portalId + ji.ProfileId = journalUserId + ji.UserId = journalUserId + ji.ContentItemId = objRating.RatingID + ji.Title = objArticle.Title + ji.ItemData = New ItemData() + ji.ItemData.Url = url + ji.Summary = objRating.Rating.ToString() + ji.Body = Nothing + ji.JournalTypeId = 17 + ji.ObjectKey = objectKey + ji.SecuritySet = "E," + + JournalController.Instance.SaveJournalItem(ji, tabId) + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/StatusType.vb b/Components/StatusType.vb new file mode 100755 index 0000000..c21717d --- /dev/null +++ b/Components/StatusType.vb @@ -0,0 +1,23 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum StatusType + + Draft + AwaitingApproval + Published + + End Enum + +End Namespace diff --git a/Components/SyndicationEnclosureType.vb b/Components/SyndicationEnclosureType.vb new file mode 100755 index 0000000..1df6df1 --- /dev/null +++ b/Components/SyndicationEnclosureType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum SyndicationEnclosureType + + Attachment + Image + + End Enum + +End Namespace diff --git a/Components/SyndicationLinkType.vb b/Components/SyndicationLinkType.vb new file mode 100755 index 0000000..d871667 --- /dev/null +++ b/Components/SyndicationLinkType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum SyndicationLinkType + + Article + Attachment + + End Enum + +End Namespace diff --git a/Components/TagController.vb b/Components/TagController.vb new file mode 100755 index 0000000..6a7c587 --- /dev/null +++ b/Components/TagController.vb @@ -0,0 +1,112 @@ +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class TagController + +#Region " Private Methods " + + Private Sub RemoveCache(ByVal tagID As Integer) + + Dim objTag As TagInfo = [Get](tagID) + + If Not (objTag Is Nothing) Then + RemoveCache(objTag.ModuleID, objTag.TagID.ToString()) + End If + + End Sub + + Private Sub RemoveCache(ByVal moduleID As Integer, ByVal nameLowered As String) + + If Not (DataCache.GetCache("Tag-" & moduleID.ToString() & "-" & nameLowered) Is Nothing) Then + DataCache.RemoveCache("Tag-" & moduleID.ToString() & "-" & nameLowered) + End If + + End Sub + +#End Region + +#Region " Public Methods " + + Public Function [Get](ByVal tagID As Integer) As TagInfo + + Return CType(CBO.FillObject(DataProvider.Instance().GetTag(tagID), GetType(TagInfo)), TagInfo) + + End Function + + Public Function [Get](ByVal moduleID As Integer, ByVal nameLowered As String) As TagInfo + + Dim objTag As TagInfo = CType(DataCache.GetCache("Tag-" & moduleID.ToString() & "-" & nameLowered), TagInfo) + + If (objTag Is Nothing) Then + objTag = CType(CBO.FillObject(DataProvider.Instance().GetTagByName(moduleID, nameLowered), GetType(TagInfo)), TagInfo) + If Not (objTag Is Nothing) Then + DataCache.SetCache("Tag-" & moduleID.ToString() & "-" & nameLowered, objTag) + End If + End If + + Return objTag + + End Function + + Public Function List(ByVal moduleID As Integer, ByVal maxCount As Integer) As ArrayList + + Return CBO.FillCollection(DataProvider.Instance().ListTag(moduleID, maxCount), GetType(TagInfo)) + + End Function + + Public Function Add(ByVal objTag As TagInfo) As Integer + + Return CType(DataProvider.Instance().AddTag(objTag.ModuleID, objTag.Name, objTag.NameLowered), Integer) + + End Function + + Public Sub Update(ByVal objTag As TagInfo) + + RemoveCache(objTag.ModuleID, objTag.NameLowered) + DataProvider.Instance().UpdateTag(objTag.TagID, objTag.ModuleID, objTag.Name, objTag.NameLowered, objTag.Usages) + + End Sub + + Public Sub Delete(ByVal tagID As Integer) + + RemoveCache(tagID) + DataProvider.Instance().DeleteTag(tagID) + + End Sub + + Public Sub DeleteArticleTag(ByVal articleID As Integer) + + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = objArticleController.GetArticle(articleID) + + If Not (objArticle Is Nothing) Then + If (objArticle.Tags.Trim() <> "") Then + For Each tag As String In objArticle.Tags.Split(","c) + RemoveCache(objArticle.ModuleID, tag.ToLower()) + Next + End If + End If + DataProvider.Instance().DeleteArticleTag(articleID) + + End Sub + + Public Sub DeleteArticleTagByTag(ByVal tagID As Integer) + + RemoveCache(tagID) + DataProvider.Instance().DeleteArticleTag(tagID) + + End Sub + + Public Sub Add(ByVal articleID As Integer, ByVal tagID As Integer) + + RemoveCache(tagID) + DataProvider.Instance().AddArticleTag(articleID, tagID) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/TagInfo.vb b/Components/TagInfo.vb new file mode 100755 index 0000000..108b877 --- /dev/null +++ b/Components/TagInfo.vb @@ -0,0 +1,93 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Namespace Ventrian.NewsArticles + + Public Class TagInfo + Implements IComparable + +#Region " Private Members " + + Dim _tagID As Integer + Dim _moduleID As Integer + Dim _name As String + Dim _nameLowered As String + Dim _usages As Integer + +#End Region + +#Region " Public Properties " + + Public Property TagID() As Integer + Get + Return _tagID + End Get + Set(ByVal Value As Integer) + _tagID = Value + End Set + End Property + + Public Property ModuleID() As Integer + Get + Return _moduleID + End Get + Set(ByVal Value As Integer) + _moduleID = Value + End Set + End Property + + Public Property Name() As String + Get + Return _name + End Get + Set(ByVal Value As String) + _name = Value + End Set + End Property + + Public Property NameLowered() As String + Get + Return _nameLowered + End Get + Set(ByVal Value As String) + _nameLowered = Value + End Set + End Property + + Public Property Usages() As Integer + Get + Return _usages + End Get + Set(ByVal Value As Integer) + _usages = Value + End Set + End Property + +#End Region + +#Region " Optional Interfaces " + + Public Function CompareTo(ByVal obj As Object) As Integer _ + Implements System.IComparable.CompareTo + + If Not TypeOf obj Is TagInfo Then + Throw New Exception("Object is not TagInfo") + End If + + Dim Compare As TagInfo = CType(obj, TagInfo) + Dim result As Integer = Me.Name.CompareTo(Compare.Name) + + If result = 0 Then + result = Me.Name.CompareTo(Compare.Name) + End If + Return result + End Function + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Components/TemplateConstants.vb b/Components/TemplateConstants.vb new file mode 100755 index 0000000..501653a --- /dev/null +++ b/Components/TemplateConstants.vb @@ -0,0 +1,36 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System + +Namespace Ventrian.NewsArticles + + Public Class TemplateConstants + +#Region " Constants " + + ' Listing Settings + Public Const LISTING_ITEM As String = "Listing.Item" + Public Const LISTING_FEATURED As String = "Listing.Featured" + Public Const LISTING_HEADER As String = "Listing.Header" + Public Const LISTING_FOOTER As String = "Listing.Footer" + + Public Const VIEW_HEADER As String = "View.Header" + Public Const VIEW_FOOTER As String = "View.Footer" + Public Const VIEW_ITEM As String = "View.Item" + + Public Const COMMENT_ITEM As String = "Comment.Item" + Public Const COMMENT_HEADER As String = "Comment.Header" + Public Const COMMENT_FOOTER As String = "Comment.Footer" + + Public Const MENU_ITEM As String = "Menu.Item" + +#End Region + + End Class + +End Namespace + diff --git a/Components/TemplateController.vb b/Components/TemplateController.vb new file mode 100755 index 0000000..965d82a --- /dev/null +++ b/Components/TemplateController.vb @@ -0,0 +1,80 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.IO +Imports System.Web.Caching +Imports System.Xml + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Portals + +Namespace Ventrian.NewsArticles + + Public Class TemplateController + +#Region " Public Methods " + + Public Function GetTemplate(ByVal name As String, ByVal portalSettings As PortalSettings, ByVal template As String, ByVal tabModuleID As Integer) As TemplateInfo + ' Me.MapPath("Templates/" & Template & "/") + ' Dim pathToTemplate As String = articleModuleBase.TemplatePath + + Dim pathToTemplate As String = portalSettings.HomeDirectoryMapPath & "DnnForge - News Articles\Templates\Templates\" & template & "\" + + Dim cacheKey As String = tabModuleID.ToString() & name + Dim cacheKeyXml As String = tabModuleID.ToString() & name & ".xml" + + Dim objTemplate As TemplateInfo = CType(DataCache.GetCache(cacheKey), TemplateInfo) + Dim objTemplateXml As TemplateInfo = CType(DataCache.GetCache(cacheKeyXml), TemplateInfo) + + If (objTemplate Is Nothing Or objTemplateXml Is Nothing) Then + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + + objTemplate = New TemplateInfo + + Dim path As String = pathToTemplate & name & ".html" + Dim pathXml As String = pathToTemplate & name & ".xml" + + If (System.IO.File.Exists(path) = False) Then + ' path = articleModuleBase.MapPath("Templates/Default/") & name & ".html" + path = pathToTemplate & "Standard\" & name & ".html" + End If + + Dim sr As System.IO.StreamReader = New System.IO.StreamReader(path) + Try + objTemplate.Template = sr.ReadToEnd() + Catch + objTemplate.Template = "
ERROR: UNABLE TO READ '" & name & "' TEMPLATE:" + Finally + If Not sr Is Nothing Then sr.Close() + End Try + + Dim doc As New XmlDocument + Try + doc.Load(pathXml) + Catch + ' Do Nothing + Finally + objTemplate.Xml = doc + End Try + + objTemplate.Tokens = objTemplate.Template.Split(delimiter) + + DataCache.SetCache(cacheKey, objTemplate, New CacheDependency(path)) + DataCache.SetCache(cacheKeyXml, objTemplate, New CacheDependency(pathXml)) + End If + + Return objTemplate + + End Function + +#End Region + + End Class + +End Namespace + diff --git a/Components/TemplateInfo.vb b/Components/TemplateInfo.vb new file mode 100755 index 0000000..b0a595a --- /dev/null +++ b/Components/TemplateInfo.vb @@ -0,0 +1,53 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.Xml + +Namespace Ventrian.NewsArticles + + Public Class TemplateInfo + +#Region "Private Members" + Dim _template As String + Dim _tokens As String() + Dim _xml As XmlDocument +#End Region + +#Region "Public Properties" + + Public Property Template() As String + Get + Return _template + End Get + Set(ByVal Value As String) + _template = Value + End Set + End Property + + + Public Property Tokens() As String() + Get + Return _tokens + End Get + Set(ByVal Value As String()) + _tokens = Value + End Set + End Property + + Public Property Xml() As XmlDocument + Get + Return _xml + End Get + Set(ByVal Value As XmlDocument) + _xml = Value + End Set + End Property + +#End Region + + End Class + +End Namespace diff --git a/Components/ThumbnailType.vb b/Components/ThumbnailType.vb new file mode 100755 index 0000000..3c2a75d --- /dev/null +++ b/Components/ThumbnailType.vb @@ -0,0 +1,20 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2011 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Namespace Ventrian.NewsArticles + + Public Enum ThumbnailType + + Proportion + Square + + End Enum + +End Namespace diff --git a/Components/TitleReplacementType.vb b/Components/TitleReplacementType.vb new file mode 100755 index 0000000..8c48441 --- /dev/null +++ b/Components/TitleReplacementType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Enum TitleReplacementType + + Dash = 0 + Underscore = 1 + + End Enum + +End Namespace diff --git a/Components/Tracking/Notification.vb b/Components/Tracking/Notification.vb new file mode 100755 index 0000000..f0b5813 --- /dev/null +++ b/Components/Tracking/Notification.vb @@ -0,0 +1,44 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities + +Imports System.Threading + +Namespace Ventrian.NewsArticles.Tracking + + Public Class Notification + + Dim t As Thread + + Public Sub NotifyExternalSites(ByVal objArticle As ArticleInfo, ByVal articleLink As String, ByVal portalTitle As String) + + Dim objNotification As New NotificationJob + objNotification.Article = objArticle + objNotification.ArticleLink = articleLink + objNotification.PortalTitle = portalTitle + + Dim t As New Thread(AddressOf objNotification.NotifyLinkedSites) + t.IsBackground = True + t.Start() + + End Sub + + Public Sub NotifyWeblogs(ByVal articleLink As String, ByVal portalTitle As String) + + Dim objPing As New PingJob + Dim t As New Thread(AddressOf objPing.NotifyWeblogs) + objPing.ArticleLink = articleLink + objPing.PortalTitle = portalTitle + t.IsBackground = True + t.Start() + + End Sub + + + End Class + +End Namespace diff --git a/Components/Tracking/NotificationJob.vb b/Components/Tracking/NotificationJob.vb new file mode 100755 index 0000000..4a26e4f --- /dev/null +++ b/Components/Tracking/NotificationJob.vb @@ -0,0 +1,58 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.Collections.Specialized + +Namespace Ventrian.NewsArticles.Tracking + + Public Class NotificationJob + + Public Article As ArticleInfo + Public ArticleLink As String + Public PortalTitle As String + + Public Sub NotifyLinkedSites() + + Try + + Dim links As New StringCollection + TrackHelper.BuildLinks(Article.Summary, links) + TrackHelper.BuildLinks(Article.Body, links) + + For Each link As String In links + + Try + + Dim pageText As String = TrackHelper.GetPageText(link) + + If Not (pageText Is Nothing) Then + Dim success As Boolean = False + + Dim objTrackBackProxy As New TrackBackProxy + success = objTrackBackProxy.TrackBackPing(pageText, link, Article.Title, ArticleLink, PortalTitle, "") + + If (success = False) Then + ' objEventLog.AddLog("Ping Exception", "Trackback failed ->" & link, DotNetNuke.Common.Globals.GetPortalSettings(), -1, DotNetNuke.Services.Log.EventLog.EventLogController.EventLogType.ADMIN_ALERT) + + Dim objPingBackProxy As New PingBackProxy + objPingBackProxy.Ping(pageText, ArticleLink, link) + End If + + End If + + Catch + End Try + + Next + + Catch + End Try + + End Sub + + End Class + +End Namespace diff --git a/Components/Tracking/PingBackProxy.resx b/Components/Tracking/PingBackProxy.resx new file mode 100755 index 0000000..dd0ea4d --- /dev/null +++ b/Components/Tracking/PingBackProxy.resx @@ -0,0 +1,42 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 1.0.0.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + diff --git a/Components/Tracking/PingBackProxy.vb b/Components/Tracking/PingBackProxy.vb new file mode 100755 index 0000000..51ed920 --- /dev/null +++ b/Components/Tracking/PingBackProxy.vb @@ -0,0 +1,82 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Text.RegularExpressions + +Imports CookComputing.XmlRpc + +Namespace Ventrian.NewsArticles.Tracking + + Public Class PingBackProxy + Inherits XmlRpcClientProtocol + +#Region " Private Members " + + Dim _errorMessage As String + +#End Region + +#Region " Private Properties " + + Private Property ErrorMessage() As String + Get + Return _errorMessage + End Get + Set(ByVal Value As String) + _errorMessage = Value + End Set + End Property + +#End Region + +#Region " Public Methods " + + Public Function Ping(ByVal pageText As String, ByVal sourceURI As String, ByVal targetURI As String) As Boolean + Dim pingbackURL As String = GetPingBackURL(pageText, targetURI, sourceURI) + If Not pingbackURL Is Nothing Then + Me.Url = pingbackURL + Try + Notifiy(sourceURI, targetURI) + Return True + Catch ex As Exception + ErrorMessage = "Error: " + ex.Message + End Try + End If + Return False + + End Function + + _ + Public Sub Notifiy(ByVal sourceURI As String, ByVal targetURI As String) + + Invoke("Notifiy", New Object() {sourceURI, targetURI}) + + End Sub + +#End Region + +#Region " Private Methods " + + Private Function GetPingBackURL(ByVal pageText As String, ByVal url As String, ByVal PostUrl As String) As String + If Not Regex.IsMatch(pageText, PostUrl, RegexOptions.IgnoreCase Or RegexOptions.Singleline) Then + If Not pageText Is Nothing Then + Dim pat As String = "" + Dim reg As Regex = New Regex(pat, RegexOptions.IgnoreCase Or RegexOptions.Singleline) + Dim m As Match = reg.Match(pageText) + If m.Success Then + Return m.Result("$1") + End If + End If + End If + Return Nothing + End Function + +#End Region + + End Class + +End Namespace diff --git a/Components/Tracking/PingJob.vb b/Components/Tracking/PingJob.vb new file mode 100755 index 0000000..90a711d --- /dev/null +++ b/Components/Tracking/PingJob.vb @@ -0,0 +1,34 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.Collections.Specialized + +Namespace Ventrian.NewsArticles.Tracking + + Public Class PingJob + + Public ArticleLink As String + Public PortalTitle As String + + Public Sub NotifyWeblogs() + + Try + + Dim objPing As New PingProxy + objPing.Ping(PortalTitle, ArticleLink) + + Catch + ' Anything can happen here, so just swallow exception + Finally + Threading.Thread.CurrentThread.Abort() + End Try + + + End Sub + + End Class + +End Namespace diff --git a/Components/Tracking/PingProxy.resx b/Components/Tracking/PingProxy.resx new file mode 100755 index 0000000..dd0ea4d --- /dev/null +++ b/Components/Tracking/PingProxy.resx @@ -0,0 +1,42 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 1.0.0.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + diff --git a/Components/Tracking/PingProxy.vb b/Components/Tracking/PingProxy.vb new file mode 100755 index 0000000..804c1e5 --- /dev/null +++ b/Components/Tracking/PingProxy.vb @@ -0,0 +1,39 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Text.RegularExpressions + +Imports CookComputing.XmlRpc + +Namespace Ventrian.NewsArticles.Tracking + + Public Class PingProxy + Inherits XmlRpcClientProtocol + +#Region " Public Methods " + + Public Function Ping(ByVal WeblogName As String, ByVal WeblogURL As String) As WeblogsUpdateResponse + Dim proxy As IWebLogsUpdate = CType(XmlRpcProxyGen.Create(GetType(IWebLogsUpdate)), IWebLogsUpdate) + Return proxy.Ping(WeblogName, WeblogURL) + End Function + + Structure WeblogsUpdateResponse + Public flerror As Boolean + Public message As String + End Structure + + _ + Public Interface IWebLogsUpdate + _ + Function Ping(ByVal WeblogName As String, ByVal WeblogURL As String) As WeblogsUpdateResponse + End Interface + +#End Region + + End Class + +End Namespace diff --git a/Components/Tracking/TrackBackProxy.vb b/Components/Tracking/TrackBackProxy.vb new file mode 100755 index 0000000..aaa1b91 --- /dev/null +++ b/Components/Tracking/TrackBackProxy.vb @@ -0,0 +1,114 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.IO +Imports System.Net +Imports System.Text.RegularExpressions + +Namespace Ventrian.NewsArticles.Tracking + + Public Class TrackBackProxy + +#Region " Public Methods " + + Public Function TrackBackPing(ByVal pageText As String, ByVal url As String, ByVal title As String, ByVal link As String, ByVal blogname As String, ByVal description As String) As Boolean + + Dim objLogController As New DotNetNuke.Services.Log.EventLog.EventLogController + Dim objEventLog As New DotNetNuke.Services.Log.EventLog.EventLogController + + ' objEventLog.AddLog("Ping Exception", "Ping with a Return URL of ->" & link, DotNetNuke.Common.Globals.GetPortalSettings(), -1, DotNetNuke.Services.Log.EventLog.EventLogController.EventLogType.ADMIN_ALERT) + + Dim trackBackItem As String = GetTrackBackText(pageText, url, link) + + If Not trackBackItem Is Nothing Then + + If Not trackBackItem.ToLower().StartsWith("http://") Then + trackBackItem = "http://" + trackBackItem + End If + + Dim parameters As String = "title=" + HtmlEncode(title) + "&url=" + HtmlEncode(link) + "&blog_name=" + HtmlEncode(blogname) + "&excerpt=" + HtmlEncode(description) + SendPing(trackBackItem, parameters) + + Else + + ' objEventLog.AddLog("Ping Exception", "Pinging ->" & link & " -> Trackback Text not found on this page!", DotNetNuke.Common.Globals.GetPortalSettings(), -1, DotNetNuke.Services.Log.EventLog.EventLogController.EventLogType.ADMIN_ALERT) + + End If + + Return True + + End Function + +#End Region + +#Region " Private Methods " + + Private Function GetTrackBackText(ByVal pageText As String, ByVal url As String, ByVal PostUrl As String) As String + If Not Regex.IsMatch(pageText, PostUrl, RegexOptions.IgnoreCase Or RegexOptions.Singleline) Then + + Dim sPattern As String = "]*?>()?" + Dim r As Regex = New Regex(sPattern, RegexOptions.IgnoreCase) + Dim m As Match + + m = r.Match(pageText) + While (m.Success) + If m.Groups.ToString().Length > 0 Then + + Dim text As String = m.Groups(0).ToString() + If text.IndexOf(url) > 0 Then + Dim tbPattern As String = "trackback:ping=\""([^\""]+)\""" + Dim reg As Regex = New Regex(tbPattern, RegexOptions.IgnoreCase) + Dim m2 As Match = reg.Match(text) + If m2.Success Then + Return m2.Result("$1") + End If + + Return text + End If + End If + m = m.NextMatch + End While + End If + + Return Nothing + + End Function + + Private Function HtmlEncode(ByVal text As String) As String + + Return System.Web.HttpUtility.HtmlEncode(text) + + End Function + + Private Sub SendPing(ByVal trackBackItem As String, ByVal parameters As String) + + Dim myWriter As StreamWriter = Nothing + + Dim request As HttpWebRequest = CType(HttpWebRequest.Create(trackBackItem), HttpWebRequest) + If Not (request Is Nothing) Then + request.UserAgent = "My User Agent String" + request.Referer = "http://www.smcculloch.net/" + request.Timeout = 60000 + End If + + request.Method = "POST" + request.ContentLength = parameters.Length + request.ContentType = "application/x-www-form-urlencoded" + request.KeepAlive = False + + ' Try + myWriter = New StreamWriter(request.GetRequestStream()) + myWriter.Write(parameters) + 'Finally + myWriter.Close() + ' End Try + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Components/Tracking/TrackHelper.vb b/Components/Tracking/TrackHelper.vb new file mode 100755 index 0000000..21df027 --- /dev/null +++ b/Components/Tracking/TrackHelper.vb @@ -0,0 +1,61 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Collections.Specialized +Imports System.IO +Imports System.Net +Imports System.Text +Imports System.Text.RegularExpressions + +Namespace Ventrian.NewsArticles.Tracking + + Public Class TrackHelper + + Public Shared Function BuildLinks(ByVal text As String, ByRef links As StringCollection) As StringCollection + + Dim pattern As String = "(?:[hH][rR][eE][fF]\s*=)(?:[\s""""']*)(?!#|[Mm]ailto|[lL]ocation.|[jJ]avascript|.*css|.*this\.)(.*?)(?:[\s>""""'])" + + Dim r As New Regex(pattern, RegexOptions.IgnoreCase) + + Dim m As Match = r.Match(Common.HtmlDecode(text)) + Dim link As String = "" + While (m.Success) + If (m.Groups.ToString().Length > 0) Then + link = m.Groups(1).ToString() + If (links.Contains(link) = False) Then + links.Add(link) + End If + End If + m = m.NextMatch + End While + + Return links + + End Function + + Public Shared Function GetPageText(ByVal inURL As String) As String + + Dim req As WebRequest = WebRequest.Create(inURL) + Dim wreq As HttpWebRequest = CType(req, HttpWebRequest) + If Not (wreq Is Nothing) Then + wreq.UserAgent = "My User Agent String" + wreq.Referer = "http://www.wwwcoder.com/" + wreq.Timeout = 60000 + End If + Dim response As HttpWebResponse = CType(wreq.GetResponse, HttpWebResponse) + Dim s As Stream = response.GetResponseStream + Dim enc As String = response.ContentEncoding.Trim + If enc = "" Then enc = "us-ascii" + Dim encode As Encoding = System.Text.Encoding.GetEncoding(enc) + Dim sr As StreamReader = New StreamReader(s, encode) + Return sr.ReadToEnd + + End Function + + End Class + +End Namespace diff --git a/Components/Types/AuthorSelectType.vb b/Components/Types/AuthorSelectType.vb new file mode 100755 index 0000000..60b1371 --- /dev/null +++ b/Components/Types/AuthorSelectType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles.Components.Types + + Public Enum AuthorSelectType + + ByDropdown + ByUsername + + End Enum + +End Namespace diff --git a/Components/Types/MenuPositionType.vb b/Components/Types/MenuPositionType.vb new file mode 100755 index 0000000..dca144a --- /dev/null +++ b/Components/Types/MenuPositionType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles.Components.Types + + Public Enum MenuPositionType + + Top + Bottom + + End Enum + +End Namespace diff --git a/Components/Types/TextEditorModeType.vb b/Components/Types/TextEditorModeType.vb new file mode 100755 index 0000000..11f430f --- /dev/null +++ b/Components/Types/TextEditorModeType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles.Components.Types + + Public Enum TextEditorModeType + + Basic + Rich + + End Enum + +End Namespace diff --git a/Components/Types/UrlModeType.vb b/Components/Types/UrlModeType.vb new file mode 100755 index 0000000..b2f0347 --- /dev/null +++ b/Components/Types/UrlModeType.vb @@ -0,0 +1,22 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Configuration +Imports System.Data + +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles.Components.Types + + Public Enum UrlModeType + + Classic + Shorterned + + End Enum + +End Namespace diff --git a/Components/UserTime.vb b/Components/UserTime.vb new file mode 100755 index 0000000..f03ba72 --- /dev/null +++ b/Components/UserTime.vb @@ -0,0 +1,91 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Data +Imports System.web + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Entities.Users + +Namespace Ventrian.NewsArticles + + Public Class UserTime1 + + Public Sub New() + + End Sub + + Public Function ConvertToUserTime(ByVal dt As DateTime, ByVal ClientTimeZone As Double) As DateTime + + Dim _portalSettings As PortalSettings = PortalController.GetCurrentPortalSettings + + Return dt.AddMinutes(ClientTimeZone) + + End Function + + Public Function ConvertToServerTime(ByVal dt As DateTime, ByVal ClientTimeZone As Double) As DateTime + + Dim _portalSettings As PortalSettings = PortalController.GetCurrentPortalSettings + + Return dt.AddMinutes(ClientTimeZone * -1) + + + End Function + + Public ReadOnly Property ClientToServerTimeZoneFactor(ByVal serverTimeZoneOffet As Integer) As Double + + Get + + Dim objUserInfo As UserInfo = UserController.GetCurrentUserInfo + Return FromClientToServerFactor(objUserInfo.Profile.TimeZone, serverTimeZoneOffet) + + End Get + + End Property + + Public ReadOnly Property PortalToServerTimeZoneFactor(ByVal serverTimeZoneOffet As Integer) As Double + + Get + + Dim _portalSettings As PortalSettings = PortalController.GetCurrentPortalSettings + Return FromClientToServerFactor(_portalSettings.TimeZoneOffset, serverTimeZoneOffet) + + End Get + + End Property + + + Public ReadOnly Property ServerToClientTimeZoneFactor() As Double + + Get + + Dim objUser As UserInfo = UserController.GetCurrentUserInfo() + Dim _portalSettings As PortalSettings = PortalController.GetCurrentPortalSettings + Return FromServerToClientFactor(objUser.Profile.TimeZone, _portalSettings.TimeZoneOffset) + + End Get + + End Property + + Private Function FromClientToServerFactor(ByVal Client As Double, ByVal Server As Double) As Double + + Return Client - Server + + End Function + + Private Function FromServerToClientFactor(ByVal Client As Double, ByVal Server As Double) As Double + + Return Server - Client + + End Function + + End Class + +End Namespace + diff --git a/Components/Utility/LocalizationUtil.vb b/Components/Utility/LocalizationUtil.vb new file mode 100755 index 0000000..5f47a1e --- /dev/null +++ b/Components/Utility/LocalizationUtil.vb @@ -0,0 +1,140 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2008 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.IO +Imports System.Xml + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Services.Localization + +Namespace Ventrian.NewsArticles.Components.Utility + + Public Class LocalizationUtil + +#Region " Private Members " + + Private Shared _strUseLanguageInUrlDefault As String = Null.NullString + +#End Region + +#Region " Public Methods " + + Private Shared Function GetHostSettingAsBoolean(ByVal key As String, ByVal defaultValue As Boolean) As Boolean + Dim retValue As Boolean = defaultValue + Try + Dim setting As String = DotNetNuke.Entities.Host.HostSettings.GetHostSetting(key) + If String.IsNullOrEmpty(setting) = False Then + retValue = (setting.ToUpperInvariant().StartsWith("Y") OrElse setting.ToUpperInvariant = "TRUE") + End If + Catch ex As Exception + 'we just want to trap the error as we may not be installed so there will be no Settings + End Try + Return retValue + End Function + + Private Shared Function GetPortalSettingAsBoolean(ByVal portalID As Integer, ByVal key As String, ByVal defaultValue As Boolean) As Boolean + Dim retValue As Boolean = defaultValue + Try + Dim setting As String = DotNetNuke.Entities.Portals.PortalSettings.GetSiteSetting(portalID, key) + If String.IsNullOrEmpty(setting) = False Then + retValue = (setting.ToUpperInvariant().StartsWith("Y") OrElse setting.ToUpperInvariant = "TRUE") + End If + Catch ex As Exception + 'we just want to trap the error as we may not be installed so there will be no Settings + End Try + Return retValue + End Function + + Public Shared Function UseLanguageInUrl() As Boolean + + Dim hostSetting As String = DotNetNuke.Entities.Host.HostSettings.GetHostSetting("EnableUrlLanguage") + If (hostSetting <> "") Then + Return GetHostSettingAsBoolean("EnableUrlLanguage", True) + End If + + Dim objSettings As PortalSettings = PortalController.GetCurrentPortalSettings() + Dim portalSetting As String = DotNetNuke.Entities.Portals.PortalSettings.GetSiteSetting(objSettings.PortalId, "EnableUrlLanguage") + If (portalSetting <> "") Then + Return GetPortalSettingAsBoolean(objSettings.PortalId, "EnableUrlLanguage", True) + End If + + If (File.Exists(HttpContext.Current.Server.MapPath(Localization.ApplicationResourceDirectory + "/Locales.xml")) = False) Then + Return GetHostSettingAsBoolean("EnableUrlLanguage", True) + End If + + Dim cacheKey As String = "" + Dim objPortalSettings As PortalSettings = PortalController.GetCurrentPortalSettings() + Dim useLanguage As Boolean = False + + ' check default host setting + If String.IsNullOrEmpty(_strUseLanguageInUrlDefault) Then + Dim xmldoc As New XmlDocument + Dim languageInUrl As XmlNode + + xmldoc.Load(HttpContext.Current.Server.MapPath(Localization.ApplicationResourceDirectory + "/Locales.xml")) + languageInUrl = xmldoc.SelectSingleNode("//root/languageInUrl") + If Not languageInUrl Is Nothing Then + _strUseLanguageInUrlDefault = languageInUrl.Attributes("enabled").InnerText + Else + Try + Dim version As Integer = Convert.ToInt32(PortalController.GetCurrentPortalSettings().Version.Replace(".", "")) + If (version >= 490) Then + _strUseLanguageInUrlDefault = "true" + Else + _strUseLanguageInUrlDefault = "false" + End If + Catch + _strUseLanguageInUrlDefault = "false" + End Try + End If + End If + useLanguage = Boolean.Parse(_strUseLanguageInUrlDefault) + + ' check current portal setting + Dim FilePath As String = HttpContext.Current.Server.MapPath(Localization.ApplicationResourceDirectory + "/Locales.Portal-" + objPortalSettings.PortalId.ToString + ".xml") + If File.Exists(FilePath) Then + cacheKey = "dotnetnuke-uselanguageinurl" & objPortalSettings.PortalId.ToString + Try + Dim o As Object = DataCache.GetCache(cacheKey) + If o Is Nothing Then + Dim xmlLocales As New XmlDocument + Dim bXmlLoaded As Boolean = False + + xmlLocales.Load(FilePath) + bXmlLoaded = True + + Dim d As New XmlDocument + d.Load(FilePath) + + If bXmlLoaded AndAlso Not xmlLocales.SelectSingleNode("//locales/languageInUrl") Is Nothing Then + useLanguage = Boolean.Parse(xmlLocales.SelectSingleNode("//locales/languageInUrl").Attributes("enabled").InnerText) + End If + If Globals.PerformanceSetting <> Globals.PerformanceSettings.NoCaching Then + Dim dp As New CacheDependency(FilePath) + DataCache.SetCache(cacheKey, useLanguage, dp) + End If + Else + useLanguage = CType(o, Boolean) + End If + Catch ex As Exception + End Try + + Return useLanguage + Else + Return useLanguage + End If + + End Function + +#End Region + + End Class + +End Namespace + + diff --git a/Components/Validators/CheckBoxListValidator.vb b/Components/Validators/CheckBoxListValidator.vb new file mode 100755 index 0000000..1d5adfd --- /dev/null +++ b/Components/Validators/CheckBoxListValidator.vb @@ -0,0 +1,114 @@ +Imports System.Web +Imports System +Imports System.ComponentModel +Imports System.Collections.Generic +Imports System.IO +Imports System.Text +Imports System.Web.UI +Imports System.Web.UI.WebControls +Imports System.Xml + +Namespace Ventrian.NewsArticles.Components.Validators + Public Class CheckBoxListValidator + Inherits BaseValidator + _ + Public Property MinimumNumberOfSelectedCheckBoxes() As Integer + Get + Dim o As Object = ViewState("MinimumNumberOfSelectedCheckBoxes") + If o Is Nothing Then + Return 1 + Else + Return CInt(o) + End If + End Get + Set(ByVal value As Integer) + ViewState("MinimumNumberOfSelectedCheckBoxes") = value + End Set + End Property + + Private _ctrlToValidate As CheckBoxList = Nothing + Protected ReadOnly Property CheckBoxListToValidate() As CheckBoxList + Get + If _ctrlToValidate Is Nothing Then + _ctrlToValidate = TryCast(FindControl(Me.ControlToValidate), CheckBoxList) + End If + + Return _ctrlToValidate + End Get + End Property + + Protected Overloads Overrides Function ControlPropertiesValid() As Boolean + ' Make sure ControlToValidate is set + If Me.ControlToValidate.Length = 0 Then + Throw New HttpException(String.Format("The ControlToValidate property of '{0}' cannot be blank.", Me.ID)) + End If + + ' Ensure that the control being validated is a CheckBoxList + If CheckBoxListToValidate Is Nothing Then + Throw New HttpException(String.Format("The CheckBoxListValidator can only validate controls of type CheckBoxList.")) + End If + + ' ... and that it has at least MinimumNumberOfSelectedCheckBoxes ListItems + 'If CheckBoxListToValidate.Items.Count < MinimumNumberOfSelectedCheckBoxes Then + ' Throw New HttpException(String.Format("MinimumNumberOfSelectedCheckBoxes must be set to a value greater than or equal to the number of ListItems; MinimumNumberOfSelectedCheckBoxes is set to {0}, but there are only {1} ListItems in '{2}'", MinimumNumberOfSelectedCheckBoxes, CheckBoxListToValidate.Items.Count, CheckBoxListToValidate.ID)) + 'End If + + Return True + ' if we reach here, everything checks out + End Function + + Protected Overloads Overrides Function EvaluateIsValid() As Boolean + ' Make sure that the CheckBoxList has at least MinimumNumberOfSelectedCheckBoxes ListItems selected + Dim selectedItemCount As Integer = 0 + For Each cb As ListItem In CheckBoxListToValidate.Items + If cb.Selected Then + selectedItemCount += 1 + End If + Next + + Return selectedItemCount >= MinimumNumberOfSelectedCheckBoxes + End Function + + Protected Overloads Overrides Sub AddAttributesToRender(ByVal writer As HtmlTextWriter) + MyBase.AddAttributesToRender(writer) + + ' Add the client-side code (if needed) + If Me.RenderUplevel Then + ' Indicate the mustBeChecked value and the client-side function to used for evaluation + ' Use AddAttribute if Helpers.EnableLegacyRendering is true; otherwise, use expando attributes + If EnableLegacyRendering() Then + writer.AddAttribute("evaluationfunction", "CheckBoxListValidatorEvaluateIsValid", False) + writer.AddAttribute("minimumNumberOfSelectedCheckBoxes", MinimumNumberOfSelectedCheckBoxes.ToString(), False) + Else + Me.Page.ClientScript.RegisterExpandoAttribute(Me.ClientID, "evaluationfunction", "CheckBoxListValidatorEvaluateIsValid", False) + Me.Page.ClientScript.RegisterExpandoAttribute(Me.ClientID, "minimumNumberOfSelectedCheckBoxes", MinimumNumberOfSelectedCheckBoxes.ToString(), False) + End If + End If + End Sub + + Protected Overloads Overrides Sub OnPreRender(ByVal e As EventArgs) + MyBase.OnPreRender(e) + + ' Register the client-side function using WebResource.axd (if needed) + ' see: http://aspnet.4guysfromrolla.com/articles/080906-1.aspx + If Me.RenderUplevel AndAlso Me.Page IsNot Nothing AndAlso Not Me.Page.ClientScript.IsClientScriptIncludeRegistered(Me.[GetType](), "VentrianValidators") Then + Me.Page.ClientScript.RegisterClientScriptInclude(Me.[GetType](), "VentrianValidators", Me.Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/Includes/VentrianValidators.js")) + End If + End Sub + + Private Function EnableLegacyRendering() As Boolean + Dim result As Boolean + + Try + Dim webConfigFile As String = Path.Combine(HttpContext.Current.Request.PhysicalApplicationPath, "web.config") + Dim webConfigReader As New XmlTextReader(New StreamReader(webConfigFile)) + result = ((webConfigReader.ReadToFollowing("xhtmlConformance")) AndAlso (webConfigReader.GetAttribute("mode") = "Legacy")) + webConfigReader.Close() + Catch + result = False + End Try + Return result + End Function + + End Class +End Namespace diff --git a/Components/WatermarkPosition.vb b/Components/WatermarkPosition.vb new file mode 100755 index 0000000..ac974ab --- /dev/null +++ b/Components/WatermarkPosition.vb @@ -0,0 +1,14 @@ +Namespace Ventrian.NewsArticles + + Public Enum WatermarkPosition + + TopLeft + TopRight + BottomLeft + BottomRight + + End Enum + +End Namespace + + diff --git a/Components/WebControls/PagingControl.vb b/Components/WebControls/PagingControl.vb new file mode 100755 index 0000000..3228708 --- /dev/null +++ b/Components/WebControls/PagingControl.vb @@ -0,0 +1,391 @@ +' +' DotNetNuke® - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by DotNetNuke Corporation +' +' Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated +' documentation files (the "Software"), to deal in the Software without restriction, including without limitation +' the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and +' to permit persons to whom the Software is furnished to do so, subject to the following conditions: +' +' The above copyright notice and this permission notice shall be included in all copies or substantial portions +' of the Software. +' +' THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED +' TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +' THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF +' CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +' DEALINGS IN THE SOFTWARE. +' + +Imports System.ComponentModel +Imports System.Web.UI +Imports DotNetNuke +Imports DotNetNuke.Common + +Namespace Ventrian.NewsArticles.Components.WebControls + + ")> Public Class PagingControl + Inherits System.Web.UI.WebControls.WebControl + + Protected tablePageNumbers As System.Web.UI.WebControls.Table + Protected WithEvents PageNumbers As System.Web.UI.WebControls.Repeater + Protected cellDisplayStatus As System.Web.UI.WebControls.TableCell + Protected cellDisplayLinks As System.Web.UI.WebControls.TableCell + + Private TotalPages As Integer = -1 + + Private _TotalRecords As Integer + Private _PageSize As Integer + Private _CurrentPage As Integer + Private _QuerystringParams As String + Private _PageParam As String = "lapg" + Private _TabID As Integer + Private _CSSClassLinkActive As String + Private _CSSClassLinkInactive As String + Private _CSSClassPagingStatus As String + + Property TotalRecords() As Integer + Get + Return _TotalRecords + End Get + + Set(ByVal Value As Integer) + _TotalRecords = Value + End Set + End Property + Property PageSize() As Integer + Get + Return _PageSize + End Get + + Set(ByVal Value As Integer) + _PageSize = Value + End Set + End Property + Property CurrentPage() As Integer + Get + Return _CurrentPage + End Get + + Set(ByVal Value As Integer) + _CurrentPage = Value + End Set + End Property + Property QuerystringParams() As String + Get + Return _QuerystringParams + End Get + + Set(ByVal Value As String) + _QuerystringParams = Value + End Set + End Property + Property TabID() As Integer + Get + Return _TabID + End Get + + Set(ByVal Value As Integer) + _TabID = Value + End Set + End Property + Property PageParam() As String + Get + Return _PageParam + End Get + + Set(ByVal Value As String) + _PageParam = Value + End Set + End Property + Property CSSClassLinkActive() As String + Get + If _CSSClassLinkActive = "" Then + Return "CommandButton" + Else + Return _CSSClassLinkActive + End If + End Get + + Set(ByVal Value As String) + _CSSClassLinkActive = Value + End Set + End Property + Property CSSClassLinkInactive() As String + Get + If _CSSClassLinkInactive = "" Then + Return "NormalDisabled" + Else + Return _CSSClassLinkInactive + End If + End Get + + Set(ByVal Value As String) + _CSSClassLinkInactive = Value + End Set + End Property + Property CSSClassPagingStatus() As String + Get + If _CSSClassPagingStatus = "" Then + Return "Normal" + Else + Return _CSSClassPagingStatus + End If + End Get + + Set(ByVal Value As String) + _CSSClassPagingStatus = Value + End Set + End Property + + Protected Overrides Sub CreateChildControls() + tablePageNumbers = New System.Web.UI.WebControls.Table + cellDisplayStatus = New System.Web.UI.WebControls.TableCell + cellDisplayLinks = New System.Web.UI.WebControls.TableCell + cellDisplayStatus.CssClass = "Normal" + cellDisplayLinks.CssClass = "Normal" + + If Me.CssClass = "" Then + tablePageNumbers.CssClass = "PagingTable" + Else + tablePageNumbers.CssClass = Me.CssClass + End If + + Dim intRowIndex As Integer = tablePageNumbers.Rows.Add(New TableRow) + + PageNumbers = New Repeater + Dim I As New PageNumberLinkTemplate(Me) + PageNumbers.ItemTemplate = I + BindPageNumbers(TotalRecords, PageSize) + + cellDisplayStatus.HorizontalAlign = HorizontalAlign.Left + cellDisplayStatus.Width = New Unit("50%") + cellDisplayLinks.HorizontalAlign = HorizontalAlign.Right + cellDisplayLinks.Width = New Unit("50%") + Dim intTotalPages As Integer = TotalPages + If intTotalPages = 0 Then intTotalPages = 1 + + Dim str As String + str = String.Format(Services.Localization.Localization.GetString("Pages"), CurrentPage.ToString, intTotalPages.ToString) + Dim lit As New LiteralControl(str) + cellDisplayStatus.Controls.Add(lit) + + tablePageNumbers.Rows(intRowIndex).Cells.Add(cellDisplayStatus) + tablePageNumbers.Rows(intRowIndex).Cells.Add(cellDisplayLinks) + + End Sub + + Protected Overrides Sub Render(ByVal output As System.Web.UI.HtmlTextWriter) + If PageNumbers Is Nothing Then + CreateChildControls() + End If + + Dim str As New System.Text.StringBuilder + + str.Append(GetFirstLink() + "   ") + str.Append(GetPreviousLink() + "   ") + Dim result As System.Text.StringBuilder = New System.Text.StringBuilder(1024) + PageNumbers.RenderControl(New HtmlTextWriter(New System.IO.StringWriter(result))) + str.Append(result.ToString()) + str.Append(GetNextLink() + "   ") + str.Append(GetLastLink() + "   ") + cellDisplayLinks.Controls.Add(New LiteralControl(str.ToString)) + + tablePageNumbers.RenderControl(output) + + End Sub + + + Private Sub BindPageNumbers(ByVal TotalRecords As Integer, ByVal RecordsPerPage As Integer) + Dim PageLinksPerPage As Integer = 10 + If TotalRecords / RecordsPerPage >= 1 Then + TotalPages = Convert.ToInt32(Math.Ceiling(CType(TotalRecords / RecordsPerPage, Double))) + Else + TotalPages = 0 + End If + + If TotalPages > 0 Then + Dim ht As New DataTable + ht.Columns.Add("PageNum") + Dim tmpRow As DataRow + + Dim LowNum As Integer = 1 + Dim HighNum As Integer = CType(TotalPages, Integer) + + Dim tmpNum As Double + tmpNum = CurrentPage - PageLinksPerPage / 2 + If tmpNum < 1 Then tmpNum = 1 + + If CurrentPage > (PageLinksPerPage / 2) Then + LowNum = CType(Math.Floor(tmpNum), Integer) + End If + + If CType(TotalPages, Integer) <= PageLinksPerPage Then + HighNum = CType(TotalPages, Integer) + Else + HighNum = LowNum + PageLinksPerPage - 1 + End If + + If HighNum > CType(TotalPages, Integer) Then + HighNum = CType(TotalPages, Integer) + If HighNum - LowNum < PageLinksPerPage Then + LowNum = HighNum - PageLinksPerPage + 1 + End If + End If + + If HighNum > CType(TotalPages, Integer) Then HighNum = CType(TotalPages, Integer) + If LowNum < 1 Then LowNum = 1 + + Dim i As Integer + For i = LowNum To HighNum + tmpRow = ht.NewRow + tmpRow("PageNum") = i + ht.Rows.Add(tmpRow) + Next + + PageNumbers.DataSource = ht + PageNumbers.DataBind() + End If + + End Sub + + Private Function CreateURL(ByVal CurrentPage As String) As String + + If QuerystringParams <> "" Then + If CurrentPage <> "" Then + Return Globals.NavigateURL(TabID, "", QuerystringParams, PageParam & "=" & CurrentPage) + Else + Return Globals.NavigateURL(TabID, "", QuerystringParams) + End If + Else + If CurrentPage <> "" Then + Return Globals.NavigateURL(TabID, "", PageParam & "=" & CurrentPage) + Else + Return Globals.NavigateURL(TabID) + End If + End If + + End Function + + ''' ----------------------------------------------------------------------------- + ''' + ''' GetLink returns the page number links for paging. + ''' + ''' + ''' + ''' + ''' [dancaron] 10/28/2004 Initial Version + ''' + ''' ----------------------------------------------------------------------------- + Private Function GetLink(ByVal PageNum As Integer) As String + If PageNum = CurrentPage Then + Return "[" + PageNum.ToString + "]" + Else + Return "" + PageNum.ToString + "" + End If + End Function + + ''' ----------------------------------------------------------------------------- + ''' + ''' GetPreviousLink returns the link for the Previous page for paging. + ''' + ''' + ''' + ''' + ''' [dancaron] 10/28/2004 Initial Version + ''' + ''' ----------------------------------------------------------------------------- + Private Function GetPreviousLink() As String + If CurrentPage > 1 AndAlso TotalPages > 0 Then + Return "" & Services.Localization.Localization.GetString("Previous", DotNetNuke.Services.Localization.Localization.SharedResourceFile) & "" + Else + Return "" & Services.Localization.Localization.GetString("Previous", DotNetNuke.Services.Localization.Localization.SharedResourceFile) & "" + End If + End Function + + ''' ----------------------------------------------------------------------------- + ''' + ''' GetNextLink returns the link for the Next Page for paging. + ''' + ''' + ''' + ''' + ''' [dancaron] 10/28/2004 Initial Version + ''' + ''' ----------------------------------------------------------------------------- + Private Function GetNextLink() As String + If CurrentPage <> TotalPages And TotalPages > 0 Then + Return "" & Services.Localization.Localization.GetString("Next", DotNetNuke.Services.Localization.Localization.SharedResourceFile) & "" + Else + Return "" & Services.Localization.Localization.GetString("Next", DotNetNuke.Services.Localization.Localization.SharedResourceFile) & "" + End If + End Function + + ''' ----------------------------------------------------------------------------- + ''' + ''' GetFirstLink returns the First Page link for paging. + ''' + ''' + ''' + ''' + ''' [dancaron] 10/28/2004 Initial Version + ''' + ''' ----------------------------------------------------------------------------- + Private Function GetFirstLink() As String + If CurrentPage > 1 AndAlso TotalPages > 0 Then + Return "" & Services.Localization.Localization.GetString("First", DotNetNuke.Services.Localization.Localization.SharedResourceFile) & "" + Else + Return "" & Services.Localization.Localization.GetString("First", DotNetNuke.Services.Localization.Localization.SharedResourceFile) & "" + End If + End Function + + ''' ----------------------------------------------------------------------------- + ''' + ''' GetLastLink returns the Last Page link for paging. + ''' + ''' + ''' + ''' + ''' [dancaron] 10/28/2004 Initial Version + ''' + ''' ----------------------------------------------------------------------------- + Private Function GetLastLink() As String + If CurrentPage <> TotalPages And TotalPages > 0 Then + Return "" & Services.Localization.Localization.GetString("Last", DotNetNuke.Services.Localization.Localization.SharedResourceFile) & "" + Else + Return "" & Services.Localization.Localization.GetString("Last", DotNetNuke.Services.Localization.Localization.SharedResourceFile) & "" + End If + End Function + + Public Class PageNumberLinkTemplate + Implements ITemplate + Shared itemcount As Integer = 0 + Private _PagingControl As PagingControl + + Sub New(ByVal ctlPagingControl As PagingControl) + _PagingControl = ctlPagingControl + End Sub + + Sub InstantiateIn(ByVal container As Control) _ + Implements ITemplate.InstantiateIn + + Dim l As New Literal + AddHandler l.DataBinding, AddressOf Me.BindData + container.Controls.Add(l) + End Sub + + Private Sub BindData(ByVal sender As Object, ByVal e As System.EventArgs) + Dim lc As Literal + lc = CType(sender, Literal) + Dim container As RepeaterItem + container = CType(lc.NamingContainer, RepeaterItem) + lc.Text = _PagingControl.GetLink(Convert.ToInt32(DataBinder.Eval(container.DataItem, "PageNum"))) + "  " + End Sub + + End Class + + End Class + + +End Namespace \ No newline at end of file diff --git a/Components/WebControls/RefreshControl.vb b/Components/WebControls/RefreshControl.vb new file mode 100755 index 0000000..f1187b1 --- /dev/null +++ b/Components/WebControls/RefreshControl.vb @@ -0,0 +1,9 @@ + +Namespace Ventrian.NewsArticles.Components.WebControls + + Public Class RefreshControl + Inherits System.Web.UI.WebControls.LinkButton + + End Class + +End Namespace diff --git a/Controls/Listing.ascx b/Controls/Listing.ascx new file mode 100755 index 0000000..6069232 --- /dev/null +++ b/Controls/Listing.ascx @@ -0,0 +1,6 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="Listing.ascx.vb" Inherits="Ventrian.NewsArticles.Controls.Listing" %> + + + + + \ No newline at end of file diff --git a/Controls/Listing.ascx.designer.vb b/Controls/Listing.ascx.designer.vb new file mode 100755 index 0000000..0b1313b --- /dev/null +++ b/Controls/Listing.ascx.designer.vb @@ -0,0 +1,35 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class Listing + + ''' + '''rptListing control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rptListing As Global.System.Web.UI.WebControls.Repeater + + ''' + '''phNoArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phNoArticles As Global.System.Web.UI.WebControls.PlaceHolder + End Class +End Namespace diff --git a/Controls/Listing.ascx.vb b/Controls/Listing.ascx.vb new file mode 100755 index 0000000..ee4af6a --- /dev/null +++ b/Controls/Listing.ascx.vb @@ -0,0 +1,1593 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.UI.WebControls +Imports Ventrian.NewsArticles.Components.CustomFields +Imports DotNetNuke.Security + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class Listing + Inherits System.Web.UI.UserControl + +#Region " Private Members " + + Private _objLayoutController As LayoutController + + Private _objLayoutHeader As LayoutInfo + Private _objLayoutItem As LayoutInfo + Private _objLayoutFeatured As LayoutInfo + Private _objLayoutFooter As LayoutInfo + Private _objLayoutEmpty As LayoutInfo + + Private _articleList As List(Of ArticleInfo) + Private _articleCount As Integer + + Private _agedDate As DateTime + Private _author As Integer + Private _bindArticles As Boolean + Private _featuredOnly As Boolean + Private _filterCategories As Integer() + Private _includeCategory As Boolean + Private _matchCategories As MatchOperatorType + Private _maxArticles As Integer + Private _month As Integer + Private _notFeaturedOnly As Boolean + Private _notSecuredOnly As Boolean + Private _searchText As String + Private _securedOnly As Boolean + Private _showExpired As Boolean + Private _showMessage As Boolean + Private _showPending As Boolean + Private _sortBy As String + Private _sortDirection As String + Private _startDate As DateTime + Private _tag As String + Private _year As Integer + + Public IsIndexed As Boolean = True + + Private _customFieldID As Integer = Null.NullInteger + Private _customValue As String = Null.NullString + +#End Region + +#Region " Private Properties " + + Private ReadOnly Property ArticleModuleBase() As NewsArticleModuleBase + Get + Return CType(Parent, NewsArticleModuleBase) + End Get + End Property + + Private ReadOnly Property ArticleSettings() As ArticleSettings + Get + Return ArticleModuleBase.ArticleSettings + End Get + End Property + + Private ReadOnly Property CurrentPage() As Integer + Get + If (Request("Page") = Null.NullString And Request("CurrentPage") = Null.NullString) Then + Return 1 + Else + IsIndexed = False + Try + If (Request("Page") <> Null.NullString) Then + Return Convert.ToInt32(Request("Page")) + Else + Return Convert.ToInt32(Request("CurrentPage")) + End If + Catch + Return 1 + End Try + End If + End Get + End Property + +#End Region + +#Region " Public Properties " + + Public Property AgedDate() As DateTime + Get + Return _agedDate + End Get + Set(ByVal Value As DateTime) + _agedDate = Value + End Set + End Property + + Public Property Author() As Integer + Get + Return _author + End Get + Set(ByVal Value As Integer) + _author = Value + End Set + End Property + + Public Property BindArticles() As Boolean + Get + Return _bindArticles + End Get + Set(ByVal Value As Boolean) + _bindArticles = Value + End Set + End Property + + Private ReadOnly Property DynamicAuthorID() As Integer + Get + Dim id As Integer = Null.NullInteger + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + If (IsNumeric(Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()))) Then + id = Convert.ToInt32(Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + End If + + Return id + End Get + End Property + + Private ReadOnly Property DynamicAZ() As String + Get + Dim id As String = Null.NullString + If (Request("naaz-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + id = Request("naaz-" & ArticleModuleBase.TabModuleId.ToString()) + End If + Return id + End Get + End Property + + Private ReadOnly Property DynamicCategoryID() As Integer + Get + Dim id As Integer = Null.NullInteger + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + If (IsNumeric(Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()))) Then + id = Convert.ToInt32(Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + End If + + Return id + End Get + End Property + + Private ReadOnly Property DynamicSortBy() As String + Get + Dim sort As String = "" + + If (Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + Select Case Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()).ToLower() + Case "publishdate" + sort = "StartDate" + Exit Select + Case "expirydate" + sort = "EndDate" + Exit Select + Case "lastupdate" + sort = "LastUpdate" + Exit Select + Case "rating" + sort = "Rating DESC, RatingCount" + Exit Select + Case "commentcount" + sort = "CommentCount" + Exit Select + Case "numberofviews" + sort = "NumberOfViews" + Exit Select + Case "random" + sort = "NewID()" + Exit Select + Case "title" + sort = "Title" + Exit Select + End Select + End If + + Return sort + End Get + End Property + + Private ReadOnly Property DynamicTime() As String + Get + Dim val As String = "" + + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + val = Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) + End If + + Return val + End Get + End Property + + Public Property FeaturedOnly() As Boolean + Get + Return _featuredOnly + End Get + Set(ByVal Value As Boolean) + _featuredOnly = Value + End Set + End Property + + Public Property FilterCategories() As Integer() + Get + Return _filterCategories + End Get + Set(ByVal Value As Integer()) + _filterCategories = Value + End Set + End Property + + Public Property IncludeCategory() As Boolean + Get + Return _includeCategory + End Get + Set(ByVal Value As Boolean) + _includeCategory = Value + End Set + End Property + + Public Property MatchCategories() As MatchOperatorType + Get + Return _matchCategories + End Get + Set(ByVal Value As MatchOperatorType) + _matchCategories = Value + End Set + End Property + + Public Property MaxArticles() As Integer + Get + Return _maxArticles + End Get + Set(ByVal Value As Integer) + _maxArticles = Value + End Set + End Property + + Public Property Month() As Integer + Get + Return _month + End Get + Set(ByVal Value As Integer) + _month = Value + End Set + End Property + + Public Property NotFeaturedOnly() As Boolean + Get + Return _notFeaturedOnly + End Get + Set(ByVal Value As Boolean) + _notFeaturedOnly = Value + End Set + End Property + + Public Property NotSecuredOnly() As Boolean + Get + Return _notSecuredOnly + End Get + Set(ByVal Value As Boolean) + _notSecuredOnly = Value + End Set + End Property + + Public Property SearchText() As String + Get + Return _searchText + End Get + Set(ByVal Value As String) + _searchText = Value + End Set + End Property + + Public Property SecuredOnly() As Boolean + Get + Return _securedOnly + End Get + Set(ByVal Value As Boolean) + _securedOnly = Value + End Set + End Property + + Public Property ShowExpired() As Boolean + Get + Return _showExpired + End Get + Set(ByVal Value As Boolean) + _showExpired = Value + End Set + End Property + + Public Property ShowMessage() As Boolean + Get + Return _showMessage + End Get + Set(ByVal Value As Boolean) + _showMessage = Value + End Set + End Property + + Public Property ShowPending() As Boolean + Get + Return _showPending + End Get + Set(ByVal Value As Boolean) + _showPending = Value + End Set + End Property + + Public Property SortBy() As String + Get + Return _sortBy + End Get + Set(ByVal Value As String) + _sortBy = Value + End Set + End Property + + Public Property SortDirection() As String + Get + Return _sortDirection + End Get + Set(ByVal Value As String) + _sortDirection = Value + End Set + End Property + + Public Property StartDate() As DateTime + Get + Return _startDate + End Get + Set(ByVal Value As DateTime) + _startDate = Value + End Set + End Property + + Public Property Tag() As String + Get + Return _tag + End Get + Set(ByVal Value As String) + _tag = Value + End Set + End Property + + Public Property Year() As Integer + Get + Return _year + End Get + Set(ByVal Value As Integer) + _year = Value + End Set + End Property + +#End Region + +#Region " Private Methods " + + Public Sub BindListing() + + InitializeTemplate() + + If (_year <> Null.NullInteger AndAlso _month <> Null.NullInteger) Then + _agedDate = New DateTime(_year, _month, 1) + StartDate = AgedDate.AddMonths(1).AddSeconds(-1) + End If + + If (_year <> Null.NullInteger AndAlso _month = Null.NullInteger) Then + _agedDate = New DateTime(_year, 1, 1) + StartDate = AgedDate.AddYears(1).AddSeconds(-1) + End If + + Dim objTags() As Integer = Nothing + If (_tag <> Null.NullString) Then + Dim objTagController As New TagController() + Dim objTag As TagInfo = objTagController.Get(ArticleModuleBase.ModuleId, _tag.ToLower()) + If (objTag IsNot Nothing) Then + Dim tags As New List(Of Integer) + tags.Add(objTag.TagID) + objTags = tags.ToArray() + End If + End If + + If (FilterCategories IsNot Nothing AndAlso FilterCategories.Length = 1) Then + + Dim objCategoryController As New CategoryController + Dim objCategory As CategoryInfo = objCategoryController.GetCategory(FilterCategories(0), ArticleModuleBase.ModuleId) + + If Not (objCategory Is Nothing) Then + + If (objCategory.InheritSecurity = False) Then + If (ArticleModuleBase.Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(ArticleModuleBase.Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString()) = False) Then + Response.Redirect(NavigateURL(ArticleModuleBase.TabId), True) + End If + End If + End If + + Dim objArticleController As New ArticleController + _articleList = objArticleController.GetArticleList(ArticleModuleBase.ModuleId, StartDate, _agedDate, FilterCategories, (MatchCategories = MatchOperatorType.MatchAll), Nothing, MaxArticles, CurrentPage, ArticleSettings.PageSize, SortBy, SortDirection, True, False, SearchText.Replace("'", "''"), Author, ShowPending, ShowExpired, FeaturedOnly, NotFeaturedOnly, SecuredOnly, NotSecuredOnly, Null.NullString, objTags, False, Null.NullString, _customFieldID, _customValue, Null.NullString, _articleCount) + + End If + Else + Dim objCategoryController As New CategoryController + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(ArticleModuleBase.ModuleId, Null.NullInteger) + + Dim excludeCategoriesRestrictive As New List(Of Integer) + + For Each objCategory As CategoryInfo In objCategories + If (objCategory.InheritSecurity = False And objCategory.CategorySecurityType = CategorySecurityType.Restrict) Then + If (Request.IsAuthenticated) Then + If (ArticleModuleBase.Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(ArticleModuleBase.Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString()) = False) Then + excludeCategoriesRestrictive.Add(objCategory.CategoryID) + End If + End If + Else + excludeCategoriesRestrictive.Add(objCategory.CategoryID) + End If + End If + Next + + Dim excludeCategories As New List(Of Integer) + + For Each objCategory As CategoryInfo In objCategories + If (objCategory.InheritSecurity = False And objCategory.CategorySecurityType = CategorySecurityType.Loose) Then + If (Request.IsAuthenticated) Then + If (ArticleModuleBase.Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(ArticleModuleBase.Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString()) = False) Then + excludeCategories.Add(objCategory.CategoryID) + End If + End If + Else + excludeCategories.Add(objCategory.CategoryID) + End If + End If + Next + + Dim includeCategories As New List(Of Integer) + + If (excludeCategories.Count > 0) Then + + For Each objCategoryToInclude As CategoryInfo In objCategories + + Dim includeCategorySecurity As Boolean = True + + For Each exclCategory As Integer In excludeCategories + If (exclCategory = objCategoryToInclude.CategoryID) Then + includeCategorySecurity = False + End If + Next + + + If (FilterCategories IsNot Nothing) Then + If (FilterCategories.Length > 0) Then + Dim filter As Boolean = False + For Each cat As Integer In FilterCategories + If (cat = objCategoryToInclude.CategoryID) Then + filter = True + End If + Next + If (filter = False) Then + includeCategorySecurity = False + End If + End If + End If + + If (includeCategorySecurity) Then + includeCategories.Add(objCategoryToInclude.CategoryID) + End If + + Next + + If (includeCategories.Count > 0) Then + includeCategories.Add(-1) + End If + + FilterCategories = includeCategories.ToArray() + + End If + + Dim objArticleController As New ArticleController + _articleList = objArticleController.GetArticleList(ArticleModuleBase.ModuleId, StartDate, _agedDate, FilterCategories, (MatchCategories = MatchOperatorType.MatchAll), excludeCategoriesRestrictive.ToArray(), MaxArticles, CurrentPage, ArticleSettings.PageSize, SortBy, SortDirection, True, False, SearchText.Replace("'", "''"), Author, ShowPending, ShowExpired, FeaturedOnly, NotFeaturedOnly, SecuredOnly, NotSecuredOnly, Null.NullString, objTags, False, Null.NullString, _customFieldID, _customValue, Null.NullString, _articleCount) + End If + + + If (_articleList.Count = 0) Then + If (ShowMessage) Then + ProcessHeader(phNoArticles.Controls, _objLayoutEmpty.Tokens) + End If + Else + rptListing.DataSource = _articleList + rptListing.DataBind() + End If + + End Sub + + Private Function GetParams(ByVal addDynamicFields As Boolean) As String + + Dim params As String = "" + + If (Request("ctl") <> "") Then + If (Request("ctl").ToLower = "categoryview" OrElse Request("ctl").ToLower = "authorview" OrElse Request("ctl").ToLower = "archiveview" OrElse Request("ctl").ToLower() = "search") Then + params += "ctl=" & Request("ctl") & "&mid=" & ArticleModuleBase.ModuleId.ToString() + End If + End If + + If (Request("articleType") <> "") Then + If (Request("articleType").ToString().ToLower = "categoryview" OrElse Request("articleType").ToString().ToLower() = "authorview" OrElse Request("articleType").ToString().ToLower() = "archiveview" OrElse Request("articleType").ToString().ToLower() = "search" OrElse Request("articleType").ToString().ToLower() = "myarticles" OrElse Request("articleType").ToString().ToLower() = "tagview") Then + params += "articleType=" & Request("articleType") + End If + End If + + If (FilterCategories IsNot Nothing AndAlso FilterCategories.Length > 0) Then + If (FilterCategories IsNot ArticleSettings.FilterCategories) Then + params += "&CategoryID=" & FilterCategories(0) + End If + End If + + Dim authorSet As Boolean = False + If (ArticleSettings.AuthorUserIDFilter) Then + If (ArticleSettings.AuthorUserIDParam <> "") Then + If (HttpContext.Current.Request(ArticleSettings.AuthorUserIDParam) <> "") Then + params += "&" & ArticleSettings.AuthorUserIDParam & "=" & HttpContext.Current.Request(ArticleSettings.AuthorUserIDParam) + authorSet = True + End If + End If + End If + + If (ArticleSettings.AuthorUsernameFilter) Then + If (ArticleSettings.AuthorUsernameParam <> "") Then + If (HttpContext.Current.Request(ArticleSettings.AuthorUsernameParam) <> "") Then + params += "&" & ArticleSettings.AuthorUsernameParam & "=" & HttpContext.Current.Request(ArticleSettings.AuthorUsernameParam) + authorSet = True + End If + End If + End If + + If (authorSet = False) Then + If (Author <> ArticleSettings.Author) Then + params += "&AuthorID=" & Author.ToString() + End If + End If + + If (Year <> Null.NullInteger) Then + params += "&Year=" & Year.ToString() + End If + + If (Month <> Null.NullInteger) Then + params += "&Month=" & Month.ToString() + End If + + If (Tag <> Null.NullString) Then + params += "&Tag=" & Server.UrlEncode(Tag) + End If + + If (SearchText <> Null.NullString) Then + If (Request("naaz-" & ArticleModuleBase.TabModuleId.ToString()) = "") Then + params += "&Search=" & ArticleModuleBase.Server.UrlEncode(SearchText) + End If + End If + + If (addDynamicFields) Then + If (Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params += "&nasort-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) + End If + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params += "&naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) + End If + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params += "&nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) + End If + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params += "&nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params += "&natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) + End If + If (Request("naaz-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params += "&naaz-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naaz-" & ArticleModuleBase.TabModuleId.ToString()) + End If + End If + + Return params + + End Function + + Private Sub InitializeTemplate() + + _objLayoutController = New LayoutController(ArticleModuleBase) + _objLayoutController.IncludeCategory = IncludeCategory + + _objLayoutHeader = LayoutController.GetLayout(ArticleModuleBase, LayoutType.Listing_Header_Html) + _objLayoutFeatured = LayoutController.GetLayout(ArticleModuleBase, LayoutType.Listing_Featured_Html) + _objLayoutItem = LayoutController.GetLayout(ArticleModuleBase, LayoutType.Listing_Item_Html) + _objLayoutFooter = LayoutController.GetLayout(ArticleModuleBase, LayoutType.Listing_Footer_Html) + _objLayoutEmpty = LayoutController.GetLayout(ArticleModuleBase, LayoutType.Listing_Empty_Html) + + If (_objLayoutFeatured.Template.Trim().Length = 0) Then + ' Featured Template Empty or does not exist, use standard item. + _objLayoutFeatured = _objLayoutItem + End If + + End Sub + + Private Sub InitSettings() + + _author = Null.NullInteger + + If (ArticleSettings.AuthorUserIDFilter) Then + _author = -100 + If (Request.QueryString(ArticleSettings.AuthorUserIDParam) <> "") Then + Try + _author = Convert.ToInt32(Request.QueryString(ArticleSettings.AuthorUserIDParam)) + Catch + End Try + End If + End If + + If (ArticleSettings.AuthorUsernameFilter) Then + _author = -100 + If (Request.QueryString(ArticleSettings.AuthorUsernameParam) <> "") Then + Try + Dim objUser As DotNetNuke.Entities.Users.UserInfo = DotNetNuke.Entities.Users.UserController.GetUserByName(ArticleModuleBase.PortalId, Request.QueryString(ArticleSettings.AuthorUsernameParam)) + If (objUser IsNot Nothing) Then + _author = objUser.UserID + End If + Catch + End Try + End If + End If + + If (ArticleSettings.AuthorLoggedInUserFilter) Then + _author = -100 + If (Request.IsAuthenticated) Then + _author = ArticleModuleBase.UserId + End If + End If + + If (ArticleSettings.Author <> Null.NullInteger) Then + _author = ArticleSettings.Author + End If + + If (DynamicAuthorID <> Null.NullInteger) Then + _author = DynamicAuthorID + End If + + _agedDate = Null.NullDate + _bindArticles = True + _featuredOnly = ArticleSettings.FeaturedOnly + If (ArticleSettings.FilterSingleCategory <> Null.NullInteger) Then + Dim cats As New List(Of Integer) + cats.Add(ArticleSettings.FilterSingleCategory) + _filterCategories = cats.ToArray() + Else + _filterCategories = ArticleSettings.FilterCategories + End If + If (DynamicCategoryID <> Null.NullInteger) Then + Dim cats As New List(Of Integer) + cats.Add(DynamicCategoryID) + _filterCategories = cats.ToArray() + End If + _includeCategory = False + _matchCategories = ArticleSettings.MatchCategories + _maxArticles = ArticleSettings.MaxArticles + _month = Null.NullInteger + _notFeaturedOnly = ArticleSettings.NotFeaturedOnly + _notSecuredOnly = ArticleSettings.NotSecuredOnly + _searchText = "" + If (DynamicAZ <> Null.NullString) Then + _searchText = DynamicAZ + End If + _securedOnly = ArticleSettings.SecuredOnly + _showExpired = False + _showMessage = True + _showPending = ArticleSettings.ShowPending + _sortBy = ArticleSettings.SortBy + If (ArticleSettings.BubbleFeatured) Then + _sortBy = "IsFeatured DESC, " & ArticleSettings.SortBy + End If + _sortDirection = ArticleSettings.SortDirection + _startDate = DateTime.Now.AddMinutes(1) + _tag = Null.NullString + _year = Null.NullInteger + + If (DynamicSortBy <> "") Then + _sortBy = DynamicSortBy + End If + + If (DynamicTime <> "") Then + If (DynamicTime.ToLower() = "today") Then + _startDate = DateTime.Now + _agedDate = DateTime.Today + End If + If (DynamicTime.ToLower() = "yesterday") Then + _startDate = DateTime.Today + _agedDate = DateTime.Today.AddDays(-1) + End If + If (DynamicTime.ToLower() = "threedays") Then + _startDate = DateTime.Now + _agedDate = DateTime.Today.AddDays(-3) + End If + If (DynamicTime.ToLower() = "sevendays") Then + _startDate = DateTime.Now + _agedDate = DateTime.Today.AddDays(-7) + End If + If (DynamicTime.ToLower() = "thirtydays") Then + _startDate = DateTime.Now + _agedDate = DateTime.Today.AddDays(-30) + End If + If (DynamicTime.ToLower() = "ninetydays") Then + _startDate = DateTime.Now + _agedDate = DateTime.Today.AddDays(-90) + End If + If (DynamicTime.ToLower() = "thisyear") Then + _startDate = DateTime.Now + _agedDate = DateTime.Today.AddYears(-1) + End If + End If + + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + Dim val As String = Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) + If (val.Split("-"c).Length = 2) Then + If (IsNumeric(val.Split("-"c)(0))) Then + _customFieldID = Convert.ToInt32(val.Split("-"c)(0)) + _customValue = val.Split("-"c)(1) + End If + End If + End If + + End Sub + + Private Sub ProcessHeader(ByRef objPlaceHolder As ControlCollection, ByVal templateArray As String()) + + Dim pageCount As Integer = ((_articleCount - 1) \ ArticleSettings.PageSize) + 1 + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(_objLayoutController.ProcessImages(templateArray(iPtr).ToString()))) + + If iPtr < templateArray.Length - 1 Then + Select Case templateArray(iPtr + 1) + + Case "AUTHOR" + Dim objAuthorController As New AuthorController() + Dim drpAuthor As New DropDownList + drpAuthor.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + drpAuthor.DataTextField = "DisplayName" + drpAuthor.DataValueField = "UserID" + drpAuthor.DataSource = objAuthorController.GetAuthorList(ArticleModuleBase.ModuleId) + drpAuthor.DataBind() + drpAuthor.Items.Insert(0, New ListItem(ArticleModuleBase.GetSharedResource("SelectAuthor.Text"), "-1")) + drpAuthor.AutoPostBack = True + If (DynamicAuthorID <> Null.NullInteger) Then + If (drpAuthor.Items.FindByValue(DynamicAuthorID.ToString()) IsNot Nothing) Then + drpAuthor.SelectedValue = DynamicAuthorID.ToString() + End If + End If + Dim objHandler As New System.EventHandler(AddressOf drpAuthor_SelectedIndexChanged) + AddHandler drpAuthor.SelectedIndexChanged, objHandler + objPlaceHolder.Add(drpAuthor) + + Case "AZ" + + Dim list As String = "" + For Each c As Char In "ABCDEFGHIJKLMNOPQRSTUVWXYZ".ToCharArray() + + Dim params As New List(Of String) + + Dim args As String = GetParams(False) + For Each arg As String In args.Split("&"c) + params.Add(arg) + Next + + If (Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nasort-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nasort-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacust-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString())) + End If + + If (list = "") Then + If (Request("naaz-" & ArticleModuleBase.TabModuleId.ToString()) = c) Then + list = c + Else + Dim paramsCopy As List(Of String) = params + paramsCopy.Add("naaz-" & ArticleModuleBase.TabModuleId.ToString() & "=" & c) + list = "" & c & "" + End If + Else + If (Request("naaz-" & ArticleModuleBase.TabModuleId.ToString()) = c) Then + list = list & " " & c + Else + Dim paramsCopy As List(Of String) = params + paramsCopy.Add("naaz-" & ArticleModuleBase.TabModuleId.ToString() & "=" & c) + list = list & " " & "" & c & "" + End If + End If + Next + If (Request("naaz-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + list = list & " " & "" & "All" & "" + Else + list = list & " " & "All" + End If + + Dim objLiteral As New Literal() + objLiteral.Text = list + objPlaceHolder.Add(objLiteral) + + Case "CATEGORY" + Dim objCategoryController As New CategoryController() + Dim drpCategory As New DropDownList + drpCategory.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + drpCategory.DataTextField = "NameIndented" + drpCategory.DataValueField = "CategoryID" + drpCategory.DataSource = objCategoryController.GetCategoriesAll(ArticleModuleBase.ModuleId, Null.NullInteger, ArticleSettings.CategorySortType) + drpCategory.DataBind() + drpCategory.Items.Insert(0, New ListItem(ArticleModuleBase.GetSharedResource("SelectCategory.Text"), "-1")) + drpCategory.AutoPostBack = True + If (DynamicCategoryID <> Null.NullInteger) Then + If (drpCategory.Items.FindByValue(DynamicCategoryID.ToString()) IsNot Nothing) Then + drpCategory.SelectedValue = DynamicCategoryID.ToString() + End If + End If + Dim objHandler As New System.EventHandler(AddressOf drpCategory_SelectedIndexChanged) + AddHandler drpCategory.SelectedIndexChanged, objHandler + objPlaceHolder.Add(drpCategory) + + Case "CATEGORYFILTER" + If (_filterCategories IsNot Nothing) Then + Dim categories As String = "" + Dim objCategoryController As New CategoryController + For Each ID As Integer In _filterCategories + Dim objCategory As CategoryInfo = objCategoryController.GetCategory(ID, ArticleModuleBase.ModuleId) + If (objCategory IsNot Nothing) Then + If (categories = "") Then + categories = objCategory.Name + Else + categories = categories & " | " & objCategory.Name + End If + End If + Next + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLiteral.Text = categories + objPlaceHolder.Add(objLiteral) + End If + + Case "CATEGORYSELECTED" + If (Request("articleType") <> "" AndAlso Request("articleType").ToLower() <> "categoryview") Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/CATEGORYSELECTED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + Else + If (Request("articleType") = "") Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/CATEGORYSELECTED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + Case "/CATEGORYSELECTED" + ' Do Nothing + + Case "CATEGORYNOTSELECTED" + If (Request("articleType") <> "" AndAlso Request("articleType").ToLower() = "categoryview") Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/CATEGORYNOTSELECTED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/CATEGORYNOTSELECTED" + ' Do Nothing + + Case "CATEGORYNOTSELECTED2" + If (Request("articleType") <> "" AndAlso Request("articleType").ToLower() = "categoryview") Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/CATEGORYNOTSELECTED") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/CATEGORYNOTSELECTED2" + ' Do Nothing + + Case "CURRENTPAGE" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLiteral.Text = CurrentPage.ToString() + objPlaceHolder.Add(objLiteral) + + Case "HASMULTIPLEPAGES" + If (pageCount = 1) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASMULTIPLEPAGES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASMULTIPLEPAGES" + ' Do Nothing + + Case "HASNEXTPAGE" + + If (CurrentPage = pageCount) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASNEXTPAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNEXTPAGE" + ' Do Nothing + + Case "HASPREVPAGE" + If (CurrentPage = 1) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASPREVPAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASPREVPAGE" + ' Do Nothing + + Case "LINKNEXT" + Dim objLink As New HyperLink + objLink.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLink.CssClass = "CommandButton" + objLink.Enabled = (CurrentPage < pageCount) + objLink.NavigateUrl = NavigateURL(ArticleModuleBase.TabId, "", GetParams(True), "CurrentPage=" & (CurrentPage + 1).ToString()) + objLink.Text = ArticleModuleBase.GetSharedResource("NextPage.Text") + objPlaceHolder.Add(objLink) + + Case "LINKNEXTURL" + If (CurrentPage < pageCount) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLiteral.Text = NavigateURL(ArticleModuleBase.TabId, "", GetParams(True), "CurrentPage=" & (CurrentPage + 1).ToString()) + objPlaceHolder.Add(objLiteral) + End If + + Case "LINKPREVIOUS" + Dim objLink As New HyperLink + objLink.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLink.CssClass = "CommandButton" + objLink.Enabled = (CurrentPage > 1) + objLink.NavigateUrl = NavigateURL(ArticleModuleBase.TabId, "", GetParams(True), "CurrentPage=" & (CurrentPage - 1).ToString()) + objLink.Text = ArticleModuleBase.GetSharedResource("PreviousPage.Text") + objPlaceHolder.Add(objLink) + + Case "LINKPREVIOUSURL" + If (CurrentPage > 1) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLiteral.Text = NavigateURL(ArticleModuleBase.TabId, "", GetParams(True), "CurrentPage=" & (CurrentPage - 1).ToString()) + objPlaceHolder.Add(objLiteral) + End If + + Case "PAGECOUNT" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLiteral.Text = pageCount.ToString() + objPlaceHolder.Add(objLiteral) + + Case "PAGER" + Dim ctlPagingControl As New PagingControl + ctlPagingControl.Visible = True + ctlPagingControl.TotalRecords = _articleCount + ctlPagingControl.PageSize = ArticleSettings.PageSize + ctlPagingControl.CurrentPage = CurrentPage + ctlPagingControl.QuerystringParams = GetParams(True) + ctlPagingControl.TabID = ArticleModuleBase.TabId + ctlPagingControl.EnableViewState = False + objPlaceHolder.Add(ctlPagingControl) + + Case "PAGER2" + Dim objLiteral As New Literal + If (_articleCount > 0) Then + Dim pages As Integer = _articleCount / ArticleSettings.PageSize + objLiteral.Text = objLiteral.Text & "
    " + For i As Integer = 1 To pages + If (CurrentPage = i) Then + objLiteral.Text = objLiteral.Text & "
  • " & i.ToString() & "
  • " + Else + Dim params As String = GetParams(True) + If (i > 1) Then + params += "¤tpage=" & i.ToString() + End If + objLiteral.Text = objLiteral.Text & "
  • " & i.ToString() & "
  • " + End If + Next + objLiteral.Text = objLiteral.Text & "
" + objPlaceHolder.Add(objLiteral) + End If + + Case "SORT" + Dim drpSort As New DropDownList + drpSort.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + drpSort.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("PublishDate.Text"), "PublishDate")) + drpSort.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("ExpiryDate.Text"), "ExpiryDate")) + drpSort.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("LastUpdate.Text"), "LastUpdate")) + drpSort.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("HighestRated.Text"), "Rating")) + drpSort.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("MostCommented.Text"), "CommentCount")) + drpSort.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("MostViewed.Text"), "NumberOfViews")) + drpSort.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("Random.Text"), "Random")) + drpSort.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("SortTitle.Text"), "Title")) + drpSort.AutoPostBack = True + + If (Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + If (drpSort.Items.FindByValue(Request("nasort-" & ArticleModuleBase.TabModuleId.ToString())) IsNot Nothing) Then + drpSort.SelectedValue = Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) + End If + Else + Dim sort As String = SortBy + + Select Case SortBy.ToLower() + Case "startdate" + sort = "PublishDate" + Exit Select + Case "enddate" + sort = "ExpiryDate" + Exit Select + Case "newid()" + sort = "random" + Exit Select + End Select + + If (drpSort.Items.FindByValue(sort) IsNot Nothing) Then + drpSort.SelectedValue = sort + End If + End If + + Dim objHandler As New System.EventHandler(AddressOf drpSort_SelectedIndexChanged) + AddHandler drpSort.SelectedIndexChanged, objHandler + objPlaceHolder.Add(drpSort) + + Case "TABID" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLiteral.Text = ArticleModuleBase.TabId.ToString() + objPlaceHolder.Add(objLiteral) + + Case "TIME" + Dim drpTime As New DropDownList + drpTime.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("Today.Text"), "Today")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("Yesterday.Text"), "Yesterday")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("ThreeDays.Text"), "ThreeDays")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("SevenDays.Text"), "SevenDays")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("ThirtyDays.Text"), "ThirtyDays")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("NinetyDays.Text"), "NinetyDays")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("ThisYear.Text"), "ThisYear")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("AllTime.Text"), "AllTime")) + drpTime.AutoPostBack = True + + If (DynamicTime <> "") Then + If (drpTime.Items.FindByValue(DynamicTime) IsNot Nothing) Then + drpTime.SelectedValue = DynamicTime + End If + Else + drpTime.SelectedValue = "AllTime" + End If + + Dim objHandler As New System.EventHandler(AddressOf drpTime_SelectedIndexChanged) + AddHandler drpTime.SelectedIndexChanged, objHandler + + objPlaceHolder.Add(drpTime) + + Case Else + + If (templateArray(iPtr + 1).ToUpper().StartsWith("CUSTOM:")) Then + Dim customField As String = templateArray(iPtr + 1).Substring(7, templateArray(iPtr + 1).Length - 7) + + Dim objCustomFieldController As New CustomFieldController() + Dim objCustomFields As ArrayList = objCustomFieldController.List(ArticleModuleBase.ModuleId) + + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.Name.ToLower() = customField.ToLower()) Then + If (objCustomField.FieldType = CustomFieldType.DropDownList) Then + Dim drpCustom As New DropDownList + drpCustom.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + + For Each val As String In objCustomField.FieldElements.Split("|"c) + drpCustom.Items.Add(val) + Next + + Dim sel As String = ArticleModuleBase.GetSharedResource("SelectCustom.Text") + If (sel.IndexOf("{0}") <> -1) Then + sel = sel.Replace("{0}", objCustomField.Caption) + End If + drpCustom.Items.Insert(0, New ListItem(sel, "-1")) + drpCustom.Attributes.Add("CustomFieldID", objCustomField.CustomFieldID.ToString()) + drpCustom.AutoPostBack = True + + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + Dim val As String = Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) + If (val.Split("-"c).Length = 2) Then + If (val.Split("-"c)(0) = objCustomField.CustomFieldID.ToString()) Then + If (drpCustom.Items.FindByValue(val.Split("-"c)(1).ToString()) IsNot Nothing) Then + drpCustom.SelectedValue = val.Split("-"c)(1).ToString() + End If + End If + End If + End If + + Dim objHandler As New System.EventHandler(AddressOf drpCustom_SelectedIndexChanged) + AddHandler drpCustom.SelectedIndexChanged, objHandler + objPlaceHolder.Add(drpCustom) + + End If + Exit For + End If + Next + + Exit Select + + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("RESX:")) Then + Dim entry As String = templateArray(iPtr + 1).Substring(5, templateArray(iPtr + 1).Length - 5) + + If (entry <> "") Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLiteral.Text = ArticleModuleBase.GetSharedResource(entry) + objPlaceHolder.Add(objLiteral) + End If + + Exit Select + + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("SORT:")) Then + + Dim params As New List(Of String) + + Dim sortItem As String = templateArray(iPtr + 1).Substring(5, templateArray(iPtr + 1).Length - 5) + Dim sortValue As String = sortItem + + Select Case sortItem.ToLower() + Case "highestrated" + sortValue = "Rating" + Exit Select + Case "mostcommented" + sortValue = "CommentCount" + Exit Select + Case "mostviewed" + sortValue = "NumberOfViews" + Exit Select + Case "sorttitle" + sortValue = "Title" + Exit Select + End Select + + Dim sort As String = SortBy + + Select Case sort.ToLower() + Case "startdate" + sort = "PublishDate" + Exit Select + Case "enddate" + sort = "ExpiryDate" + Exit Select + Case "newid()" + sort = "random" + Exit Select + Case "rating desc, ratingcount" + sort = "rating" + Exit Select + End Select + + If (sortValue.ToLower() = sort.ToLower()) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + objLiteral.Text = ArticleModuleBase.GetSharedResource(sortItem & ".Text") + objPlaceHolder.Add(objLiteral) + Else + Dim objLink As New HyperLink + objLink.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + params.Add("nasort-" & ArticleModuleBase.TabModuleId.ToString() & "=" & sortValue) + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacust-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString())) + End If + objLink.NavigateUrl = NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()) + objLink.Text = ArticleModuleBase.GetSharedResource(sortItem & ".Text") + objPlaceHolder.Add(objLink) + End If + Exit Select + + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("TIME:")) Then + + Dim timeItem As String = templateArray(iPtr + 1).Substring(5, templateArray(iPtr + 1).Length - 5) + + Dim drpTime As New DropDownList + drpTime.ID = Globals.CreateValidID("Article-Header-" & iPtr.ToString()) + + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("Today"), "Today")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("Yesterday"), "Yesterday")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("ThreeDays"), "ThreeDays")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("SevenDays"), "SevenDays")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("ThirtyDays"), "ThirtyDays")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("NinetyDays"), "NinetyDays")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("ThisYear"), "ThisYear")) + drpTime.Items.Add(New ListItem(ArticleModuleBase.GetSharedResource("AllTime"), "AllTime")) + drpTime.AutoPostBack = True + + If (DynamicTime <> "") Then + If (drpTime.Items.FindByValue(DynamicTime) IsNot Nothing) Then + drpTime.SelectedValue = DynamicTime + End If + Else + If (drpTime.Items.FindByValue(timeItem) IsNot Nothing) Then + Dim params As New List(Of String) + If (Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nasort-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nasort-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & timeItem) + Response.Redirect(NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()), True) + Else + drpTime.SelectedValue = "AllTime" + End If + End If + + Dim objHandler As New System.EventHandler(AddressOf drpTime_SelectedIndexChanged) + AddHandler drpTime.SelectedIndexChanged, objHandler + objPlaceHolder.Add(drpTime) + Exit Select + End If + + TokenProcessor.ProcessMenuItem(templateArray(iPtr + 1), objPlaceHolder, _objLayoutController, ArticleModuleBase, iPtr, templateArray, MenuOptionType.CurrentArticles) + + End Select + End If + + Next + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + Try + + InitSettings() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub Page_PreRender(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.PreRender + + Try + + If (BindArticles) Then + BindListing() + End If + ArticleModuleBase.LoadStyleSheet() + + If (IsIndexed = False) Then + ' no index but follow links + + Try + 'remove the existing MetaRobots entry + Page.Header.Controls.Remove(Page.Header.FindControl("MetaRobots")) + + 'build our own new entry + Dim mymetatag As New System.Web.UI.HtmlControls.HtmlMeta + mymetatag.Name = "robots" + mymetatag.Content = "NOINDEX, FOLLOW" + Page.Header.Controls.Add(mymetatag) + Catch ex As Exception + 'catch an exception if MetaRobots is not present + + End Try + + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub rptListing_OnItemDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.RepeaterItemEventArgs) Handles rptListing.ItemDataBound + + Try + + If (e.Item.ItemType = ListItemType.Header) Then + ProcessHeader(e.Item.Controls, _objLayoutHeader.Tokens) + End If + + If e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem Then + + Dim objArticle As ArticleInfo = CType(e.Item.DataItem, ArticleInfo) + + If (objArticle.IsFeatured) Then + _objLayoutController.ProcessArticleItem(e.Item.Controls, _objLayoutFeatured.Tokens, objArticle) + Else + _objLayoutController.ProcessArticleItem(e.Item.Controls, _objLayoutItem.Tokens, objArticle) + End If + + End If + + If (e.Item.ItemType = ListItemType.Footer) Then + ProcessHeader(e.Item.Controls, _objLayoutFooter.Tokens) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub drpAuthor_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) + + Dim params As New List(Of String) + + Dim args As String = GetParams(False) + For Each arg As String In args.Split("&"c) + params.Add(arg) + Next + + If (Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nasort-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nasort-" & ArticleModuleBase.TabModuleId.ToString())) + End If + + Dim drpAuthor As DropDownList = CType(sender, DropDownList) + + If (drpAuthor IsNot Nothing) Then + If (drpAuthor.SelectedValue <> "-1") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & drpAuthor.SelectedValue) + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacust-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString())) + End If + Response.Redirect(NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()), True) + Else + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacust-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString())) + End If + Response.Redirect(NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()), True) + End If + End If + + End Sub + + Private Sub drpCategory_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) + + Dim params As New List(Of String) + + Dim args As String = GetParams(False) + For Each arg As String In args.Split("&"c) + params.Add(arg) + Next + + If (Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nasort-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nasort-" & ArticleModuleBase.TabModuleId.ToString())) + End If + + Dim drpCategory As DropDownList = CType(sender, DropDownList) + + If (drpCategory IsNot Nothing) Then + If (drpCategory.SelectedValue <> "-1") Then + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & drpCategory.SelectedValue) + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacust-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString())) + End If + Response.Redirect(NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()), True) + Else + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacust-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString())) + End If + Response.Redirect(NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()), True) + End If + End If + + End Sub + + Private Sub drpCustom_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) + + Dim params As New List(Of String) + + Dim args As String = GetParams(False) + For Each arg As String In args.Split("&"c) + params.Add(arg) + Next + + If (Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nasort-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nasort-" & ArticleModuleBase.TabModuleId.ToString())) + End If + + Dim drpCustom As DropDownList = CType(sender, DropDownList) + + If (drpCustom IsNot Nothing) Then + If (drpCustom.SelectedValue <> "-1") Then + params.Add("nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & drpCustom.Attributes("CustomFieldID") & "-" & drpCustom.SelectedValue) + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString())) + End If + Response.Redirect(NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()), True) + Else + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString())) + End If + Response.Redirect(NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()), True) + End If + End If + + End Sub + + Private Sub drpSort_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) + + Dim params As New List(Of String) + + Dim args As String = GetParams(False) + For Each arg As String In args.Split("&"c) + params.Add(arg) + Next + + Dim drpSort As DropDownList = CType(sender, DropDownList) + + If (drpSort IsNot Nothing) Then + params.Add("nasort-" & ArticleModuleBase.TabModuleId.ToString() & "=" & drpSort.SelectedValue) + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacust-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("natime-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("natime-" & ArticleModuleBase.TabModuleId.ToString())) + End If + Response.Redirect(NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()), True) + End If + + End Sub + + Private Sub drpTime_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) + + Dim params As New List(Of String) + + Dim args As String = GetParams(False) + For Each arg As String In args.Split("&"c) + params.Add(arg) + Next + + If (Request("nasort-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nasort-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nasort-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("naauth-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("naauth-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("naauth-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacat-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacat-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacat-" & ArticleModuleBase.TabModuleId.ToString())) + End If + If (Request("nacust-" & ArticleModuleBase.TabModuleId.ToString()) <> "") Then + params.Add("nacust-" & ArticleModuleBase.TabModuleId.ToString() & "=" & Request("nacust-" & ArticleModuleBase.TabModuleId.ToString())) + End If + + Dim drpTime As DropDownList = CType(sender, DropDownList) + + If (drpTime IsNot Nothing) Then + params.Add("natime-" & ArticleModuleBase.TabModuleId.ToString() & "=" & drpTime.SelectedValue) + Response.Redirect(NavigateURL(ArticleModuleBase.TabId, "", params.ToArray()), True) + End If + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Controls/PostComment.ascx b/Controls/PostComment.ascx new file mode 100755 index 0000000..8ff659c --- /dev/null +++ b/Controls/PostComment.ascx @@ -0,0 +1,40 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="PostComment.ascx.vb" Inherits="Ventrian.NewsArticles.Controls.PostComment" %> +<%@ Register TagPrefix="dnn" Assembly="DotNetNuke" Namespace="DotNetNuke.UI.WebControls"%> + +

+ + + +

+

+ + + + +

+

+ + +

+

+ + +

+ +

+ +

+

+ +

+
+ + + + + + diff --git a/Controls/PostComment.ascx.designer.vb b/Controls/PostComment.ascx.designer.vb new file mode 100755 index 0000000..cd621de --- /dev/null +++ b/Controls/PostComment.ascx.designer.vb @@ -0,0 +1,215 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class PostComment + + ''' + '''phCommentForm control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phCommentForm As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''pName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pName As Global.System.Web.UI.HtmlControls.HtmlGenericControl + + ''' + '''txtName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtName As Global.System.Web.UI.WebControls.TextBox + + ''' + '''lblName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblName As Global.System.Web.UI.WebControls.Label + + ''' + '''valName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valName As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''pEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pEmail As Global.System.Web.UI.HtmlControls.HtmlGenericControl + + ''' + '''txtEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtEmail As Global.System.Web.UI.WebControls.TextBox + + ''' + '''lblEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblEmail As Global.System.Web.UI.WebControls.Label + + ''' + '''valEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valEmail As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valEmailIsValid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valEmailIsValid As Global.System.Web.UI.WebControls.RegularExpressionValidator + + ''' + '''pUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pUrl As Global.System.Web.UI.HtmlControls.HtmlGenericControl + + ''' + '''txtURL control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtURL As Global.System.Web.UI.WebControls.TextBox + + ''' + '''lblUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblUrl As Global.System.Web.UI.WebControls.Label + + ''' + '''txtComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtComment As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valComment As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''ctlCaptcha control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ctlCaptcha As Global.DotNetNuke.UI.WebControls.CaptchaControl + + ''' + '''btnAddComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents btnAddComment As Global.System.Web.UI.WebControls.Button + + ''' + '''chkNotifyMe control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkNotifyMe As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''phCommentPosted control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phCommentPosted As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''lblRequiresApproval control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblRequiresApproval As Global.System.Web.UI.WebControls.Label + + ''' + '''phCommentAnonymous control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phCommentAnonymous As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''lblRequiresAccess control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblRequiresAccess As Global.System.Web.UI.WebControls.Label + End Class +End Namespace diff --git a/Controls/PostComment.ascx.vb b/Controls/PostComment.ascx.vb new file mode 100755 index 0000000..3bb13c5 --- /dev/null +++ b/Controls/PostComment.ascx.vb @@ -0,0 +1,518 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Security +Imports DotNetNuke.Services.Localization +Imports Joel.Net +Imports Ventrian.NewsArticles.Components.Social + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class PostComment + Inherits NewsArticleControlBase + +#Region " Private Properties " + + Private ReadOnly Property ArticleModuleBase() As NewsArticleModuleBase + Get + If (TypeOf Parent.Parent Is NewsArticleModuleBase) Then + Return CType(Parent.Parent, NewsArticleModuleBase) + Else + Return CType(Parent.Parent.Parent.Parent, NewsArticleModuleBase) + End If + End Get + End Property + + Private ReadOnly Property ArticleSettings() As ArticleSettings + Get + Return ArticleModuleBase.ArticleSettings + End Get + End Property + +#End Region + +#Region " Private Methods " + + Private Sub AssignLocalization() + + lblName.Text = GetResourceKey("Name") + valName.ErrorMessage = GetResourceKey("valName.ErrorMessage") + + If (ArticleSettings.CommentRequireName = False) Then + valName.Enabled = False + lblName.Text = GetResourceKey("NameNotRequired") + End If + + lblEmail.Text = GetResourceKey("Email") + valEmail.ErrorMessage = GetResourceKey("valEmail.ErrorMessage") + valEmailIsValid.ErrorMessage = GetResourceKey("valEmailIsValid.ErrorMessage") + + If (ArticleSettings.CommentRequireEmail = False) Then + valEmail.Enabled = False + valEmailIsValid.Enabled = False + lblEmail.Text = GetResourceKey("EmailNotRequired") + End If + + lblUrl.Text = GetResourceKey("Website") + + valComment.ErrorMessage = GetResourceKey("valComment.ErrorMessage") + ctlCaptcha.Text = GetResourceKey("ctlCaptcha.Text") + ctlCaptcha.ErrorMessage = GetResourceKey("ctlCaptcha.ErrorMessage") + + btnAddComment.Text = GetResourceKey("AddComment") + chkNotifyMe.Text = GetResourceKey("NotifyMe") + lblRequiresApproval.Text = GetResourceKey("RequiresApproval") + + lblRequiresAccess.Text = GetResourceKey("RequiresAccess") + + End Sub + + Private Sub CheckSecurity() + + If (ArticleSettings.IsCommentsAnonymous = False And Request.IsAuthenticated = False) Then + phCommentForm.Visible = False + phCommentAnonymous.Visible = True + End If + + End Sub + + Private Function FilterInput(ByVal stringToFilter As String) As String + + Dim objPortalSecurity As New PortalSecurity + + stringToFilter = objPortalSecurity.InputFilter(stringToFilter, PortalSecurity.FilterFlag.NoScripting) + + stringToFilter = Replace(stringToFilter, Chr(13), "") + stringToFilter = Replace(stringToFilter, ControlChars.Lf, "
") + + Return stringToFilter + + End Function + + Private Sub GetCookie() + + If (Request.IsAuthenticated = False) Then + Dim cookie As HttpCookie = Request.Cookies("comment") + + If (cookie IsNot Nothing) Then + txtName.Text = cookie.Values("name") + txtEmail.Text = cookie.Values("email") + txtURL.Text = cookie.Values("url") + End If + End If + + chkNotifyMe.Checked = ArticleSettings.NotifyDefault + + End Sub + + Public Function GetResourceKey(ByVal key As String) As String + + Dim path As String = "~/DesktopModules/DnnForge - NewsArticles/" & Localization.LocalResourceDirectory & "/PostComment.ascx.resx" + Return DotNetNuke.Services.Localization.Localization.GetString(key, path) + + End Function + + Private Sub NotifyAuthor(ByVal objComment As CommentInfo, ByVal objArticle As ArticleInfo) + + Dim objEmailTemplateController As New EmailTemplateController + objEmailTemplateController.SendFormattedEmail(ArticleModuleBase.ModuleId, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentNotification, ArticleSettings) + + End Sub + + Private Sub NotifyComments(ByVal objComment As CommentInfo, ByVal objArticle As ArticleInfo) + + Dim objEmailTemplateController As New EmailTemplateController + Dim objMailList As New Hashtable + + Dim objCommentController As New CommentController + Dim objComments As List(Of CommentInfo) = objCommentController.GetCommentList(ArticleModuleBase.ModuleId, ArticleID, True, SortDirection.Ascending, Null.NullInteger) + + For Each objNotifyComment As CommentInfo In objComments + If (objNotifyComment.CommentID <> objComment.CommentID And objNotifyComment.NotifyMe) Then + If (objNotifyComment.UserID = Null.NullInteger) Then + If (objNotifyComment.AnonymousEmail <> "") Then + If (objNotifyComment.AnonymousEmail <> objComment.AnonymousEmail) Then + If (objMailList.Contains(objNotifyComment.AnonymousEmail) = False) Then + objEmailTemplateController.SendFormattedEmail(ArticleModuleBase.ModuleId, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentNotification, ArticleSettings, objNotifyComment.AnonymousEmail) + objMailList.Add(objNotifyComment.AnonymousEmail, objNotifyComment.AnonymousEmail) + End If + End If + End If + Else + If (objNotifyComment.AuthorEmail <> "") Then + If (objNotifyComment.UserID <> objComment.UserID) Then + If (objMailList.Contains(objNotifyComment.AuthorEmail.ToString()) = False) Then + objEmailTemplateController.SendFormattedEmail(ArticleModuleBase.ModuleId, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentNotification, ArticleSettings, objNotifyComment.AuthorEmail) + objMailList.Add(objNotifyComment.AuthorEmail, objNotifyComment.AuthorEmail) + End If + End If + End If + End If + + End If + Next + + End Sub + + Private Sub SetCookie() + + If (Request.IsAuthenticated = False) Then + Dim objCookie As New HttpCookie("comment") + + objCookie.Expires = DateTime.Now.AddMonths(24) + objCookie.Values.Add("name", txtName.Text) + objCookie.Values.Add("email", txtEmail.Text) + objCookie.Values.Add("url", txtURL.Text) + + Response.Cookies.Add(objCookie) + End If + + End Sub + + Private Sub SetVisibility() + + pName.Visible = Not Request.IsAuthenticated + pEmail.Visible = Not Request.IsAuthenticated + pUrl.Visible = Not Request.IsAuthenticated + ctlCaptcha.Visible = (ArticleSettings.UseCaptcha And Request.IsAuthenticated = False) + + If (Request.IsAuthenticated = False) Then + pUrl.Visible = Not ArticleSettings.IsCommentWebsiteHidden + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Protected Sub Page_Init(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Init + + If Not (TypeOf Parent.Parent Is NewsArticleModuleBase Or TypeOf Parent.Parent.Parent.Parent Is NewsArticleModuleBase) Then + Visible = False + Return + End If + + CheckSecurity() + AssignLocalization() + SetVisibility() + + valName.ValidationGroup = "PostComment-" & ArticleID.ToString() + valEmail.ValidationGroup = "PostComment-" & ArticleID.ToString() + valEmailIsValid.ValidationGroup = "PostComment-" & ArticleID.ToString() + valComment.ValidationGroup = "PostComment-" & ArticleID.ToString() + btnAddComment.ValidationGroup = "PostComment-" & ArticleID.ToString() + + If (Page.IsPostBack = False) Then + GetCookie() + End If + + End Sub + + Protected Sub Page_PreRender(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.PreRender + + If (HttpContext.Current.Items.Contains("IgnoreCaptcha")) Then + ctlCaptcha.ErrorMessage = "" + End If + + End Sub + + Protected Sub btnAddComment_Click(ByVal sender As Object, ByVal e As EventArgs) Handles btnAddComment.Click + + If (Page.IsValid) Then + If (ArticleSettings.UseCaptcha And Request.IsAuthenticated = False) Then + If (ctlCaptcha.IsValid = False) Then + txtComment.Focus() + Return + End If + End If + + Dim objController As New ArticleController + Dim objArticle As ArticleInfo = objController.GetArticle(ArticleID) + + Dim objCommentController As New CommentController + Dim objComments As List(Of CommentInfo) = objCommentController.GetCommentList(ArticleModuleBase.ModuleId, ArticleID, True, SortDirection.Ascending, Null.NullInteger) + + For Each objArticleComment As CommentInfo In objComments + If (objArticleComment.CreatedDate > DateTime.Now.AddMinutes(-1)) Then + Dim id As Integer = Null.NullInteger + If (Request.IsAuthenticated) Then + id = ArticleModuleBase.UserId + End If + If (objArticleComment.Comment = FilterInput(txtComment.Text) And objArticleComment.UserID = id) Then + ' Existing Comment just posted - so ignore redirect. + If (Request("articleType") <> "ArticleView") Then + Response.Redirect(Request.RawUrl & "#Comment" & objArticleComment.CommentID.ToString(), True) + Else + Response.Redirect(Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False) & "#Comment" & objArticleComment.CommentID.ToString(), True) + End If + Return + End If + End If + Next + + objComments = objCommentController.GetCommentList(ArticleModuleBase.ModuleId, ArticleID, False, SortDirection.Ascending, Null.NullInteger) + + For Each objArticleComment As CommentInfo In objComments + If (objArticleComment.CreatedDate > DateTime.Now.AddMinutes(-1)) Then + Dim id As Integer = Null.NullInteger + If (Request.IsAuthenticated) Then + id = ArticleModuleBase.UserId + End If + If (objArticleComment.Comment = FilterInput(txtComment.Text) And objArticleComment.UserID = id) Then + ' Existing Comment just posted - so ignore redirect. + If (Request("articleType") <> "ArticleView") Then + Response.Redirect(Request.RawUrl & "#Comment" & objArticleComment.CommentID.ToString(), True) + Else + Response.Redirect(Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False) & "#Comment" & objArticleComment.CommentID.ToString(), True) + End If + Return + End If + End If + Next + + Dim objComment As New CommentInfo + objComment.ArticleID = ArticleID + objComment.CreatedDate = DateTime.Now + If (Request.IsAuthenticated) Then + objComment.UserID = ArticleModuleBase.UserId + Else + objComment.UserID = Null.NullInteger + objComment.AnonymousName = txtName.Text + objComment.AnonymousEmail = txtEmail.Text + objComment.AnonymousURL = txtURL.Text + SetCookie() + End If + objComment.Comment = FilterInput(txtComment.Text) + objComment.RemoteAddress = Request.UserHostAddress + objComment.NotifyMe = chkNotifyMe.Checked + objComment.Type = 0 + + If (ArticleSettings.IsApprover Or ArticleSettings.IsAutoApproverComment) Then + objComment.IsApproved = True + objComment.ApprovedBy = ArticleModuleBase.UserId + Else + If (ArticleSettings.CommentModeration) Then + objComment.IsApproved = False + objComment.ApprovedBy = Null.NullInteger + Else + objComment.IsApproved = True + objComment.ApprovedBy = Null.NullInteger + End If + End If + + ' Akismet + If (ArticleSettings.CommentAkismetKey <> "") Then + Dim api As New Akismet(ArticleSettings.CommentAkismetKey, DotNetNuke.Common.Globals.NavigateURL(CType(Parent.Parent, DotNetNuke.Entities.Modules.PortalModuleBase).TabId), "Test/1.0") + If (api.VerifyKey()) Then + Dim comment As New AkismetComment() + + comment.Blog = DotNetNuke.Common.Globals.NavigateURL(CType(Parent.Parent, DotNetNuke.Entities.Modules.PortalModuleBase).TabId) + comment.UserIp = objComment.RemoteAddress + comment.UserAgent = "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)" + comment.CommentContent = objComment.Comment + comment.CommentType = "comment" + + If (Request.IsAuthenticated) Then + comment.CommentAuthor = CType(Parent.Parent, DotNetNuke.Entities.Modules.PortalModuleBase).UserInfo.DisplayName + comment.CommentAuthorEmail = CType(Parent.Parent, DotNetNuke.Entities.Modules.PortalModuleBase).UserInfo.Email + comment.CommentAuthorUrl = "" + Else + comment.CommentAuthor = objComment.AnonymousName + comment.CommentAuthorEmail = objComment.AnonymousEmail + comment.CommentAuthorUrl = objComment.AnonymousURL + End If + + If (api.CommentCheck(comment)) Then + txtComment.Focus() + Return + End If + End If + End If + + objComment.CommentID = objCommentController.AddComment(objComment) + + ' Re-init for user details. + objComment = objCommentController.GetComment(objComment.CommentID) + + If Not (objArticle Is Nothing) Then + + ' Notifications + If (objComment.IsApproved) Then + If (ArticleSettings.NotifyAuthorOnComment) Then + NotifyAuthor(objComment, objArticle) + End If + NotifyComments(objComment, objArticle) + + If (ArticleSettings.NotifyEmailOnComment <> "") Then + Dim objEmailTemplateController As New EmailTemplateController + For Each email As String In ArticleSettings.NotifyEmailOnComment.Split(Convert.ToChar(";")) + If (email <> "") Then + objEmailTemplateController.SendFormattedEmail(ArticleModuleBase.ModuleId, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentNotification, ArticleSettings, email) + End If + Next + End If + + If (ArticleSettings.EnableActiveSocialFeed And Request.IsAuthenticated) Then + If (ArticleSettings.ActiveSocialCommentKey <> "") Then + If IO.File.Exists(HttpContext.Current.Server.MapPath("~/bin/active.modules.social.dll")) Then + Dim ai As Object = Nothing + Dim asm As System.Reflection.Assembly + Dim ac As Object = Nothing + Try + asm = System.Reflection.Assembly.Load("Active.Modules.Social") + ac = asm.CreateInstance("Active.Modules.Social.API.Journal") + If Not ac Is Nothing Then + ac.AddProfileItem(New Guid(ArticleSettings.ActiveSocialCommentKey), objComment.UserID, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False), objArticle.Title, objComment.Comment, objComment.Comment, 1, "") + End If + Catch ex As Exception + End Try + End If + End If + End If + + If (Request.IsAuthenticated) Then + If (ArticleSettings.JournalIntegration) Then + Dim objJournal As New Journal + objJournal.AddCommentToJournal(objArticle, objComment, ArticleModuleBase.PortalId, ArticleModuleBase.TabId, ArticleModuleBase.UserId, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False)) + End If + End If + + If (ArticleSettings.EnableSmartThinkerStoryFeed And Request.IsAuthenticated) Then + Dim objStoryFeed As New wsStoryFeed.StoryFeedWS + objStoryFeed.Url = DotNetNuke.Common.Globals.AddHTTP(Request.ServerVariables("HTTP_HOST") & Me.ResolveUrl("~/DesktopModules/Smart-Thinker%20-%20UserProfile/StoryFeed.asmx")) + + Dim val As String = ArticleModuleBase.GetSharedResource("StoryFeed-AddComment") + + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + Dim layoutArray As String() = val.Split(delimiter) + + Dim valResult As String = "" + + For iPtr As Integer = 0 To layoutArray.Length - 1 Step 2 + + valResult = valResult & layoutArray(iPtr) + + If iPtr < layoutArray.Length - 1 Then + Select Case layoutArray(iPtr + 1) + + Case "ARTICLEID" + valResult = valResult & objComment.ArticleID.ToString() + + Case "AUTHORID" + valResult = valResult & objComment.UserID.ToString() + + Case "AUTHOR" + If (objComment.UserID = Null.NullInteger) Then + valResult = valResult & objComment.AnonymousName + Else + valResult = valResult & objComment.AuthorDisplayName + End If + + Case "ARTICLELINK" + valResult = valResult & Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False) + + Case "ARTICLETITLE" + valResult = valResult & objArticle.Title + + Case "ISANONYMOUS" + If (objComment.UserID <> Null.NullInteger) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISANONYMOUS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISANONYMOUS" + ' Do Nothing + + Case "ISNOTANONYMOUS" + If (objComment.UserID <> Null.NullInteger) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISNOTANONYMOUS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISNOTANONYMOUS" + ' Do Nothing + + End Select + End If + Next + + Try + objStoryFeed.AddAction(81, objComment.CommentID, valResult, objComment.UserID, "VE6457624576460436531768") + Catch + End Try + + End If + Else + + If (ArticleSettings.NotifyApproverForCommentApproval) Then + + ' Notify Approvers + Dim objEmailTemplateController As New EmailTemplateController + Dim emails As String = objEmailTemplateController.GetApproverDistributionList(ArticleModuleBase.ModuleId) + + For Each email As String In emails.Split(Convert.ToChar(";")) + If (email <> "") Then + Try + objEmailTemplateController.SendFormattedEmail(ArticleModuleBase.ModuleId, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentRequiringApproval, ArticleSettings, email) + Catch + End Try + End If + Next + + End If + + If (ArticleSettings.NotifyEmailForCommentApproval <> "") Then + + Dim objEmailTemplateController As New EmailTemplateController + + For Each email As String In ArticleSettings.NotifyEmailForCommentApproval.Split(Convert.ToChar(";")) + If (email <> "") Then + Try + objEmailTemplateController.SendFormattedEmail(ArticleModuleBase.ModuleId, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentRequiringApproval, ArticleSettings, email) + Catch + End Try + End If + Next + + End If + + End If + + ' Redirect + If (objComment.IsApproved) Then + If (Request("articleType") <> "ArticleView") Then + Response.Redirect(Request.RawUrl & "#Comment" & objComment.CommentID.ToString(), True) + Else + Response.Redirect(Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False) & "#Comment" & objComment.CommentID.ToString(), True) + End If + Else + phCommentForm.Visible = False + phCommentPosted.Visible = True + End If + + Else + + ' Should never be here. + Response.Redirect(DotNetNuke.Common.NavigateURL(), True) + + End If + + End If + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Controls/PostRating.ascx b/Controls/PostRating.ascx new file mode 100755 index 0000000..85629c3 --- /dev/null +++ b/Controls/PostRating.ascx @@ -0,0 +1,9 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="PostRating.ascx.vb" Inherits="Ventrian.NewsArticles.Controls.PostRating" %> + + 1 + 2 + 3 + 4 + 5 + + diff --git a/Controls/PostRating.ascx.designer.vb b/Controls/PostRating.ascx.designer.vb new file mode 100755 index 0000000..7fdaeec --- /dev/null +++ b/Controls/PostRating.ascx.designer.vb @@ -0,0 +1,35 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class PostRating + + ''' + '''lstRating control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstRating As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''lblRatingSaved control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblRatingSaved As Global.System.Web.UI.WebControls.Label + End Class +End Namespace diff --git a/Controls/PostRating.ascx.vb b/Controls/PostRating.ascx.vb new file mode 100755 index 0000000..b74666f --- /dev/null +++ b/Controls/PostRating.ascx.vb @@ -0,0 +1,248 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Localization +Imports DotNetNuke.Framework +Imports Ventrian.NewsArticles.Components.Social + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class PostRating + Inherits System.Web.UI.UserControl + +#Region " Private Members " + + Private _articleID As Integer = Null.NullInteger + +#End Region + +#Region " Private Properties " + + Private ReadOnly Property ArticleModuleBase() As NewsArticleModuleBase + Get + Return CType(Parent.Parent, NewsArticleModuleBase) + End Get + End Property + + Private ReadOnly Property ArticleSettings() As ArticleSettings + Get + Return ArticleModuleBase.ArticleSettings + End Get + End Property + +#End Region + +#Region " Private Methods " + + Private Sub AssignLocalization() + + lblRatingSaved.Text = GetResourceKey("RatingSaved") + + End Sub + + Public Function GetResourceKey(ByVal key As String) As String + + Dim path As String = "~/DesktopModules/DnnForge - NewsArticles/" & Localization.LocalResourceDirectory & "/PostRating.ascx.resx" + Return DotNetNuke.Services.Localization.Localization.GetString(key, path) + + End Function + + Private Sub ReadQueryString() + + If (ArticleSettings.UrlModeType = Components.Types.UrlModeType.Shorterned) Then + Try + If (IsNumeric(Request(ArticleSettings.ShortenedID))) Then + _articleID = Convert.ToInt32(Request(ArticleSettings.ShortenedID)) + End If + Catch + End Try + End If + + If (IsNumeric(Request("ArticleID"))) Then + _articleID = Convert.ToInt32(Request("ArticleID")) + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load + + If Not (TypeOf Parent.Parent Is NewsArticleModuleBase) Then + Visible = False + Return + End If + + ReadQueryString() + AssignLocalization() + + If (ArticleSettings.IsRateable = False) Then + Me.Visible = False + Return + End If + + If (IsPostBack = False) Then + + Dim objRatingController As New RatingController + If (Request.IsAuthenticated) Then + Dim objRating As RatingInfo = objRatingController.Get(_articleID, ArticleModuleBase.UserId, ArticleModuleBase.ModuleId) + + If Not (objRating Is Nothing) Then + If (objRating.RatingID <> Null.NullInteger) Then + If Not (lstRating.Items.FindByValue(Convert.ToDouble(objRating.Rating).ToString()) Is Nothing) Then + lstRating.SelectedValue = Convert.ToDouble(objRating.Rating).ToString() + End If + End If + End If + Else + Dim cookie As HttpCookie = Request.Cookies("ArticleRating" & _articleID.ToString()) + If Not (cookie Is Nothing) Then + Dim objRating As RatingInfo = objRatingController.GetByID(Convert.ToInt32(cookie.Value), _articleID, ArticleModuleBase.ModuleId) + + If Not (objRating Is Nothing) Then + If Not (lstRating.Items.FindByValue(Convert.ToDouble(objRating.Rating).ToString()) Is Nothing) Then + lstRating.SelectedValue = Convert.ToDouble(objRating.Rating).ToString() + End If + End If + End If + End If + + End If + + End Sub + + Protected Sub lstRating_SelectedIndexChanged(ByVal sender As Object, ByVal e As EventArgs) Handles lstRating.SelectedIndexChanged + + If (Request.IsAuthenticated) Then + + Dim objRatingController As New RatingController + + Dim objRatingExists As RatingInfo = objRatingController.Get(_articleID, ArticleModuleBase.UserId, ArticleModuleBase.ModuleId) + + If (objRatingExists.RatingID <> Null.NullInteger) Then + objRatingController.Delete(objRatingExists.RatingID, _articleID, ArticleModuleBase.ModuleId) + End If + + Dim objRating As New RatingInfo + + objRating.ArticleID = _articleID + objRating.CreatedDate = DateTime.Now + objRating.Rating = Convert.ToDouble(lstRating.SelectedValue) + objRating.UserID = ArticleModuleBase.UserId + + objRating.RatingID = objRatingController.Add(objRating, ArticleModuleBase.ModuleId) + + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + + If (ArticleSettings.EnableActiveSocialFeed And Request.IsAuthenticated) Then + If (ArticleSettings.ActiveSocialRateKey <> "") Then + If IO.File.Exists(HttpContext.Current.Server.MapPath("~/bin/active.modules.social.dll")) Then + Dim ai As Object = Nothing + Dim asm As System.Reflection.Assembly + Dim ac As Object = Nothing + Try + asm = System.Reflection.Assembly.Load("Active.Modules.Social") + ac = asm.CreateInstance("Active.Modules.Social.API.Journal") + If Not ac Is Nothing Then + ac.AddProfileItem(New Guid(ArticleSettings.ActiveSocialRateKey), objRating.UserID, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False), objArticle.Title, objRating.Rating.ToString(), objRating.Rating.ToString(), 1, "") + End If + Catch ex As Exception + End Try + End If + End If + End If + + If (ArticleSettings.JournalIntegration) Then + Dim objJournal As New Journal + objJournal.AddRatingToJournal(objArticle, objRating, ArticleModuleBase.PortalId, ArticleModuleBase.TabId, ArticleModuleBase.UserId, Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False)) + End If + + If (ArticleSettings.EnableSmartThinkerStoryFeed) Then + Dim objStoryFeed As New wsStoryFeed.StoryFeedWS + objStoryFeed.Url = DotNetNuke.Common.Globals.AddHTTP(Request.ServerVariables("HTTP_HOST") & Me.ResolveUrl("~/DesktopModules/Smart-Thinker%20-%20UserProfile/StoryFeed.asmx")) + + Dim val As String = ArticleModuleBase.GetSharedResource("StoryFeed-AddRating") + + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + Dim layoutArray As String() = val.Split(delimiter) + + Dim valResult As String = "" + + For iPtr As Integer = 0 To layoutArray.Length - 1 Step 2 + + valResult = valResult & layoutArray(iPtr) + + If iPtr < layoutArray.Length - 1 Then + Select Case layoutArray(iPtr + 1) + + Case "ARTICLEID" + valResult = valResult & objRating.ArticleID.ToString() + + Case "AUTHORID" + valResult = valResult & objRating.UserID.ToString() + + Case "AUTHOR" + valResult = valResult & ArticleModuleBase.UserInfo.DisplayName + + Case "ARTICLELINK" + valResult = valResult & Common.GetArticleLink(objArticle, ArticleModuleBase.PortalSettings.ActiveTab, ArticleSettings, False) + + Case "ARTICLETITLE" + valResult = valResult & objArticle.Title + + End Select + End If + Next + + Try + objStoryFeed.AddAction(82, objRating.RatingID, valResult, objRating.UserID, "VE6457624576460436531768") + Catch + End Try + End If + + Else + + Dim objRatingController As New RatingController + Dim objRating As New RatingInfo + Dim cookie As HttpCookie = Request.Cookies("ArticleRating" & _articleID.ToString()) + If Not (cookie Is Nothing) Then + objRating = objRatingController.GetByID(Convert.ToInt32(cookie.Value), _articleID, ArticleModuleBase.ModuleId) + If Not (objRating Is Nothing) Then + If (objRating.ArticleID <> Null.NullInteger) Then + objRatingController.Delete(objRating.RatingID, _articleID, ArticleModuleBase.ModuleId) + End If + End If + End If + + objRating = New RatingInfo + + objRating.ArticleID = _articleID + objRating.CreatedDate = DateTime.Now + objRating.Rating = Convert.ToDouble(lstRating.SelectedValue) + objRating.UserID = -1 + + Dim ratingID As Integer = objRatingController.Add(objRating, ArticleModuleBase.ModuleId) + + cookie = New HttpCookie("ArticleRating" & _articleID.ToString()) + cookie.Value = ratingID.ToString() + cookie.Expires = DateTime.Now.AddDays(7) + Context.Response.Cookies.Add(cookie) + + End If + + lblRatingSaved.Visible = True + + HttpContext.Current.Items.Add("IgnoreCaptcha", "True") + Response.Redirect(Request.RawUrl, True) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Controls/SWFUploader.ashx b/Controls/SWFUploader.ashx new file mode 100755 index 0000000..55489a2 --- /dev/null +++ b/Controls/SWFUploader.ashx @@ -0,0 +1 @@ +<%@ WebHandler Language="VB" CodeBehind="SWFUploader.ashx.vb" Class="Ventrian.NewsArticles.Controls.SWFUploader" %> diff --git a/Controls/SWFUploader.ashx.vb b/Controls/SWFUploader.ashx.vb new file mode 100755 index 0000000..30dfb36 --- /dev/null +++ b/Controls/SWFUploader.ashx.vb @@ -0,0 +1,415 @@ +Imports System.Web +Imports System.Web.Services + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Security.Roles +Imports DotNetNuke.Services.FileSystem +Imports System.IO +Imports System.Drawing +Imports System.Drawing.Drawing2D +Imports System.Drawing.Imaging + +Namespace Ventrian.NewsArticles.Controls + + Public Class SWFUploader + Implements System.Web.IHttpHandler + +#Region " Private Members " + + Private _articleID As Integer = Null.NullInteger + Private _moduleID As Integer = Null.NullInteger + Private _tabID As Integer = Null.NullInteger + Private _tabModuleID As Integer = Null.NullInteger + Private _portalID As Integer = Null.NullInteger + Private _ticket As String = Null.NullString + Private _userID As Integer = Null.NullInteger + Private _imageGuid As String = Null.NullString + + Private _articleSettings As Ventrian.NewsArticles.ArticleSettings + Private _settings As Hashtable + Private _context As HttpContext + +#End Region + +#Region " Private Properties " + + Private ReadOnly Property ArticleSettings() As Ventrian.NewsArticles.ArticleSettings + Get + If _articleSettings Is Nothing Then + Dim objModuleController As New ModuleController + Dim objModule As ModuleInfo = objModuleController.GetModule(_moduleID, _tabID) + + _articleSettings = New Ventrian.NewsArticles.ArticleSettings(Settings, PortalController.GetCurrentPortalSettings(), objModule) + End If + Return _articleSettings + End Get + End Property + + Private ReadOnly Property Settings() As Hashtable + Get + If _settings Is Nothing Then + Dim objModuleController As New ModuleController + _settings = objModuleController.GetModuleSettings(_moduleID) + _settings = GetTabModuleSettings(_tabModuleID, _settings) + End If + Return _settings + End Get + End Property + +#End Region + +#Region " Private Methods " + + Private Sub AuthenticateUserFromTicket() + + If (_ticket <> "") Then + + Dim ticket As FormsAuthenticationTicket = FormsAuthentication.Decrypt(_ticket) + Dim fi As FormsIdentity = New FormsIdentity(ticket) + + Dim roles As String() = Nothing + HttpContext.Current.User = New System.Security.Principal.GenericPrincipal(fi, roles) + + Dim objUser As UserInfo = UserController.GetUserByName(_portalID, HttpContext.Current.User.Identity.Name) + + If Not (objUser Is Nothing) Then + _userID = objUser.UserID + HttpContext.Current.Items("UserInfo") = objUser + + Dim objRoleController As New RoleController + roles = objRoleController.GetRolesByUser(_userID, _portalID) + + Dim strPortalRoles As String = Join(roles, New Char() {";"c}) + _context.Items.Add("UserRoles", ";" + strPortalRoles + ";") + End If + + End If + + End Sub + + Private Function GetTabModuleSettings(ByVal TabModuleId As Integer, ByVal settings As Hashtable) As Hashtable + + Dim dr As IDataReader = DotNetNuke.Data.DataProvider.Instance().GetTabModuleSettings(TabModuleId) + + While dr.Read() + + If Not dr.IsDBNull(1) Then + settings(dr.GetString(0)) = dr.GetString(1) + Else + settings(dr.GetString(0)) = "" + End If + + End While + + dr.Close() + + Return settings + + End Function + + Private Sub ReadQueryString() + + If (_context.Request("ModuleID") <> "") Then + _moduleID = Convert.ToInt32(_context.Request("ModuleID")) + End If + + If (_context.Request("PortalID") <> "") Then + _portalID = Convert.ToInt32(_context.Request("PortalID")) + End If + + If (_context.Request("ArticleID") <> "") Then + _articleID = Convert.ToInt32(_context.Request("ArticleID")) + End If + + If (_context.Request("TabModuleID") <> "") Then + _tabModuleID = Convert.ToInt32(_context.Request("TabModuleID")) + End If + + If (_context.Request("TabID") <> "") Then + _tabID = Convert.ToInt32(_context.Request("TabID")) + End If + + If (_context.Request("Ticket") <> "") Then + _ticket = _context.Request("Ticket") + End If + + If (_articleID = Null.NullInteger) Then + If (_context.Request("ArticleGuid") <> "") Then + _imageGuid = _context.Request("ArticleGuid") + End If + End If + + End Sub + +#End Region + +#Region " Interface Methods " + + Sub ProcessRequest(ByVal context As HttpContext) Implements IHttpHandler.ProcessRequest + + _context = context + context.Response.ContentType = "text/plain" + + ReadQueryString() + AuthenticateUserFromTicket() + + If (_context.Request.IsAuthenticated = False) Then + _context.Response.Write("-2") + _context.Response.End() + End If + + Dim objImageController As New ImageController() + Dim objFile As HttpPostedFile = _context.Request.Files("Filedata") + + If Not (objFile Is Nothing) Then + + Dim objPortalController As New PortalController() + If (objPortalController.HasSpaceAvailable(_portalID, objFile.ContentLength) = False) Then + _context.Response.Write("-1") + _context.Response.End() + End If + + Dim username As String = _context.User.Identity.Name + + Dim objImage As New ImageInfo + + objImage.ArticleID = _articleID + If (_articleID = Null.NullInteger) Then + objImage.ImageGuid = _imageGuid + End If + objImage.FileName = objFile.FileName + + If (objFile.FileName.ToLower().EndsWith(".jpg")) Then + objImage.ContentType = "image/jpeg" + End If + + If (objFile.FileName.ToLower().EndsWith(".gif")) Then + objImage.ContentType = "image/gif" + End If + + If (objFile.FileName.ToLower().EndsWith(".png")) Then + objImage.ContentType = "image/png" + End If + + Dim maxWidth As Integer = ArticleSettings.MaxImageWidth + Dim maxHeight As Integer = ArticleSettings.MaxImageHeight + + Dim photo As Drawing.Image = Drawing.Image.FromStream(objFile.InputStream) + + objImage.Width = photo.Width + objImage.Height = photo.Height + + If (objImage.Width > maxWidth) Then + objImage.Width = maxWidth + objImage.Height = Convert.ToInt32(objImage.Height / (photo.Width / maxWidth)) + End If + + If (objImage.Height > maxHeight) Then + objImage.Height = maxHeight + objImage.Width = Convert.ToInt32(photo.Width / (photo.Height / maxHeight)) + End If + + objImage.SortOrder = 0 + + Dim imagesList As List(Of ImageInfo) = objImageController.GetImageList(_articleID, _imageGuid) + + If (imagesList.Count > 0) Then + objImage.SortOrder = CType(imagesList(imagesList.Count - 1), ImageInfo).SortOrder + 1 + End If + + Dim objPortalSettings As PortalSettings = PortalController.GetCurrentPortalSettings() + + Dim folder As String = "" + Dim folderID As Integer = Null.NullInteger + If (IsNumeric(context.Request.Form("FolderID"))) Then + folderID = Convert.ToInt32(context.Request.Form("FolderID")) + End If + + If (folderID <> Null.NullInteger) Then + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(_portalID, folderID) + If (objFolder IsNot Nothing) Then + folder = objFolder.FolderPath + End If + End If + + objImage.Folder = folder + + Select Case objImage.ContentType.ToLower() + Case "image/jpeg" + objImage.Extension = "jpg" + Exit Select + Case "image/gif" + objImage.Extension = "gif" + Exit Select + Case "image/png" + objImage.Extension = "png" + Exit Select + End Select + + objImage.Title = objFile.FileName.Replace("." & objImage.Extension, "") + + Dim filePath As String = objPortalSettings.HomeDirectoryMapPath & folder.Replace("/", "\") + + If Not (Directory.Exists(filePath)) Then + Directory.CreateDirectory(filePath) + End If + + If (File.Exists(filePath & objImage.FileName)) Then + For i As Integer = 1 To 100 + If (File.Exists(filePath & i.ToString() & "_" & objImage.FileName) = False) Then + objImage.FileName = i.ToString() & "_" & objImage.FileName + Exit For + End If + Next + End If + + objImage.Size = objFile.ContentLength + If ((photo.Width < maxWidth And photo.Height < maxHeight) Or (ArticleSettings.ResizeImages = False)) Then + objFile.SaveAs(filePath & objImage.FileName) + Else + Dim bmp As New Bitmap(objImage.Width, objImage.Height) + Dim g As Graphics = Graphics.FromImage(DirectCast(bmp, Drawing.Image)) + + g.InterpolationMode = InterpolationMode.HighQualityBicubic + g.SmoothingMode = SmoothingMode.HighQuality + g.PixelOffsetMode = PixelOffsetMode.HighQuality + g.CompositingQuality = CompositingQuality.HighQuality + + g.DrawImage(photo, 0, 0, objImage.Width, objImage.Height) + + If (ArticleSettings.WatermarkEnabled And ArticleSettings.WatermarkText <> "") Then + Dim crSize As SizeF = New SizeF + Dim brushColor As Brush = Brushes.Yellow + Dim fnt As Font = New Font("Verdana", 11, FontStyle.Bold) + Dim strDirection As StringFormat = New StringFormat + + strDirection.Alignment = StringAlignment.Center + crSize = g.MeasureString(ArticleSettings.WatermarkText, fnt) + + Dim yPixelsFromBottom As Integer = Convert.ToInt32(Convert.ToDouble(objImage.Height) * 0.05) + Dim yPosFromBottom As Single = Convert.ToSingle((objImage.Height - yPixelsFromBottom) - (crSize.Height / 2)) + Dim xCenterOfImage As Single = Convert.ToSingle((objImage.Width / 2)) + + g.SmoothingMode = Drawing2D.SmoothingMode.AntiAlias + + Dim semiTransBrush2 As SolidBrush = New SolidBrush(Color.FromArgb(153, 0, 0, 0)) + g.DrawString(ArticleSettings.WatermarkText, fnt, semiTransBrush2, New PointF(xCenterOfImage + 1, yPosFromBottom + 1), strDirection) + + Dim semiTransBrush As SolidBrush = New SolidBrush(Color.FromArgb(153, 255, 255, 255)) + g.DrawString(ArticleSettings.WatermarkText, fnt, semiTransBrush, New PointF(xCenterOfImage, yPosFromBottom), strDirection) + End If + + If (ArticleSettings.WatermarkEnabled And ArticleSettings.WatermarkImage <> "") Then + Dim watermark As String = objPortalSettings.HomeDirectoryMapPath & ArticleSettings.WatermarkImage + If (File.Exists(watermark)) Then + Dim imgWatermark As Image = New Bitmap(watermark) + Dim wmWidth As Integer = imgWatermark.Width + Dim wmHeight As Integer = imgWatermark.Height + + Dim objImageAttributes As New ImageAttributes() + Dim objColorMap As New ColorMap() + objColorMap.OldColor = Color.FromArgb(255, 0, 255, 0) + objColorMap.NewColor = Color.FromArgb(0, 0, 0, 0) + Dim remapTable As ColorMap() = {objColorMap} + objImageAttributes.SetRemapTable(remapTable, ColorAdjustType.Bitmap) + + Dim colorMatrixElements As Single()() = {New Single() {1.0F, 0.0F, 0.0F, 0.0F, 0.0F}, New Single() {0.0F, 1.0F, 0.0F, 0.0F, 0.0F}, New Single() {0.0F, 0.0F, 1.0F, 0.0F, 0.0F}, New Single() {0.0F, 0.0F, 0.0F, 0.3F, 0.0F}, New Single() {0.0F, 0.0F, 0.0F, 0.0F, 1.0F}} + Dim wmColorMatrix As New ColorMatrix(colorMatrixElements) + objImageAttributes.SetColorMatrix(wmColorMatrix, ColorMatrixFlag.[Default], ColorAdjustType.Bitmap) + + Dim xPosOfWm As Integer = ((objImage.Width - wmWidth) - 10) + Dim yPosOfWm As Integer = 10 + + Select Case ArticleSettings.WatermarkPosition + Case WatermarkPosition.TopLeft + xPosOfWm = 10 + yPosOfWm = 10 + Exit Select + + Case WatermarkPosition.TopRight + xPosOfWm = ((objImage.Width - wmWidth) - 10) + yPosOfWm = 10 + Exit Select + + Case WatermarkPosition.BottomLeft + xPosOfWm = 10 + yPosOfWm = ((objImage.Height - wmHeight) - 10) + + Case WatermarkPosition.BottomRight + xPosOfWm = ((objImage.Width - wmWidth) - 10) + yPosOfWm = ((objImage.Height - wmHeight) - 10) + End Select + + g.DrawImage(imgWatermark, New Rectangle(xPosOfWm, yPosOfWm, wmWidth, wmHeight), 0, 0, wmWidth, wmHeight, _ + GraphicsUnit.Pixel, objImageAttributes) + imgWatermark.Dispose() + End If + End If + + photo.Dispose() + + Select Case objFile.ContentType.ToLower() + Case "image/jpeg" + Dim info As ImageCodecInfo() = ImageCodecInfo.GetImageEncoders() + Dim encoderParameters As New EncoderParameters(1) + encoderParameters.Param(0) = New EncoderParameter(Encoder.Quality, 100L) + bmp.Save(filePath & objImage.FileName, info(1), encoderParameters) + + Case "image/gif" + 'Dim quantizer As New ImageQuantization.OctreeQuantizer(255, 8) + 'Dim bmpQuantized As Bitmap = quantizer.Quantize(bmp) + 'bmpQuantized.Save(filePath & objPhoto.Filename, ImageFormat.Gif) + ' Not working in medium trust. + bmp.Save(filePath & objImage.FileName, ImageFormat.Gif) + + Case Else + 'Shouldn't get to here because of validators. + Dim info As ImageCodecInfo() = ImageCodecInfo.GetImageEncoders() + Dim encoderParameters As New EncoderParameters(1) + encoderParameters.Param(0) = New EncoderParameter(Encoder.Quality, 100L) + bmp.Save(filePath & objImage.FileName, info(1), encoderParameters) + End Select + + bmp.Dispose() + + If (File.Exists(filePath & objImage.FileName)) Then + Dim fi As New IO.FileInfo(filePath & objImage.FileName) + If (fi IsNot Nothing) Then + objImage.Size = Convert.ToInt32(fi.Length) + End If + End If + End If + + objImage.ImageID = objImageController.Add(objImage) + + If (_articleID <> Null.NullInteger) Then + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + If (objArticle IsNot Nothing) Then + objArticle.ImageCount = objArticle.ImageCount + 1 + objArticleController.UpdateArticle(objArticle) + End If + End If + + End If + + _context.Response.Write("0") + _context.Response.End() + + End Sub + + ReadOnly Property IsReusable() As Boolean Implements IHttpHandler.IsReusable + Get + Return False + End Get + End Property + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Controls/SWFUploaderFiles.ashx b/Controls/SWFUploaderFiles.ashx new file mode 100755 index 0000000..962213f --- /dev/null +++ b/Controls/SWFUploaderFiles.ashx @@ -0,0 +1 @@ +<%@ WebHandler Language="VB" CodeBehind="SWFUploaderFiles.ashx.vb" Class="Ventrian.NewsArticles.Controls.SWFUploaderFiles" %> diff --git a/Controls/SWFUploaderFiles.ashx.vb b/Controls/SWFUploaderFiles.ashx.vb new file mode 100755 index 0000000..0443e62 --- /dev/null +++ b/Controls/SWFUploaderFiles.ashx.vb @@ -0,0 +1,281 @@ +Imports System.Web +Imports System.Web.Services + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Security.Roles +Imports DotNetNuke.Services.FileSystem +Imports System.IO +Imports System.Drawing +Imports System.Drawing.Drawing2D +Imports System.Drawing.Imaging + +Namespace Ventrian.NewsArticles.Controls + + Public Class SWFUploaderFiles + Implements System.Web.IHttpHandler + +#Region " Private Members " + + Private _articleID As Integer = Null.NullInteger + Private _moduleID As Integer = Null.NullInteger + Private _tabID As Integer = Null.NullInteger + Private _tabModuleID As Integer = Null.NullInteger + Private _portalID As Integer = Null.NullInteger + Private _ticket As String = Null.NullString + Private _userID As Integer = Null.NullInteger + Private _fileGuid As String = Null.NullString + + Private _articleSettings As Ventrian.NewsArticles.ArticleSettings + Private _settings As Hashtable + Private _context As HttpContext + +#End Region + +#Region " Private Properties " + + Private ReadOnly Property ArticleSettings() As Ventrian.NewsArticles.ArticleSettings + Get + If _articleSettings Is Nothing Then + Dim objModuleController As New ModuleController + Dim objModule As ModuleInfo = objModuleController.GetModule(_moduleID, _tabID) + + _articleSettings = New Ventrian.NewsArticles.ArticleSettings(Settings, PortalController.GetCurrentPortalSettings(), objModule) + End If + Return _articleSettings + End Get + End Property + + Private ReadOnly Property Settings() As Hashtable + Get + If _settings Is Nothing Then + Dim objModuleController As New ModuleController + _settings = objModuleController.GetModuleSettings(_moduleID) + _settings = GetTabModuleSettings(_tabModuleID, _settings) + End If + Return _settings + End Get + End Property + +#End Region + +#Region " Private Methods " + + Private Sub AuthenticateUserFromTicket() + + If (_ticket <> "") Then + + Dim ticket As FormsAuthenticationTicket = FormsAuthentication.Decrypt(_ticket) + Dim fi As FormsIdentity = New FormsIdentity(ticket) + + Dim roles As String() = Nothing + HttpContext.Current.User = New System.Security.Principal.GenericPrincipal(fi, roles) + + Dim objUser As UserInfo = UserController.GetUserByName(_portalID, HttpContext.Current.User.Identity.Name) + + If Not (objUser Is Nothing) Then + _userID = objUser.UserID + HttpContext.Current.Items("UserInfo") = objUser + + Dim objRoleController As New RoleController + roles = objRoleController.GetRolesByUser(_userID, _portalID) + + Dim strPortalRoles As String = Join(roles, New Char() {";"c}) + _context.Items.Add("UserRoles", ";" + strPortalRoles + ";") + End If + + End If + + End Sub + + Private Function GetTabModuleSettings(ByVal TabModuleId As Integer, ByVal settings As Hashtable) As Hashtable + + Dim dr As IDataReader = DotNetNuke.Data.DataProvider.Instance().GetTabModuleSettings(TabModuleId) + + While dr.Read() + + If Not dr.IsDBNull(1) Then + settings(dr.GetString(0)) = dr.GetString(1) + Else + settings(dr.GetString(0)) = "" + End If + + End While + + dr.Close() + + Return settings + + End Function + + Private Sub ReadQueryString() + + If (_context.Request("ModuleID") <> "") Then + _moduleID = Convert.ToInt32(_context.Request("ModuleID")) + End If + + If (_context.Request("PortalID") <> "") Then + _portalID = Convert.ToInt32(_context.Request("PortalID")) + End If + + If (_context.Request("ArticleID") <> "") Then + _articleID = Convert.ToInt32(_context.Request("ArticleID")) + End If + + If (_context.Request("TabModuleID") <> "") Then + _tabModuleID = Convert.ToInt32(_context.Request("TabModuleID")) + End If + + If (_context.Request("TabID") <> "") Then + _tabID = Convert.ToInt32(_context.Request("TabID")) + End If + + If (_context.Request("Ticket") <> "") Then + _ticket = _context.Request("Ticket") + End If + + If (_articleID = Null.NullInteger) Then + If (_context.Request("ArticleGuid") <> "") Then + _fileGuid = _context.Request("ArticleGuid") + End If + End If + + End Sub + +#End Region + +#Region " Interface Methods " + + Sub ProcessRequest(ByVal context As HttpContext) Implements IHttpHandler.ProcessRequest + + _context = context + context.Response.ContentType = "text/plain" + + ReadQueryString() + AuthenticateUserFromTicket() + + If (_context.Request.IsAuthenticated = False) Then + _context.Response.Write("-2") + _context.Response.End() + End If + + Dim objFileController As New FileController + + Dim objFilePosted As HttpPostedFile = _context.Request.Files("Filedata") + + If Not (objFilePosted Is Nothing) Then + + Dim objPortalController As New PortalController() + If (objPortalController.HasSpaceAvailable(_portalID, objFilePosted.ContentLength) = False) Then + _context.Response.Write("-1") + _context.Response.End() + End If + + Dim username As String = _context.User.Identity.Name + + If (_articleID <> Null.NullInteger) Then + FileProvider.Instance().AddFile(_articleID, _moduleID, objFilePosted) + Else + FileProvider.Instance().AddFile(_fileGuid, _moduleID, objFilePosted) + End If + + 'Dim objFile As New FileInfo + + 'objFile.ArticleID = _articleID + 'If (_articleID = Null.NullInteger) Then + ' objFile.FileGuid = _fileGuid + 'End If + 'objFile.FileName = objFilePosted.FileName + 'objFile.SortOrder = 0 + + 'Dim filesList As List(Of FileInfo) = objFileController.GetFileList(_articleID, _fileGuid) + + 'If (filesList.Count > 0) Then + ' objFile.SortOrder = CType(filesList(filesList.Count - 1), FileInfo).SortOrder + 1 + 'End If + + 'Dim objPortalSettings As PortalSettings = PortalController.GetCurrentPortalSettings() + + 'Dim folder As String = "" + 'If (ArticleSettings.DefaultFilesFolder <> Null.NullInteger) Then + ' Dim objFolderController As New FolderController + ' Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(_portalID, ArticleSettings.DefaultFilesFolder) + ' If (objFolder IsNot Nothing) Then + ' folder = objFolder.FolderPath + ' End If + 'End If + + 'objFile.Folder = folder + 'objFile.ContentType = objFilePosted.ContentType + + 'If (objFile.FileName.Split("."c).Length > 0) Then + ' objFile.Extension = objFile.FileName.Split("."c)(objFile.FileName.Split("."c).Length - 1) + + ' If (objFile.Extension.ToLower() = "jpg") Then + ' objFile.ContentType = "image/jpeg" + ' End If + ' If (objFile.Extension.ToLower() = "gif") Then + ' objFile.ContentType = "image/gif" + ' End If + ' If (objFile.Extension.ToLower() = "txt") Then + ' objFile.ContentType = "text/plain" + ' End If + ' If (objFile.Extension.ToLower() = "html") Then + ' objFile.ContentType = "text/html" + ' End If + ' If (objFile.Extension.ToLower() = "mp3") Then + ' objFile.ContentType = "audio/mpeg" + ' End If + + 'End If + 'objFile.Title = objFile.FileName.Replace("." & objFile.Extension, "") + + 'Dim filePath As String = objPortalSettings.HomeDirectoryMapPath & folder.Replace("/", "\") + + 'If Not (Directory.Exists(filePath)) Then + ' Directory.CreateDirectory(filePath) + 'End If + + 'If (File.Exists(filePath & objFile.FileName)) Then + ' For i As Integer = 1 To 100 + ' If (File.Exists(filePath & i.ToString() & "_" & objFile.FileName) = False) Then + ' objFile.FileName = i.ToString() & "_" & objFile.FileName + ' Exit For + ' End If + ' Next + 'End If + + 'objFile.Size = objFilePosted.ContentLength + 'objFilePosted.SaveAs(filePath & objFile.FileName) + + 'objFile.FileID = objFileController.Add(objFile) + + 'If (_articleID <> Null.NullInteger) Then + ' Dim objArticleController As New ArticleController + ' Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + ' If (objArticle IsNot Nothing) Then + ' objArticle.FileCount = objArticle.FileCount + 1 + ' objArticleController.UpdateArticle(objArticle) + ' End If + 'End If + + End If + + _context.Response.Write("0") + _context.Response.End() + + End Sub + + ReadOnly Property IsReusable() As Boolean Implements IHttpHandler.IsReusable + Get + Return False + End Get + End Property + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Controls/UploadFiles.ascx b/Controls/UploadFiles.ascx new file mode 100755 index 0000000..1a36b8f --- /dev/null +++ b/Controls/UploadFiles.ascx @@ -0,0 +1,183 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="UploadFiles.ascx.vb" Inherits="Ventrian.NewsArticles.Controls.UploadFiles" %> +<%@ Register TagPrefix="Ventrian" Assembly="Ventrian.NewsArticles" Namespace="Ventrian.NewsArticles.Components.WebControls" %> + +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="URL" Src="~/controls/URLControl.ascx" %> + + +
+ + + + + + + + + +
+
+ + + + + + +
+ + + + + + + + + +
 
+ +
+
+ +
+
+
+
+
+ + + + + +
+ + + + + +

 
+
+
+
+ + + + + +
+ + + + + <%#DataBinder.Eval(Container.DataItem, "Title")%> + +
+ + + + +
+ + + <%#DataBinder.Eval(Container.DataItem, "Title")%> + +
+ +
+ + +
+
+
+
+
+
+ + + diff --git a/Controls/UploadFiles.ascx.designer.vb b/Controls/UploadFiles.ascx.designer.vb new file mode 100755 index 0000000..57b9571 --- /dev/null +++ b/Controls/UploadFiles.ascx.designer.vb @@ -0,0 +1,233 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class UploadFiles + + ''' + '''litModuleID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litModuleID As Global.System.Web.UI.WebControls.Literal + + ''' + '''litTabModuleID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litTabModuleID As Global.System.Web.UI.WebControls.Literal + + ''' + '''litTicketID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litTicketID As Global.System.Web.UI.WebControls.Literal + + ''' + '''litArticleGuid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litArticleGuid As Global.System.Web.UI.WebControls.Literal + + ''' + '''lblSelectFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSelectFiles As Global.System.Web.UI.WebControls.Label + + ''' + '''dshFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshFiles As DotNetNuke.UI.UserControls.SectionHeadControl + + ''' + '''tblFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblFiles As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblFilesHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblFilesHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''phFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phFiles As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''trUpload control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trUpload As Global.System.Web.UI.HtmlControls.HtmlTableCell + + ''' + '''dshUploadFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshUploadFiles As DotNetNuke.UI.UserControls.SectionHeadControl + + ''' + '''tblUploadFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblUploadFiles As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plFolder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plFolder As Global.System.Web.UI.UserControl + + ''' + '''drpUploadFilesFolder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpUploadFilesFolder As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''trExisting control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trExisting As Global.System.Web.UI.HtmlControls.HtmlTableCell + + ''' + '''dshExistingFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshExistingFiles As DotNetNuke.UI.UserControls.SectionHeadControl + + ''' + '''tblExistingFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblExistingFiles As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''ctlFile control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ctlFile As DotNetNuke.UI.UserControls.UrlControl + + ''' + '''cmdAddExistingFile control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdAddExistingFile As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''dshSelectedFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshSelectedFiles As DotNetNuke.UI.UserControls.SectionHeadControl + + ''' + '''tblSelectedFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSelectedFiles As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''dlFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dlFiles As Global.System.Web.UI.WebControls.DataList + + ''' + '''lblNoFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoFiles As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdRefreshFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdRefreshFiles As Global.Ventrian.NewsArticles.Components.WebControls.RefreshControl + End Class +End Namespace diff --git a/Controls/UploadFiles.ascx.vb b/Controls/UploadFiles.ascx.vb new file mode 100755 index 0000000..515c067 --- /dev/null +++ b/Controls/UploadFiles.ascx.vb @@ -0,0 +1,508 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.FileSystem +Imports DotNetNuke.Security + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class UploadFiles + Inherits NewsArticleControlBase + +#Region " Private Members " + + Private _articleID As Integer = Null.NullInteger + + Private _filesInit As Boolean = False + Private _objFiles As List(Of FileInfo) + +#End Region + +#Region " Private Properties " + + Private ReadOnly Property ArticleModuleBase() As NewsArticleModuleBase + Get + Return CType(Parent.Parent.Parent.Parent.Parent, NewsArticleModuleBase) + End Get + End Property + + Private ReadOnly Property ArticleSettings() As ArticleSettings + Get + Return ArticleModuleBase.ArticleSettings + End Get + End Property + +#End Region + +#Region " Public Properties " + + Public Property ArticleGuid() As Integer + Get + If (_articleID = Null.NullInteger) Then + If (litArticleGuid.Text = Null.NullString) Then + litArticleGuid.Text = (GetRandom(1, 100000) * -1).ToString() + End If + Return Convert.ToInt32(litArticleGuid.Text) + End If + Return _articleID + End Get + Set(ByVal value As Integer) + litArticleGuid.Text = value + End Set + End Property + + Public ReadOnly Property AttachedFiles() As List(Of FileInfo) + Get + + If (_filesInit = False) Then + '_objFiles = objFileController.GetFileList(_articleID, ArticleGuid) + If (_articleID = Null.NullInteger) Then + _objFiles = FileProvider.Instance().GetFiles(ArticleGuid) + Else + _objFiles = FileProvider.Instance().GetFiles(_articleID) + End If + _filesInit = True + End If + + Return _objFiles + + End Get + End Property + +#End Region + +#Region " Private Methods " + + Private Sub BindFiles() + + dlFiles.DataSource = AttachedFiles + dlFiles.DataBind() + + dlFiles.Visible = (dlFiles.Items.Count > 0) + lblNoFiles.Visible = (dlFiles.Items.Count = 0) + + End Sub + + Private Sub BindFolders() + + Dim ReadRoles As String = Null.NullString + Dim WriteRoles As String = Null.NullString + + drpUploadFilesFolder.Items.Clear() + + Dim folders As ArrayList = FileSystemUtils.GetFolders(ArticleModuleBase.PortalId) + For Each folder As FolderInfo In folders + Dim FolderItem As New ListItem() + If folder.FolderPath = Null.NullString Then + FolderItem.Text = ArticleModuleBase.GetSharedResource("Root") + ReadRoles = FileSystemUtils.GetRoles("", ArticleModuleBase.PortalId, "READ") + WriteRoles = FileSystemUtils.GetRoles("", ArticleModuleBase.PortalId, "WRITE") + Else + FolderItem.Text = folder.FolderPath + ReadRoles = FileSystemUtils.GetRoles(FolderItem.Text, ArticleModuleBase.PortalId, "READ") + WriteRoles = FileSystemUtils.GetRoles(FolderItem.Text, ArticleModuleBase.PortalId, "WRITE") + End If + FolderItem.Value = folder.FolderID + + If PortalSecurity.IsInRoles(ReadRoles) OrElse PortalSecurity.IsInRoles(WriteRoles) Then + drpUploadFilesFolder.Items.Add(FolderItem) + End If + Next + + If (drpUploadFilesFolder.Items.FindByValue(ArticleSettings.DefaultFilesFolder.ToString()) IsNot Nothing) Then + drpUploadFilesFolder.SelectedValue = ArticleSettings.DefaultFilesFolder.ToString() + End If + + End Sub + + Protected Function GetArticleID() As String + + Return _articleID.ToString() + + End Function + + Protected Function GetMaximumFileSize() As String + + Return "20480" + + End Function + + Protected Function GetPostBackReference() As String + + Return Page.ClientScript.GetPostBackEventReference(cmdRefreshFiles, "Refresh") + + End Function + + Private Function GetRandom(ByVal Min As Integer, ByVal Max As Integer) As Integer + Dim Generator As System.Random = New System.Random() + Return Generator.Next(Min, Max) + End Function + + Public Function GetResourceKey(ByVal key As String) As String + + Dim path As String = "~/DesktopModules/DnnForge - NewsArticles/App_LocalResources/UploadFiles.ascx.resx" + Return DotNetNuke.Services.Localization.Localization.GetString(key, path) + + End Function + + Protected Function GetUploadUrl() As String + + Dim link As String = Page.ResolveUrl("~/DesktopModules/DnnForge%20-%20NewsArticles/Controls/SWFUploaderFiles.ashx?PortalID=" & ArticleModuleBase.PortalId.ToString()) + + If (link.ToLower().StartsWith("http")) Then + Return link + Else + If (Request.Url.Port = 80) Then + Return DotNetNuke.Common.AddHTTP(Request.Url.Host & link) + Else + Return DotNetNuke.Common.AddHTTP(Request.Url.Host & ":" & Request.Url.Port.ToString() & link) + End If + End If + + End Function + + Private Sub ReadQueryString() + + If (ArticleSettings.UrlModeType = Components.Types.UrlModeType.Shorterned) Then + Try + If (IsNumeric(Request(ArticleSettings.ShortenedID))) Then + _articleID = Convert.ToInt32(Request(ArticleSettings.ShortenedID)) + End If + Catch + End Try + End If + + If (IsNumeric(Request("ArticleID"))) Then + _articleID = Convert.ToInt32(Request("ArticleID")) + End If + + End Sub + + Private Sub RegisterScripts() + + DotNetNuke.Framework.jQuery.RequestRegistration() + + 'If (HttpContext.Current.Items("jquery_registered") Is Nothing And HttpContext.Current.Items("jQueryRequested") Is Nothing) Then + ' If (HttpContext.Current.Items("PropertyAgent-jQuery-ScriptsRegistered") Is Nothing And HttpContext.Current.Items("SimpleGallery-ScriptsRegistered") Is Nothing And HttpContext.Current.Items("NewsArticles-ScriptsRegistered") Is Nothing) Then + ' Dim objCSS As System.Web.UI.Control = Page.FindControl("CSS") + + ' If Not (objCSS Is Nothing) Then + ' Dim litLink As New Literal + ' litLink.Text = "" & vbCrLf _ + ' & "" & vbCrLf + ' objCSS.Controls.Add(litLink) + ' End If + ' HttpContext.Current.Items.Add("NewsArticles-ScriptsRegistered", "true") + ' End If + 'End If + + End Sub + + Private Sub SetLocalization() + + dshFiles.Text = GetResourceKey("Files") + lblFilesHelp.Text = GetResourceKey("FilesHelp") + + dshExistingFiles.Text = GetResourceKey("SelectExisting") + dshUploadFiles.Text = GetResourceKey("UploadFiles") + dshSelectedFiles.Text = GetResourceKey("SelectedFiles") + + lblNoFiles.Text = GetResourceKey("NoFiles") + + cmdAddExistingFile.Text = GetResourceKey("cmdAddExistingFile") + + End Sub + +#End Region + +#Region " Public Methods " + + Public Sub UpdateFiles(ByVal articleID As Integer) + + For Each objFile As FileInfo In AttachedFiles + objFile.ArticleID = articleID + FileProvider.Instance().UpdateFile(objFile) + ' objFileController.Update(objFile) + Next + + End Sub + +#End Region + +#Region " Event Handlers " + + Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load + + Try + + ReadQueryString() + SetLocalization() + + 'trUpload.Visible = ArticleSettings.EnableImagesUpload + 'trExisting.Visible = ArticleSettings.EnablePortalImages + + 'phFiles.Visible = (trUpload.Visible Or trExisting.Visible) + + If (ArticleSettings.IsFilesEnabled = False) Then + Me.Visible = False + Return + End If + + If (IsPostBack = False) Then + + lblSelectFiles.Text = GetResourceKey("SelectFiles") + litModuleID.Text = Me.ArticleModuleBase.ModuleId.ToString() + litTabModuleID.Text = Me.ArticleModuleBase.TabModuleId.ToString() + + If (Request.IsAuthenticated) Then + litTicketID.Text = Request.Cookies(System.Web.Security.FormsAuthentication.FormsCookieName()).Value + End If + litArticleGuid.Text = ArticleGuid.ToString() + + BindFolders() + BindFiles() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub Page_PreRender(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.PreRender + + Try + + RegisterScripts() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdRefreshPhotos_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdRefreshFiles.Click + + Try + + BindFiles() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + + Private Sub dlFiles_OnItemDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.DataListItemEventArgs) Handles dlFiles.ItemDataBound + + Try + + If (e.Item.ItemType = Web.UI.WebControls.ListItemType.Item Or e.Item.ItemType = Web.UI.WebControls.ListItemType.AlternatingItem) Then + + Dim objFile As FileInfo = CType(e.Item.DataItem, FileInfo) + + Dim btnEdit As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnEdit"), System.Web.UI.WebControls.ImageButton) + Dim btnDelete As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnDelete"), System.Web.UI.WebControls.ImageButton) + Dim btnUp As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnUp"), System.Web.UI.WebControls.ImageButton) + Dim btnDown As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnDown"), System.Web.UI.WebControls.ImageButton) + + If Not (btnDelete Is Nothing) Then + btnDelete.Attributes.Add("onClick", "javascript:return confirm('" & GetResourceKey("DeleteFile") & "');") + + If Not (objFile Is Nothing) Then + btnDelete.CommandArgument = objFile.FileID.ToString() + End If + + End If + + If Not (btnEdit Is Nothing) Then + + If Not (objFile Is Nothing) Then + btnEdit.CommandArgument = objFile.FileID.ToString() + End If + + End If + + If Not (btnUp Is Nothing And btnDown Is Nothing) Then + + If (objFile.FileID = CType(AttachedFiles(0), FileInfo).FileID) Then + btnUp.Visible = False + End If + + If (objFile.FileID = CType(AttachedFiles(AttachedFiles.Count - 1), FileInfo).FileID) Then + btnDown.Visible = False + End If + + btnUp.CommandArgument = objFile.FileID.ToString() + btnUp.CommandName = "Up" + btnUp.CausesValidation = False + + btnDown.CommandArgument = objFile.FileID.ToString() + btnDown.CommandName = "Down" + btnDown.CausesValidation = False + + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub dlFiles_OnItemCommand(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.DataListCommandEventArgs) Handles dlFiles.ItemCommand + + Try + + If (e.CommandName = "Delete") Then + + Dim objFile As FileInfo = FileProvider.Instance().GetFile(Convert.ToInt32(e.CommandArgument)) + + If Not (objFile Is Nothing) Then + 'Dim objPortalSettings As PortalSettings = PortalController.GetCurrentPortalSettings() + 'Dim filePath As String = objPortalSettings.HomeDirectoryMapPath & objFile.Folder & objFile.FileName + 'If (File.Exists(filePath)) Then + ' File.Delete(filePath) + 'End If + FileProvider.Instance().DeleteFile(_articleID, Convert.ToInt32(e.CommandArgument)) + ' objFileController.Delete(Convert.ToInt32(e.CommandArgument)) + End If + + End If + + If (e.CommandName = "Edit") Then + + dlFiles.EditItemIndex = e.Item.ItemIndex + + End If + + If (e.CommandName = "Up") Then + + Dim fileID As Integer = Convert.ToInt32(e.CommandArgument) + + For i As Integer = 0 To AttachedFiles.Count - 1 + Dim objFile As FileInfo = CType(AttachedFiles(i), FileInfo) + If (fileID = objFile.FileID) Then + + Dim objFileToSwap As FileInfo = CType(AttachedFiles(i - 1), FileInfo) + + Dim sortOrder As Integer = objFile.SortOrder + Dim sortOrderPrevious As Integer = objFileToSwap.SortOrder + + objFile.SortOrder = sortOrderPrevious + objFileToSwap.SortOrder = sortOrder + + FileProvider.Instance().UpdateFile(objFile) + FileProvider.Instance().UpdateFile(objFileToSwap) + + End If + Next + + End If + + If (e.CommandName = "Down") Then + + Dim fileID As Integer = Convert.ToInt32(e.CommandArgument) + + For i As Integer = 0 To AttachedFiles.Count - 1 + Dim objFile As FileInfo = CType(AttachedFiles(i), FileInfo) + If (fileID = objFile.FileID) Then + Dim objFileToSwap As FileInfo = CType(AttachedFiles(i + 1), FileInfo) + + Dim sortOrder As Integer = objFile.SortOrder + Dim sortOrderNext As Integer = objFileToSwap.SortOrder + + objFile.SortOrder = sortOrderNext + objFileToSwap.SortOrder = sortOrder + + FileProvider.Instance().UpdateFile(objFile) + FileProvider.Instance().UpdateFile(objFileToSwap) + End If + Next + + End If + + If (e.CommandName = "Cancel") Then + + dlFiles.EditItemIndex = -1 + + End If + + If (e.CommandName = "Update") Then + + Dim txtTitle As TextBox = CType(e.Item.FindControl("txtTitle"), TextBox) + + Dim objFile As FileInfo = FileProvider.Instance().GetFile(Convert.ToInt32(dlFiles.DataKeys(e.Item.ItemIndex))) + + If Not (objFile Is Nothing) Then + objFile.Title = txtTitle.Text + FileProvider.Instance().UpdateFile(objFile) + End If + + dlFiles.EditItemIndex = -1 + + End If + + _filesInit = False + BindFiles() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdAddExistingFile_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdAddExistingFile.Click + + Try + + If (ctlFile.Url <> "") Then + If (ctlFile.Url.ToLower().StartsWith("fileid=")) Then + If (IsNumeric(ctlFile.Url.ToLower().Replace("fileid=", ""))) Then + Dim fileID As Integer = Convert.ToInt32(ctlFile.Url.ToLower().Replace("fileid=", "")) + Dim objDnnFileController As New DotNetNuke.Services.FileSystem.FileController + Dim objDnnFile As DotNetNuke.Services.FileSystem.FileInfo = objDnnFileController.GetFileById(fileID, ArticleModuleBase.PortalId) + If (objDnnFile IsNot Nothing) Then + + Dim objFileController As New FileController + + Dim objFile As New FileInfo + + objFile.ArticleID = _articleID + If (_articleID = Null.NullInteger) Then + objFile.ArticleID = ArticleGuid + End If + objFile.FileName = objDnnFile.FileName + objFile.ContentType = objDnnFile.ContentType + objFile.SortOrder = 0 + Dim filesList As List(Of FileInfo) = objFileController.GetFileList(_articleID, ArticleGuid) + If (filesList.Count > 0) Then + objFile.SortOrder = CType(filesList(filesList.Count - 1), FileInfo).SortOrder + 1 + End If + objFile.Folder = objDnnFile.Folder + objFile.Extension = objDnnFile.Extension + objFile.Size = objDnnFile.Size + objFile.Title = objFile.FileName.Replace("." & objFile.Extension, "") + + objFileController.Add(objFile) + BindFiles() + + End If + End If + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Controls/UploadImages.ascx b/Controls/UploadImages.ascx new file mode 100755 index 0000000..109b0ea --- /dev/null +++ b/Controls/UploadImages.ascx @@ -0,0 +1,197 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="UploadImages.ascx.vb" Inherits="Ventrian.NewsArticles.Controls.UploadImages" %> +<%@ Register TagPrefix="Ventrian" Assembly="Ventrian.NewsArticles" Namespace="Ventrian.NewsArticles.Components.WebControls" %> + +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="URL" Src="~/controls/URLControl.ascx" %> + + +
+ + + + + + + + + +
+
+ + + + + + +
+ + + + + + + + + +
 
+ +
+
+ +
+
+
+
+
+ + + + + +
+ + + + + +

 
+
+
+
+ + + + + +
+ + + + Photo
+ + <%#DataBinder.Eval(Container.DataItem, "Title")%> + +
+ + + + + + +
+ + Photo
+ +
+ +
+ + +
+
+
+
+
+ +
+ + + + + + +
+
+
+ + diff --git a/Controls/UploadImages.ascx.designer.vb b/Controls/UploadImages.ascx.designer.vb new file mode 100755 index 0000000..d3bcf32 --- /dev/null +++ b/Controls/UploadImages.ascx.designer.vb @@ -0,0 +1,277 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class UploadImages + + ''' + '''litModuleID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litModuleID As Global.System.Web.UI.WebControls.Literal + + ''' + '''litTabModuleID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litTabModuleID As Global.System.Web.UI.WebControls.Literal + + ''' + '''litTicketID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litTicketID As Global.System.Web.UI.WebControls.Literal + + ''' + '''litArticleGuid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litArticleGuid As Global.System.Web.UI.WebControls.Literal + + ''' + '''lblSelectImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSelectImages As Global.System.Web.UI.WebControls.Label + + ''' + '''dshImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshImages As DotNetNuke.UI.UserControls.SectionHeadControl + + ''' + '''tblImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblImages As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblImagesHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblImagesHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''phImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phImages As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''trUpload control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trUpload As Global.System.Web.UI.HtmlControls.HtmlTableCell + + ''' + '''dshUploadImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshUploadImages As DotNetNuke.UI.UserControls.SectionHeadControl + + ''' + '''tblUploadImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblUploadImages As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plFolder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plFolder As Global.System.Web.UI.UserControl + + ''' + '''drpUploadImageFolder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpUploadImageFolder As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''trExisting control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trExisting As Global.System.Web.UI.HtmlControls.HtmlTableCell + + ''' + '''dshExistingImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshExistingImages As DotNetNuke.UI.UserControls.SectionHeadControl + + ''' + '''tblExistingImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblExistingImages As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''ctlImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ctlImage As DotNetNuke.UI.UserControls.UrlControl + ''' + '''cmdAddExistingImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdAddExistingImage As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''dshSelectedImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshSelectedImages As DotNetNuke.UI.UserControls.SectionHeadControl + + ''' + '''tblSelectedImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSelectedImages As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''dlImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dlImages As Global.System.Web.UI.WebControls.DataList + + ''' + '''lblNoImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoImages As Global.System.Web.UI.WebControls.Label + + ''' + '''phExternalImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phExternalImage As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshExternalImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshExternalImage As DotNetNuke.UI.UserControls.SectionHeadControl + + ''' + '''tblExternalImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblExternalImage As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plImageUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plImageUrl As Global.System.Web.UI.UserControl + + ''' + '''txtImageExternal control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtImageExternal As Global.System.Web.UI.WebControls.TextBox + + ''' + '''cmdRefreshPhotos control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdRefreshPhotos As Global.Ventrian.NewsArticles.Components.WebControls.RefreshControl + End Class +End Namespace diff --git a/Controls/UploadImages.ascx.vb b/Controls/UploadImages.ascx.vb new file mode 100755 index 0000000..223b4ae --- /dev/null +++ b/Controls/UploadImages.ascx.vb @@ -0,0 +1,606 @@ +Imports System.IO + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization +Imports DotNetNuke.Services.FileSystem +Imports DotNetNuke.Security + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles.Controls + + Partial Public Class UploadImages + Inherits NewsArticleControlBase + +#Region " Private Members " + + Private _articleID As Integer = Null.NullInteger + + Private _imagesInit As Boolean = False + Private _objImages As List(Of ImageInfo) + +#End Region + +#Region " Private Properties " + + Private ReadOnly Property ArticleModuleBase() As NewsArticleModuleBase + Get + Return CType(Parent.Parent.Parent.Parent.Parent, NewsArticleModuleBase) + End Get + End Property + + Private ReadOnly Property ArticleSettings() As ArticleSettings + Get + Return ArticleModuleBase.ArticleSettings + End Get + End Property + +#End Region + +#Region " Public Properties " + + Public Property ArticleGuid() As String + Get + If (_articleID = Null.NullInteger) Then + If (litArticleGuid.Text = Null.NullString) Then + litArticleGuid.Text = Guid.NewGuid.ToString() + End If + End If + Return litArticleGuid.Text + End Get + Set(ByVal value As String) + litArticleGuid.Text = value + End Set + End Property + + Public ReadOnly Property AttachedImages() As List(Of ImageInfo) + Get + + If (_imagesInit = False) Then + Dim objImageController As New ImageController + _objImages = objImageController.GetImageList(_articleID, ArticleGuid) + _imagesInit = True + End If + + Return _objImages + + End Get + End Property + + Public Property ImageExternalUrl() As String + Get + Return txtImageExternal.Text + End Get + Set(ByVal value As String) + txtImageExternal.Text = value + End Set + End Property + +#End Region + +#Region " Private Methods " + + Private Sub BindFolders() + + Dim ReadRoles As String = Null.NullString + Dim WriteRoles As String = Null.NullString + + drpUploadImageFolder.Items.Clear() + + Dim folders As ArrayList = FileSystemUtils.GetFolders(ArticleModuleBase.PortalId) + For Each folder As FolderInfo In folders + Dim FolderItem As New ListItem() + If folder.FolderPath = Null.NullString Then + FolderItem.Text = ArticleModuleBase.GetSharedResource("Root") + ReadRoles = FileSystemUtils.GetRoles("", ArticleModuleBase.PortalId, "READ") + WriteRoles = FileSystemUtils.GetRoles("", ArticleModuleBase.PortalId, "WRITE") + Else + FolderItem.Text = folder.FolderPath + ReadRoles = FileSystemUtils.GetRoles(FolderItem.Text, ArticleModuleBase.PortalId, "READ") + WriteRoles = FileSystemUtils.GetRoles(FolderItem.Text, ArticleModuleBase.PortalId, "WRITE") + End If + FolderItem.Value = folder.FolderID + + If PortalSecurity.IsInRoles(ReadRoles) OrElse PortalSecurity.IsInRoles(WriteRoles) Then + drpUploadImageFolder.Items.Add(FolderItem) + End If + Next + + If (drpUploadImageFolder.Items.FindByValue(ArticleSettings.DefaultImagesFolder.ToString()) IsNot Nothing) Then + drpUploadImageFolder.SelectedValue = ArticleSettings.DefaultImagesFolder.ToString() + End If + + End Sub + + Private Sub BindImages() + + Dim objImageController As New ImageController() + + dlImages.DataSource = AttachedImages + dlImages.DataBind() + + dlImages.Visible = (dlImages.Items.Count > 0) + lblNoImages.Visible = (dlImages.Items.Count = 0) + + End Sub + + Protected Function GetArticleID() As String + + Return _articleID.ToString() + + End Function + + Protected Function GetImageUrl(ByVal objImage As ImageInfo) As String + + Dim thumbWidth As Integer = 150 + Dim thumbHeight As Integer = 150 + + Dim width As Integer + If (objImage.Width > thumbWidth) Then + width = thumbWidth + Else + width = objImage.Width + End If + + Dim height As Integer = Convert.ToInt32(objImage.Height / (objImage.Width / width)) + If (height > thumbHeight) Then + height = thumbHeight + width = Convert.ToInt32(objImage.Width / (objImage.Height / height)) + End If + + Dim settings As PortalSettings = PortalController.GetCurrentPortalSettings() + + Return Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(settings.HomeDirectory) & "&FileName=" & Server.UrlEncode(objImage.Folder & objImage.FileName) & "&PortalID=" & settings.PortalId.ToString() & "&q=1") + + End Function + + Protected Function GetMaximumFileSize() As String + + Return "20480" + + End Function + + Protected Function GetPostBackReference() As String + + Return Page.ClientScript.GetPostBackEventReference(cmdRefreshPhotos, "Refresh") + + End Function + + Public Function GetResourceKey(ByVal key As String) As String + + Dim path As String = "~/DesktopModules/DnnForge - NewsArticles/App_LocalResources/UploadImages.ascx.resx" + Return DotNetNuke.Services.Localization.Localization.GetString(key, path) + + End Function + + Protected Function GetUploadUrl() As String + + Dim link As String = Page.ResolveUrl("~/DesktopModules/DnnForge%20-%20NewsArticles/Controls/SWFUploader.ashx?PortalID=" & ArticleModuleBase.PortalId.ToString()) + + If (link.ToLower().StartsWith("http")) Then + Return link + Else + If (Request.Url.Port = 80) Then + Return DotNetNuke.Common.AddHTTP(Request.Url.Host & link) + Else + Return DotNetNuke.Common.AddHTTP(Request.Url.Host & ":" & Request.Url.Port.ToString() & link) + End If + End If + + End Function + + Private Sub ReadQueryString() + + If (ArticleSettings.UrlModeType = Components.Types.UrlModeType.Shorterned) Then + Try + If (IsNumeric(Request(ArticleSettings.ShortenedID))) Then + _articleID = Convert.ToInt32(Request(ArticleSettings.ShortenedID)) + End If + Catch + End Try + End If + + If (IsNumeric(Request("ArticleID"))) Then + _articleID = Convert.ToInt32(Request("ArticleID")) + End If + + End Sub + + Private Sub RegisterScripts() + + DotNetNuke.Framework.jQuery.RequestRegistration() + + 'If (HttpContext.Current.Items("jquery_registered") Is Nothing And HttpContext.Current.Items("jQueryRequested") Is Nothing) Then + ' If (HttpContext.Current.Items("PropertyAgent-jQuery-ScriptsRegistered") Is Nothing And HttpContext.Current.Items("SimpleGallery-ScriptsRegistered") Is Nothing And HttpContext.Current.Items("NewsArticles-ScriptsRegistered") Is Nothing) Then + ' Dim objCSS As System.Web.UI.Control = Page.FindControl("CSS") + + ' If Not (objCSS Is Nothing) Then + ' Dim litLink As New Literal + ' litLink.Text = "" & vbCrLf _ + ' & "" & vbCrLf + ' If (HttpContext.Current.Items("NewsArticles-ScriptsRegistered") IsNot Nothing) Then + ' objCSS.Controls.Add(litLink) + ' End If + ' End If + ' If (HttpContext.Current.Items("NewsArticles-ScriptsRegistered") IsNot Nothing) Then + ' HttpContext.Current.Items.Add("NewsArticles-ScriptsRegistered", "true") + ' End If + ' End If + 'End If + + End Sub + + Private Sub SetLocalization() + + dshImages.Text = GetResourceKey("Images") + lblImagesHelp.Text = GetResourceKey("ImagesHelp") + + dshExistingImages.Text = GetResourceKey("SelectExisting") + dshUploadImages.Text = GetResourceKey("UploadImages") + dshSelectedImages.Text = GetResourceKey("SelectedImages") + dshExternalImage.Text = GetResourceKey("ExternalImage") + + lblNoImages.Text = GetResourceKey("NoImages") + + End Sub + +#End Region + +#Region " Public Methods " + + Public Sub UpdateImages(ByVal articleID As Integer) + + Dim objImageController As New ImageController + For Each objImage As ImageInfo In AttachedImages + objImage.ArticleID = articleID + objImageController.Update(objImage) + Next + + End Sub + +#End Region + +#Region " Event Handlers " + + Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load + + Try + + ReadQueryString() + SetLocalization() + + trUpload.Visible = ArticleSettings.EnableImagesUpload + trExisting.Visible = ArticleSettings.EnablePortalImages + + phImages.Visible = (trUpload.Visible Or trExisting.Visible) + + phExternalImage.Visible = ArticleSettings.EnableExternalImages + + If (ArticleSettings.IsImagesEnabled = False Or (trUpload.Visible = False And trExisting.Visible = False And phExternalImage.Visible = False)) Then + Me.Visible = False + Return + End If + + If (IsPostBack = False) Then + lblSelectImages.Text = GetResourceKey("SelectImages") + litModuleID.Text = Me.ArticleModuleBase.ModuleId.ToString() + litTabModuleID.Text = Me.ArticleModuleBase.TabModuleId.ToString() + + If (Request.IsAuthenticated) Then + litTicketID.Text = Request.Cookies(System.Web.Security.FormsAuthentication.FormsCookieName()).Value + End If + litArticleGuid.Text = ArticleGuid.ToString() + + BindFolders() + BindImages() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub Page_PreRender(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.PreRender + + Try + + RegisterScripts() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdRefreshPhotos_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdRefreshPhotos.Click + + Try + + BindImages() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + + Private Sub dlImages_OnItemDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.DataListItemEventArgs) Handles dlImages.ItemDataBound + + Try + + If (e.Item.ItemType = Web.UI.WebControls.ListItemType.Item Or e.Item.ItemType = Web.UI.WebControls.ListItemType.AlternatingItem) Then + + Dim objImage As ImageInfo = CType(e.Item.DataItem, ImageInfo) + + Dim btnEdit As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnEdit"), System.Web.UI.WebControls.ImageButton) + Dim btnDelete As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnDelete"), System.Web.UI.WebControls.ImageButton) + Dim btnTop As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnTop"), System.Web.UI.WebControls.ImageButton) + Dim btnUp As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnUp"), System.Web.UI.WebControls.ImageButton) + Dim btnDown As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnDown"), System.Web.UI.WebControls.ImageButton) + Dim btnBottom As System.Web.UI.WebControls.ImageButton = CType(e.Item.FindControl("btnBottom"), System.Web.UI.WebControls.ImageButton) + + If Not (btnDelete Is Nothing) Then + btnDelete.Attributes.Add("onClick", "javascript:return confirm('" & GetResourceKey("DeleteImage") & "');") + + If Not (objImage Is Nothing) Then + btnDelete.CommandArgument = objImage.ImageID.ToString() + End If + + End If + + If Not (btnEdit Is Nothing) Then + + If Not (objImage Is Nothing) Then + btnEdit.CommandArgument = objImage.ImageID.ToString() + End If + + End If + + If Not (btnUp Is Nothing And btnDown Is Nothing) Then + + If (objImage.ImageID = CType(AttachedImages(0), ImageInfo).ImageID) Then + btnUp.Visible = False + btnTop.Visible = False + End If + + If (objImage.ImageID = CType(AttachedImages(AttachedImages.Count - 1), ImageInfo).ImageID) Then + btnDown.Visible = False + btnBottom.Visible = False + End If + + btnTop.CommandArgument = objImage.ImageID.ToString() + btnTop.CommandName = "Top" + btnTop.CausesValidation = False + + btnUp.CommandArgument = objImage.ImageID.ToString() + btnUp.CommandName = "Up" + btnUp.CausesValidation = False + + btnDown.CommandArgument = objImage.ImageID.ToString() + btnDown.CommandName = "Down" + btnDown.CausesValidation = False + + btnBottom.CommandArgument = objImage.ImageID.ToString() + btnBottom.CommandName = "Bottom" + btnBottom.CausesValidation = False + + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub dlImages_OnItemCommand(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.DataListCommandEventArgs) Handles dlImages.ItemCommand + + Try + + Dim objImageController As New ImageController + + If (e.CommandName = "Delete") Then + + Dim objImage As ImageInfo = objImageController.Get(Convert.ToInt32(e.CommandArgument)) + + If Not (objImage Is Nothing) Then + objImageController.Delete(Convert.ToInt32(e.CommandArgument), _articleID, objImage.ImageGuid) + End If + + End If + + If (e.CommandName = "Edit") Then + + dlImages.EditItemIndex = e.Item.ItemIndex + + End If + + If (e.CommandName = "Top") Then + + Dim imageID As Integer = Convert.ToInt32(e.CommandArgument) + + Dim objImagesSorted As New List(Of ImageInfo) + + For i As Integer = 0 To AttachedImages.Count - 1 + Dim objImage As ImageInfo = CType(AttachedImages(i), ImageInfo) + If (imageID = objImage.ImageID) Then + objImagesSorted.Insert(0, objImage) + Else + objImagesSorted.Add(objImage) + End If + Next + + Dim sortOrder As Integer = 0 + For Each objImage As ImageInfo In objImagesSorted + objImage.SortOrder = sortOrder + objImageController.Update(objImage) + sortOrder = sortOrder + 1 + Next + + End If + + If (e.CommandName = "Up") Then + + Dim imageID As Integer = Convert.ToInt32(e.CommandArgument) + + For i As Integer = 0 To AttachedImages.Count - 1 + Dim objImage As ImageInfo = CType(AttachedImages(i), ImageInfo) + If (imageID = objImage.ImageID) Then + + Dim objImageToSwap As ImageInfo = CType(AttachedImages(i - 1), ImageInfo) + + Dim sortOrder As Integer = objImage.SortOrder + Dim sortOrderPrevious As Integer = objImageToSwap.SortOrder + + objImage.SortOrder = sortOrderPrevious + objImageToSwap.SortOrder = sortOrder + + objImageController.Update(objImage) + objImageController.Update(objImageToSwap) + + End If + Next + + End If + + If (e.CommandName = "Down") Then + + Dim imageID As Integer = Convert.ToInt32(e.CommandArgument) + + For i As Integer = 0 To AttachedImages.Count - 1 + Dim objImage As ImageInfo = CType(AttachedImages(i), ImageInfo) + If (imageID = objImage.ImageID) Then + Dim objImageToSwap As ImageInfo = CType(AttachedImages(i + 1), ImageInfo) + + Dim sortOrder As Integer = objImage.SortOrder + Dim sortOrderNext As Integer = objImageToSwap.SortOrder + + objImage.SortOrder = sortOrderNext + objImageToSwap.SortOrder = sortOrder + + objImageController.Update(objImage) + objImageController.Update(objImageToSwap) + End If + Next + + End If + + If (e.CommandName = "Bottom") Then + + Dim imageID As Integer = Convert.ToInt32(e.CommandArgument) + + Dim objImageEnd As ImageInfo = Nothing + Dim objImagesSorted As New List(Of ImageInfo) + + For i As Integer = 0 To AttachedImages.Count - 1 + Dim objImage As ImageInfo = CType(AttachedImages(i), ImageInfo) + If (imageID = objImage.ImageID) Then + objImageEnd = objImage + Else + objImagesSorted.Add(objImage) + End If + Next + + If (objImageEnd IsNot Nothing) Then + objImagesSorted.Add(objImageEnd) + + Dim sortOrder As Integer = 0 + For Each objImage As ImageInfo In objImagesSorted + objImage.SortOrder = sortOrder + objImageController.Update(objImage) + sortOrder = sortOrder + 1 + Next + End If + + End If + + If (e.CommandName = "Cancel") Then + + dlImages.EditItemIndex = -1 + + End If + + If (e.CommandName = "Update") Then + + Dim txtTitle As TextBox = CType(e.Item.FindControl("txtTitle"), TextBox) + Dim txtDescription As TextBox = CType(e.Item.FindControl("txtDescription"), TextBox) + + Dim objImage As ImageInfo = objImageController.Get(Convert.ToInt32(dlImages.DataKeys(e.Item.ItemIndex))) + + If Not (objImage Is Nothing) Then + objImage.Title = txtTitle.Text + objImage.Description = txtDescription.Text + objImageController.Update(objImage) + End If + + dlImages.EditItemIndex = -1 + + End If + + _imagesInit = False + BindImages() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdAddExistingImage_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdAddExistingImage.Click + + Try + + If (ctlImage.Url <> "") Then + If (ctlImage.Url.ToLower().StartsWith("fileid=")) Then + If (IsNumeric(ctlImage.Url.ToLower().Replace("fileid=", ""))) Then + Dim fileID As Integer = Convert.ToInt32(ctlImage.Url.ToLower().Replace("fileid=", "")) + Dim objFileController As New DotNetNuke.Services.FileSystem.FileController + Dim objFile As DotNetNuke.Services.FileSystem.FileInfo = objFileController.GetFileById(fileID, ArticleModuleBase.PortalId) + If (objFile IsNot Nothing) Then + + Dim objImageController As New ImageController + Dim objImage As New ImageInfo + + objImage.ArticleID = _articleID + If (_articleID = Null.NullInteger) Then + objImage.ImageGuid = ArticleGuid + End If + objImage.FileName = objFile.FileName + objImage.ContentType = objFile.ContentType + objImage.Width = objFile.Width + objImage.Height = objFile.Height + objImage.SortOrder = 0 + Dim imagesList As List(Of ImageInfo) = objImageController.GetImageList(_articleID, ArticleGuid) + If (imagesList.Count > 0) Then + objImage.SortOrder = CType(imagesList(imagesList.Count - 1), ImageInfo).SortOrder + 1 + End If + objImage.Folder = objFile.Folder + objImage.Extension = objFile.Extension + objImage.Title = objFile.FileName.Replace("." & objImage.Extension, "") + objImage.Size = objFile.Size + objImage.Description = "" + + objImageController.Add(objImage) + BindImages() + + End If + End If + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ImageHandler.ashx b/ImageHandler.ashx new file mode 100755 index 0000000..853aea5 --- /dev/null +++ b/ImageHandler.ashx @@ -0,0 +1 @@ +<%@ WebHandler Language="VB" CodeBehind="ImageHandler.ashx.vb" Class="Ventrian.NewsArticles.ImageHandler" %> diff --git a/ImageHandler.ashx.vb b/ImageHandler.ashx.vb new file mode 100755 index 0000000..713c9f8 --- /dev/null +++ b/ImageHandler.ashx.vb @@ -0,0 +1,264 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities + +Imports System.Drawing +Imports System.Drawing.Drawing2d +Imports System.Drawing.Imaging +Imports System.Web +Imports System.Web.Services +Imports Ventrian.ImageResizer +Imports System.IO + +Namespace Ventrian.NewsArticles + + Public Class ImageHandler + Implements System.Web.IHttpHandler + +#Region " Private Members " + + Private _width As Integer = ArticleConstants.DEFAULT_THUMBNAIL_WIDTH + Private _height As Integer = ArticleConstants.DEFAULT_THUMBNAIL_HEIGHT + Private _homeDirectory As String = Null.NullString + Private _fileName As String = Null.NullString + Private _quality As Boolean = False + Private _cropped As Boolean = False + +#End Region + +#Region " Private Methods " + + Private Function GetPhotoHeight(ByVal objPhoto As Image) As Integer + + Dim width As Integer + If (objPhoto.Width > _width) Then + width = _width + Else + width = objPhoto.Width + End If + + Dim height As Integer = Convert.ToInt32(objPhoto.Height / (objPhoto.Width / width)) + If (height > _height) Then + height = _height + width = Convert.ToInt32(objPhoto.Width / (objPhoto.Height / height)) + End If + + Return height + + End Function + + Private Function GetPhotoWidth(ByVal objPhoto As Image) As Integer + + Dim width As Integer + + If (objPhoto.Width > _width) Then + width = _width + Else + width = objPhoto.Width + End If + + Dim height As Integer = Convert.ToInt32(objPhoto.Height / (objPhoto.Width / width)) + If (height > _height) Then + height = _height + width = Convert.ToInt32(objPhoto.Width / (objPhoto.Height / height)) + End If + + Return width + + End Function + + Private Sub ReadQueryString(ByVal context As HttpContext) + + If Not (context.Request("Width") Is Nothing) Then + If (IsNumeric(context.Request("Width"))) Then + _width = Convert.ToInt32(context.Request("Width")) + End If + End If + + If Not (context.Request("Height") Is Nothing) Then + If (IsNumeric(context.Request("Height"))) Then + _height = Convert.ToInt32(context.Request("Height")) + End If + End If + + If Not (context.Request("HomeDirectory") Is Nothing) Then + _homeDirectory = context.Server.UrlDecode(context.Request("HomeDirectory")) + End If + + If Not (context.Request("FileName") Is Nothing) Then + _fileName = context.Server.UrlDecode(context.Request("FileName")) + End If + + If Not (context.Request("Q") Is Nothing) Then + If (context.Request("Q") = "1") Then + _quality = True + End If + End If + + If Not (context.Request("S") Is Nothing) Then + If (context.Request("S") = "1") Then + _cropped = True + End If + End If + + End Sub + +#End Region + +#Region " Properties " + + Public ReadOnly Property IsReusable() As Boolean Implements IHttpHandler.IsReusable + Get + Return True + End Get + End Property + +#End Region + +#Region " Event Handlers " + + Public Sub ProcessRequest(ByVal context As HttpContext) Implements IHttpHandler.ProcessRequest + + ' Set up the response settings + context.Response.ContentType = "image/jpeg" + + ' Caching + context.Response.Cache.SetCacheability(HttpCacheability.Public) + context.Response.Cache.SetExpires(DateTime.Now.AddDays(30)) + context.Response.Cache.VaryByParams("FileName") = True + context.Response.Cache.VaryByParams("HomeDirectory") = True + context.Response.Cache.VaryByParams("Width") = True + context.Response.Cache.VaryByParams("Height") = True + context.Response.Cache.VaryByParams("s") = True + context.Response.Cache.AppendCacheExtension("max-age=86400") + + ReadQueryString(context) + + Dim path As String = "" + If _fileName = "placeholder-600.jpg" Then + path = "Images/placeholder-600.jpg" + Else + path = _homeDirectory & "/" & _fileName + End If + + context.Items.Add("httpcompress.attemptedinstall", "true") + + If Not (System.IO.File.Exists(context.Server.MapPath(path))) Then + path = path & ".resources" + If Not (System.IO.File.Exists(context.Server.MapPath(path))) Then + Return + End If + End If + + If (_cropped = False) Then + Dim photo As Image = Image.FromFile(context.Server.MapPath(path)) + + Dim width As Integer = GetPhotoWidth(photo) + Dim height As Integer = GetPhotoHeight(photo) + + photo.Dispose() + + _width = width + _height = height + + End If + + Dim objQueryString As New NameValueCollection() + + For Each key As String In context.Request.QueryString.Keys + Dim values() As String = context.Request.QueryString.GetValues(key) + For Each value As String In values + + If (key.ToLower() = "width" Or key.ToLower() = "height") Then + If (key.ToLower() = "width") Then + objQueryString.Add("maxwidth", _width.ToString()) + objQueryString.Add(key, _width.ToString()) + End If + If (key.ToLower() = "height") Then + objQueryString.Add("maxheight", _height.ToString()) + objQueryString.Add(key, _height.ToString()) + End If + Else + objQueryString.Add(key, value) + End If + Next + Next + + If (_cropped) Then + objQueryString.Add("crop", "auto") + End If + + Dim objImage As Bitmap = ImageManager.getBestInstance().BuildImage(context.Server.MapPath(path), objQueryString, New WatermarkSettings(objQueryString)) + If (path.ToLower().EndsWith("jpg")) Then + objImage.Save(context.Response.OutputStream, ImageFormat.Jpeg) + Else + If (path.ToLower().EndsWith("gif")) Then + context.Response.ContentType = "image/gif" + Dim ios As ImageOutputSettings = New ImageOutputSettings(ImageOutputSettings.GetImageFormatFromPhysicalPath(context.Server.MapPath(path)), objQueryString) + ios.SaveImage(context.Response.OutputStream, objImage) + Else + If (path.ToLower().EndsWith("png")) Then + Dim objMemoryStream As New MemoryStream() + context.Response.ContentType = "image/png" + objImage.Save(objMemoryStream, ImageFormat.Png) + objMemoryStream.WriteTo(context.Response.OutputStream) + Else + objImage.Save(context.Response.OutputStream, ImageFormat.Jpeg) + End If + End If + End If + + 'Dim photo As Image = Image.FromFile(context.Server.MapPath(path)) + + 'Dim width As Integer = GetPhotoWidth(photo) + 'Dim height As Integer = GetPhotoHeight(photo) + + 'Dim bmp As New Bitmap(width, height) + 'Dim g As Graphics = Graphics.FromImage(DirectCast(bmp, Image)) + + 'If (_quality) Then + ' g.InterpolationMode = InterpolationMode.HighQualityBicubic + ' g.SmoothingMode = SmoothingMode.HighQuality + ' g.PixelOffsetMode = PixelOffsetMode.HighQuality + ' g.CompositingQuality = CompositingQuality.HighQuality + 'End If + + 'g.FillRectangle(Brushes.White, 0, 0, width, height) + 'g.DrawImage(photo, 0, 0, width, height) + + 'photo.Dispose() + + 'If (_quality) Then + ' Dim info As ImageCodecInfo() = ImageCodecInfo.GetImageEncoders() + ' Dim params As New EncoderParameters + ' params.Param(0) = New EncoderParameter(Encoder.Quality, 90L) + ' bmp.Save(context.Response.OutputStream, info(1), params) + ' bmp.Dispose() + 'Else + ' bmp.Save(context.Response.OutputStream, Imaging.ImageFormat.Jpeg) + 'End If + + End Sub + + Public Shared Function GetEncoderInfo(ByVal mimeType As String) As ImageCodecInfo + Dim codecs() As ImageCodecInfo = ImageCodecInfo.GetImageEncoders() + + Dim i As Integer + For i = 0 To codecs.Length - 1 Step i + 1 + If codecs(i).MimeType = mimeType Then + Return codecs(i) + End If + Next + + Return Nothing + End Function + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Images/Admin/Categories.gif b/Images/Admin/Categories.gif new file mode 100755 index 0000000000000000000000000000000000000000..60269f41b4de73278cde7c33dfd123e89c1c0066 GIT binary patch literal 1144 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 literal 0 HcmV?d00001 diff --git a/Images/Includes/Handout.xml b/Images/Includes/Handout.xml new file mode 100755 index 0000000..f56407f --- /dev/null +++ b/Images/Includes/Handout.xml @@ -0,0 +1,15 @@ + + + PDF Handout Title + My Handout Description + +
+ Easy Freezy Vanilla Ice Cream + Detail +
+
+ Test Title 2 + Detail 2 +
+
+
\ No newline at end of file diff --git a/Images/Includes/Handout.xsd b/Images/Includes/Handout.xsd new file mode 100755 index 0000000..52d59bf --- /dev/null +++ b/Images/Includes/Handout.xsd @@ -0,0 +1,31 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Images/Includes/IIK.sps b/Images/Includes/IIK.sps new file mode 100755 index 0000000..51c6071 --- /dev/null +++ b/Images/Includes/IIK.sps @@ -0,0 +1 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + News Articles Latest + Allows you to display a list of the latest articles. + + + Scott McCulloch + Ventrian + www.ventrian.com + support@ventrian.com + + The license for this package is not currently included within the installation file, please check with the vendor for full license details. + This package has no Release Notes + + + + DnnForge - LatestArticles + DnnForge - LatestArticles + Ventrian.NewsArticles.LatestArticleController, Ventrian.NewsArticles + + + + DnnForge - LatestArticles + 0 + + + + DesktopModules/DnnForge - LatestArticles/LatestArticles.ascx + False + + View + + + False + 0 + + + Settings + DesktopModules/DnnForge - LatestArticles/LatestArticlesOptions.ascx + False + Latest Articles Options + Edit + + + False + 0 + + + + + + + + + DesktopModules/DnnForge - LatestArticles + + ResourcesLatestArticles.zip + + + + + + + News Articles Comments + Allows you to display a list of the latest comments. + + + Scott McCulloch + Ventrian + www.ventrian.com + support@ventrian.com + + The license for this package is not currently included within the installation file, please check with the vendor for full license details. + This package has no Release Notes + + + + DnnForge - LatestComments + DnnForge - LatestComments + + + + + DnnForge - LatestComments + 0 + + + + DesktopModules/DnnForge - LatestComments/LatestComments.ascx + False + + View + + + False + 0 + + + Settings + DesktopModules/DnnForge - LatestComments/LatestCommentsOptions.ascx + False + Latest Comments Options + Edit + + + False + 0 + + + + + + + + + DesktopModules/DnnForge - LatestComments + + ResourcesLatestComments.zip + + + + + + + News Articles Archives + Allows you to display a list of articles by month. + + + Scott McCulloch + Ventrian + www.ventrian.com + support@ventrian.com + + The license for this package is not currently included within the installation file, please check with the vendor for full license details. + This package has no Release Notes + + + + DnnForge - NewsArchives + DnnForge - NewsArchives + + + + + DnnForge - NewsArchives + 0 + + + + DesktopModules/DnnForge - NewsArchives/NewsArchives.ascx + False + + View + + + False + 0 + + + Settings + DesktopModules/DnnForge - NewsArchives/NewsArchivesOptions.ascx + False + News Archive Options + Edit + + + False + 0 + + + + + + + + + DesktopModules/DnnForge - NewsArchives + + ResourcesNewsArchives.zip + + + + + + + News Articles Search + Allows you to display a list of articles by month. + + + Scott McCulloch + Ventrian + www.ventrian.com + support@ventrian.com + + The license for this package is not currently included within the installation file, please check with the vendor for full license details. + This package has no Release Notes + + + + DnnForge - NewsSearch + DnnForge - NewsSearch + + + + + DnnForge - NewsSearch + 0 + + + + DesktopModules/DnnForge - NewsSearch/NewsSearch.ascx + False + + View + + + False + 0 + + + Settings + DesktopModules/DnnForge - NewsSearch/NewsSearchOptions.ascx + False + News Search Options + Edit + + + False + 0 + + + + + + + + + DesktopModules/DnnForge - NewsSearch + + ResourcesNewsSearch.zip + + + + + + + diff --git a/NewsSearch.ascx b/NewsSearch.ascx new file mode 100755 index 0000000..719b468 --- /dev/null +++ b/NewsSearch.ascx @@ -0,0 +1,11 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="NewsSearch.ascx.vb" Inherits="Ventrian.NewsArticles.NewsSearch" %> + + +
+ + + + +
+
diff --git a/NewsSearch.ascx.designer.vb b/NewsSearch.ascx.designer.vb new file mode 100755 index 0000000..b52716b --- /dev/null +++ b/NewsSearch.ascx.designer.vb @@ -0,0 +1,62 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class NewsSearch + + ''' + '''lblNotConfigured control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNotConfigured As Global.System.Web.UI.WebControls.Label + + ''' + '''phSearchForm control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phSearchForm As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''pnlSearch control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSearch As Global.System.Web.UI.WebControls.Panel + + ''' + '''txtSearch control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtSearch As Global.System.Web.UI.WebControls.TextBox + + ''' + '''btnSearch control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents btnSearch As Global.System.Web.UI.WebControls.Button + End Class +End Namespace diff --git a/NewsSearch.ascx.vb b/NewsSearch.ascx.vb new file mode 100755 index 0000000..e7c5edf --- /dev/null +++ b/NewsSearch.ascx.vb @@ -0,0 +1,104 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2009 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class NewsSearch + Inherits NewsArticleModuleBase + +#Region " Constants " + + Private Const PARAM_SEARCH_ID As String = "Search" + +#End Region + +#Region " Private Members " + + Private _articleTabID As Integer = Null.NullInteger + Private _articleModuleID As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Function FindSettings() As Boolean + + If (Settings.Contains(ArticleConstants.NEWS_SEARCH_TAB_ID)) Then + If (IsNumeric(Settings(ArticleConstants.NEWS_SEARCH_TAB_ID).ToString())) Then + _articleTabID = Convert.ToInt32(Settings(ArticleConstants.NEWS_SEARCH_TAB_ID).ToString()) + End If + End If + + If (Settings.Contains(ArticleConstants.NEWS_SEARCH_MODULE_ID)) Then + If (IsNumeric(Settings(ArticleConstants.NEWS_SEARCH_MODULE_ID).ToString())) Then + _articleModuleID = Convert.ToInt32(Settings(ArticleConstants.NEWS_SEARCH_MODULE_ID).ToString()) + If (_articleModuleID <> Null.NullInteger) Then + Return True + End If + End If + End If + + Return False + + End Function + + Private Sub ReadQueryString() + + If (Request(PARAM_SEARCH_ID) <> "") Then + txtSearch.Text = Server.UrlDecode(Request(PARAM_SEARCH_ID)) + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load + + Try + If (IsPostBack = False) Then + ReadQueryString() + End If + + If (FindSettings()) Then + phSearchForm.Visible = True + lblNotConfigured.Visible = False + Else + lblNotConfigured.Visible = True + phSearchForm.Visible = False + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub btnSearch_Click(ByVal sender As Object, ByVal e As EventArgs) Handles btnSearch.Click + + Try + + If (txtSearch.Text.Trim() <> "") Then + Response.Redirect(Common.GetModuleLink(_articleTabID, _articleModuleID, "Search", ArticleSettings, "Search=" & Server.UrlEncode(txtSearch.Text)), True) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/NewsSearchOptions.ascx b/NewsSearchOptions.ascx new file mode 100755 index 0000000..147b704 --- /dev/null +++ b/NewsSearchOptions.ascx @@ -0,0 +1,11 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="NewsSearchOptions.ascx.vb" Inherits="Ventrian.NewsArticles.NewsSearchOptions" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> + + + + + +
+ +
\ No newline at end of file diff --git a/NewsSearchOptions.ascx.designer.vb b/NewsSearchOptions.ascx.designer.vb new file mode 100755 index 0000000..6e47193 --- /dev/null +++ b/NewsSearchOptions.ascx.designer.vb @@ -0,0 +1,35 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class NewsSearchOptions + + ''' + '''plModuleID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plModuleID As Global.System.Web.UI.UserControl + + ''' + '''drpModuleID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpModuleID As Global.System.Web.UI.WebControls.DropDownList + End Class +End Namespace diff --git a/NewsSearchOptions.ascx.vb b/NewsSearchOptions.ascx.vb new file mode 100755 index 0000000..d72d729 --- /dev/null +++ b/NewsSearchOptions.ascx.vb @@ -0,0 +1,109 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Tabs +Imports DotNetNuke.Security +Imports DotNetNuke.Services.Exceptions + +Namespace Ventrian.NewsArticles + + Partial Public Class NewsSearchOptions + Inherits ModuleSettingsBase + +#Region " Private Methods " + + Private Sub BindModules() + + Dim objDesktopModuleController As New DesktopModuleController + Dim objDesktopModuleInfo As DesktopModuleInfo = objDesktopModuleController.GetDesktopModuleByModuleName("DnnForge - NewsArticles") + + If Not (objDesktopModuleInfo Is Nothing) Then + + Dim objTabController As New TabController() + Dim objTabs As ArrayList = objTabController.GetTabs(PortalId) + For Each objTab As DotNetNuke.Entities.Tabs.TabInfo In objTabs + If Not (objTab Is Nothing) Then + If (objTab.IsDeleted = False) Then + Dim objModules As New ModuleController + For Each pair As KeyValuePair(Of Integer, ModuleInfo) In objModules.GetTabModules(objTab.TabID) + Dim objModule As ModuleInfo = pair.Value + If (objModule.IsDeleted = False) Then + If (objModule.DesktopModuleID = objDesktopModuleInfo.DesktopModuleID) Then + If PortalSecurity.IsInRoles(objModule.AuthorizedEditRoles) = True And objModule.IsDeleted = False Then + Dim strPath As String = objTab.TabName + Dim objTabSelected As TabInfo = objTab + While objTabSelected.ParentId <> Null.NullInteger + objTabSelected = objTabController.GetTab(objTabSelected.ParentId, objTab.PortalID, False) + If (objTabSelected Is Nothing) Then + Exit While + End If + strPath = objTabSelected.TabName & " -> " & strPath + End While + + Dim objListItem As New ListItem + + objListItem.Value = objModule.TabID.ToString() & "-" & objModule.ModuleID.ToString() + objListItem.Text = strPath & " -> " & objModule.ModuleTitle + + drpModuleID.Items.Add(objListItem) + End If + End If + End If + Next + End If + End If + Next + + End If + + End Sub + +#End Region + +#Region " Base Method Implementations " + + Public Overrides Sub LoadSettings() + Try + + If (Page.IsPostBack = False) Then + + BindModules() + + If (Settings.Contains(ArticleConstants.NEWS_SEARCH_MODULE_ID) And Settings.Contains(ArticleConstants.NEWS_SEARCH_TAB_ID)) Then + If Not (drpModuleID.Items.FindByValue(Settings(ArticleConstants.NEWS_SEARCH_TAB_ID).ToString() & "-" & Settings(ArticleConstants.NEWS_SEARCH_MODULE_ID).ToString()) Is Nothing) Then + drpModuleID.SelectedValue = Settings(ArticleConstants.NEWS_SEARCH_TAB_ID).ToString() & "-" & Settings(ArticleConstants.NEWS_SEARCH_MODULE_ID).ToString() + End If + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + End Sub + + Public Overrides Sub UpdateSettings() + Try + + Dim objModules As New ModuleController + + If (drpModuleID.Items.Count > 0) Then + + Dim values As String() = drpModuleID.SelectedValue.Split(Convert.ToChar("-")) + + If (values.Length = 2) Then + objModules.UpdateTabModuleSetting(Me.TabModuleId, ArticleConstants.NEWS_SEARCH_TAB_ID, values(0)) + objModules.UpdateTabModuleSetting(Me.TabModuleId, ArticleConstants.NEWS_SEARCH_MODULE_ID, values(1)) + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Print.aspx b/Print.aspx new file mode 100755 index 0000000..00a5eb9 --- /dev/null +++ b/Print.aspx @@ -0,0 +1,11 @@ +<%@ Page Language="vb" AutoEventWireup="false" CodeBehind="Print.aspx.vb" Inherits="Ventrian.NewsArticles.Print" %> + + + + + +
+ + + + diff --git a/Print.aspx.designer.vb b/Print.aspx.designer.vb new file mode 100755 index 0000000..4a63a29 --- /dev/null +++ b/Print.aspx.designer.vb @@ -0,0 +1,44 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class Print + + ''' + '''CSS control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents CSS As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''Form1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Form1 As Global.System.Web.UI.HtmlControls.HtmlForm + + ''' + '''phArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phArticle As Global.System.Web.UI.WebControls.PlaceHolder + End Class +End Namespace diff --git a/Print.aspx.vb b/Print.aspx.vb new file mode 100755 index 0000000..785e46f --- /dev/null +++ b/Print.aspx.vb @@ -0,0 +1,312 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2005-2012 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.IO + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Framework + + +Namespace Ventrian.NewsArticles + + Partial Public Class Print + Inherits PageBase + +#Region " Private Members " + + Private _articleID As Integer = Null.NullInteger + Private _moduleID As Integer = Null.NullInteger + Private _tabModuleID As Integer = Null.NullInteger + Private _tabID As Integer = Null.NullInteger + Private _pageID As Integer = Null.NullInteger + Private _portalID As Integer = Null.NullInteger + Private _template As String = Null.NullString + + Private _articleSettings As ArticleSettings + +#End Region + +#Region " Private Methods " + + Private Sub ReadQueryString() + + If Not (Request("ArticleID") Is Nothing) Then + _articleID = Convert.ToInt32(Request("ArticleID")) + End If + + If Not (Request("ModuleID") Is Nothing) Then + _moduleID = Convert.ToInt32(Request("ModuleID")) + End If + + If Not (Request("TabID") Is Nothing) Then + _tabID = Convert.ToInt32(Request("TabID")) + End If + + If Not (Request("TabModuleID") Is Nothing) Then + _tabModuleID = Convert.ToInt32(Request("TabModuleID")) + End If + + If Not (Request("PageID") Is Nothing) Then + _pageID = Convert.ToInt32(Request("PageID")) + End If + + If Not (Request("PortalID") Is Nothing) Then + _portalID = Convert.ToInt32(Request("PortalID")) + End If + + End Sub + + Private Sub ManageStyleSheets(ByVal PortalCSS As Boolean) + + ' initialize reference paths to load the cascading style sheets + Dim objCSS As Control = Me.FindControl("CSS") + Dim objLink As HtmlGenericControl + Dim ID As String + + Dim objCSSCache As Hashtable = CType(DataCache.GetCache("CSS"), Hashtable) + If objCSSCache Is Nothing Then + objCSSCache = New Hashtable + End If + + If Not objCSS Is Nothing Then + If PortalCSS = False Then + ' module style sheet + ID = CreateValidID("PropertyAgent") + objLink = New HtmlGenericControl("link") + objLink.ID = ID + objLink.Attributes("rel") = "stylesheet" + objLink.Attributes("type") = "text/css" + objLink.Attributes("href") = Me.ResolveUrl("module.css") + objCSS.Controls.Add(objLink) + + ' default style sheet ( required ) + ID = CreateValidID(DotNetNuke.Common.Globals.HostPath) + objLink = New HtmlGenericControl("link") + objLink.ID = ID + objLink.Attributes("rel") = "stylesheet" + objLink.Attributes("type") = "text/css" + objLink.Attributes("href") = DotNetNuke.Common.Globals.HostPath & "default.css" + objCSS.Controls.Add(objLink) + + ' skin package style sheet + ID = CreateValidID(PortalSettings.ActiveTab.SkinPath) + If objCSSCache.ContainsKey(ID) = False Then + If File.Exists(Server.MapPath(PortalSettings.ActiveTab.SkinPath) & "skin.css") Then + objCSSCache(ID) = PortalSettings.ActiveTab.SkinPath & "skin.css" + Else + objCSSCache(ID) = "" + End If + If Not DotNetNuke.Common.Globals.PerformanceSetting = DotNetNuke.Common.Globals.PerformanceSettings.NoCaching Then + DataCache.SetCache("CSS", objCSSCache) + End If + End If + If objCSSCache(ID).ToString <> "" Then + objLink = New HtmlGenericControl("link") + objLink.ID = ID + objLink.Attributes("rel") = "stylesheet" + objLink.Attributes("type") = "text/css" + objLink.Attributes("href") = objCSSCache(ID).ToString + objCSS.Controls.Add(objLink) + End If + + ' skin file style sheet + ID = CreateValidID(Replace(PortalSettings.ActiveTab.SkinSrc, ".ascx", ".css")) + If objCSSCache.ContainsKey(ID) = False Then + If File.Exists(Server.MapPath(Replace(PortalSettings.ActiveTab.SkinSrc, ".ascx", ".css"))) Then + objCSSCache(ID) = Replace(PortalSettings.ActiveTab.SkinSrc, ".ascx", ".css") + Else + objCSSCache(ID) = "" + End If + If Not DotNetNuke.Common.Globals.PerformanceSetting = DotNetNuke.Common.Globals.PerformanceSettings.NoCaching Then + DataCache.SetCache("CSS", objCSSCache) + End If + End If + If objCSSCache(ID).ToString <> "" Then + objLink = New HtmlGenericControl("link") + objLink.ID = ID + objLink.Attributes("rel") = "stylesheet" + objLink.Attributes("type") = "text/css" + objLink.Attributes("href") = objCSSCache(ID).ToString + objCSS.Controls.Add(objLink) + End If + Else + ' portal style sheet + ID = CreateValidID(PortalSettings.HomeDirectory) + objLink = New HtmlGenericControl("link") + objLink.ID = ID + objLink.Attributes("rel") = "stylesheet" + objLink.Attributes("type") = "text/css" + objLink.Attributes("href") = PortalSettings.HomeDirectory & "portal.css" + objCSS.Controls.Add(objLink) + End If + + End If + + End Sub + + Private Sub BindArticle() + + If (_articleID = Null.NullInteger) Then + Response.Redirect(NavigateURL(_tabID), True) + End If + + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + + If Not (objArticle Is Nothing) Then + + ' Check Article Security + If (objArticle.IsSecure) Then + If (ArticleSettings.IsSecureEnabled = False) Then + If (ArticleSettings.SecureUrl <> "") Then + Dim url As String = Request.Url.ToString().Replace(AddHTTP(Request.Url.Host), "") + If (ArticleSettings.SecureUrl.IndexOf("?") <> -1) Then + Response.Redirect(ArticleSettings.SecureUrl & "&returnurl=" & Server.UrlEncode(url), True) + Else + Response.Redirect(ArticleSettings.SecureUrl & "?returnurl=" & Server.UrlEncode(url), True) + End If + Else + Response.Redirect(NavigateURL(_tabID), True) + End If + End If + End If + + Dim objModuleController As New ModuleController + Dim objModule As ModuleInfo = objModuleController.GetModule(objArticle.ModuleID, _tabID) + + If Not (objModule Is Nothing) Then + If (DotNetNuke.Security.PortalSecurity.IsInRoles(objModule.AuthorizedViewRoles) = False) Then + Response.Redirect(NavigateURL(_tabID), True) + End If + + If (objModule.PortalID <> PortalSettings.PortalId) Then + Response.Redirect(NavigateURL(_tabID), True) + End If + End If + + Dim objLayoutController As New LayoutController(PortalSettings, ArticleSettings, objModule, Page) + + 'Dim objLayoutController As New LayoutController(PortalSettings, ArticleSettings, Page, False, _tabID, _moduleID, _tabModuleID, _portalID, _pageID, Null.NullInteger, "Articles-Print-" & _moduleID.ToString()) + Dim objLayoutItem As LayoutInfo = LayoutController.GetLayout(ArticleSettings, objModule, Page, LayoutType.Print_Item_Html) + objLayoutController.ProcessArticleItem(phArticle.Controls, objLayoutItem.Tokens, objArticle) + objLayoutController.LoadStyleSheet(ArticleSettings.Template) + + Dim objLayoutTitle As LayoutInfo = LayoutController.GetLayout(ArticleSettings, objModule, Page, LayoutType.View_Title_Html) + If (objLayoutTitle.Template <> "") Then + Dim phPageTitle As New PlaceHolder() + objLayoutController.ProcessArticleItem(phPageTitle.Controls, objLayoutTitle.Tokens, objArticle) + Me.Title = RenderControlToString(phPageTitle) + End If + + Dim objLayoutDescription As LayoutInfo = LayoutController.GetLayout(ArticleSettings, objModule, Page, LayoutType.View_Description_Html) + If (objLayoutDescription.Template <> "") Then + Dim phPageDescription As New PlaceHolder() + objLayoutController.ProcessArticleItem(phPageDescription.Controls, objLayoutDescription.Tokens, objArticle) + Dim meta As New HtmlMeta + meta.Name = "MetaDescription" + meta.Content = RenderControlToString(phPageDescription) + If (meta.Content <> "") Then + Me.Header.Controls.Add(meta) + End If + End If + + Dim objLayoutKeyword As LayoutInfo = LayoutController.GetLayout(ArticleSettings, objModule, Page, LayoutType.View_Keyword_Html) + If (objLayoutKeyword.Template <> "") Then + Dim phPageKeyword As New PlaceHolder() + objLayoutController.ProcessArticleItem(phPageKeyword.Controls, objLayoutKeyword.Tokens, objArticle) + + Dim meta As New HtmlMeta + meta.Name = "MetaKeywords" + meta.Content = RenderControlToString(phPageKeyword) + If (meta.Content <> "") Then + Me.Header.Controls.Add(meta) + End If + End If + + Else + + Response.Redirect(NavigateURL(), True) + + End If + + End Sub + + Protected Function GetSharedResource(ByVal key As String) As String + + Dim path As String = Me.TemplateSourceDirectory & "/" & DotNetNuke.Services.Localization.Localization.LocalResourceDirectory & "/" & DotNetNuke.Services.Localization.Localization.LocalSharedResourceFile + path = "~" & path.Substring(path.IndexOf("/DesktopModules/"), path.Length - path.IndexOf("/DesktopModules/")) + Return DotNetNuke.Services.Localization.Localization.GetString(key, path) + + End Function + + Private Function RenderControlToString(ByVal ctrl As Control) As String + + Dim sb As New StringBuilder() + Dim tw As New IO.StringWriter(sb) + Dim hw As New HtmlTextWriter(tw) + + ctrl.RenderControl(hw) + + Return sb.ToString() + + End Function + + Protected Function StripHtml(ByVal html As String) As String + + Dim pattern As String = "<(.|\n)*?>" + Return Regex.Replace(html, pattern, String.Empty) + + End Function + +#End Region + +#Region " Private Properties " + + Public ReadOnly Property BasePage() As DotNetNuke.Framework.CDefault + Get + Return CType(Me.Page, DotNetNuke.Framework.CDefault) + End Get + End Property + + Public ReadOnly Property ArticleSettings() As ArticleSettings + Get + If (_articleSettings Is Nothing) Then + Dim objModuleController As New ModuleController + Dim settings As Hashtable = objModuleController.GetModuleSettings(_moduleID) + 'Add TabModule Settings + settings = DotNetNuke.Entities.Portals.PortalSettings.GetTabModuleSettings(_tabModuleID, settings) + Dim objModule As ModuleInfo = objModuleController.GetModule(_moduleID, _tabID) + _articleSettings = New ArticleSettings(settings, Me.PortalSettings, objModule) + End If + Return _articleSettings + End Get + End Property + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Initialization(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + ManageStyleSheets(False) + ManageStyleSheets(True) + ReadQueryString() + BindArticle() + + End Sub + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Providers/DataProvider/DataProvider.vb b/Providers/DataProvider/DataProvider.vb new file mode 100755 index 0000000..fb898fe --- /dev/null +++ b/Providers/DataProvider/DataProvider.vb @@ -0,0 +1,155 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System +Imports System.Web.Caching +Imports System.Reflection + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public MustInherit Class DataProvider + +#Region " Shared/Static Methods " + + ' singleton reference to the instantiated object + Private Shared objProvider As DataProvider = Nothing + + ' constructor + Shared Sub New() + CreateProvider() + End Sub + + ' dynamically create provider + Private Shared Sub CreateProvider() + objProvider = CType(Framework.Reflection.CreateObject("data", "Ventrian.NewsArticles", "Ventrian.NewsArticles"), DataProvider) + End Sub + + ' return the provider + Public Shared Shadows Function Instance() As DataProvider + Return objProvider + End Function + +#End Region + +#Region " Abstract methods " + + Public MustOverride Function GetArticleListByApproved(ByVal moduleID As Integer, ByVal isApproved As Boolean) As IDataReader + Public MustOverride Function GetArticleListBySearchCriteria(ByVal moduleID As Integer, ByVal currentDate As DateTime, ByVal agedDate As DateTime, ByVal categoryID As Integer(), ByVal matchAll As Boolean, ByVal categoryIDExclude As Integer(), ByVal maxCount As Integer, ByVal pageNumber As Integer, ByVal pageSize As Integer, ByVal sortBy As String, ByVal sortDirection As String, ByVal isApproved As Boolean, ByVal isDraft As Boolean, ByVal keywords As String, ByVal authorID As Integer, ByVal showPending As Boolean, ByVal showExpired As Boolean, ByVal showFeaturedOnly As Boolean, ByVal showNotFeaturedOnly As Boolean, ByVal showSecuredOnly As Boolean, ByVal showNotSecuredOnly As Boolean, ByVal articleIDs As String, ByVal tagID As Integer(), ByVal matchAllTag As Boolean, ByVal rssGuid As String, ByVal customFieldID As Integer, ByVal customValue As String, ByVal linkFilter As String) As IDataReader + Public MustOverride Function GetArticle(ByVal articleID As Integer) As IDataReader + Public MustOverride Function GetArticleCategories(ByVal articleID As Integer) As IDataReader + Public MustOverride Function GetNewsArchive(ByVal moduleID As Integer, ByVal categoryID As Integer(), ByVal categoryIDExclude As Integer(), ByVal authorID As Integer, ByVal groupBy As String, ByVal showPending As Boolean) As IDataReader + Public MustOverride Sub DeleteArticle(ByVal articleID As Integer) + Public MustOverride Sub DeleteArticleCategories(ByVal articleID As Integer) + Public MustOverride Function AddArticle(ByVal authorID As Integer, ByVal approverID As Integer, ByVal createdDate As DateTime, ByVal lastUpdate As DateTime, ByVal title As String, ByVal summary As String, ByVal isApproved As Boolean, ByVal numberOfViews As Integer, ByVal isDraft As Boolean, ByVal startDate As DateTime, ByVal endDate As DateTime, ByVal moduleID As Integer, ByVal imageUrl As String, ByVal isFeatured As Boolean, ByVal lastUpdateID As Integer, ByVal url As String, ByVal isSecure As Boolean, ByVal isNewWindow As Boolean, ByVal metaTitle As String, ByVal metaDescription As String, ByVal metaKeywords As String, ByVal pageHeadText As String, ByVal shortUrl As String, ByVal rssGuid As String) As Integer + Public MustOverride Sub AddArticleCategory(ByVal articleID As Integer, ByVal categoryID As Integer) + Public MustOverride Sub UpdateArticle(ByVal articleID As Integer, ByVal authorID As Integer, ByVal approverID As Integer, ByVal createdDate As DateTime, ByVal lastUpdate As DateTime, ByVal title As String, ByVal summary As String, ByVal isApproved As Boolean, ByVal numberOfViews As Integer, ByVal isDraft As Boolean, ByVal startDate As DateTime, ByVal endDate As DateTime, ByVal moduleID As Integer, ByVal imageUrl As String, ByVal isFeatured As Boolean, ByVal lastUpdateID As Integer, ByVal url As String, ByVal isSecure As Boolean, ByVal isNewWindow As Boolean, ByVal metaTitle As String, ByVal metaDescription As String, ByVal metaKeywords As String, ByVal pageHeadText As String, ByVal shortUrl As String, ByVal rssGuid As String) + Public MustOverride Sub UpdateArticleCount(ByVal articleID As Integer, ByVal numberOfViews As Integer) + + Public MustOverride Function SecureCheck(ByVal portalID As Integer, ByVal articleID As Integer, ByVal userID As Integer) As Boolean + + Public MustOverride Function GetAuthorList(ByVal moduleID As Integer) As IDataReader + Public MustOverride Function GetAuthorStatistics(ByVal moduleID As Integer, ByVal categoryID As Integer(), ByVal categoryIDExclude As Integer(), ByVal authorID As Integer, ByVal sortBy As String, ByVal showPending As Boolean) As IDataReader + + Public MustOverride Function GetCategoryList(ByVal moduleID As Integer, ByVal parentID As Integer) As IDataReader + Public MustOverride Function GetCategoryListAll(ByVal moduleID As Integer, ByVal authorID As Integer, ByVal showPending As Boolean, ByVal sortType As Integer) As IDataReader + Public MustOverride Function GetCategory(ByVal categoryID As Integer) As IDataReader + Public MustOverride Sub DeleteCategory(ByVal categoryID As Integer) + Public MustOverride Function AddCategory(ByVal moduleID As Integer, ByVal parentID As Integer, ByVal name As String, ByVal image As String, ByVal description As String, ByVal sortOrder As Integer, ByVal inheritSecurity As Boolean, ByVal categorySecurityType As Integer, ByVal metaTitle As String, ByVal metaDescription As String, ByVal metaKeywords As String) As Integer + Public MustOverride Sub UpdateCategory(ByVal categoryID As Integer, ByVal moduleID As Integer, ByVal parentID As Integer, ByVal name As String, ByVal image As String, ByVal description As String, ByVal sortOrder As Integer, ByVal inheritSecurity As Boolean, ByVal categorySecurityType As Integer, ByVal metaTitle As String, ByVal metaDescription As String, ByVal metaKeywords As String) + + Public MustOverride Function GetCommentList(ByVal moduleID As Integer, ByVal articleID As Integer, ByVal isApproved As Boolean, ByVal direction As SortDirection, ByVal maxCount As Integer) As IDataReader + Public MustOverride Function GetComment(ByVal commentID As Integer) As IDataReader + Public MustOverride Sub DeleteComment(ByVal commentID As Integer) + Public MustOverride Function AddComment(ByVal articleID As Integer, ByVal createdDate As DateTime, ByVal userID As Integer, ByVal comment As String, ByVal remoteAddress As String, ByVal type As Integer, ByVal trackbackUrl As String, ByVal trackbackTitle As String, ByVal trackbackBlogName As String, ByVal trackbackExcerpt As String, ByVal anonymousName As String, ByVal anonymousEmail As String, ByVal anonymousURL As String, ByVal notifyMe As Boolean, ByVal isApproved As Boolean, ByVal approvedBy As Integer) As Integer + Public MustOverride Sub UpdateComment(ByVal commentID As Integer, ByVal articleID As Integer, ByVal userID As Integer, ByVal comment As String, ByVal remoteAddress As String, ByVal type As Integer, ByVal trackbackUrl As String, ByVal trackbackTitle As String, ByVal trackbackBlogName As String, ByVal trackbackExcerpt As String, ByVal anonymousName As String, ByVal anonymousEmail As String, ByVal anonymousURL As String, ByVal notifyMe As Boolean, ByVal isApproved As Boolean, ByVal approvedBy As Integer) + + Public MustOverride Function GetCustomField(ByVal customFieldID As Integer) As IDataReader + Public MustOverride Function GetCustomFieldList(ByVal moduleID As Integer) As IDataReader + Public MustOverride Sub DeleteCustomField(ByVal commentID As Integer) + Public MustOverride Function AddCustomField(ByVal moduleID As Integer, ByVal name As String, ByVal fieldType As Integer, ByVal fieldElements As String, ByVal defaultValue As String, ByVal caption As String, ByVal captionHelp As String, ByVal isRequired As Boolean, ByVal isVisible As Boolean, ByVal sortOrder As Integer, ByVal validationType As Integer, ByVal length As Integer, ByVal regularExpression As String) As Integer + Public MustOverride Sub UpdateCustomField(ByVal customFieldID As Integer, ByVal moduleID As Integer, ByVal name As String, ByVal fieldType As Integer, ByVal fieldElements As String, ByVal defaultValue As String, ByVal caption As String, ByVal captionHelp As String, ByVal isRequired As Boolean, ByVal isVisible As Boolean, ByVal sortOrder As Integer, ByVal validationType As Integer, ByVal length As Integer, ByVal regularExpression As String) + + Public MustOverride Function GetCustomValueList(ByVal articleID As Integer) As IDataReader + Public MustOverride Function AddCustomValue(ByVal articleID As Integer, ByVal customFieldID As Integer, ByVal customValue As String) As Integer + Public MustOverride Sub UpdateCustomValue(ByVal customValueID As Integer, ByVal articleID As Integer, ByVal customFieldID As Integer, ByVal customValue As String) + Public MustOverride Sub DeleteCustomValue(ByVal articleID As Integer, ByVal customFieldID As Integer) + + Public MustOverride Function GetFeed(ByVal feedID As Integer) As IDataReader + Public MustOverride Function GetFeedList(ByVal moduleID As Integer, ByVal showActiveOnly As Boolean) As IDataReader + Public MustOverride Function AddFeed(ByVal moduleID As Integer, ByVal title As String, ByVal url As String, ByVal userID As Integer, ByVal autoFeature As Boolean, ByVal isActive As Boolean, ByVal dateMode As Integer, ByVal autoExpire As Integer, ByVal autoExpireUnit As Integer) As Integer + Public MustOverride Sub UpdateFeed(ByVal feedID As Integer, ByVal moduleID As Integer, ByVal title As String, ByVal url As String, ByVal userID As Integer, ByVal autoFeature As Boolean, ByVal isActive As Boolean, ByVal dateMode As Integer, ByVal autoExpire As Integer, ByVal autoExpireUnit As Integer) + Public MustOverride Sub DeleteFeed(ByVal feedID As Integer) + + Public MustOverride Function GetFeedCategoryList(ByVal feedID As Integer) As IDataReader + Public MustOverride Sub AddFeedCategory(ByVal feedID As Integer, ByVal categoryID As Integer) + Public MustOverride Sub DeleteFeedCategory(ByVal feedID As Integer) + + Public MustOverride Function GetFile(ByVal fileID As Integer) As IDataReader + Public MustOverride Function GetFileList(ByVal articleID As Integer, ByVal fileGuid As String) As IDataReader + Public MustOverride Function AddFile(ByVal articleID As Integer, ByVal title As String, ByVal fileName As String, ByVal extension As String, ByVal size As Integer, ByVal contentType As String, ByVal folder As String, ByVal sortOrder As Integer, ByVal fileGuid As String) As Integer + Public MustOverride Sub UpdateFile(ByVal fileID As Integer, ByVal articleID As Integer, ByVal title As String, ByVal fileName As String, ByVal extension As String, ByVal size As Integer, ByVal contentType As String, ByVal folder As String, ByVal sortOrder As Integer, ByVal fileGuid As String) + Public MustOverride Sub DeleteFile(ByVal fileID As Integer) + + Public MustOverride Function GetImage(ByVal imageID As Integer) As IDataReader + Public MustOverride Function GetImageList(ByVal articleID As Integer, ByVal imageGuid As String) As IDataReader + Public MustOverride Function AddImage(ByVal articleID As Integer, ByVal title As String, ByVal fileName As String, ByVal extension As String, ByVal size As Integer, ByVal width As Integer, ByVal height As Integer, ByVal contentType As String, ByVal folder As String, ByVal sortOrder As Integer, ByVal imageGuid As String, ByVal description As String) As Integer + Public MustOverride Sub UpdateImage(ByVal imageID As Integer, ByVal articleID As Integer, ByVal title As String, ByVal fileName As String, ByVal extension As String, ByVal size As Integer, ByVal width As Integer, ByVal height As Integer, ByVal contentType As String, ByVal folder As String, ByVal sortOrder As Integer, ByVal imageGuid As String, ByVal description As String) + Public MustOverride Sub DeleteImage(ByVal imageID As Integer) + + Public MustOverride Sub AddMirrorArticle(ByVal articleID As Integer, ByVal linkedArticleID As Integer, ByVal linkedPortalID As Integer, ByVal autoUpdate As Boolean) + Public MustOverride Function GetMirrorArticle(ByVal articleID As Integer) As IDataReader + Public MustOverride Function GetMirrorArticleList(ByVal linkedArticleID As Integer) As IDataReader + + Public MustOverride Function GetPageList(ByVal articleID As Integer) As IDataReader + Public MustOverride Function GetPage(ByVal pageID As Integer) As IDataReader + Public MustOverride Sub DeletePage(ByVal pageID As Integer) + Public MustOverride Function AddPage(ByVal articleID As Integer, ByVal title As String, ByVal pageText As String, ByVal sortOrder As Integer) As Integer + Public MustOverride Sub UpdatePage(ByVal pageID As Integer, ByVal articleID As Integer, ByVal title As String, ByVal pageText As String, ByVal sortOrder As Integer) + + Public MustOverride Function AddRating(ByVal articleID As Integer, ByVal userID As Integer, ByVal createdDate As DateTime, ByVal rating As Double) As Integer + Public MustOverride Function GetRating(ByVal articleID As Integer, ByVal userID As Integer) As IDataReader + Public MustOverride Function GetRatingByID(ByVal ratingID As Integer) As IDataReader + Public MustOverride Sub DeleteRating(ByVal ratingID As Integer) + + Public MustOverride Function AddHandout(ByVal moduleID As Integer, ByVal userID As Integer, ByVal name As String, ByVal description As String) As Integer + Public MustOverride Sub AddHandoutArticle(ByVal handoutID As Integer, ByVal articleID As Integer, ByVal sortOrder As Integer) + Public MustOverride Sub DeleteHandout(ByVal handoutID As Integer) + Public MustOverride Sub DeleteHandoutArticleList(ByVal handoutID As Integer) + Public MustOverride Function GetHandout(ByVal handoutID As Integer) As IDataReader + Public MustOverride Function GetHandoutList(ByVal userID As Integer) As IDataReader + Public MustOverride Function GetHandoutArticleList(ByVal handoutID As Integer) As IDataReader + Public MustOverride Sub UpdateHandout(ByVal handoutID As Integer, ByVal moduleID As Integer, ByVal userID As Integer, ByVal name As String, ByVal description As String) + + Public MustOverride Function GetTag(ByVal tagID As Integer) As IDataReader + Public MustOverride Function GetTagByName(ByVal moduleID As Integer, ByVal nameLowered As String) As IDataReader + Public MustOverride Function ListTag(ByVal moduleID As Integer, ByVal maxCount As Integer) As IDataReader + Public MustOverride Function AddTag(ByVal moduleID As Integer, ByVal name As String, ByVal nameLowered As String) As Integer + Public MustOverride Sub UpdateTag(ByVal tagID As Integer, ByVal moduleID As Integer, ByVal name As String, ByVal nameLowered As String, ByVal usages As Integer) + Public MustOverride Sub DeleteTag(ByVal tagID As Integer) + + Public MustOverride Sub AddArticleTag(ByVal articleID As Integer, ByVal tagID As Integer) + Public MustOverride Sub DeleteArticleTag(ByVal articleID As Integer) + Public MustOverride Sub DeleteArticleTagByTag(ByVal tagID As Integer) + +#Region " EmailTemplate Methods " + + Public MustOverride Function GetEmailTemplate(ByVal templateID As Integer) As IDataReader + Public MustOverride Function GetEmailTemplateByName(ByVal moduleID As Integer, ByVal name As String) As IDataReader + Public MustOverride Function ListEmailTemplate(ByVal moduleID As Integer) As IDataReader + Public MustOverride Function AddEmailTemplate(ByVal moduleID As Integer, ByVal name As String, ByVal subject As String, ByVal template As String) As Integer + Public MustOverride Sub UpdateEmailTemplate(ByVal templateID As Integer, ByVal moduleID As Integer, ByVal name As String, ByVal subject As String, ByVal template As String) + Public MustOverride Sub DeleteEmailTemplate(ByVal templateID As Integer) + +#End Region + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Providers/DataProvider/SqlDataProvider/00.00.01.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.00.01.SqlDataProvider new file mode 100755 index 0000000..099e259 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.00.01.SqlDataProvider @@ -0,0 +1,442 @@ +if not exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article') and OBJECTPROPERTY(id, N'IsTable') = 1) +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [ArticleID] [int] IDENTITY (1, 1) NOT NULL , + [CategoryID] [int] NOT NULL , + [AuthorID] [int] NOT NULL , + [ApproverID] [int] NULL , + [CreatedDate] [datetime] NOT NULL , + [LastUpdate] [datetime] NOT NULL , + [Title] [nvarchar] (255) NOT NULL , + [Summary] [nvarchar] (4000) NOT NULL , + [IsApproved] [bit] NOT NULL , + [NumberOfViews] [int] NOT NULL +) ON [PRIMARY] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category') and OBJECTPROPERTY(id, N'IsTable') = 1) +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [CategoryID] [int] IDENTITY (1, 1) NOT NULL , + [ModuleID] [int] NOT NULL , + [Name] [nvarchar] (255) NOT NULL , + [Image] [nvarchar] (255) NULL +) ON [PRIMARY] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment') and OBJECTPROPERTY(id, N'IsTable') = 1) +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [CommentID] [int] IDENTITY (1, 1) NOT NULL , + [ArticleID] [int] NOT NULL , + [UserID] [int] NOT NULL , + [CreatedDate] [datetime] NOT NULL , + [Comment] [ntext] NOT NULL +) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'PK_{objectQualifier}DnnForge_NewsArticles_Article') and OBJECTPROPERTY(id, N'IsPrimaryKey') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Article] PRIMARY KEY CLUSTERED + ( + [ArticleID] + ) ON [PRIMARY] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'DF_{objectQualifier}DnnForge_NewsArticles_Article_CreatedDate') and OBJECTPROPERTY(id, N'IsConstraint') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + CONSTRAINT [DF_{objectQualifier}DnnForge_NewsArticles_Article_CreatedDate] DEFAULT (getdate()) FOR [CreatedDate] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'DF_{objectQualifier}DnnForge_NewsArticles_Article_LastUpdate') and OBJECTPROPERTY(id, N'IsConstraint') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + CONSTRAINT [DF_{objectQualifier}DnnForge_NewsArticles_Article_LastUpdate] DEFAULT (getdate()) FOR [LastUpdate] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'DF_{objectQualifier}DnnForge_NewsArticles_Article_IsApproved') and OBJECTPROPERTY(id, N'IsConstraint') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + CONSTRAINT [DF_{objectQualifier}DnnForge_NewsArticles_Article_IsApproved] DEFAULT (0) FOR [IsApproved] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'DF_{objectQualifier}DnnForge_NewsArticles_Article_NumberOfViews') and OBJECTPROPERTY(id, N'IsConstraint') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + CONSTRAINT [DF_{objectQualifier}DnnForge_NewsArticles_Article_NumberOfViews] DEFAULT (0) FOR [NumberOfViews] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'PK_{objectQualifier}DnnForge_NewsArticles_Category') and OBJECTPROPERTY(id, N'IsPrimaryKey') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Category] PRIMARY KEY CLUSTERED + ( + [CategoryID] + ) ON [PRIMARY] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'PK_{objectQualifier}DnnForge_NewsArticles_Comment') and OBJECTPROPERTY(id, N'IsPrimaryKey') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Comment] PRIMARY KEY CLUSTERED + ( + [CommentID] + ) ON [PRIMARY] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'DF_{objectQualifier}DF_DnnForge_NewsArticles_Comment_CreatedDate') and OBJECTPROPERTY(id, N'IsConstraint') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ADD + CONSTRAINT [DF_{objectQualifier}DnnForge_NewsArticles_Comment_CreatedDate] DEFAULT (getdate()) FOR [CreatedDate] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'FK_{objectQualifier}DnnForge_NewsArticles_Article_{objectQualifier}DnnForge_NewsArticles_Category') and OBJECTPROPERTY(id, N'IsForeignKey') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + CONSTRAINT [FK_{objectQualifier}DnnForge_NewsArticles_Article_{objectQualifier}DnnForge_NewsArticles_Category] FOREIGN KEY + ( + [CategoryID] + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [CategoryID] + ) ON DELETE CASCADE +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'FK_{objectQualifier}DnnForge_NewsArticles_Article_{objectQualifier}Users') and OBJECTPROPERTY(id, N'IsForeignKey') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + CONSTRAINT [FK_{objectQualifier}DnnForge_NewsArticles_Article_{objectQualifier}Users] FOREIGN KEY + ( + [AuthorID] + ) REFERENCES {databaseOwner}{objectQualifier}Users ( + [UserID] + ) ON DELETE CASCADE +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'FK_{objectQualifier}DnnForge_NewsArticles_Category_{objectQualifier}Modules') and OBJECTPROPERTY(id, N'IsForeignKey') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ADD + CONSTRAINT [FK_{objectQualifier}DnnForge_NewsArticles_Category_{objectQualifier}Modules] FOREIGN KEY + ( + [ModuleID] + ) REFERENCES {databaseOwner}{objectQualifier}Modules ( + [ModuleID] + ) ON DELETE CASCADE +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'FK_{objectQualifier}DnnForge_NewsArticles_Comment_{objectQualifier}DnnForge_NewsArticles_Article') and OBJECTPROPERTY(id, N'IsForeignKey') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ADD + CONSTRAINT [FK_{objectQualifier}DnnForge_NewsArticles_Comment_{objectQualifier}DnnForge_NewsArticles_Article] FOREIGN KEY + ( + [ArticleID] + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [ArticleID] + ) ON DELETE CASCADE +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticle') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticle +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteCategory') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteCategory +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteComment') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteComment +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByApproved') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByApproved +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @CategoryID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [CategoryID], + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews] +) VALUES ( + @CategoryID, + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory + @ModuleID int, + @Name nvarchar(255), + @Image nvarchar(255) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [ModuleID], + [Name], + [Image] +) VALUES ( + @ModuleID, + @Name, + @Image +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment + @ArticleID int, + @UserID int, + @Comment ntext +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [ArticleID], + [UserID], + [Comment] +) VALUES ( + @ArticleID, + @UserID, + @Comment +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticle + @ArticleID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +WHERE + [ArticleID] = @ArticleID + +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteCategory + @CategoryID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [CategoryID] = @CategoryID + +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteComment + @CommentID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment +WHERE + [CommentID] = @CommentID + +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByApproved + @ModuleID int, + @AuthorID int, + @IsApproved bit +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID int, + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255) +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory + @CategoryID int +AS + +SELECT + [CategoryID], + [ModuleID], + [Name], + [Image] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [CategoryID] = @CategoryID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList + @ModuleID int +AS + +SELECT + [CategoryID], + [ModuleID], + [Name], + [Image] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [ModuleID] = @ModuleID + +ORDER BY Name +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment + @CommentID int +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ArticleID int +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @CategoryID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [CategoryID] = @CategoryID, + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews +WHERE + [ArticleID] = @ArticleID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory + @CategoryID int, + @ModuleID int, + @Name nvarchar(255), + @Image nvarchar(255) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category SET + [ModuleID] = @ModuleID, + [Name] = @Name, + [Image] = @Image +WHERE + [CategoryID] = @CategoryID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment + @CommentID int, + @ArticleID int, + @UserID int, + @Comment ntext +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment SET + [ArticleID] = @ArticleID, + [UserID] = @UserID, + [Comment] = @Comment +WHERE + [CommentID] = @CommentID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.00.02.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.00.02.SqlDataProvider new file mode 100755 index 0000000..9d37198 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.00.02.SqlDataProvider @@ -0,0 +1,271 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + Add [IsDraft] bit NOT NULL DEFAULT 0 +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page') and OBJECTPROPERTY(id, N'IsTable') = 1) +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page ( + [PageID] [int] IDENTITY (1, 1) NOT NULL , + [ArticleID] [int] NOT NULL , + [Title] [nvarchar] (255) NOT NULL , + [PageText] [ntext] NOT NULL , + [SortOrder] [int] NOT NULL +) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'PK_{objectQualifier}DnnForge_NewsArticles_Page') and OBJECTPROPERTY(id, N'IsPrimaryKey') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Page] PRIMARY KEY CLUSTERED + ( + [PageID] + ) ON [PRIMARY] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'DF_{objectQualifier}DnnForge_NewsArticles_Page_SortOrder') and OBJECTPROPERTY(id, N'IsConstraint') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page ADD + CONSTRAINT [DF_{objectQualifier}DnnForge_NewsArticles_Page_SortOrder] DEFAULT (0) FOR [SortOrder] +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'FK_{objectQualifier}DnnForge_NewsArticles_Page_{objectQualifier}DnnForge_NewsArticles_Article') and OBJECTPROPERTY(id, N'IsForeignKey') = 1) +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page ADD + CONSTRAINT [FK_{objectQualifier}DnnForge_NewsArticles_Page_{objectQualifier}DnnForge_NewsArticles_Article] FOREIGN KEY + ( + [ArticleID] + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [ArticleID] + ) ON DELETE CASCADE +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @CategoryID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [CategoryID], + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft] +) VALUES ( + @CategoryID, + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft +) + +select SCOPE_IDENTITY() +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddPage') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddPage +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddPage + @ArticleID int, + @Title nvarchar(255), + @PageText ntext, + @SortOrder int +AS + +declare @count int + +select @count = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where ArticleID = @ArticleID) + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page ( + [ArticleID], + [Title], + [PageText], + [SortOrder] +) VALUES ( + @ArticleID, + @Title, + @PageText, + @count +) + +select SCOPE_IDENTITY() +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeletePage') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeletePage +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeletePage + @PageID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page +WHERE + [PageID] = @PageID +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByApproved') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetPage') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetPage +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetPage + @PageID int +AS + +SELECT + [PageID], + [ArticleID], + [Title], + [PageText], + [SortOrder] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page +WHERE + [PageID] = @PageID +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetPageList') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetPageList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetPageList + @ArticleID int +AS + +SELECT + [PageID], + [ArticleID], + [Title], + [PageText], + [SortOrder] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page + +WHERE + [ArticleID] = @ArticleID + +ORDER BY + [SortOrder] ASC +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @CategoryID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [CategoryID] = @CategoryID, + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft +WHERE + [ArticleID] = @ArticleID +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdatePage') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdatePage +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdatePage + @PageID int, + @ArticleID int, + @Title nvarchar(255), + @PageText ntext, + @SortOrder int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page SET + [ArticleID] = @ArticleID, + [Title] = @Title, + [PageText] = @PageText, + [SortOrder] = @SortOrder +WHERE + [PageID] = @PageID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.00.03.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.00.03.SqlDataProvider new file mode 100755 index 0000000..cec6144 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.00.03.SqlDataProvider @@ -0,0 +1,14 @@ +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID int, + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255) +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.00.04.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.00.04.SqlDataProvider new file mode 100755 index 0000000..c36b15d --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.00.04.SqlDataProvider @@ -0,0 +1,8 @@ +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics') and OBJECTPROPERTY(id, N'IsProcedure') = 1) +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics + @ModuleID int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.00.05.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.00.05.SqlDataProvider new file mode 100755 index 0000000..c016c48 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.00.05.SqlDataProvider @@ -0,0 +1,255 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + StartDate datetime NULL, + EndDate datetime NULL, + ModuleID int NULL +GO + +UPDATE + {databaseOwner}{objectQualifier}dnnforge_newsarticles_article +SET + {databaseOwner}{objectQualifier}dnnforge_newsarticles_article.moduleid = (select moduleid from {databaseOwner}{objectQualifier}dnnforge_newsarticles_category where {databaseOwner}{objectQualifier}dnnforge_newsarticles_category.categoryid = {databaseOwner}{objectQualifier}dnnforge_newsarticles_article.categoryid) +GO + +if exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories') and OBJECTPROPERTY(id, N'IsUserTable') = 1) +drop table {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories +GO + +if not exists (select * from dbo.sysobjects where id = object_id(N'{databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories') and OBJECTPROPERTY(id, N'IsUserTable') = 1) +BEGIN +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ( + [ArticleID] [int] NOT NULL , + [CategoryID] [int] NOT NULL +) ON [PRIMARY] +END +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories WITH NOCHECK ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_ArticleCategories] PRIMARY KEY CLUSTERED + ( + [ArticleID], + [CategoryID] + ) ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ADD + CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_ArticleCategories_DnnForge_NewsArticles_Article FOREIGN KEY + ( + [ArticleID] + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [ArticleID] + ) , + CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_ArticleCategories_DnnForge_NewsArticles_Category FOREIGN KEY + ( + [CategoryID] + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [CategoryID] + ) +GO + +insert into {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories select ArticleID, CategoryID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + DROP CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_Article_{objectQualifier}DnnForge_NewsArticles_Category +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + DROP COLUMN CategoryID +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article WITH NOCHECK ADD CONSTRAINT + FK_{objectQualifier}DnnForge_NewsArticles_Article_Modules FOREIGN KEY + ( + ModuleID + ) REFERENCES {databaseOwner}{objectQualifier}Modules + ( + ModuleID + ) ON DELETE CASCADE + +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID +WHERE + [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255) +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics + @ModuleID int +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticleCategories + @ArticleID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories +WHERE + [ArticleID] = @ArticleID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticleCategory + @ArticleID int, + @CategoryID int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories( ArticleID, CategoryID ) +VALUES (@ArticleID, @CategoryID) +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleCategories + @ArticleID int +AS + +SELECT + Category.CategoryID, + Category.[Name] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category Category + +WHERE + ArticleCategories.CategoryID = Category.CategoryID + AND + ArticleCategories.ArticleID = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.00.06.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.00.06.SqlDataProvider new file mode 100755 index 0000000..89b6376 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.00.06.SqlDataProvider @@ -0,0 +1,13 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255) +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.00.07.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.00.07.SqlDataProvider new file mode 100755 index 0000000..a39a2e8 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.00.07.SqlDataProvider @@ -0,0 +1,144 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + ImageUrl nvarchar(255) NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl +WHERE + [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255) +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.00.10.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.00.10.SqlDataProvider new file mode 100755 index 0000000..ef0f293 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.00.10.SqlDataProvider @@ -0,0 +1,15 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticle + @ArticleID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories +WHERE + [ArticleID] = @ArticleID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +WHERE + [ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.01.00.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.01.00.SqlDataProvider new file mode 100755 index 0000000..fa9c110 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.01.00.SqlDataProvider @@ -0,0 +1,269 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + IsFeatured bit NOT NULL CONSTRAINT DF_{objectQualifier}DnnForge_NewsArticles_Article_IsFeatured DEFAULT 0 +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment + DROP CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_Comment_{objectQualifier}DnnForge_NewsArticles_Article +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ADD + Rating float NULL, + RemoteAddress nvarchar(50) NULL +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment WITH NOCHECK ADD CONSTRAINT + FK_{objectQualifier}DnnForge_NewsArticles_Comment_{objectQualifier}DnnForge_NewsArticles_Article FOREIGN KEY + ( + ArticleID + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + ( + ArticleID + ) ON DELETE CASCADE + +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary nvarchar(4000), + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured +WHERE + [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment + @ArticleID int, + @UserID int, + @Comment ntext, + @Rating float, + @RemoteAddress nvarchar(50) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [ArticleID], + [UserID], + [Comment], + [Rating], + [RemoteAddress] +) VALUES ( + @ArticleID, + @UserID, + @Comment, + @Rating, + @RemoteAddress +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment + @CommentID int, + @ArticleID int, + @UserID int, + @Comment ntext, + @Rating float, + @RemoteAddress nvarchar(50) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment SET + [ArticleID] = @ArticleID, + [UserID] = @UserID, + [Comment] = @Comment, + [Rating] = @Rating, + [RemoteAddress] = @RemoteAddress +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment + @CommentID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ArticleID int +AS +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorList + @ModuleID int +AS + +SELECT DISTINCT + Authors.UserID, + Authors.Username, + Authors.FirstName, + Authors.LastName + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles, {databaseOwner}{objectQualifier}Users Authors + +WHERE + Articles.AuthorID = Authors.UserID + and + Articles.ModuleID = @ModuleID + and + Articles.IsApproved = 1 + +ORDER BY + Authors.FirstName, Authors.LastName +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.01.01.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.01.01.SqlDataProvider new file mode 100755 index 0000000..00202dc --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.01.01.SqlDataProvider @@ -0,0 +1,16 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.01.02.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.01.02.SqlDataProvider new file mode 100755 index 0000000..5472184 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.01.02.SqlDataProvider @@ -0,0 +1,291 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + DROP CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_Article_{objectQualifier}Users +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + DROP CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_Article_Modules +GO + +CREATE TABLE {databaseOwner}{objectQualifier}Tmp_DnnForge_NewsArticles_Article + ( + ArticleID int NOT NULL IDENTITY (1, 1), + AuthorID int NOT NULL, + ApproverID int NULL, + CreatedDate datetime NOT NULL, + LastUpdate datetime NOT NULL, + Title nvarchar(255) NOT NULL, + Summary ntext NOT NULL, + IsApproved bit NOT NULL, + NumberOfViews int NOT NULL, + IsDraft bit NOT NULL, + StartDate datetime NULL, + EndDate datetime NULL, + ModuleID int NULL, + ImageUrl nvarchar(255) NULL, + IsFeatured bit NOT NULL + ) ON [PRIMARY] + TEXTIMAGE_ON [PRIMARY] +GO + +SET IDENTITY_INSERT {databaseOwner}{objectQualifier}Tmp_DnnForge_NewsArticles_Article ON +GO + +IF EXISTS(SELECT * FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article) + EXEC('INSERT INTO {databaseOwner}{objectQualifier}Tmp_DnnForge_NewsArticles_Article (ArticleID, AuthorID, ApproverID, CreatedDate, LastUpdate, Title, Summary, IsApproved, NumberOfViews, IsDraft, StartDate, EndDate, ModuleID, ImageUrl, IsFeatured) + SELECT ArticleID, AuthorID, ApproverID, CreatedDate, LastUpdate, Title, CONVERT(ntext, Summary), IsApproved, NumberOfViews, IsDraft, StartDate, EndDate, ModuleID, ImageUrl, IsFeatured FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article (HOLDLOCK TABLOCKX)') +GO + +SET IDENTITY_INSERT {databaseOwner}{objectQualifier}Tmp_DnnForge_NewsArticles_Article OFF +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories + DROP CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_ArticleCategories_DnnForge_NewsArticles_Article +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment + DROP CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_Comment_{objectQualifier}DnnForge_NewsArticles_Article +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page + DROP CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_Page_{objectQualifier}DnnForge_NewsArticles_Article +GO + +DROP TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +GO + +EXECUTE sp_rename N'{objectQualifier}Tmp_DnnForge_NewsArticles_Article', N'{objectQualifier}DnnForge_NewsArticles_Article', 'OBJECT' +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD CONSTRAINT + PK_{objectQualifier}DnnForge_NewsArticles_Article PRIMARY KEY CLUSTERED + ( + ArticleID + ) ON [PRIMARY] + +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article WITH NOCHECK ADD CONSTRAINT + FK_{objectQualifier}DnnForge_NewsArticles_Article_Modules FOREIGN KEY + ( + ModuleID + ) REFERENCES {databaseOwner}{objectQualifier}Modules + ( + ModuleID + ) ON DELETE CASCADE + + +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article WITH NOCHECK ADD CONSTRAINT + FK_{objectQualifier}DnnForge_NewsArticles_Article_Users FOREIGN KEY + ( + AuthorID + ) REFERENCES {databaseOwner}{objectQualifier}Users + ( + UserID + ) ON DELETE CASCADE + +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page WITH NOCHECK ADD CONSTRAINT + FK_{objectQualifier}DnnForge_NewsArticles_Page_{objectQualifier}DnnForge_NewsArticles_Article FOREIGN KEY + ( + ArticleID + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + ( + ArticleID + ) ON DELETE CASCADE + +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment WITH NOCHECK ADD CONSTRAINT + FK_{objectQualifier}DnnForge_NewsArticles_Comment_{objectQualifier}DnnForge_NewsArticles_Article FOREIGN KEY + ( + ArticleID + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + ( + ArticleID + ) ON DELETE CASCADE + + +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories WITH NOCHECK ADD CONSTRAINT + FK_{objectQualifier}DnnForge_NewsArticles_ArticleCategories_{objectQualifier}DnnForge_NewsArticles_Article FOREIGN KEY + ( + ArticleID + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + ( + ArticleID + ) + +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + LastUpdateID int NULL +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET LastUpdateID = AuthorID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID +WHERE + [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.02.00.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.02.00.SqlDataProvider new file mode 100755 index 0000000..41d2242 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.02.00.SqlDataProvider @@ -0,0 +1,15 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteCategory + @CategoryID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories +WHERE + [CategoryID] = @CategoryID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [CategoryID] = @CategoryID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.02.05.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.02.05.SqlDataProvider new file mode 100755 index 0000000..1bfa11a --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.02.05.SqlDataProvider @@ -0,0 +1,111 @@ +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplate ( + [TemplateID] [int] IDENTITY (1, 1) NOT NULL , + [ModuleID] [int] NOT NULL , + [Name] [nvarchar] (50) NOT NULL , + [Subject] [nvarchar] (255) NOT NULL , + [Template] [ntext] NOT NULL +) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplate ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_EmailTemplate] PRIMARY KEY CLUSTERED + ( + [TemplateID] + ) ON [PRIMARY] +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplateGet + @TemplateID int +AS + +SELECT + [TemplateID], + [ModuleID], + [Name], + [Subject], + [Template] +FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplate +WHERE + [TemplateID] = @TemplateID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplateList + @ModuleID int +AS + +SELECT + [TemplateID], + [ModuleID], + [Name], + [Subject], + [Template] +FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplate +WHERE + [ModuleID] = @ModuleID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplateAdd + @ModuleID int, + @Name nvarchar(50), + @Subject nvarchar(255), + @Template ntext +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplate ( + [ModuleID], + [Name], + [Subject], + [Template] +) VALUES ( + @ModuleID, + @Name, + @Subject, + @Template +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplateUpdate + @TemplateID int, + @ModuleID int, + @Name nvarchar(50), + @Subject nvarchar(255), + @Template ntext +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplate SET + [ModuleID] = @ModuleID, + [Name] = @Name, + [Subject] = @Subject, + [Template] = @Template +WHERE + [TemplateID] = @TemplateID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplateDelete + @TemplateID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplate +WHERE + [TemplateID] = @TemplateID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplateGetByName + @ModuleID int, + @Name nvarchar(50) +AS + +SELECT + [TemplateID], + [ModuleID], + [Name], + [Subject], + [Template] +FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_EmailTemplate +WHERE + [ModuleID] = @ModuleID + and + [Name] = @Name +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.02.07.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.02.07.SqlDataProvider new file mode 100755 index 0000000..ccd619e --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.02.07.SqlDataProvider @@ -0,0 +1,4 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + DROP CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_Article_Users +GO + diff --git a/Providers/DataProvider/SqlDataProvider/00.03.00.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.03.00.SqlDataProvider new file mode 100755 index 0000000..f5ff526 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.03.00.SqlDataProvider @@ -0,0 +1,7 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.03.02.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.03.02.SqlDataProvider new file mode 100755 index 0000000..c7fd868 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.03.02.SqlDataProvider @@ -0,0 +1,8 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.04.02.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.04.02.SqlDataProvider new file mode 100755 index 0000000..1aa3bd5 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.04.02.SqlDataProvider @@ -0,0 +1,18 @@ + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50) +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.04.03.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.04.03.SqlDataProvider new file mode 100755 index 0000000..4caf4c2 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.04.03.SqlDataProvider @@ -0,0 +1,171 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + URL nvarchar(255) NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50) +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID], + [Url] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID, + @Url +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID, + [Url] = @Url +WHERE + [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.04.08.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.04.08.SqlDataProvider new file mode 100755 index 0000000..f958e6b --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.04.08.SqlDataProvider @@ -0,0 +1,23 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories DROP + CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_ArticleCategories_{objectQualifier}DnnForge_NewsArticles_Article +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories DROP + CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_ArticleCategories_DnnForge_NewsArticles_Category +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ADD + CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_ArticleCategories_{objectQualifier}DnnForge_NewsArticles_Article FOREIGN KEY + ( + [ArticleID] + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [ArticleID] + ) ON DELETE CASCADE + , + CONSTRAINT FK_{objectQualifier}DnnForge_NewsArticles_ArticleCategories_{objectQualifier}DnnForge_NewsArticles_Category FOREIGN KEY + ( + [CategoryID] + ) REFERENCES {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [CategoryID] + ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.04.09.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.04.09.SqlDataProvider new file mode 100755 index 0000000..8bdbb67 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.04.09.SqlDataProvider @@ -0,0 +1,12 @@ +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET StartDate = CreatedDate +WHERE StartDate IS NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics + @ModuleID int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.00.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.00.SqlDataProvider new file mode 100755 index 0000000..b6dc815 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.00.SqlDataProvider @@ -0,0 +1,116 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ADD + Type int NOT NULL Default 0, + TrackbackUrl nvarchar(255) NULL, + TrackbackTitle nvarchar(255) NULL, + TrackbackBlogName nvarchar(255) NULL, + TrackbackExcerpt ntext NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment + @ArticleID int, + @UserID int, + @Comment ntext, + @Rating float, + @RemoteAddress nvarchar(50) , + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [ArticleID], + [UserID], + [Comment], + [Rating], + [RemoteAddress], + [Type], + [TrackbackUrl], + [TrackbackTitle], + [TrackbackBlogName], + [TrackbackExcerpt] +) VALUES ( + @ArticleID, + @UserID, + @Comment, + @Rating, + @RemoteAddress, + @Type, + @TrackbackUrl, + @TrackbackTitle, + @TrackbackBlogName, + @TrackbackExcerpt +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment + @CommentID int, + @ArticleID int, + @UserID int, + @Comment ntext, + @Rating float, + @RemoteAddress nvarchar(50), + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment SET + [ArticleID] = @ArticleID, + [UserID] = @UserID, + [Comment] = @Comment, + [Rating] = @Rating, + [RemoteAddress] = @RemoteAddress, + [Type] = @Type, + [TrackbackUrl] = @TrackbackUrl, + [TrackbackTitle] = @TrackbackTitle, + [TrackbackBlogName] = @TrackbackBlogName, + [TrackbackExcerpt] = @TrackbackExcerpt +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment + @CommentID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ArticleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50) +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.02.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.02.SqlDataProvider new file mode 100755 index 0000000..9532b78 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.02.SqlDataProvider @@ -0,0 +1,19 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics + @ModuleID int +AS + +select + Category.CategoryID, + Category.Name, + (select count(*) from {databaseOwner}{objectQualifier}dnnforge_newsarticles_articlecategories articleCategories, {databaseOwner}{objectQualifier}dnnforge_newsarticles_article articles where categoryid = Category.CategoryID and articleCategories.articleID = articles.ArticleID and articles.IsApproved = 1 AND (articles.StartDate is null or articles.StartDate < DateAdd(mi, 1, GetDate())) AND (articles.EndDate is null or articles.EndDate > DateAdd(mi, 1, GetDate())) ) as 'NumberOfArticles', + (select sum(NumberOfViews) from {databaseOwner}{objectQualifier}dnnforge_newsarticles_articlecategories articleCategories, {databaseOwner}{objectQualifier}dnnforge_newsarticles_article articles where categoryid = Category.CategoryID and articleCategories.articleID = articles.ArticleID AND (articles.StartDate is null or articles.StartDate < DateAdd(mi, 1, GetDate())) AND (articles.EndDate is null or articles.EndDate > DateAdd(mi, 1, GetDate())) ) as 'NumberOfViews' +from + {databaseOwner}{objectQualifier}dnnforge_newsarticles_category Category +where + Category.ModuleID = @ModuleID +ORDER BY + Category.Name +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.05.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.05.SqlDataProvider new file mode 100755 index 0000000..61424e9 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.05.SqlDataProvider @@ -0,0 +1,30 @@ +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int +AS + +select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] +from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article +where ModuleID = @ModuleID and IsApproved = 1 and IsDraft = 0 +group by Year(StartDate), Month(StartDate) +order by [Year] desc, [Month] desc +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.09.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.09.SqlDataProvider new file mode 100755 index 0000000..6b7da1a --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.09.SqlDataProvider @@ -0,0 +1,25 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +EXEC(' +select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] +from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article +where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' +group by Year(StartDate), Month(StartDate) +order by [Year] desc, [Month] desc') +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.11.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.11.SqlDataProvider new file mode 100755 index 0000000..577cdcc --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.11.SqlDataProvider @@ -0,0 +1,28 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +EXEC(' +select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] +from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article +where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' +group by Year(StartDate), Month(StartDate) +order by [Year] desc, [Month] desc') +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.12.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.12.SqlDataProvider new file mode 100755 index 0000000..24289d9 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.12.SqlDataProvider @@ -0,0 +1,465 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +EXEC(' +select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] +from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article +where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' +group by Year(StartDate), Month(StartDate) +order by [Year] desc, [Month] desc') +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @Month int, + @Year int +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = ' 1 = 1 ' + +IF (@MaxCount is not null) + SELECT @strTop = ' TOP ' + convert(nvarchar, @MaxCount) + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@MaxAge is not null) and (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND Article.CreatedDate > ''' + convert(nvarchar, DateAdd(day, @MaxAge, @StartDate)) + '''' + +IF (@MaxAge is not null) and (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND Article.CreatedDate < ''' + convert(nvarchar, @StartDate) + '''' + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' + +IF (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null or Article.EndDate > ''' + convert(nvarchar, DateAdd(day, -1, GetDate())) + ''')' + +IF (@Month is not null) + SELECT @strWhere = @strWhere + ' AND Month(Article.StartDate) = ' + convert(nvarchar, @Month) + +IF (@Year is not null) + SELECT @strWhere = @strWhere + ' AND Year(Article.StartDate) = ' + convert(nvarchar, @Year) + +EXEC(' +SELECT ' + @strTop + ' + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '''' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '''' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as ''PageCount'', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as ''CommentCount'', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as ''Rating'', + case when Images.FileName is null then '''' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article INNER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID INNER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = ''fileid='' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = ''fileid='' + CONVERT(nvarchar, Images.FileID) + +WHERE ' + + @strWhere + ' + +ORDER BY + ' + @SortBy + ' DESC') +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article INNER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID INNER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article INNER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID INNER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[IsApproved] = @IsApproved + AND + Article.[IsDraft] = 0 + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article INNER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID INNER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[AuthorID] = @AuthorID + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as CommentCount, + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as Rating, + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS Url + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article INNER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID INNER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[AuthorID] = @AuthorID + AND + Article.[IsApproved] = @IsApproved + AND + Article.[IsDraft] = @IsDraft + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article INNER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID INNER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment + @CommentID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[Rating], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ArticleID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[Rating], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + Comment.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.13.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.13.SqlDataProvider new file mode 100755 index 0000000..fbf4290 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.13.SqlDataProvider @@ -0,0 +1,30 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' + +EXEC(' +select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] +from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article +where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' +group by Year(StartDate), Month(StartDate) +order by [Year] desc, [Month] desc') +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.17.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.17.SqlDataProvider new file mode 100755 index 0000000..933e47b --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.17.SqlDataProvider @@ -0,0 +1,274 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + IsSecure int NOT NULL Default 0 +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @Month int, + @Year int +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = ' 1 = 1 ' + +IF (@MaxCount is not null) + SELECT @strTop = ' TOP ' + convert(nvarchar, @MaxCount) + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@MaxAge is not null) and (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND Article.CreatedDate > ''' + convert(nvarchar, DateAdd(day, @MaxAge, @StartDate)) + '''' + +IF (@MaxAge is not null) and (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND Article.CreatedDate < ''' + convert(nvarchar, @StartDate) + '''' + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' + +IF (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null or Article.EndDate > ''' + convert(nvarchar, DateAdd(day, -1, GetDate())) + ''')' + +IF (@Month is not null) + SELECT @strWhere = @strWhere + ' AND Month(Article.StartDate) = ' + convert(nvarchar, @Month) + +IF (@Year is not null) + SELECT @strWhere = @strWhere + ' AND Year(Article.StartDate) = ' + convert(nvarchar, @Year) + +EXEC(' +SELECT ' + @strTop + ' + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + '''' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '''' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as ''PageCount'', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as ''CommentCount'', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as ''Rating'', + case when Images.FileName is null then '''' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article INNER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID INNER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = ''fileid='' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = ''fileid='' + CONVERT(nvarchar, Images.FileID) + +WHERE ' + + @strWhere + ' + +ORDER BY + ' + @SortBy + ' DESC') +GO + + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article INNER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID INNER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ArticleID] = @ArticleID +GO + + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID], + [Url], + [IsSecure] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID, + @Url, + @IsSecure +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID, + [Url] = @Url, + [IsSecure] = @IsSecure +WHERE + [ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.20.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.20.SqlDataProvider new file mode 100755 index 0000000..8619d1b --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.20.SqlDataProvider @@ -0,0 +1,163 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ADD + AnonymousName nvarchar(255) NULL, + AnonymousEmail nvarchar(255) NULL, + AnonymousURL nvarchar(255) NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment + @ArticleID int, + @UserID int, + @Comment ntext, + @Rating float, + @RemoteAddress nvarchar(50) , + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [ArticleID], + [UserID], + [Comment], + [Rating], + [RemoteAddress], + [Type], + [TrackbackUrl], + [TrackbackTitle], + [TrackbackBlogName], + [TrackbackExcerpt], + [AnonymousName], + [AnonymousEmail], + [AnonymousURL] +) VALUES ( + @ArticleID, + @UserID, + @Comment, + @Rating, + @RemoteAddress, + @Type, + @TrackbackUrl, + @TrackbackTitle, + @TrackbackBlogName, + @TrackbackExcerpt, + @AnonymousName, + @AnonymousEmail, + @AnonymousURL +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment + @CommentID int, + @ArticleID int, + @UserID int, + @Comment ntext, + @Rating float, + @RemoteAddress nvarchar(50), + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment SET + [ArticleID] = @ArticleID, + [UserID] = @UserID, + [Comment] = @Comment, + [Rating] = @Rating, + [RemoteAddress] = @RemoteAddress, + [Type] = @Type, + [TrackbackUrl] = @TrackbackUrl, + [TrackbackTitle] = @TrackbackTitle, + [TrackbackBlogName] = @TrackbackBlogName, + [TrackbackExcerpt] = @TrackbackExcerpt, + [AnonymousName] = @AnonymousName, + [AnonymousEmail] = @AnonymousEmail, + [AnonymousURL] = @AnonymousURL +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment + @CommentID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[Rating], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ArticleID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[Rating], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + Comment.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.21.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.21.SqlDataProvider new file mode 100755 index 0000000..84ee571 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.21.SqlDataProvider @@ -0,0 +1,168 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ADD + NotifyMe bit NOT NULL CONSTRAINT DF_{objectQualifier}DnnForge_NewsArticles_Comment_NotifyMe DEFAULT 0 +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment + @ArticleID int, + @UserID int, + @Comment ntext, + @Rating float, + @RemoteAddress nvarchar(50) , + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255), + @NotifyMe bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [ArticleID], + [UserID], + [Comment], + [Rating], + [RemoteAddress], + [Type], + [TrackbackUrl], + [TrackbackTitle], + [TrackbackBlogName], + [TrackbackExcerpt], + [AnonymousName], + [AnonymousEmail], + [AnonymousURL], + [NotifyMe] +) VALUES ( + @ArticleID, + @UserID, + @Comment, + @Rating, + @RemoteAddress, + @Type, + @TrackbackUrl, + @TrackbackTitle, + @TrackbackBlogName, + @TrackbackExcerpt, + @AnonymousName, + @AnonymousEmail, + @AnonymousURL, + @NotifyMe +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment + @CommentID int, + @ArticleID int, + @UserID int, + @Comment ntext, + @Rating float, + @RemoteAddress nvarchar(50), + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255), + @NotifyMe bit +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment SET + [ArticleID] = @ArticleID, + [UserID] = @UserID, + [Comment] = @Comment, + [Rating] = @Rating, + [RemoteAddress] = @RemoteAddress, + [Type] = @Type, + [TrackbackUrl] = @TrackbackUrl, + [TrackbackTitle] = @TrackbackTitle, + [TrackbackBlogName] = @TrackbackBlogName, + [TrackbackExcerpt] = @TrackbackExcerpt, + [AnonymousName] = @AnonymousName, + [AnonymousEmail] = @AnonymousEmail, + [AnonymousURL] = @AnonymousURL, + [NotifyMe] = @NotifyMe +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment + @CommentID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[Rating], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ArticleID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[Rating], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + Comment.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.22.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.22.SqlDataProvider new file mode 100755 index 0000000..654f4f0 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.22.SqlDataProvider @@ -0,0 +1,109 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @Month int, + @Year int +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = ' 1 = 1 ' + +IF (@MaxCount is not null) + SELECT @strTop = ' TOP ' + convert(nvarchar, @MaxCount) + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@MaxAge is not null) and (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND Article.CreatedDate > ''' + convert(nvarchar, DateAdd(day, @MaxAge, @StartDate)) + '''' + +IF (@MaxAge is not null) and (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND Article.CreatedDate < ''' + convert(nvarchar, @StartDate) + '''' + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' + +IF (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null or Article.EndDate > ''' + convert(nvarchar, GetDate()) + ''')' + +IF (@Month is not null) + SELECT @strWhere = @strWhere + ' AND Month(Article.StartDate) = ' + convert(nvarchar, @Month) + +IF (@Year is not null) + SELECT @strWhere = @strWhere + ' AND Year(Article.StartDate) = ' + convert(nvarchar, @Year) + +EXEC(' +SELECT ' + @strTop + ' + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + '''' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '''' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as ''PageCount'', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as ''CommentCount'', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as ''Rating'', + case when Images.FileName is null then '''' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article INNER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID INNER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = ''fileid='' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = ''fileid='' + CONVERT(nvarchar, Images.FileID) + +WHERE ' + + @strWhere + ' + +ORDER BY + ' + @SortBy + ' DESC') +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.24.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.24.SqlDataProvider new file mode 100755 index 0000000..5b2a0c0 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.24.SqlDataProvider @@ -0,0 +1,37 @@ + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ArticleID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[Rating], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + Comment.[ArticleID] = @ArticleID +ORDER BY + Comment.[CreatedDate] ASC +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.26.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.26.SqlDataProvider new file mode 100755 index 0000000..2074d25 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.26.SqlDataProvider @@ -0,0 +1,378 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @Month int, + @Year int +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = ' 1 = 1 ' + +IF (@MaxCount is not null) + SELECT @strTop = ' TOP ' + convert(nvarchar, @MaxCount) + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@MaxAge is not null) and (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, DateAdd(day, @MaxAge, @StartDate)) + '''' + +IF (@MaxAge is not null) and (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND Article.StartDate < ''' + convert(nvarchar, @StartDate) + '''' + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' + +IF (@ShowHiddenAndExpired = 0) + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null or Article.EndDate > ''' + convert(nvarchar, GetDate()) + ''')' + +IF (@Month is not null) + SELECT @strWhere = @strWhere + ' AND Month(Article.StartDate) = ' + convert(nvarchar, @Month) + +IF (@Year is not null) + SELECT @strWhere = @strWhere + ' AND Year(Article.StartDate) = ' + convert(nvarchar, @Year) + +EXEC(' +SELECT ' + @strTop + ' + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + '''' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '''' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as ''PageCount'', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as ''CommentCount'', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as ''Rating'', + case when Images.FileName is null then '''' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = ''fileid='' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = ''fileid='' + CONVERT(nvarchar, Images.FileID) + +WHERE ' + + @strWhere + ' + +ORDER BY + ' + @SortBy + ' DESC') +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[AuthorID] = @AuthorID + +ORDER BY + Article.[CreatedDate] DESC +GO + + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[AuthorID] = @AuthorID + AND + Article.[IsApproved] = @IsApproved + AND + Article.[IsDraft] = @IsDraft + +ORDER BY + Article.[CreatedDate] DESC +GO + + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[IsApproved] = @IsApproved + AND + Article.[IsDraft] = 0 + +ORDER BY + Article.[CreatedDate] DESC +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.28.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.28.SqlDataProvider new file mode 100755 index 0000000..eca3b7b --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.28.SqlDataProvider @@ -0,0 +1,19 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.40.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.40.SqlDataProvider new file mode 100755 index 0000000..3fe492a --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.40.SqlDataProvider @@ -0,0 +1,33 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics + @ModuleID int, + @CategoryID varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Category.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND CategoryID in (' + @CategoryID + ')' + +EXEC(' +select + Category.CategoryID, + Category.Name, + (select count(*) from {databaseOwner}{objectQualifier}dnnforge_newsarticles_articlecategories articleCategories, {databaseOwner}{objectQualifier}dnnforge_newsarticles_article articles where categoryid = Category.CategoryID and articleCategories.articleID = articles.ArticleID and articles.IsApproved = 1 AND (articles.StartDate is null or articles.StartDate < DateAdd(mi, 1, GetDate())) AND (articles.EndDate is null or articles.EndDate > DateAdd(mi, 1, GetDate())) ) as ''NumberOfArticles'', + (select sum(NumberOfViews) from {databaseOwner}{objectQualifier}dnnforge_newsarticles_articlecategories articleCategories, {databaseOwner}{objectQualifier}dnnforge_newsarticles_article articles where categoryid = Category.CategoryID and articleCategories.articleID = articles.ArticleID AND (articles.StartDate is null or articles.StartDate < DateAdd(mi, 1, GetDate())) AND (articles.EndDate is null or articles.EndDate > DateAdd(mi, 1, GetDate())) ) as ''NumberOfViews'' +from + {databaseOwner}{objectQualifier}dnnforge_newsarticles_category Category +where 1 = 1 ' + + @strWhere + ' +ORDER BY + Category.Name') +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.41.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.41.SqlDataProvider new file mode 100755 index 0000000..79b6a9e --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.41.SqlDataProvider @@ -0,0 +1,27 @@ +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + +EXEC(' +SELECT + UserID, UserName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where 1 = 1 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, FirstName, LastName') +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.46.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.46.SqlDataProvider new file mode 100755 index 0000000..ce8df66 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.46.SqlDataProvider @@ -0,0 +1,537 @@ +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating ( + [RatingID] [int] IDENTITY (1, 1) NOT NULL , + [ArticleID] [int] NOT NULL , + [UserID] [int] NOT NULL , + [CreatedDate] [datetime] NOT NULL , + [Rating] [float] NULL +) ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Rating] PRIMARY KEY CLUSTERED + ( + [RatingID] + ) ON [PRIMARY] +GO + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating(ArticleID, UserID, CreatedDate, Rating) +SELECT ArticleID, UserID, CreatedDate, Rating FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment WHERE Rating is not null +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_RatingAdd + @ArticleID int, + @UserID int, + @CreatedDate datetime, + @Rating float +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating ( + [ArticleID], + [UserID], + [CreatedDate], + [Rating] +) VALUES ( + @ArticleID, + @UserID, + @CreatedDate, + @Rating +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_RatingDelete + @RatingID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating +WHERE + [RatingID] = @RatingID + +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_RatingGet + @ArticleID int, + @UserID int + +AS + +SELECT + [RatingID], + [ArticleID], + [UserID], + [CreatedDate], + [Rating] +FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating +WHERE + [ArticleID] = @ArticleID + and + [UserID] = @UserID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_RatingGetByID + @RatingID int + +AS + +SELECT + [RatingID], + [ArticleID], + [UserID], + [CreatedDate], + [Rating] +FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating +WHERE + [RatingID] = @RatingID +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment + DROP COLUMN Rating +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment + @ArticleID int, + @UserID int, + @Comment ntext, + @RemoteAddress nvarchar(50) , + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255), + @NotifyMe bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [ArticleID], + [UserID], + [Comment], + [RemoteAddress], + [Type], + [TrackbackUrl], + [TrackbackTitle], + [TrackbackBlogName], + [TrackbackExcerpt], + [AnonymousName], + [AnonymousEmail], + [AnonymousURL], + [NotifyMe] +) VALUES ( + @ArticleID, + @UserID, + @Comment, + @RemoteAddress, + @Type, + @TrackbackUrl, + @TrackbackTitle, + @TrackbackBlogName, + @TrackbackExcerpt, + @AnonymousName, + @AnonymousEmail, + @AnonymousURL, + @NotifyMe +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment + @CommentID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ArticleID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + Comment.[ArticleID] = @ArticleID +ORDER BY + Comment.[CreatedDate] ASC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment + @CommentID int, + @ArticleID int, + @UserID int, + @Comment ntext, + @RemoteAddress nvarchar(50), + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255), + @NotifyMe bit +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment SET + [ArticleID] = @ArticleID, + [UserID] = @UserID, + [Comment] = @Comment, + [RemoteAddress] = @RemoteAddress, + [Type] = @Type, + [TrackbackUrl] = @TrackbackUrl, + [TrackbackTitle] = @TrackbackTitle, + [TrackbackBlogName] = @TrackbackBlogName, + [TrackbackExcerpt] = @TrackbackExcerpt, + [AnonymousName] = @AnonymousName, + [AnonymousEmail] = @AnonymousEmail, + [AnonymousURL] = @AnonymousURL, + [NotifyMe] = @NotifyMe +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[IsApproved] = @IsApproved + AND + Article.[IsDraft] = 0 + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[AuthorID] = @AuthorID + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[AuthorID] = @AuthorID + AND + Article.[IsApproved] = @IsApproved + AND + Article.[IsDraft] = @IsDraft + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.48.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.48.SqlDataProvider new file mode 100755 index 0000000..7a29c79 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.48.SqlDataProvider @@ -0,0 +1,421 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + ADD IsNewWindow bit NOT NULL CONSTRAINT DF_{objectQualifier}DnnForge_NewsArticles_Article_IsNewWindow DEFAULT 0 +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID], + [Url], + [IsSecure], + [IsNewWindow] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID, + @Url, + @IsSecure, + @IsNewWindow +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID, + [Url] = @Url, + [IsSecure] = @IsSecure, + [IsNewWindow] = @IsNewWindow +WHERE + [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'RatingCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList + @ModuleID int +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'RatingCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved + @ModuleID int, + @IsApproved bit +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'RatingCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[IsApproved] = @IsApproved + AND + Article.[IsDraft] = 0 + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor + @ModuleID int, + @AuthorID int +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'RatingCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[AuthorID] = @AuthorID + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus + @ModuleID int, + @AuthorID int, + @IsApproved bit, + @IsDraft bit +AS + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'RatingCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) +WHERE + Article.[ModuleID] = @ModuleID + AND + Article.[AuthorID] = @AuthorID + AND + Article.[IsApproved] = @IsApproved + AND + Article.[IsDraft] = @IsDraft + +ORDER BY + Article.[CreatedDate] DESC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.51.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.51.SqlDataProvider new file mode 100755 index 0000000..16975c9 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.51.SqlDataProvider @@ -0,0 +1,20 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.55.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.55.SqlDataProvider new file mode 100755 index 0000000..9abf13d --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.55.SqlDataProvider @@ -0,0 +1,21 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.56.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.56.SqlDataProvider new file mode 100755 index 0000000..b83ef97 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.56.SqlDataProvider @@ -0,0 +1,22 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowHiddenAndExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.58.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.58.SqlDataProvider new file mode 100755 index 0000000..072310d --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.58.SqlDataProvider @@ -0,0 +1,23 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.66.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.66.SqlDataProvider new file mode 100755 index 0000000..072310d --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.66.SqlDataProvider @@ -0,0 +1,23 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.68.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.68.SqlDataProvider new file mode 100755 index 0000000..072310d --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.68.SqlDataProvider @@ -0,0 +1,23 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved int, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.69.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.69.SqlDataProvider new file mode 100755 index 0000000..4b74274 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.69.SqlDataProvider @@ -0,0 +1,50 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + '' as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + '' as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'RatingCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.74.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.74.SqlDataProvider new file mode 100755 index 0000000..0602bc3 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.74.SqlDataProvider @@ -0,0 +1,36 @@ +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleList +GO + +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByApproved +GO + +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthor +GO + +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListByAuthorByStatus +GO + +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved bit, + @IsDraft bit, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.76.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.76.SqlDataProvider new file mode 100755 index 0000000..fb8f447 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.76.SqlDataProvider @@ -0,0 +1,24 @@ +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved bit, + @IsDraft bit, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.77.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.77.SqlDataProvider new file mode 100755 index 0000000..dc9b9e3 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.77.SqlDataProvider @@ -0,0 +1,52 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment.ArticleID = Article.ArticleID) as 'CommentCount', + (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page.ArticleID = Article.ArticleID) as 'PageCount', + (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'Rating', + (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating.ArticleID = Article.ArticleID) as 'RatingCount', + case when Images.FileName is null then '' else Images.Folder + Images.FileName end AS ImageUrlResolved, + case when UrlFiles.FileName is null then Article.URL else UrlFiles.Folder + UrlFiles.FileName end AS URL + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files UrlFiles ON Article.URL = 'fileid=' + CONVERT(nvarchar, UrlFiles.FileID) LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Files Images ON Article.ImageUrl = 'fileid=' + CONVERT(nvarchar, Images.FileID) + +WHERE + Article.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.05.78.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.05.78.SqlDataProvider new file mode 100755 index 0000000..6c9d8af --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.05.78.SqlDataProvider @@ -0,0 +1,84 @@ +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved bit, + @IsDraft bit, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO + +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorList + @ModuleID int +AS + +SELECT DISTINCT + Authors.UserID, + Authors.Username, + Authors.FirstName, + Authors.LastName, + Authors.DisplayName + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles, {databaseOwner}{objectQualifier}Users Authors + +WHERE + Articles.AuthorID = Authors.UserID + and + Articles.ModuleID = @ModuleID + and + Articles.IsApproved = 1 + +ORDER BY + Authors.FirstName, Authors.LastName +GO + +drop procedure {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' +SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null or Article.EndDate > ''' + convert(nvarchar, DateAdd(mi, -1, GetDate())) + ''')' + +EXEC(' +select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] +from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article +where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' +group by Year(StartDate), Month(StartDate) +order by [Year] desc, [Month] desc') +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.06.00.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.06.00.SqlDataProvider new file mode 100755 index 0000000..cc52fb0 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.06.00.SqlDataProvider @@ -0,0 +1,218 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ADD + isApproved bit NOT NULL CONSTRAINT DF_{objectQualifier}DnnForge_NewsArticles_Comment_isApproved DEFAULT 1, + approvedBy int NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment + @ArticleID int, + @UserID int, + @Comment ntext, + @RemoteAddress nvarchar(50) , + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255), + @NotifyMe bit, + @IsApproved bit, + @ApprovedBy int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [ArticleID], + [UserID], + [Comment], + [RemoteAddress], + [Type], + [TrackbackUrl], + [TrackbackTitle], + [TrackbackBlogName], + [TrackbackExcerpt], + [AnonymousName], + [AnonymousEmail], + [AnonymousURL], + [NotifyMe], + [IsApproved], + [ApprovedBy] +) VALUES ( + @ArticleID, + @UserID, + @Comment, + @RemoteAddress, + @Type, + @TrackbackUrl, + @TrackbackTitle, + @TrackbackBlogName, + @TrackbackExcerpt, + @AnonymousName, + @AnonymousEmail, + @AnonymousURL, + @NotifyMe, + @IsApproved, + @ApprovedBy +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment + @CommentID int, + @ArticleID int, + @UserID int, + @Comment ntext, + @RemoteAddress nvarchar(50), + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255), + @NotifyMe bit, + @IsApproved bit, + @ApprovedBy int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment SET + [ArticleID] = @ArticleID, + [UserID] = @UserID, + [Comment] = @Comment, + [RemoteAddress] = @RemoteAddress, + [Type] = @Type, + [TrackbackUrl] = @TrackbackUrl, + [TrackbackTitle] = @TrackbackTitle, + [TrackbackBlogName] = @TrackbackBlogName, + [TrackbackExcerpt] = @TrackbackExcerpt, + [AnonymousName] = @AnonymousName, + [AnonymousEmail] = @AnonymousEmail, + [AnonymousURL] = @AnonymousURL, + [NotifyMe] = @NotifyMe, + [IsApproved] = @IsApproved, + [ApprovedBy] = @ApprovedBy +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ModuleID int, + @ArticleID int, + @IsApproved bit +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Comment.[IsApproved], + Comment.[ApprovedBy], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article on Comment.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + Article.ModuleID = @ModuleID + and + (@ArticleID is null OR Comment.[ArticleID] = @ArticleID) + and + Comment.IsApproved = @IsApproved +ORDER BY + Comment.[CreatedDate] ASC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment + @CommentID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Comment.[IsApproved], + Comment.[ApprovedBy], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved bit, + @IsDraft bit, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.06.04.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.06.04.SqlDataProvider new file mode 100755 index 0000000..335a20b --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.06.04.SqlDataProvider @@ -0,0 +1,45 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(255), + @GroupBy varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' +SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null or Article.EndDate > ''' + convert(nvarchar, DateAdd(mi, -1, GetDate())) + ''')' + +IF( @GroupBy = 'Month' ) +BEGIN +EXEC(' +select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] +from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article +where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' +group by Year(StartDate), Month(StartDate) +order by [Year] desc, [Month] desc') +END +ELSE +BEGIN +EXEC(' +select 1 as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] +from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article +where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' +group by Year(StartDate) +order by [Year] desc') +END +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.06.07.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.06.07.SqlDataProvider new file mode 100755 index 0000000..72d5284 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.06.07.SqlDataProvider @@ -0,0 +1,74 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + Add Summary2 ntext +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + SET Summary2 = Summary +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + DROP COLUMN Summary +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + Add Summary ntext +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + SET Summary = Summary2 +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + DROP COLUMN Summary2 +GO + +CREATE TABLE #Article +( + ArticleID INT +) + +INSERT INTO #Article +select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article where Article.ArticleID not in (select ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page WHERE Article.ArticleID = Page.ArticleID) + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page(ArticleID, Title, PageText, SortOrder) +select ArticleID, Title, Summary, 0 from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article where Article.ArticleID not in (select ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page WHERE Article.ArticleID = Page.ArticleID) + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET Summary = null +WHERE ArticleID in (select ArticleID from #Article) + +DROP TABLE #Article +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved bit, + @IsDraft bit, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.06.08.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.06.08.SqlDataProvider new file mode 100755 index 0000000..cfe460c --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.06.08.SqlDataProvider @@ -0,0 +1,24 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved bit, + @IsDraft bit, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.06.09.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.06.09.SqlDataProvider new file mode 100755 index 0000000..cfe460c --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.06.09.SqlDataProvider @@ -0,0 +1,24 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved bit, + @IsDraft bit, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.06.11.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.06.11.SqlDataProvider new file mode 100755 index 0000000..18dea9d --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.06.11.SqlDataProvider @@ -0,0 +1,63 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + +EXEC(' +SELECT + UserID, UserName, DisplayName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where 1 = 1 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, DisplayName, FirstName, LastName') +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved bit, + @IsDraft bit, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.06.14.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.06.14.SqlDataProvider new file mode 100755 index 0000000..a825ac0 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.06.14.SqlDataProvider @@ -0,0 +1,26 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @MaxAge int, + @IsApproved bit, + @IsDraft bit, + @StartDate datetime, + @KeyWords varchar(255), + @ShowPending bit, + @ShowExpired bit, + @AuthorID int, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @SortBy varchar(50), + @SortDirection varchar(50), + @Month int, + @Year int +AS +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.06.16.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.06.16.SqlDataProvider new file mode 100755 index 0000000..9142f72 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.06.16.SqlDataProvider @@ -0,0 +1,116 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetComment + @CommentID int +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Comment.[IsApproved], + Comment.[ApprovedBy], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + [CommentID] = @CommentID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ModuleID int, + @ArticleID int, + @IsApproved bit +AS + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Comment.[IsApproved], + Comment.[ApprovedBy], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article on Comment.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + Article.ModuleID = @ModuleID + and + (@ArticleID is null OR Comment.[ArticleID] = @ArticleID) + and + Comment.IsApproved = @IsApproved +ORDER BY + Comment.[CreatedDate] ASC +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(255), + @SortBy varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + +EXEC(' +SELECT + UserID, UserName, DisplayName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where 1 = 1 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, DisplayName, FirstName, LastName +ORDER BY ' + + @SortBy) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.06.18.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.06.18.SqlDataProvider new file mode 100755 index 0000000..af0744a --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.06.18.SqlDataProvider @@ -0,0 +1 @@ + diff --git a/Providers/DataProvider/SqlDataProvider/00.07.00.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.00.SqlDataProvider new file mode 100755 index 0000000..10e5a60 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.00.SqlDataProvider @@ -0,0 +1,653 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + ADD [CommentCount] int, [PageCount] int, [Rating] decimal(3,2), [RatingCount] int +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords varchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit +AS +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as UpdatedDisplayName, + Page.PageText as 'Body' + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + Article.[ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(255), + @GroupBy varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' + +IF( @GroupBy = 'Month' ) +BEGIN +EXEC(' + select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate), Month(StartDate) + order by [Year] desc, [Month] desc') +END +ELSE +BEGIN +EXEC(' + select 1 as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate) + order by [Year] desc') +END +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(255), + @SortBy varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + +EXEC(' +SELECT + UserID, UserName, DisplayName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where Articles.IsApproved = 1 and Articles.IsDraft = 0 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, DisplayName, FirstName, LastName +ORDER BY ' + + @SortBy) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics + @ModuleID int, + @CategoryID varchar(255) +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND c.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND c.CategoryID in (' + @CategoryID + ')' + +EXEC(' +SELECT + c.CategoryID, c.Name, count(ac.ArticleID) as ''NumberOfArticles'', sum(a.NumberOfViews) as ''NumberOfViews'' +FROM + {databaseOwner}{objectQualifier}dnnforge_newsarticles_category c + INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON c.CategoryID = ac.CategoryID + INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON + a.ArticleID = ac.ArticleID AND + a.IsDraft = 0 AND + a.IsApproved = 1 AND + (a.StartDate is null or a.StartDate < DateAdd(mi, 1, GetDate())) +WHERE + 1=1 ' + + @strWhere + ' +GROUP BY + c.CategoryID, c.Name +ORDER BY + c.Name') +GO + +DELETE FROM {databaseOwner}{objectQualifier}ModuleControls WHERE ControlSrc = 'DesktopModules/DnnForge - NewsArticles/ucArticleView.ascx' +GO + +DELETE FROM {databaseOwner}{objectQualifier}ModuleControls WHERE ControlSrc = 'DesktopModules/DnnForge - NewsArticles/ucArchiveView.ascx' +GO + +DELETE FROM {databaseOwner}{objectQualifier}ModuleControls WHERE ControlSrc = 'DesktopModules/DnnForge - NewsArticles/ucAuthorView.ascx' +GO + +DELETE FROM {databaseOwner}{objectQualifier}ModuleControls WHERE ControlSrc = 'DesktopModules/DnnForge - NewsArticles/ucCategories.ascx' +GO + +DELETE FROM {databaseOwner}{objectQualifier}ModuleControls WHERE ControlSrc = 'DesktopModules/DnnForge - NewsArticles/ucCategoryView.ascx' +GO + +DELETE FROM {databaseOwner}{objectQualifier}ModuleControls WHERE ControlSrc = 'DesktopModules/DnnForge - NewsArticles/ucDeleteComment.ascx' +GO + +DELETE FROM {databaseOwner}{objectQualifier}ModuleControls WHERE ControlSrc = 'DesktopModules/DnnForge - NewsArticles/ucPostComment.ascx' +GO + +DELETE FROM {databaseOwner}{objectQualifier}ModuleControls WHERE ControlSrc = 'DesktopModules/DnnForge - NewsArticles/ucSearch.ascx' +GO + +DELETE FROM {databaseOwner}{objectQualifier}ModuleControls WHERE ControlSrc = 'DesktopModules/DnnForge - NewsArticles/ucSyndication.ascx' +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddPage +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddPage + @ArticleID int, + @Title nvarchar(255), + @PageText ntext, + @SortOrder int +AS + +declare @count int + +select @count = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where ArticleID = @ArticleID) + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page ( + [ArticleID], + [Title], + [PageText], + [SortOrder] +) VALUES ( + @ArticleID, + @Title, + @PageText, + @count +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeletePage +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeletePage + @PageID int +AS + +DECLARE @ArticleID int +SELECT @ArticleID = ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page WHERE [PageID] = @PageID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page +WHERE + [PageID] = @PageID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdatePage +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdatePage + @PageID int, + @ArticleID int, + @Title nvarchar(255), + @PageText ntext, + @SortOrder int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page SET + [ArticleID] = @ArticleID, + [Title] = @Title, + [PageText] = @PageText, + [SortOrder] = @SortOrder +WHERE + [PageID] = @PageID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment + @ArticleID int, + @UserID int, + @Comment ntext, + @RemoteAddress nvarchar(50) , + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255), + @NotifyMe bit, + @IsApproved bit, + @ApprovedBy int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [ArticleID], + [UserID], + [Comment], + [RemoteAddress], + [Type], + [TrackbackUrl], + [TrackbackTitle], + [TrackbackBlogName], + [TrackbackExcerpt], + [AnonymousName], + [AnonymousEmail], + [AnonymousURL], + [NotifyMe], + [IsApproved], + [ApprovedBy] +) VALUES ( + @ArticleID, + @UserID, + @Comment, + @RemoteAddress, + @Type, + @TrackbackUrl, + @TrackbackTitle, + @TrackbackBlogName, + @TrackbackExcerpt, + @AnonymousName, + @AnonymousEmail, + @AnonymousURL, + @NotifyMe, + @IsApproved, + @ApprovedBy +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteComment + @CommentID int +AS + +DECLARE @ArticleID int +SELECT @ArticleID = ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment WHERE [CommentID] = @CommentID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment +WHERE [CommentID] = @CommentID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateComment + @CommentID int, + @ArticleID int, + @UserID int, + @Comment ntext, + @RemoteAddress nvarchar(50), + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255), + @NotifyMe bit, + @IsApproved bit, + @ApprovedBy int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment SET + [ArticleID] = @ArticleID, + [UserID] = @UserID, + [Comment] = @Comment, + [RemoteAddress] = @RemoteAddress, + [Type] = @Type, + [TrackbackUrl] = @TrackbackUrl, + [TrackbackTitle] = @TrackbackTitle, + [TrackbackBlogName] = @TrackbackBlogName, + [TrackbackExcerpt] = @TrackbackExcerpt, + [AnonymousName] = @AnonymousName, + [AnonymousEmail] = @AnonymousEmail, + [AnonymousURL] = @AnonymousURL, + [NotifyMe] = @NotifyMe, + [IsApproved] = @IsApproved, + [ApprovedBy] = @ApprovedBy +WHERE + [CommentID] = @CommentID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_RatingAdd +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_RatingAdd + @ArticleID int, + @UserID int, + @CreatedDate datetime, + @Rating float +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating ( + [ArticleID], + [UserID], + [CreatedDate], + [Rating] +) VALUES ( + @ArticleID, + @UserID, + @CreatedDate, + @Rating +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_RatingDelete +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_RatingDelete + @RatingID int +AS + +DECLARE @ArticleID int +SELECT @ArticleID = ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating WHERE [RatingID] = @RatingID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating +WHERE [RatingID] = @RatingID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID], + [Url], + [IsSecure], + [IsNewWindow] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID, + @Url, + @IsSecure, + @IsNewWindow +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID, + [Url] = @Url, + [IsSecure] = @IsSecure, + [IsNewWindow] = @IsNewWindow +WHERE + [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.01.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.01.SqlDataProvider new file mode 100755 index 0000000..f9189de --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.01.SqlDataProvider @@ -0,0 +1,204 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords varchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''')' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.05.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.05.SqlDataProvider new file mode 100755 index 0000000..17eed4e --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.05.SqlDataProvider @@ -0,0 +1,204 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords varchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.06.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.06.SqlDataProvider new file mode 100755 index 0000000..b1b7165 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.06.SqlDataProvider @@ -0,0 +1,170 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + ADD [ParentID] int NULL +GO + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +SET + [ParentID] = -1 +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [ModuleID], + [ParentID], + [Name], + [Image] +) VALUES ( + @ModuleID, + @ParentID, + @Name, + @Image +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory + @CategoryID int, + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category SET + [ModuleID] = @ModuleID, + [ParentID] = @ParentID, + [Name] = @Name, + [Image] = @Image +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory + @CategoryID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList + @ModuleID int, + @ParentID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [ModuleID] = @ModuleID + AND + [ParentID] = @ParentID +ORDER BY + [Name] +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255) +AS + +SET NOCOUNT ON +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [Name] DESC + + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac WHERE ac.CategoryID = c.CategoryID) as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryStatistics +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.08.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.08.SqlDataProvider new file mode 100755 index 0000000..633aa2f --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.08.SqlDataProvider @@ -0,0 +1,173 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + ADD [Description] ntext +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [ModuleID], + [ParentID], + [Name], + [Image], + [Description] +) VALUES ( + @ModuleID, + @ParentID, + @Name, + @Image, + @Description +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory + @CategoryID int, + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category SET + [ModuleID] = @ModuleID, + [ParentID] = @ParentID, + [Name] = @Name, + [Image] = @Image, + [Description] = @Description +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory + @CategoryID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList + @ModuleID int, + @ParentID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [ModuleID] = @ModuleID + AND + [ParentID] = @ParentID +ORDER BY + [Name] +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255) +AS + +SET NOCOUNT ON +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [Name] DESC + + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + [Description], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac WHERE ac.CategoryID = c.CategoryID) as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.10.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.10.SqlDataProvider new file mode 100755 index 0000000..5b96359 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.10.SqlDataProvider @@ -0,0 +1,197 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + ADD SortOrder int +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category SET SortOrder = 0 +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext, + @SortOrder int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [ModuleID], + [ParentID], + [Name], + [Image], + [Description], + [SortOrder] +) VALUES ( + @ModuleID, + @ParentID, + @Name, + @Image, + @Description, + @SortOrder +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory + @CategoryID int, + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext, + @SortOrder int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category SET + [ModuleID] = @ModuleID, + [ParentID] = @ParentID, + [Name] = @Name, + [Image] = @Image, + [Description] = @Description, + [SortOrder] = @SortOrder +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory + @CategoryID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description], + [SortOrder] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList + @ModuleID int, + @ParentID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description], + [SortOrder] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [ModuleID] = @ModuleID + AND + [ParentID] = @ParentID +ORDER BY + [SortOrder], [Name] +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255), + @MaxDepth int +AS + +SET NOCOUNT ON + +DECLARE @FilterID int +SET @FilterID = @Current + +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + IF( @MaxDepth IS NULL OR @MaxDepth >= @level ) + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [SortOrder] DESC, [Name] DESC + + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +IF( @FilterID IS NOT NULL ) +BEGIN + DELETE FROM #hierarchy WHERE CategoryID = @FilterID +END + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + c.[Description], + c.[SortOrder], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac WHERE ac.CategoryID = c.CategoryID) as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.13.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.13.SqlDataProvider new file mode 100755 index 0000000..43d8b50 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.13.SqlDataProvider @@ -0,0 +1,207 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords varchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.14.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.14.SqlDataProvider new file mode 100755 index 0000000..1fbcc10 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.14.SqlDataProvider @@ -0,0 +1,88 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255), + @MaxDepth int +AS + +SET NOCOUNT ON + +DECLARE @FilterID int +SET @FilterID = @Current + +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + IF( @MaxDepth IS NULL OR @MaxDepth >= @level ) + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [SortOrder] DESC, [Name] DESC + + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +IF( @FilterID IS NOT NULL ) +BEGIN + DELETE FROM #hierarchy WHERE CategoryID = @FilterID +END + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + c.[Description], + c.[SortOrder], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1) as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.20.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.20.SqlDataProvider new file mode 100755 index 0000000..64e3763 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.20.SqlDataProvider @@ -0,0 +1,138 @@ +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Handout( + [HandoutID] [int] IDENTITY(1,1) NOT NULL, + [ModuleID] [int] NOT NULL, + [UserID] [int] NULL, + [Name] [nvarchar](255) NOT NULL, + [Description] [ntext] NULL +) ON [PRIMARY] +GO + +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_HandoutArticle( + [HandoutID] [int] NOT NULL, + [ArticleID] [int] NOT NULL, + [SortOrder] [int] NOT NULL +) ON [PRIMARY] +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddHandout + @ModuleID int, + @UserID int, + @Name nvarchar(255), + @Description ntext +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Handout ( + [ModuleID], + [UserID], + [Name], + [Description] +) VALUES ( + @ModuleID, + @UserID, + @Name, + @Description +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddHandoutArticle + @HandoutID int, + @ArticleID int, + @SortOrder int +AS + +INSERT INTO + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_HandoutArticle(HandoutID, ArticleID, SortOrder) +VALUES + (@HandoutID, @ArticleID, @SortOrder) +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteHandout + @HandoutID int +AS + +DELETE FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Handout +WHERE + HandoutID = @HandoutID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteHandoutArticleList + @HandoutID int +AS + +DELETE FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_HandoutArticle +WHERE + HandoutID = @HandoutID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetHandout + @HandoutID int +AS + +SELECT + [HandoutID], + [ModuleID], + [UserID], + [Name], + [Description] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Handout +WHERE + HandoutID = @HandoutID +Go + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetHandoutArticleList + @HandoutID int +AS + +SELECT + [HandoutID], + [ArticleID], + [SortOrder] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_HandoutArticle +WHERE + HandoutID = @HandoutID +ORDER BY + [SortOrder] ASC +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetHandoutList + @UserID int +AS + +SELECT + [HandoutID], + [ModuleID], + [UserID], + [Name], + [Description] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Handout +WHERE + [UserID] = @UserID +ORDER BY + [Name] +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateHandout + @HandoutID int, + @ModuleID int, + @UserID int, + @Name nvarchar(255), + @Description ntext +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Handout +SET + [ModuleID] = @ModuleID, + [UserID] = @UserID, + [Name] = @Name, + [Description] = @Description +WHERE + HandoutID = @HandoutID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.32.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.32.SqlDataProvider new file mode 100755 index 0000000..1fdbd5c --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.32.SqlDataProvider @@ -0,0 +1,398 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(255), + @SortBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@ShowPending is null ) + SELECT @strWhere = @strWhere + ' AND (Articles.StartDate is null OR Articles.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' + +EXEC(' +SELECT + UserID, UserName, DisplayName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where Articles.IsApproved = 1 and Articles.IsDraft = 0 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, DisplayName, FirstName, LastName +ORDER BY ' + + @SortBy) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255), + @MaxDepth int, + @ShowPending bit +AS + +SET NOCOUNT ON + +DECLARE @FilterID int +SET @FilterID = @Current + +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + IF( @MaxDepth IS NULL OR @MaxDepth >= @level ) + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [SortOrder] DESC, [Name] DESC + + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +IF( @FilterID IS NOT NULL ) +BEGIN + DELETE FROM #hierarchy WHERE CategoryID = @FilterID +END + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +DECLARE @strPending nvarchar(2000) +IF (@ShowPending is null) + SELECT @strPending = ' AND (a.StartDate IS NULL OR a.StartDate < GetDate())' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + c.[Description], + c.[SortOrder], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 ' + @strPending + ') as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(255), + @GroupBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@ShowPending is null) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' +END + +IF( @GroupBy = 'Month' ) +BEGIN +EXEC(' + select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate), Month(StartDate) + order by [Year] desc, [Month] desc') +END +ELSE +BEGIN +EXEC(' + select 1 as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate) + order by [Year] desc') +END +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords varchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.33.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.33.SqlDataProvider new file mode 100755 index 0000000..081f079 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.33.SqlDataProvider @@ -0,0 +1,193 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(255), + @AuthorID int, + @SortBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null ) + SELECT @strWhere = @strWhere + ' AND (Articles.StartDate is null OR Articles.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' + +EXEC(' +SELECT + UserID, UserName, DisplayName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where Articles.IsApproved = 1 and Articles.IsDraft = 0 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, DisplayName, FirstName, LastName +ORDER BY ' + + @SortBy) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(255), + @AuthorID int, + @GroupBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' +END + +IF( @GroupBy = 'Month' ) +BEGIN +EXEC(' + select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate), Month(StartDate) + order by [Year] desc, [Month] desc') +END +ELSE +BEGIN +EXEC(' + select 1 as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate) + order by [Year] desc') +END +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255), + @AuthorID int, + @MaxDepth int, + @ShowPending bit +AS + +SET NOCOUNT ON + +DECLARE @FilterID int +SET @FilterID = @Current + +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + IF( @MaxDepth IS NULL OR @MaxDepth >= @level ) + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [SortOrder] DESC, [Name] DESC + + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +IF( @FilterID IS NOT NULL ) +BEGIN + DELETE FROM #hierarchy WHERE CategoryID = @FilterID +END + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +DECLARE @strAuthorId nvarchar(255) +IF (@authorId is not null) + SELECT @strAuthorId = ' AND a.AuthorID = ' + cast(@AuthorID as nvarchar) + +DECLARE @strPending nvarchar(2000) +IF (@ShowPending is null) + SELECT @strPending = ' AND (a.StartDate IS NULL OR a.StartDate < GetDate())' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + c.[Description], + c.[SortOrder], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 ' + @strAuthorId + @strPending + ') as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.41.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.41.SqlDataProvider new file mode 100755 index 0000000..48fa2af --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.41.SqlDataProvider @@ -0,0 +1,217 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(255), + @CategoryIDCount int, + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.44.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.44.SqlDataProvider new file mode 100755 index 0000000..0bd6bf8 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.44.SqlDataProvider @@ -0,0 +1,230 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + MetaTitle nvarchar(200) NULL, + MetaDescription nvarchar(500) NULL, + MetaKeywords nvarchar(500) NULL, + PageHeadText nvarchar(500) NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID], + [Url], + [IsSecure], + [IsNewWindow], + [MetaTitle], + [MetaDescription], + [MetaKeywords], + [PageHeadText] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID, + @Url, + @IsSecure, + @IsNewWindow, + @MetaTitle, + @MetaDescription, + @MetaKeywords, + @PageHeadText +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID, + [Url] = @Url, + [IsSecure] = @IsSecure, + [IsNewWindow] = @IsNewWindow, + [MetaTitle] = @MetaTitle, + [MetaDescription] = @MetaDescription, + [MetaKeywords] = @MetaKeywords, + [PageHeadText] = @PageHeadText +WHERE + [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as UpdatedDisplayName, + Page.PageText as 'Body' + +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + Article.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.46.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.46.SqlDataProvider new file mode 100755 index 0000000..f6637d9 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.46.SqlDataProvider @@ -0,0 +1,221 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.47.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.47.SqlDataProvider new file mode 100755 index 0000000..999a871 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.47.SqlDataProvider @@ -0,0 +1,288 @@ +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomField( + [CustomFieldID] [int] IDENTITY(1,1) NOT NULL, + [ModuleID] [int] NOT NULL, + [Name] [nvarchar](255) NOT NULL, + [FieldType] [int] NOT NULL, + [FieldElements] [ntext] NULL, + [DefaultValue] [nvarchar](255) NULL, + [Caption] [nvarchar](255) NULL, + [CaptionHelp] [nvarchar](255) NULL, + [IsRequired] [bit] NOT NULL, + [IsVisible] [bit] NOT NULL, + [SortOrder] [int] NOT NULL, + [ValidationType] [int] NOT NULL, + [RegularExpression] [nvarchar](4000) NULL, + [Length] [int] NULL +) ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomField ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_CustomField] PRIMARY KEY CLUSTERED + ( + [CustomFieldID] + ) ON [PRIMARY] +GO + +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue( + [CustomValueID] [int] IDENTITY(1,1) NOT NULL, + [ArticleID] [int] NOT NULL, + [CustomFieldID] [int] NOT NULL, + [CustomValue] [ntext] NOT NULL +) ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_CustomValue] PRIMARY KEY CLUSTERED + ( + [CustomValueID] + ) ON [PRIMARY] +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticle + @ArticleID int +AS + +DELETE FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue +WHERE + [ArticleID] = @ArticleID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories +WHERE + [ArticleID] = @ArticleID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +WHERE + [ArticleID] = @ArticleID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteCustomField + @CustomFieldID int +AS + +DELETE FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue +WHERE + CustomFieldID = @CustomFieldID + +DELETE FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomField +WHERE + CustomFieldID = @CustomFieldID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteCustomValue + @CustomValueID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue +WHERE + [CustomValueID] = @CustomValueID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCustomField + @CustomFieldID int +AS + +SELECT + CustomFieldID, + ModuleID, + [Name], + FieldType, + FieldElements, + DefaultValue, + Caption, + CaptionHelp, + IsRequired, + IsVisible, + SortOrder, + ValidationType, + RegularExpression, + [Length] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomField +WHERE + [CustomFieldID] = @CustomFieldID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCustomFieldList + @ModuleID int +AS + +SELECT + CustomFieldID, + ModuleID, + [Name], + FieldType, + FieldElements, + DefaultValue, + Caption, + CaptionHelp, + IsRequired, + IsVisible, + SortOrder, + ValidationType, + RegularExpression, + [Length] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomField +WHERE + [ModuleID] = @ModuleID +ORDER BY + SortOrder +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCustomValueByField + @ArticleID int, + @CustomFieldID int +AS + +SELECT + [CustomValueID], + [ArticleID], + [CustomFieldID], + [CustomValue] +FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue +WHERE + [ArticleID] = @ArticleID + and + [CustomFieldID] = @CustomFieldID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCustomValueList + @ArticleID int +AS + +SELECT + [CustomValueID], + [ArticleID], + [CustomFieldID], + [CustomValue] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue +WHERE + [ArticleID] = @ArticleID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCustomField + @CustomFieldID int, + @ModuleID int, + @Name nvarchar(255), + @FieldType int, + @FieldElements ntext, + @DefaultValue nvarchar(255), + @Caption nvarchar(255), + @CaptionHelp nvarchar(255), + @IsRequired bit, + @IsVisible bit, + @SortOrder int, + @ValidationType int, + @Length int, + @RegularExpression nvarchar(4000) +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomField +SET + [ModuleID] = @ModuleID, + [Name] = @Name, + [FieldType] = @FieldType, + [FieldElements] = @FieldElements, + [DefaultValue] = @DefaultValue, + [Caption] = @Caption, + [CaptionHelp] = @CaptionHelp, + [IsRequired] = @IsRequired, + [IsVisible] = @IsVisible, + [SortOrder] = @SortOrder, + [ValidationType] = @ValidationType, + [Length] = @Length, + [RegularExpression] = @RegularExpression +WHERE + CustomFieldID = @CustomFieldID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCustomValue + @CustomValueID int, + @ArticleID int, + @CustomFieldID int, + @CustomValue ntext +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue SET + [ArticleID] = @ArticleID, + [CustomFieldID] = @CustomFieldID, + [CustomValue] = @CustomValue +WHERE + [CustomValueID] = @CustomValueID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCustomField + @ModuleID int, + @Name nvarchar(255), + @FieldType int, + @FieldElements ntext, + @DefaultValue nvarchar(255), + @Caption nvarchar(255), + @CaptionHelp nvarchar(255), + @IsRequired bit, + @IsVisible bit, + @SortOrder int, + @ValidationType int, + @Length int, + @RegularExpression nvarchar(4000) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomField ( + [ModuleID], + [Name], + [FieldType], + [FieldElements], + [DefaultValue], + [Caption], + [CaptionHelp], + [IsRequired], + [IsVisible], + [SortOrder], + [ValidationType], + [Length], + [RegularExpression] +) VALUES ( + @ModuleID, + @Name, + @FieldType, + @FieldElements, + @DefaultValue, + @Caption, + @CaptionHelp, + @IsRequired, + @IsVisible, + @SortOrder, + @ValidationType, + @Length, + @RegularExpression +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCustomValue + @ArticleID int, + @CustomFieldID int, + @CustomValue ntext +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue ( + [ArticleID], + [CustomFieldID], + [CustomValue] +) VALUES ( + @ArticleID, + @CustomFieldID, + @CustomValue +) + +select SCOPE_IDENTITY() +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.48.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.48.SqlDataProvider new file mode 100755 index 0000000..d7c9ebe --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.48.SqlDataProvider @@ -0,0 +1,10 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue DROP + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_CustomValue] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_CustomValue] PRIMARY KEY CLUSTERED + ( + [CustomValueID] + ) ON [PRIMARY] +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.52.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.52.SqlDataProvider new file mode 100755 index 0000000..52a4aad --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.52.SqlDataProvider @@ -0,0 +1,6 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Handout ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Handout] PRIMARY KEY CLUSTERED + ( + [HandoutID] + ) ON [PRIMARY] +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.53.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.53.SqlDataProvider new file mode 100755 index 0000000..bb75557 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.53.SqlDataProvider @@ -0,0 +1,487 @@ +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag( + [TagID] [int] IDENTITY(1,1) NOT NULL, + [ModuleID] [int] NOT NULL, + [Name] [nvarchar](255) NOT NULL, + [NameLowered] [nvarchar](255) NOT NULL, + [Usages] [int] NULL +) ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Tag] PRIMARY KEY CLUSTERED + ( + [TagID] + ) ON [PRIMARY] +GO + +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag( + [ArticleID] [int] NOT NULL, + [TagID] [int] NOT NULL +) ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_ArticleTag] PRIMARY KEY CLUSTERED + ( + [ArticleID] ASC, + [TagID] ASC + ) ON [PRIMARY] +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_TagAdd + @ModuleID int, + @Name nvarchar(50), + @NameLowered nvarchar(50) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag ( + [ModuleID], + [Name], + [NameLowered] +) VALUES ( + @ModuleID, + @Name, + @NameLowered +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_TagGet + @TagID int +AS + +SELECT + [TagID], + [ModuleID], + [Name], + [NameLowered], + [Usages] +FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag +WHERE + [TagID] = @TagID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_TagGetByName + @ModuleID int, + @NameLowered nvarchar(50) +AS + +SELECT TOP 1 + [TagID], + [ModuleID], + [Name], + [NameLowered], + [Usages] +FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag +WHERE + [ModuleID] = @ModuleID + and + [NameLowered] = @NameLowered +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_TagList + @ModuleID int, + @MaxCount int +AS + +if( @MaxCount is not null ) +begin + SET ROWCOUNT @MaxCount +end + +SELECT + t.[TagID], + t.[ModuleID], + t.[Name], + t.[NameLowered], + t.[Usages] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag t +WHERE + t.[ModuleID] = @ModuleID +ORDER BY + t.[Usages] DESC +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_TagUpdate + @TagID int, + @ModuleID int, + @Name nvarchar(50), + @NameLowered nvarchar(50), + @Usages int +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag +SET + [ModuleID] = @ModuleID, + [Name] = @Name, + [NameLowered] = @NameLowered, + [Usages] = @Usages +WHERE + [TagID] = @TagID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTagAdd + @ArticleID int, + @TagID int +AS + +IF( (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag WHERE ArticleID = @ArticleID and TagID = @TagID) = 0 ) +BEGIN + INSERT INTO + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag(ArticleID, TagID) + VALUES(@ArticleID, @TagID) + + UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag + SET + Usages = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag pt where pt.TagID = @TagID) + WHERE + TagID = @TagID +END +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTagDelete + @ArticleID int +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag +SET + Usages = Usages - 1 +WHERE + TagID in (SELECT pt.TagID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag pt where ArticleID = @ArticleID) + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag +WHERE Usages = 0 + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag +WHERE ArticleID = @ArticleID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTagDeleteByTag + @TagID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag +WHERE TagID = @TagID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_TagDelete + @TagID int +AS + +exec {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTagDeleteByTag @TagID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag +WHERE + [TagID] = @TagID +GO + +CREATE FUNCTION {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags +(@ArticleID int) +RETURNS nvarchar(2000) +AS + BEGIN + + DECLARE @p_str nvarchar(2000) + SET @p_str = '' + + SELECT @p_str = @p_str + ' ' + CAST(t.[Name] AS NVARCHAR(50)) + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag t, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag at + WHERE t.TagID = at.TagID and at.ArticleID = @ArticleID + + RETURN LTRIM(@p_str) + +END +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as UpdatedDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + Article.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.55.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.55.SqlDataProvider new file mode 100755 index 0000000..45e6742 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.55.SqlDataProvider @@ -0,0 +1,469 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + ShortUrl nvarchar(50) NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500), + @ShortUrl nvarchar(50) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID], + [Url], + [IsSecure], + [IsNewWindow], + [MetaTitle], + [MetaDescription], + [MetaKeywords], + [PageHeadText], + [ShortUrl] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID, + @Url, + @IsSecure, + @IsNewWindow, + @MetaTitle, + @MetaDescription, + @MetaKeywords, + @PageHeadText, + @ShortUrl +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500), + @ShortUrl nvarchar(50) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID, + [Url] = @Url, + [IsSecure] = @IsSecure, + [IsNewWindow] = @IsNewWindow, + [MetaTitle] = @MetaTitle, + [MetaDescription] = @MetaDescription, + [MetaKeywords] = @MetaKeywords, + [PageHeadText] = @PageHeadText, + [ShortUrl] = @ShortUrl +WHERE + [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE ''%' + @Keywords + '%'' OR Article.Summary LIKE ''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE ''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as UpdatedDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + Article.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.56.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.56.SqlDataProvider new file mode 100755 index 0000000..c246660 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.56.SqlDataProvider @@ -0,0 +1,261 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP FUNCTION {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags +GO + +CREATE FUNCTION {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags +(@ArticleID int) +RETURNS nvarchar(2000) +AS + BEGIN + + DECLARE @p_str nvarchar(2000) + SET @p_str = '' + + SELECT @p_str = @p_str + ',' + CAST(t.[Name] AS NVARCHAR(50)) + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag t, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag at + WHERE t.TagID = at.TagID and at.ArticleID = @ArticleID + + IF( LEN(@p_str) > 0 ) + BEGIN + SELECT @p_str = SUBSTRING(@p_str, 2, (LEN(@p_str)-1)) + END + + RETURN LTRIM(@p_str) + +END +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.57.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.57.SqlDataProvider new file mode 100755 index 0000000..81e7657 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.57.SqlDataProvider @@ -0,0 +1,615 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + RssGuid nvarchar(255) NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP FUNCTION {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags +GO + +CREATE FUNCTION {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags +(@ArticleID int) +RETURNS nvarchar(2000) +AS + BEGIN + + DECLARE @p_str nvarchar(2000) + SET @p_str = '' + + SELECT @p_str = @p_str + ',' + CAST(t.[Name] AS NVARCHAR(50)) + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Tag t, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag at + WHERE t.TagID = at.TagID and at.ArticleID = @ArticleID + + IF( LEN(@p_str) > 0 ) + BEGIN + SELECT @p_str = SUBSTRING(@p_str, 2, (LEN(@p_str)-1)) + END + + RETURN LTRIM(@p_str) + +END +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500), + @ShortUrl nvarchar(50), + @RssGuid nvarchar(255) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID], + [Url], + [IsSecure], + [IsNewWindow], + [MetaTitle], + [MetaDescription], + [MetaKeywords], + [PageHeadText], + [ShortUrl], + [RssGuid] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID, + @Url, + @IsSecure, + @IsNewWindow, + @MetaTitle, + @MetaDescription, + @MetaKeywords, + @PageHeadText, + @ShortUrl, + @RssGuid +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500), + @ShortUrl nvarchar(50), + @RssGuid nvarchar(255) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID, + [Url] = @Url, + [IsSecure] = @IsSecure, + [IsNewWindow] = @IsNewWindow, + [MetaTitle] = @MetaTitle, + [MetaDescription] = @MetaDescription, + [MetaKeywords] = @MetaKeywords, + [PageHeadText] = @PageHeadText, + [ShortUrl] = @ShortUrl, + [RssGuid] = @RssGuid +WHERE + [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID +GO + +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed( + [FeedID] [int] IDENTITY(1,1) NOT NULL, + [ModuleID] [int] NOT NULL, + [Title] [nvarchar](255) NULL, + [Url] [nvarchar](255) NOT NULL, + [UserID] [int] NOT NULL, + [AutoFeature] [bit] NOT NULL, + [IsActive] [bit] NOT NULL, +) ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Feed] PRIMARY KEY CLUSTERED + ( + [FeedID] + ) ON [PRIMARY] +GO + +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedCategory( + [FeedID] [int] NOT NULL, + [CategoryID] [int] NOT NULL, +) ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedCategory ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_FeedCategory] PRIMARY KEY CLUSTERED + ( + [FeedID], + [CategoryID] + ) ON [PRIMARY] +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedAdd + @ModuleID int, + @Title nvarchar(255), + @Url nvarchar(255), + @UserID int, + @AutoFeature bit, + @IsActive bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed ( + [ModuleID], + [Title], + [Url], + [UserID], + [AutoFeature], + [IsActive] +) VALUES ( + @ModuleID, + @Title, + @Url, + @UserID, + @AutoFeature, + @IsActive +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedCategoryAdd + @FeedID int, + @CategoryID int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedCategory(FeedID, CategoryID) + VALUES(@FeedID, @CategoryID) +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedCategoryDelete + @FeedID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedCategory +WHERE FeedID = @FeedID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedCategoryList + @FeedID int +AS + +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + c.[Image], + c.[Description], + c.[SortOrder] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedCategory fc INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON fc.categoryID = c.categoryID +WHERE + fc.FeedID = @FeedID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedDelete + @FeedID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed +WHERE + [FeedID] = @FeedID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedGet + @FeedID int +AS + +SELECT + FeedID, + ModuleID, + Title, + Url, + UserID, + AutoFeature, + IsActive +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed +WHERE + FeedID = @FeedID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedList + @ModuleID int, + @ShowActiveOnly bit +AS + +SELECT + FeedID, + ModuleID, + Title, + Url, + UserID, + AutoFeature, + IsActive +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed +WHERE + (@ModuleID = -1 OR ModuleID = @ModuleID) + AND + (@ShowActiveOnly = 0 OR IsActive = 1) +ORDER BY + Title +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedUpdate + @FeedID int, + @ModuleID int, + @Title nvarchar(255), + @Url nvarchar(255), + @UserID int, + @AutoFeature bit, + @IsActive bit +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed +SET + [ModuleID] = @ModuleID, + [Title] = @Title, + [Url] = @Url, + [UserID] = @UserID, + [AutoFeature] = @AutoFeature, + [IsActive] = @IsActive +WHERE + [FeedID] = @FeedID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.58.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.58.SqlDataProvider new file mode 100755 index 0000000..a5670b8 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.58.SqlDataProvider @@ -0,0 +1,299 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate < GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate < ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate > ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate > ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as UpdatedDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + Article.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.59.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.59.SqlDataProvider new file mode 100755 index 0000000..423b3a7 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.59.SqlDataProvider @@ -0,0 +1,240 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.61.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.61.SqlDataProvider new file mode 100755 index 0000000..a2a703e --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.61.SqlDataProvider @@ -0,0 +1,806 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed ADD + DateMode int NOT NULL CONSTRAINT DF_{objectQualifier}DnnForge_NewsArticles_Feed_DateMode DEFAULT 0, + AutoExpire int NULL, + AutoExpireUnit int NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedAdd +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedAdd + @ModuleID int, + @Title nvarchar(255), + @Url nvarchar(255), + @UserID int, + @AutoFeature bit, + @IsActive bit, + @DateMode int, + @AutoExpire int, + @AutoExpireUnit int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed ( + [ModuleID], + [Title], + [Url], + [UserID], + [AutoFeature], + [IsActive], + [DateMode], + [AutoExpire], + [AutoExpireUnit] +) VALUES ( + @ModuleID, + @Title, + @Url, + @UserID, + @AutoFeature, + @IsActive, + @DateMode, + @AutoExpire, + @AutoExpireUnit +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedGet +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedGet + @FeedID int +AS + +SELECT + FeedID, + ModuleID, + Title, + Url, + UserID, + AutoFeature, + IsActive, + DateMode, + AutoExpire, + AutoExpireUnit +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed +WHERE + FeedID = @FeedID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedList + @ModuleID int, + @ShowActiveOnly bit +AS + +SELECT + FeedID, + ModuleID, + Title, + Url, + UserID, + AutoFeature, + IsActive, + DateMode, + AutoExpire, + AutoExpireUnit +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed +WHERE + (@ModuleID = -1 OR ModuleID = @ModuleID) + AND + (@ShowActiveOnly = 0 OR IsActive = 1) +ORDER BY + Title +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedUpdate +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FeedUpdate + @FeedID int, + @ModuleID int, + @Title nvarchar(255), + @Url nvarchar(255), + @UserID int, + @AutoFeature bit, + @IsActive bit, + @DateMode int, + @AutoExpire int, + @AutoExpireUnit int +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Feed +SET + [ModuleID] = @ModuleID, + [Title] = @Title, + [Url] = @Url, + [UserID] = @UserID, + [AutoFeature] = @AutoFeature, + [IsActive] = @IsActive, + [DateMode] = @DateMode, + [AutoExpire] = @AutoExpire, + [AutoExpireUnit] = @AutoExpireUnit +WHERE + [FeedID] = @FeedID +GO + +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image( + [ImageID] [int] IDENTITY(1,1) NOT NULL, + [ArticleID] [int] NULL, + [Title] [nvarchar](100) NULL, + [FileName] [nvarchar](100) NULL, + [Extension] [nvarchar](100) NULL, + [Size] [int] NULL, + [Width] [int] NULL, + [Height] [int] NULL, + [ContentType] [nvarchar](200) NULL, + [Folder] [nvarchar](200) NULL, + [SortOrder] [int] NOT NULL CONSTRAINT [DF_{objectQualifier}DnnForge_NewsArticles_Image_SortOrder] DEFAULT ((0)), + [ImageGuid] [nvarchar](50) NULL, + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Image] PRIMARY KEY CLUSTERED +( + [ImageID] ASC +) +) ON [PRIMARY] +GO + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image(ArticleID, Title, FileName, Extension, Size, Width, Height, ContentType, Folder, SortOrder) +SELECT + a.ArticleID, + f.FileName, + f.FileName, + f.Extension, + f.Size, + f.Width, + f.Height, + f.ContentType, + f.Folder, + 0 +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN + {databaseOwner}{objectQualifier}Files f ON 'FileID=' + CONVERT(varchar, f.FileID) = a.ImageUrl +GO + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET + ImageUrl = NULL +WHERE + ArticleID IN (SELECT a.ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}Files f ON 'FileID=' + CONVERT(varchar, f.FileID) = a.ImageUrl) +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageAdd + @ArticleID int, + @Title nvarchar(100), + @FileName nvarchar(100), + @Extension nvarchar(100), + @Size int, + @Width int, + @Height int, + @ContentType nvarchar(200), + @Folder nvarchar(200), + @SortOrder int, + @ImageGuid nvarchar(50) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image ( + [ArticleID], + [Title], + [FileName], + [Extension], + [Size], + [Width], + [Height], + [ContentType], + [Folder], + [SortOrder], + [ImageGuid] +) VALUES ( + @ArticleID, + @Title, + @FileName, + @Extension, + @Size, + @Width, + @Height, + @ContentType, + @Folder, + @SortOrder, + @ImageGuid +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageUpdate + @ImageID int, + @ArticleID int, + @Title nvarchar(100), + @FileName nvarchar(100), + @Extension nvarchar(100), + @Size int, + @Width int, + @Height int, + @ContentType nvarchar(200), + @Folder nvarchar(200), + @SortOrder int, + @ImageGuid nvarchar(50) +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +SET + [ArticleID] = @ArticleID, + [Title] = @Title, + [FileName] = @FileName, + [Extension] = @Extension, + [Size] = @Size, + [Width] = @Width, + [Height] = @Height, + [ContentType] = @ContentType, + [Folder] = @Folder, + [SortOrder] = @SortOrder, + [ImageGuid] = @ImageGuid +WHERE + [ImageID] = @ImageID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageGet + @ImageID int +AS + +SELECT + ImageID, + ArticleID, + Title, + FileName, + Extension, + Size, + Width, + Height, + ContentType, + Folder, + SortOrder, + ImageGuid +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +WHERE + ImageID = @ImageID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageList + @ArticleID int, + @ImageGuid nvarchar(50) +AS + +SELECT + ImageID, + ArticleID, + Title, + FileName, + Extension, + Size, + Width, + Height, + ContentType, + Folder, + SortOrder, + ImageGuid +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +WHERE + (@ArticleID IS NULL OR ArticleID = @ArticleID) + AND + (@ImageGuid IS NULL OR ImageGuid = @ImageGuid) +ORDER BY + SortOrder +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageDelete + @ImageID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image WHERE ImageID = @ImageID +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + ImageCount int NULL +GO + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET + ImageCount = (SELECT count(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image i WHERE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID = i.ArticleID) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @CurrentDate is not null AND @AgedDate is not null ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + '''))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' + END +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as UpdatedDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + Article.[ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500), + @ShortUrl nvarchar(50), + @RssGuid nvarchar(255) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID], + [Url], + [IsSecure], + [IsNewWindow], + [MetaTitle], + [MetaDescription], + [MetaKeywords], + [PageHeadText], + [ShortUrl], + [RssGuid] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID, + @Url, + @IsSecure, + @IsNewWindow, + @MetaTitle, + @MetaDescription, + @MetaKeywords, + @PageHeadText, + @ShortUrl, + @RssGuid +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [ImageCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image i where i.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500), + @ShortUrl nvarchar(50), + @RssGuid nvarchar(255) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID, + [Url] = @Url, + [IsSecure] = @IsSecure, + [IsNewWindow] = @IsNewWindow, + [MetaTitle] = @MetaTitle, + [MetaDescription] = @MetaDescription, + [MetaKeywords] = @MetaKeywords, + [PageHeadText] = @PageHeadText, + [ShortUrl] = @ShortUrl, + [RssGuid] = @RssGuid +WHERE + [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [ImageCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image i where i.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.63.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.63.SqlDataProvider new file mode 100755 index 0000000..46fcaa2 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.63.SqlDataProvider @@ -0,0 +1,236 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.64.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.64.SqlDataProvider new file mode 100755 index 0000000..7cb3921 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.64.SqlDataProvider @@ -0,0 +1,241 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255), + @CustomFieldID int, + @CustomValue nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@CustomFieldID is not null AND @CustomValue is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID IN (SELECT ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv WHERE cv.customFieldID = ' + convert(nvarchar, @CustomFieldID) + ' AND cv.CustomValue LIKE N''%' + @CustomValue + '%'')' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.66.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.66.SqlDataProvider new file mode 100755 index 0000000..0ed7574 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.66.SqlDataProvider @@ -0,0 +1,13 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteCustomValue +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteCustomValue + @ArticleID int, + @CustomFieldID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue +WHERE + [ArticleID] = @ArticleID AND + [CustomFieldID] = @CustomFieldID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.67.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.67.SqlDataProvider new file mode 100755 index 0000000..e94aad1 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.67.SqlDataProvider @@ -0,0 +1,110 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255), + @AuthorID int, + @MaxDepth int, + @ShowPending bit, + @SortType int +AS + +SET NOCOUNT ON + +DECLARE @FilterID int +SET @FilterID = @Current + +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + IF( @MaxDepth IS NULL OR @MaxDepth >= @level ) + BEGIN + IF( @SortType = 0 ) + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [SortOrder] DESC, [Name] DESC + END + ELSE + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [Name] DESC + END + + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +IF( @FilterID IS NOT NULL ) +BEGIN + DELETE FROM #hierarchy WHERE CategoryID = @FilterID +END + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +DECLARE @strAuthorId nvarchar(255) +IF (@authorId is not null) + SELECT @strAuthorId = ' AND a.AuthorID = ' + cast(@AuthorID as nvarchar) + +DECLARE @strPending nvarchar(2000) +IF (@ShowPending is null) + SELECT @strPending = ' AND (a.StartDate IS NULL OR a.StartDate < GetDate())' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + c.[Description], + c.[SortOrder], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 ' + @strAuthorId + @strPending + ') as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.68.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.68.SqlDataProvider new file mode 100755 index 0000000..5f69070 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.68.SqlDataProvider @@ -0,0 +1,601 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ADD + FileCount int NULL +GO + +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File ( + [FileID] [int] IDENTITY(1,1) NOT NULL, + [ArticleID] [int] NULL, + [Title] [nvarchar](255) NULL, + [FileName] [nvarchar](255) NULL, + [Extension] [nvarchar](100) NULL, + [Size] [int] NULL, + [ContentType] [nvarchar](255) NULL, + [Folder] [nvarchar](255) NULL, + [SortOrder] [int] NOT NULL, + [FileGuid] [nvarchar](50) NULL +) ON [PRIMARY] +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File ADD + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_File] PRIMARY KEY CLUSTERED + ( + [FileID] + ) ON [PRIMARY] +GO + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File +SELECT + a.ArticleID, + f.FileName, + CASE WHEN fo.StorageLocation = 0 THEN f.FileName ELSE f.FileName + '.resources' END AS 'FileName', + f.Extension, + f.Size, + f.ContentType, + f.Folder, + 0 AS 'SortOrder', + '' AS 'FileGuid' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN + {databaseOwner}{objectQualifier}Files f ON replace(a.Url, 'FileID=', '') = f.FileID INNER JOIN + {databaseOwner}{objectQualifier}Folders fo ON f.FolderID = fo.FolderID +WHERE + a.Url LIKE 'FileID=%' +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET Url = null +WHERE articleID IN +( + SELECT a.articleID + FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN + {databaseOwner}{objectQualifier}Files f ON replace(a.Url, 'FileID=', '') = f.FileID INNER JOIN + {databaseOwner}{objectQualifier}Folders fo ON f.FolderID = fo.FolderID + WHERE + a.Url LIKE 'FileID=%' +) +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [FileCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File f where f.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FileAdd + @ArticleID int, + @Title nvarchar(255), + @FileName nvarchar(255), + @Extension nvarchar(200), + @Size int, + @ContentType nvarchar(200), + @Folder nvarchar(255), + @SortOrder int, + @FileGuid nvarchar(50) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File ( + [ArticleID], + [Title], + [FileName], + [Extension], + [Size], + [ContentType], + [Folder], + [SortOrder], + [FileGuid] +) VALUES ( + @ArticleID, + @Title, + @FileName, + @Extension, + @Size, + @ContentType, + @Folder, + @SortOrder, + @FileGuid +) + +select SCOPE_IDENTITY() +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FileDelete + @FileID int +AS + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File WHERE FileID = @FileID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FileGet + @FileID int +AS + +SELECT + FileID, + ArticleID, + Title, + FileName, + Extension, + Size, + ContentType, + Folder, + SortOrder, + FileGuid +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File +WHERE + FileID = @FileID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FileList + @ArticleID int, + @FileGuid nvarchar(50) +AS + +SELECT + FileID, + ArticleID, + Title, + FileName, + Extension, + Size, + ContentType, + Folder, + SortOrder, + FileGuid +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File +WHERE + (@ArticleID IS NULL OR ArticleID = @ArticleID) + AND + (@FileGuid IS NULL OR FileGuid = @FileGuid) +ORDER BY + SortOrder +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_FileUpdate + @FileID int, + @ArticleID int, + @Title nvarchar(255), + @FileName nvarchar(255), + @Extension nvarchar(200), + @Size int, + @ContentType nvarchar(200), + @Folder nvarchar(255), + @SortOrder int, + @FileGuid nvarchar(50) +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File +SET + [ArticleID] = @ArticleID, + [Title] = @Title, + [FileName] = @FileName, + [Extension] = @Extension, + [Size] = @Size, + [ContentType] = @ContentType, + [Folder] = @Folder, + [SortOrder] = @SortOrder, + [FileGuid] = @FileGuid +WHERE + [FileID] = @FileID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_DeleteArticle + @ArticleID int +AS + +DELETE FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue +WHERE + [ArticleID] = @ArticleID + +DELETE FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +WHERE + [ArticleID] = @ArticleID + +DELETE FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File +WHERE + [ArticleID] = @ArticleID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories +WHERE + [ArticleID] = @ArticleID + +DELETE FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +WHERE + [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255), + @CustomFieldID int, + @CustomValue nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) + if(@CategoryIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@CustomFieldID is not null AND @CustomValue is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID IN (SELECT ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv WHERE cv.customFieldID = ' + convert(nvarchar, @CustomFieldID) + ' AND cv.CustomValue LIKE N''%' + @CustomValue + '%'')' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[FileCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticle + @ArticleID int, + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500), + @ShortUrl nvarchar(50), + @RssGuid nvarchar(255) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article SET + [AuthorID] = @AuthorID, + [ApproverID] = @ApproverID, + [CreatedDate] = @CreatedDate, + [LastUpdate] = @LastUpdate, + [Title] = @Title, + [Summary] = @Summary, + [IsApproved] = @IsApproved, + [NumberOfViews] = @NumberOfViews, + [IsDraft] = @IsDraft, + [StartDate] = @StartDate, + [EndDate] = @EndDate, + [ModuleID] = @ModuleID, + [ImageUrl] = @ImageUrl, + [IsFeatured] = @IsFeatured, + [LastUpdateID] = @LastUpdateID, + [Url] = @Url, + [IsSecure] = @IsSecure, + [IsNewWindow] = @IsNewWindow, + [MetaTitle] = @MetaTitle, + [MetaDescription] = @MetaDescription, + [MetaKeywords] = @MetaKeywords, + [PageHeadText] = @PageHeadText, + [ShortUrl] = @ShortUrl, + [RssGuid] = @RssGuid +WHERE + [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [ImageCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image i where i.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [FileCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File f where f.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticle + @ArticleID int +AS +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[IsDraft], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[FileCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as UpdatedDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + Article.[ArticleID] = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.69.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.69.SqlDataProvider new file mode 100755 index 0000000..cd87f74 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.69.SqlDataProvider @@ -0,0 +1,53 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCommentList + @ModuleID int, + @ArticleID int, + @IsApproved bit, + @SortDirection int, + @MaxCount int +AS + +IF( @MaxCount is not null ) +BEGIN + SET ROWCOUNT @MaxCount +END + +SELECT + Comment.[CommentID], + Comment.[ArticleID], + Comment.[UserID], + Comment.[CreatedDate], + Comment.[Comment], + Comment.[RemoteAddress], + Comment.[Type], + Comment.[TrackbackUrl], + Comment.[TrackbackTitle], + Comment.[TrackbackBlogName], + Comment.[TrackbackExcerpt], + Comment.[AnonymousName], + Comment.[AnonymousEmail], + Comment.[AnonymousURL], + Comment.[NotifyMe], + Comment.[IsApproved], + Comment.[ApprovedBy], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article on Comment.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Comment.UserID = Author.UserID +WHERE + Article.ModuleID = @ModuleID + and + (@ArticleID is null OR Comment.[ArticleID] = @ArticleID) + and + Comment.IsApproved = @IsApproved +ORDER BY + CASE WHEN @SortDirection = 0 THEN Comment.[CreatedDate] END ASC, + CASE WHEN @SortDirection = 1 THEN Comment.[CreatedDate] END DESC +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.71.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.71.SqlDataProvider new file mode 100755 index 0000000..8b9aade --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.71.SqlDataProvider @@ -0,0 +1,223 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ADD + InheritSecurity bit NOT NULL CONSTRAINT DF_{objectQualifier}DnnForge_NewsArticles_Category_InheritSecurity DEFAULT 1 +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext, + @SortOrder int, + @InheritSecurity bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [ModuleID], + [ParentID], + [Name], + [Image], + [Description], + [SortOrder], + [InheritSecurity] +) VALUES ( + @ModuleID, + @ParentID, + @Name, + @Image, + @Description, + @SortOrder, + @InheritSecurity +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory + @CategoryID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description], + [SortOrder], + [InheritSecurity] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList + @ModuleID int, + @ParentID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description], + [SortOrder], + [InheritSecurity] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [ModuleID] = @ModuleID + AND + [ParentID] = @ParentID +ORDER BY + [SortOrder], [Name] +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255), + @AuthorID int, + @MaxDepth int, + @ShowPending bit, + @SortType int +AS + +SET NOCOUNT ON + +DECLARE @FilterID int +SET @FilterID = @Current + +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + IF( @MaxDepth IS NULL OR @MaxDepth >= @level ) + BEGIN + IF( @SortType = 0 ) + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [SortOrder] DESC, [Name] DESC + END + ELSE + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [Name] DESC + END + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +IF( @FilterID IS NOT NULL ) +BEGIN + DELETE FROM #hierarchy WHERE CategoryID = @FilterID +END + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +DECLARE @strAuthorId nvarchar(255) +IF (@authorId is not null) + SELECT @strAuthorId = ' AND a.AuthorID = ' + cast(@AuthorID as nvarchar) + +DECLARE @strPending nvarchar(2000) +IF (@ShowPending is null) + SELECT @strPending = ' AND (a.StartDate IS NULL OR a.StartDate < GetDate())' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + c.[Description], + c.[SortOrder], + c.[InheritSecurity], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 ' + @strAuthorId + @strPending + ') as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory + @CategoryID int, + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext, + @SortOrder int, + @InheritSecurity bit +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category SET + [ModuleID] = @ModuleID, + [ParentID] = @ParentID, + [Name] = @Name, + [Image] = @Image, + [Description] = @Description, + [SortOrder] = @SortOrder, + [InheritSecurity] = @InheritSecurity +WHERE + [CategoryID] = @CategoryID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.72.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.72.SqlDataProvider new file mode 100755 index 0000000..518fffb --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.72.SqlDataProvider @@ -0,0 +1,18 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleCategories +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleCategories + @ArticleID int +AS + +SELECT + Category.CategoryID, + Category.[Name], + Category.[InheritSecurity] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category Category +WHERE + ArticleCategories.CategoryID = Category.CategoryID + AND + ArticleCategories.ArticleID = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.73.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.73.SqlDataProvider new file mode 100755 index 0000000..e57ce9a --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.73.SqlDataProvider @@ -0,0 +1,231 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ADD + CategorySecurityType int NOT NULL CONSTRAINT DF_{objectQualifier}DnnForge_NewsArticles_Category_CategorySecurityType DEFAULT 0 +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext, + @SortOrder int, + @InheritSecurity bit, + @CategorySecurityType int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [ModuleID], + [ParentID], + [Name], + [Image], + [Description], + [SortOrder], + [InheritSecurity], + [CategorySecurityType] +) VALUES ( + @ModuleID, + @ParentID, + @Name, + @Image, + @Description, + @SortOrder, + @InheritSecurity, + @CategorySecurityType +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory + @CategoryID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description], + [SortOrder], + [InheritSecurity], + [CategorySecurityType] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList + @ModuleID int, + @ParentID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description], + [SortOrder], + [InheritSecurity], + [CategorySecurityType] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [ModuleID] = @ModuleID + AND + [ParentID] = @ParentID +ORDER BY + [SortOrder], [Name] +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255), + @AuthorID int, + @MaxDepth int, + @ShowPending bit, + @SortType int +AS + +SET NOCOUNT ON + +DECLARE @FilterID int +SET @FilterID = @Current + +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + IF( @MaxDepth IS NULL OR @MaxDepth >= @level ) + BEGIN + IF( @SortType = 0 ) + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [SortOrder] DESC, [Name] DESC + END + ELSE + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [Name] DESC + END + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +IF( @FilterID IS NOT NULL ) +BEGIN + DELETE FROM #hierarchy WHERE CategoryID = @FilterID +END + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +DECLARE @strAuthorId nvarchar(255) +IF (@authorId is not null) + SELECT @strAuthorId = ' AND a.AuthorID = ' + cast(@AuthorID as nvarchar) + +DECLARE @strPending nvarchar(2000) +IF (@ShowPending is null) + SELECT @strPending = ' AND (a.StartDate IS NULL OR a.StartDate < GetDate())' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + c.[Description], + c.[SortOrder], + c.[InheritSecurity], + c.[CategorySecurityType], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 ' + @strAuthorId + @strPending + ') as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory + @CategoryID int, + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext, + @SortOrder int, + @InheritSecurity bit, + @CategorySecurityType int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category SET + [ModuleID] = @ModuleID, + [ParentID] = @ParentID, + [Name] = @Name, + [Image] = @Image, + [Description] = @Description, + [SortOrder] = @SortOrder, + [InheritSecurity] = @InheritSecurity, + [CategorySecurityType] = @CategorySecurityType +WHERE + [CategoryID] = @CategoryID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.74.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.74.SqlDataProvider new file mode 100755 index 0000000..5278655 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.74.SqlDataProvider @@ -0,0 +1,383 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255), + @CustomFieldID int, + @CustomValue nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) +BEGIN + IF(@CategoryIDCount is not null) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + END + ELSE + BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END + END +END + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@CustomFieldID is not null AND @CustomValue is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID IN (SELECT ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv WHERE cv.customFieldID = ' + convert(nvarchar, @CustomFieldID) + ' AND cv.CustomValue LIKE N''%' + @CustomValue + '%'')' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[FileCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(2000), + @CategoryIDExclude varchar(2000), + @AuthorID int, + @GroupBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) +BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END +END + +IF (@CategoryIDExclude is not null) +BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID NOT IN (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' +END + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' +END + +IF( @GroupBy = 'Month' ) +BEGIN +EXEC(' + select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate), Month(StartDate) + order by [Year] desc, [Month] desc') +END +ELSE +BEGIN +EXEC(' + select 1 as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate) + order by [Year] desc') +END +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(2000), + @CategoryIDExclude varchar(2000), + @AuthorID int, + @SortBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) +BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Articles.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END +END + +IF (@CategoryIDExclude is not null) +BEGIN + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID NOT IN (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' +END + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null ) + SELECT @strWhere = @strWhere + ' AND (Articles.StartDate is null OR Articles.StartDate < ''' + convert(nvarchar, DateAdd(mi, 1, GetDate())) + ''')' + +EXEC(' +SELECT + UserID, UserName, DisplayName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where Articles.IsApproved = 1 and Articles.IsDraft = 0 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, DisplayName, FirstName, LastName +ORDER BY ' + + @SortBy) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.75.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.75.SqlDataProvider new file mode 100755 index 0000000..6449ec7 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.75.SqlDataProvider @@ -0,0 +1,7 @@ +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_SecureCheck + @PortalID int, + @ArticleID int, + @UserID int +AS + SELECT 1 +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.77.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.77.SqlDataProvider new file mode 100755 index 0000000..82616ac --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.77.SqlDataProvider @@ -0,0 +1,262 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255), + @CustomFieldID int, + @CustomValue nvarchar(255), + @LinkFilter nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) +BEGIN + IF(@CategoryIDCount is not null) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + END + ELSE + BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END + END +END + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + +IF (@CustomFieldID is not null AND @CustomValue is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID IN (SELECT ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv WHERE cv.customFieldID = ' + convert(nvarchar, @CustomFieldID) + ' AND cv.CustomValue LIKE N''%' + @CustomValue + '%'')' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +IF (@LinkFilter is not null) + SELECT @strWhere = @strWhere + ' AND Article.Url = N''' + @LinkFilter + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[FileCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.81.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.81.SqlDataProvider new file mode 100755 index 0000000..9efa4bf --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.81.SqlDataProvider @@ -0,0 +1,257 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ADD + MetaTitle nvarchar(200) NULL, + MetaDescription nvarchar(500) NULL, + MetaKeywords nvarchar(500) NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddCategory + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext, + @SortOrder int, + @InheritSecurity bit, + @CategorySecurityType bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category ( + [ModuleID], + [ParentID], + [Name], + [Image], + [Description], + [SortOrder], + [InheritSecurity], + [CategorySecurityType], + [MetaTitle], + [MetaDescription], + [MetaKeywords] +) VALUES ( + @ModuleID, + @ParentID, + @Name, + @Image, + @Description, + @SortOrder, + @InheritSecurity, + @CategorySecurityType, + @MetaTitle, + @MetaDescription, + @MetaKeywords +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateCategory + @CategoryID int, + @ModuleID int, + @ParentID int, + @Name nvarchar(255), + @Image nvarchar(255), + @Description ntext, + @SortOrder int, + @InheritSecurity bit, + @CategorySecurityType int, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500) +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category SET + [ModuleID] = @ModuleID, + [ParentID] = @ParentID, + [Name] = @Name, + [Image] = @Image, + [Description] = @Description, + [SortOrder] = @SortOrder, + [InheritSecurity] = @InheritSecurity, + [CategorySecurityType] = @CategorySecurityType, + [MetaTitle] = @MetaTitle, + [MetaDescription] = @MetaDescription, + [MetaKeywords] = @MetaKeywords +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategory + @CategoryID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description], + [SortOrder], + [InheritSecurity], + [CategorySecurityType], + [MetaTitle], + [MetaDescription], + [MetaKeywords] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [CategoryID] = @CategoryID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryList + @ModuleID int, + @ParentID int +AS + +SELECT + [CategoryID], + [ParentID], + [ModuleID], + [Name], + [Image], + [Description], + [SortOrder], + [InheritSecurity], + [CategorySecurityType], + [MetaTitle], + [MetaDescription], + [MetaKeywords] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category +WHERE + [ModuleID] = @ModuleID + AND + [ParentID] = @ParentID +ORDER BY + [SortOrder], [Name] +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255), + @AuthorID int, + @MaxDepth int, + @ShowPending bit, + @SortType int +AS + +SET NOCOUNT ON + +DECLARE @FilterID int +SET @FilterID = @Current + +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT * FROM #stack WHERE level = @level) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + IF( @MaxDepth IS NULL OR @MaxDepth >= @level ) + BEGIN + IF( @SortType = 0 ) + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [SortOrder] DESC, [Name] DESC + END + ELSE + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [Name] DESC + END + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +IF( @FilterID IS NOT NULL ) +BEGIN + DELETE FROM #hierarchy WHERE CategoryID = @FilterID +END + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +DECLARE @strAuthorId nvarchar(255) +IF (@authorId is not null) + SELECT @strAuthorId = ' AND a.AuthorID = ' + cast(@AuthorID as nvarchar) + +DECLARE @strPending nvarchar(2000) +IF (@ShowPending is null) + SELECT @strPending = ' AND (a.StartDate IS NULL OR a.StartDate < GetDate())' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + c.[Description], + c.[SortOrder], + c.[InheritSecurity], + c.[CategorySecurityType], + c.[MetaTitle], + c.[MetaDescription], + c.[MetaKeywords], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 ' + @strAuthorId + @strPending + ') as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.84.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.84.SqlDataProvider new file mode 100755 index 0000000..6b82048 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.84.SqlDataProvider @@ -0,0 +1,105 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +ADD Title2 nvarchar(100) +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +SET Title2 = Title +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +DROP COLUMN Title +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +ADD Title nvarchar(255) +GO + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +SET Title = Title2 +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +DROP COLUMN Title2 +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageAdd +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageAdd + @ArticleID int, + @Title nvarchar(255), + @FileName nvarchar(100), + @Extension nvarchar(100), + @Size int, + @Width int, + @Height int, + @ContentType nvarchar(200), + @Folder nvarchar(200), + @SortOrder int, + @ImageGuid nvarchar(50) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image ( + [ArticleID], + [Title], + [FileName], + [Extension], + [Size], + [Width], + [Height], + [ContentType], + [Folder], + [SortOrder], + [ImageGuid] +) VALUES ( + @ArticleID, + @Title, + @FileName, + @Extension, + @Size, + @Width, + @Height, + @ContentType, + @Folder, + @SortOrder, + @ImageGuid +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageUpdate +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageUpdate + @ImageID int, + @ArticleID int, + @Title nvarchar(255), + @FileName nvarchar(100), + @Extension nvarchar(100), + @Size int, + @Width int, + @Height int, + @ContentType nvarchar(200), + @Folder nvarchar(200), + @SortOrder int, + @ImageGuid nvarchar(50) +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +SET + [ArticleID] = @ArticleID, + [Title] = @Title, + [FileName] = @FileName, + [Extension] = @Extension, + [Size] = @Size, + [Width] = @Width, + [Height] = @Height, + [ContentType] = @ContentType, + [Folder] = @Folder, + [SortOrder] = @SortOrder, + [ImageGuid] = @ImageGuid +WHERE + [ImageID] = @ImageID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.85.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.85.SqlDataProvider new file mode 100755 index 0000000..f69de7a --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.85.SqlDataProvider @@ -0,0 +1,39 @@ +CREATE NONCLUSTERED INDEX [_dta_index_{objectQualifier}DnnForge_NewsArticles_Page] ON {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page +( + [SortOrder] ASC, + [ArticleID] ASC +) ON [PRIMARY] +GO + +CREATE NONCLUSTERED INDEX [_dta_index_{objectQualifier}DnnForge_NewsArticles_Article] ON {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +( + [ModuleID] ASC, + [ArticleID] ASC, + [IsApproved] ASC, + [IsDraft] ASC, + [EndDate] ASC, + [StartDate] ASC +) ON [PRIMARY] +GO + +CREATE NONCLUSTERED INDEX [_dta_index_{objectQualifier}DnnForge_NewsArticles_Article_Category] ON {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories +( + [ArticleID] ASC, + [CategoryID] ASC +)ON [PRIMARY] +GO + +CREATE NONCLUSTERED INDEX [_dta_index_{objectQualifier}DnnForge_NewsArticles_Article_Views] ON {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +( + [ArticleID] ASC +) +INCLUDE ( [NumberOfViews]) ON [PRIMARY] +GO + +CREATE NONCLUSTERED INDEX [_dta_index_{objectQualifier}DnnForge_NewsArticles_Article_Status] ON {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +( + [ArticleID] ASC, + [IsDraft] ASC, + [IsApproved] ASC +)ON [PRIMARY] +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.87.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.87.SqlDataProvider new file mode 100755 index 0000000..95cfece --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.87.SqlDataProvider @@ -0,0 +1,271 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255), + @CustomFieldID int, + @CustomValue nvarchar(255), + @LinkFilter nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + convert(nvarchar, @CurrentDate) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END +ELSE +BEGIN + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + convert(nvarchar, @AgedDate) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + convert(nvarchar, @CurrentDate) + ''')' +END + +IF (@CategoryId is not null) +BEGIN + IF(@CategoryIDCount is not null) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + END + ELSE + BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END + END +END + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) +BEGIN + IF( LEN(@Keywords) = 1 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''' + @Keywords + '%'')' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + END +END + +IF (@CustomFieldID is not null AND @CustomValue is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID IN (SELECT ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv WHERE cv.customFieldID = ' + convert(nvarchar, @CustomFieldID) + ' AND cv.CustomValue LIKE N''%' + @CustomValue + '%'')' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +IF (@LinkFilter is not null) + SELECT @strWhere = @strWhere + ' AND Article.Url = N''' + @LinkFilter + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[FileCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.88.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.88.SqlDataProvider new file mode 100755 index 0000000..0ce0468 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.88.SqlDataProvider @@ -0,0 +1,61 @@ +CREATE TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Mirror( + [ArticleID] [int] NOT NULL, + [LinkedArticleID] [int] NOT NULL, + [LinkedPortalID] [int] NOT NULL, + [AutoUpdate] [bit] NOT NULL, + CONSTRAINT [PK_{objectQualifier}DnnForge_NewsArticles_Mirror] PRIMARY KEY CLUSTERED +( + [ArticleID] ASC +) +) ON [PRIMARY] +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetMirrorArticle + @ArticleID int +AS + +SELECT + m.[ArticleID], + m.[LinkedArticleID], + m.[LinkedPortalID], + m.[AutoUpdate] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Mirror m +WHERE + m.[ArticleID] = @ArticleID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetMirrorArticleList + @LinkedArticleID int +AS + +SELECT + m.[ArticleID], + m.[LinkedArticleID], + m.[LinkedPortalID], + m.[AutoUpdate] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Mirror m +WHERE + m.[LinkedArticleID] = @LinkedArticleID +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddMirrorArticle + @ArticleID int, + @LinkedArticleID int, + @LinkedPortalID int, + @AutoUpdate bit +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Mirror ( + [ArticleID], + [LinkedArticleID], + [LinkedPortalID], + [AutoUpdate] +) VALUES ( + @ArticleID, + @LinkedArticleID, + @LinkedPortalID, + @AutoUpdate +) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.89.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.89.SqlDataProvider new file mode 100755 index 0000000..759d1ff --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.89.SqlDataProvider @@ -0,0 +1,21 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetMirrorArticleList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetMirrorArticleList + @LinkedArticleID int +AS + +SELECT + m.[ArticleID], + m.[LinkedArticleID], + m.[LinkedPortalID], + m.[AutoUpdate], + mo.[PortalID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Mirror m INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON m.ArticleID = a.ArticleID INNER JOIN + {databaseOwner}{objectQualifier}Modules mo ON a.ModuleID = mo.ModuleID +WHERE + m.[LinkedArticleID] = @LinkedArticleID +GO + \ No newline at end of file diff --git a/Providers/DataProvider/SqlDataProvider/00.07.96.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.96.SqlDataProvider new file mode 100755 index 0000000..7ea8171 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.96.SqlDataProvider @@ -0,0 +1,396 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255), + @CustomFieldID int, + @CustomValue nvarchar(255), + @LinkFilter nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + CONVERT(char(24), @CurrentDate, 126) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + CONVERT(char(24), @AgedDate, 126) + '''' +END +ELSE +BEGIN + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + CONVERT(char(24), @AgedDate, 126) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + CONVERT(char(24), @CurrentDate, 126) + ''')' +END + +IF (@CategoryId is not null) +BEGIN + IF(@CategoryIDCount is not null) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + END + ELSE + BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END + END +END + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) +BEGIN + IF( LEN(@Keywords) = 1 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''' + @Keywords + '%'')' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0))' + END +END + +IF (@CustomFieldID is not null AND @CustomValue is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID IN (SELECT ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv WHERE cv.customFieldID = ' + convert(nvarchar, @CustomFieldID) + ' AND cv.CustomValue LIKE N''%' + @CustomValue + '%'')' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +IF (@LinkFilter is not null) + SELECT @strWhere = @strWhere + ' AND Article.Url = N''' + @LinkFilter + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[FileCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(2000), + @CategoryIDExclude varchar(2000), + @AuthorID int, + @GroupBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) +BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END +END + +IF (@CategoryIDExclude is not null) +BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID NOT IN (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' +END + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + CONVERT(char(24), DateAdd(mi, 1, GetDate()), 126) + ''')' +END + +IF( @GroupBy = 'Month' ) +BEGIN +EXEC(' + select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate), Month(StartDate) + order by [Year] desc, [Month] desc') +END +ELSE +BEGIN +EXEC(' + select 1 as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate) + order by [Year] desc') +END +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(2000), + @CategoryIDExclude varchar(2000), + @AuthorID int, + @SortBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) +BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Articles.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END +END + +IF (@CategoryIDExclude is not null) +BEGIN + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID NOT IN (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' +END + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null ) + SELECT @strWhere = @strWhere + ' AND (Articles.StartDate is null OR Articles.StartDate < ''' + CONVERT(char(24), DateAdd(mi, 1, GetDate()), 126) + ''')' + +EXEC(' +SELECT + UserID, UserName, DisplayName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where Articles.IsApproved = 1 and Articles.IsDraft = 0 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, DisplayName, FirstName, LastName +ORDER BY ' + + @SortBy) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.97.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.97.SqlDataProvider new file mode 100755 index 0000000..dc76b87 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.97.SqlDataProvider @@ -0,0 +1,149 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image ADD + Description ntext NULL +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageAdd +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageAdd + @ArticleID int, + @Title nvarchar(255), + @FileName nvarchar(100), + @Extension nvarchar(100), + @Size int, + @Width int, + @Height int, + @ContentType nvarchar(200), + @Folder nvarchar(200), + @SortOrder int, + @ImageGuid nvarchar(50), + @Description ntext +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image ( + [ArticleID], + [Title], + [FileName], + [Extension], + [Size], + [Width], + [Height], + [ContentType], + [Folder], + [SortOrder], + [ImageGuid], + [Description] +) VALUES ( + @ArticleID, + @Title, + @FileName, + @Extension, + @Size, + @Width, + @Height, + @ContentType, + @Folder, + @SortOrder, + @ImageGuid, + @Description +) + +select SCOPE_IDENTITY() +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageGet +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageGet + @ImageID int +AS + +SELECT + ImageID, + ArticleID, + Title, + FileName, + Extension, + Size, + Width, + Height, + ContentType, + Folder, + SortOrder, + ImageGuid, + Description +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +WHERE + ImageID = @ImageID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageList +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageList + @ArticleID int, + @ImageGuid nvarchar(50) +AS + +SELECT + ImageID, + ArticleID, + Title, + FileName, + Extension, + Size, + Width, + Height, + ContentType, + Folder, + SortOrder, + ImageGuid, + Description +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +WHERE + (@ArticleID IS NULL OR ArticleID = @ArticleID) + AND + (@ImageGuid IS NULL OR ImageGuid = @ImageGuid) +ORDER BY + SortOrder +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageUpdate +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ImageUpdate + @ImageID int, + @ArticleID int, + @Title nvarchar(255), + @FileName nvarchar(100), + @Extension nvarchar(100), + @Size int, + @Width int, + @Height int, + @ContentType nvarchar(200), + @Folder nvarchar(200), + @SortOrder int, + @ImageGuid nvarchar(50), + @Description ntext +AS + +UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image +SET + [ArticleID] = @ArticleID, + [Title] = @Title, + [FileName] = @FileName, + [Extension] = @Extension, + [Size] = @Size, + [Width] = @Width, + [Height] = @Height, + [ContentType] = @ContentType, + [Folder] = @Folder, + [SortOrder] = @SortOrder, + [ImageGuid] = @ImageGuid, + [Description] = @Description +WHERE + [ImageID] = @ImageID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.98.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.98.SqlDataProvider new file mode 100755 index 0000000..d3bbbcd --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.98.SqlDataProvider @@ -0,0 +1,402 @@ +CREATE NONCLUSTERED INDEX [_dta_index_{objectQualifier}DnnForge_NewsArticles_Articl_5_160719625__K2] ON {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories +( + [CategoryID] ASC +)WITH (SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, DROP_EXISTING = OFF, ONLINE = OFF) ON [PRIMARY] +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255), + @CustomFieldID int, + @CustomValue nvarchar(255), + @LinkFilter nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + CONVERT(char(24), @CurrentDate, 126) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + CONVERT(char(24), @AgedDate, 126) + '''' +END +ELSE +BEGIN + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + CONVERT(char(24), @AgedDate, 126) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + CONVERT(char(24), @CurrentDate, 126) + ''')' +END + +IF (@CategoryId is not null) +BEGIN + IF(@CategoryIDCount is not null) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + END + ELSE + BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END + END +END + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) +BEGIN + IF( LEN(@Keywords) = 1 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''' + @Keywords + '%'')' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0) OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv where cv.ArticleID = Article.ArticleID and cv.CustomValue LIKE N''%' + @Keywords + '%'') > 0))' + END +END + +IF (@CustomFieldID is not null AND @CustomValue is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID IN (SELECT ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv WHERE cv.customFieldID = ' + convert(nvarchar, @CustomFieldID) + ' AND cv.CustomValue LIKE N''%' + @CustomValue + '%'')' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +IF (@LinkFilter is not null) + SELECT @strWhere = @strWhere + ' AND Article.Url = N''' + @LinkFilter + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[FileCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(2000), + @CategoryIDExclude varchar(2000), + @AuthorID int, + @GroupBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) +BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END +END + +IF (@CategoryIDExclude is not null) +BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID NOT IN (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' +END + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + CONVERT(char(24), DateAdd(mi, 1, GetDate()), 126) + ''')' +END + +IF( @GroupBy = 'Month' ) +BEGIN +EXEC(' + select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate), Month(StartDate) + order by [Year] desc, [Month] desc') +END +ELSE +BEGIN +EXEC(' + select 1 as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate) + order by [Year] desc') +END +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(2000), + @CategoryIDExclude varchar(2000), + @AuthorID int, + @SortBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) +BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Articles.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END +END + +IF (@CategoryIDExclude is not null) +BEGIN + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID NOT IN (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' +END + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null ) + SELECT @strWhere = @strWhere + ' AND (Articles.StartDate is null OR Articles.StartDate < ''' + CONVERT(char(24), DateAdd(mi, 1, GetDate()), 126) + ''')' + +EXEC(' +SELECT + UserID, UserName, DisplayName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where Articles.IsApproved = 1 and Articles.IsDraft = 0 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, DisplayName, FirstName, LastName +ORDER BY ' + + @SortBy) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.07.99.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.07.99.SqlDataProvider new file mode 100755 index 0000000..ee1f7f8 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.07.99.SqlDataProvider @@ -0,0 +1,396 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetArticleListBySearchCriteria + @ModuleID int, + @CurrentDate datetime, + @AgedDate datetime, + @CategoryID varchar(2000), + @CategoryIDCount int, + @CategoryIDExclude varchar(2000), + @MaxCount int, + @PageNumber int, + @PageSize int, + @SortBy varchar(50), + @SortDirection varchar(50), + @IsApproved bit, + @IsDraft bit, + @KeyWords nvarchar(255), + @AuthorID int, + @ShowPending bit, + @ShowExpired bit, + @ShowFeaturedOnly bit, + @ShowNotFeaturedOnly bit, + @ShowSecuredOnly bit, + @ShowNotSecuredOnly bit, + @ArticleIDs varchar(255), + @TagID varchar(2000), + @TagIDCount int, + @RssGuid nvarchar(255), + @CustomFieldID int, + @CustomValue nvarchar(255), + @LinkFilter nvarchar(255) +AS + +-- Form Where Query + +DECLARE @strWhere nvarchar(4000) +SELECT @strWhere = 'Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF( @CurrentDate is null ) + SELECT @CurrentDate = GetDate() + +IF( @ShowPending is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null OR (Article.StartDate <= ''' + CONVERT(char(24), @CurrentDate, 126) + ''' AND Article.StartDate <= GetDate()))' + + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + CONVERT(char(24), @AgedDate, 126) + '''' +END +ELSE +BEGIN + IF( @AgedDate is not null ) + SELECT @strWhere = @strWhere + ' AND Article.StartDate >= ''' + CONVERT(char(24), @AgedDate, 126) + '''' +END + +IF( @ShowExpired is null ) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.EndDate is null OR Article.EndDate >= ''' + CONVERT(char(24), @CurrentDate, 126) + ''')' +END + +IF (@CategoryId is not null) +BEGIN + IF(@CategoryIDCount is not null) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ') group by articleID having count(*) > ' + convert(nvarchar, @CategoryIDCount) + ')' + END + ELSE + BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END + END +END + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@CategoryIDExclude is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID not in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@IsApproved = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 1' + +IF (@IsApproved = 0 ) + SELECT @strWhere = @strWhere + ' AND Article.IsApproved = 0' + +IF (@IsDraft = 0) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 0' + +IF (@IsDraft = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsDraft = 1' + +IF (@ShowFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 1' + +IF (@ShowNotFeaturedOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsFeatured = 0' + +IF (@ShowSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 1' + +IF (@ShowNotSecuredOnly = 1 ) + SELECT @strWhere = @strWhere + ' AND Article.IsSecure = 0' + +IF (@Keywords is not null) +BEGIN + IF( LEN(@Keywords) = 1 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''' + @Keywords + '%'')' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.Title LIKE N''%' + @Keywords + '%'' OR Article.Summary LIKE N''%' + @Keywords + '%'' OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = Article.ArticleID and Page.PageText LIKE N''%' + @Keywords + '%'') > 0) OR ((select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv where cv.ArticleID = Article.ArticleID and cv.CustomValue LIKE N''%' + @Keywords + '%'') > 0))' + END +END + +IF (@CustomFieldID is not null AND @CustomValue is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID IN (SELECT ArticleID FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_CustomValue cv WHERE cv.customFieldID = ' + convert(nvarchar, @CustomFieldID) + ' AND cv.CustomValue LIKE N''%' + @CustomValue + '%'')' + +IF (@ArticleIDs is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in (' + @ArticleIDs + ')' + +IF (@SortBy = 'Title') + SELECT @SortBy = 'Article.Title' + +IF (@SortBy = 'IsFeatured DESC, Title') + SELECT @SortBy = 'IsFeatured DESC, Article.Title' + +IF (@TagID is not null) + if(@TagIDCount is not null) + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + ') group by articleID having count(*) > ' + convert(nvarchar, @TagIDCount) + ')' + else + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleTag.TagID in (' + @TagID + '))' + +IF (@RssGuid is not null) + SELECT @strWhere = @strWhere + ' AND Article.RssGuid = N''' + @RssGuid + '''' + +IF (@LinkFilter is not null) + SELECT @strWhere = @strWhere + ' AND Article.Url = N''' + @LinkFilter + '''' + +-- Set Paging Options + +IF( @PageNumber is null ) + SET @PageNumber = 1 + +IF( @PageSize is null ) + SET @PageSize = 100 + +SET @PageNumber = @PageNumber - 1 + +DECLARE @startRowIndex int +SET @startRowIndex = (@PageNumber * @PageSize) + +DECLARE @maxRow int +SET @maxRow = (@startRowIndex + @PageSize) +IF( @MaxCount is not null ) +BEGIN + IF( @MaxCount < @MaxRow ) + BEGIN + SET ROWCOUNT @MaxCount + END + ELSE + BEGIN + SET ROWCOUNT @maxRow + END +END +ELSE +BEGIN + SET ROWCOUNT @maxRow +END + +-- Create Temporary Table + +CREATE TABLE #TempItems +( + ID int IDENTITY, + ArticleID int +) + +EXEC(' +INSERT INTO #TempItems (ArticleID) +SELECT + Article.[ArticleID] +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID +WHERE ' + + @strWhere + ' +ORDER BY + ' + @SortBy + ' ' + @SortDirection) + +SET ROWCOUNT 0 + +SELECT + Article.[ArticleID], + Article.[AuthorID], + Article.[ApproverID], + Article.[CreatedDate], + Article.[LastUpdate], + Article.[Title], + Article.[Summary], + Article.[IsApproved], + Article.[NumberOfViews], + Article.[StartDate], + Article.[EndDate], + Article.[ModuleID], + Article.[IsFeatured], + Article.[ImageUrl], + Article.[LastUpdateID], + Article.[IsSecure], + Article.[IsNewWindow], + Article.[ImageUrl], + Article.[Url], + Article.[PageCount], + Article.[CommentCount], + Article.[Rating], + Article.[RatingCount], + Article.[FileCount], + Article.[ImageCount], + Article.[MetaTitle], + Article.[MetaDescription], + Article.[MetaKeywords], + Article.[PageHeadText], + Article.[ShortUrl], + Article.[RssGuid], + Author.[Email] as AuthorEmail, + Author.[UserName] as AuthorUserName, + Author.[FirstName] as AuthorFirstName, + Author.[LastName] as AuthorLastName, + Author.[DisplayName] as AuthorDisplayName, + Updated.[Email] as LastUpdateEmail, + Updated.[UserName] as LastUpdateUserName, + Updated.[FirstName] as LastUpdateFirstName, + Updated.[LastName] as LastUpdateLastName, + Updated.[DisplayName] as LastUpdateDisplayName, + Page.PageText as 'Body', + {databaseOwner}{objectQualifier}Ventrian_NewsArticles_SplitTags(Article.[ArticleID]) as 'Tags' + +FROM + #TempItems t INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article ON t.ArticleID = Article.ArticleID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page on Page.ArticleID = Article.ArticleID AND Page.SortOrder = 0 LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Author ON Article.AuthorID = Author.UserID LEFT OUTER JOIN + {databaseOwner}{objectQualifier}Users Updated ON Article.LastUpdateID = Updated.UserID + +WHERE + ID > @startRowIndex + +ORDER BY + ID + +DROP TABLE #TempItems + +EXEC(' +SELECT + COUNT(Article.ArticleID) as ''TotalRecords'' +FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Article +WHERE ' + + @strWhere ) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetNewsArchive + @ModuleID int, + @CategoryID varchar(2000), + @CategoryIDExclude varchar(2000), + @AuthorID int, + @GroupBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Article.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) +BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.ArticleID in ( select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories where {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.ArticleID = Article.ArticleID and {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Article.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END +END + +IF (@CategoryIDExclude is not null) +BEGIN + SELECT @strWhere = @strWhere + ' AND Article.ArticleID NOT IN (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' +END + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Article.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null) +BEGIN + SELECT @strWhere = @strWhere + ' AND (Article.StartDate is null or Article.StartDate < ''' + CONVERT(char(24), DateAdd(mi, 1, GetDate()), 126) + ''')' +END + +IF( @GroupBy = 'Month' ) +BEGIN +EXEC(' + select Month(StartDate) as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate), Month(StartDate) + order by [Year] desc, [Month] desc') +END +ELSE +BEGIN +EXEC(' + select 1 as [Month], Year(StartDate) as [Year], 1 as Day, Count(*) as [Count] + from {databaseOwner}{objectQualifier}dnnforge_newsarticles_article Article + where IsApproved = 1 and IsDraft = 0 ' + + @strWhere + ' + group by Year(StartDate) + order by [Year] desc') +END +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetAuthorStatistics + @ModuleID int, + @CategoryID varchar(2000), + @CategoryIDExclude varchar(2000), + @AuthorID int, + @SortBy varchar(255), + @ShowPending bit +AS + +DECLARE @strTop nvarchar(2000) +DECLARE @strWhere nvarchar(2000) + +SELECT @strTop = '' +SELECT @strWhere = '' + +IF (@ModuleID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.ModuleID = ' + convert(nvarchar, @ModuleId) + +IF (@CategoryId is not null) +BEGIN + IF( CHARINDEX('-1', @CategoryID) = 0 ) + BEGIN + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + '))' + END + ELSE + BEGIN + SELECT @strWhere = @strWhere + ' AND (Articles.ArticleID in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryID + ')) OR Articles.ArticleID not in (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories))' + END +END + +IF (@CategoryIDExclude is not null) +BEGIN + SELECT @strWhere = @strWhere + ' AND Articles.ArticleID NOT IN (select ArticleID from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ArticleCategories where ArticleCategories.CategoryID in (' + @CategoryIDExclude + '))' +END + +IF (@AuthorID is not null) + SELECT @strWhere = @strWhere + ' AND Articles.AuthorID = ' + convert(nvarchar, @AuthorID) + +IF (@ShowPending is null ) + SELECT @strWhere = @strWhere + ' AND (Articles.StartDate is null OR Articles.StartDate < ''' + CONVERT(char(24), DateAdd(mi, 1, GetDate()), 126) + ''')' + +EXEC(' +SELECT + UserID, UserName, DisplayName, FirstName, LastName, count(*) as ''ArticleCount'' +FROM + {databaseOwner}{objectQualifier}Users Users, {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article Articles +where Articles.IsApproved = 1 and Articles.IsDraft = 0 and Users.UserID = Articles.AuthorID ' + + @strWhere + ' +GROUP BY + UserID, UserName, DisplayName, FirstName, LastName +ORDER BY ' + + @SortBy) +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.08.00.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.08.00.SqlDataProvider new file mode 100755 index 0000000..5cdaf0f --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.08.00.SqlDataProvider @@ -0,0 +1,114 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @Current int, + @CategoryID varchar(255), + @AuthorID int, + @MaxDepth int, + @ShowPending bit, + @SortType int +AS + +SET NOCOUNT ON + +DECLARE @FilterID int +SET @FilterID = @Current + +DECLARE @level int, @line int + +CREATE TABLE #hierarchy(HierarchyID int IDENTITY (1,1), CategoryID int, level int) +CREATE TABLE #stack (StackID int IDENTITY (1,1), item int, level int) +INSERT INTO #stack VALUES (@current, 1) +SELECT @level = 1 + +WHILE @level > 0 +BEGIN + IF EXISTS (SELECT TOP 1 * FROM #stack WHERE level = @level ORDER BY StackID) + BEGIN + SELECT @current = item + FROM #stack + WHERE level = @level + + insert into #hierarchy(CategoryID, level) values(@current, @level) + + DELETE FROM #stack + WHERE level = @level + AND item = @current + + IF( @MaxDepth IS NULL OR @MaxDepth >= @level ) + BEGIN + IF( @SortType = 0 ) + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [SortOrder] DESC, [Name] DESC + END + ELSE + BEGIN + INSERT #stack + SELECT CategoryID, @level + 1 + FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE ParentID = @current and ModuleID = @ModuleID + ORDER BY [Name] DESC + END + IF @@ROWCOUNT > 0 + SELECT @level = @level + 1 + END + END + ELSE + SELECT @level = @level - 1 +END -- WHILE + +IF( @FilterID IS NOT NULL ) +BEGIN + DELETE FROM #hierarchy WHERE CategoryID = @FilterID +END + +DECLARE @strModuleID nvarchar(50) +SELECT @strModuleID = convert(varchar, @ModuleID) + +DECLARE @strCategoryId nvarchar(255) +IF (@CategoryId is not null) + SELECT @strCategoryId = ' AND c.CategoryID in (' + @CategoryID + ')' + +DECLARE @strAuthorId nvarchar(255) +IF (@authorId is not null) + SELECT @strAuthorId = ' AND a.AuthorID = ' + cast(@AuthorID as nvarchar) + +DECLARE @strPending nvarchar(2000) +IF (@ShowPending is null) + SELECT @strPending = ' AND (a.StartDate IS NULL OR a.StartDate < GetDate())' + +EXEC(' +SELECT + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE(''.'',(level-2)*2) + c.[Name] as ''NameIndented'', + c.[Image], + c.[Description], + c.[SortOrder], + c.[InheritSecurity], + c.[CategorySecurityType], + c.[MetaTitle], + c.[MetaDescription], + c.[MetaKeywords], + level-1 as ''Level'', + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 ' + @strAuthorId + @strPending + ') as ''NumberofArticles'', + (SELECT SUM(a.NumberOfViews) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac ON a.ArticleID = ac.ArticleID WHERE ac.CategoryID = c.CategoryID) as ''NumberofViews'' +FROM + #hierarchy h INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON h.CategoryID = c.CategoryID +WHERE + c.[ModuleID] = ' + @strModuleID + @strCategoryId + ' +ORDER BY + h.HierarchyID ASC') + +drop table #hierarchy +drop table #stack +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.08.04.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.08.04.SqlDataProvider new file mode 100755 index 0000000..1229535 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.08.04.SqlDataProvider @@ -0,0 +1,134 @@ +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdateArticleCount + @ArticleID int, + @NumberOfViews int +AS + UPDATE + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article + SET + [NumberOfViews] = @NumberOfViews + WHERE + [ArticleID] = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @AuthorID int, + @ShowPending bit, + @SortType int +AS + +;WITH CategoryHierarchy AS +( + SELECT + CategoryID, + ParentID, + CONVERT(nvarchar(max), Name) AS Path, + 1 as level, + SortOrder * (CONVERT(bigint, '1' + REPLICATE('0', 10))) AS 'SortOrderCount' + FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE + ParentID = -1 + AND + ModuleID = @ModuleID + + UNION ALL + + SELECT + TH.CategoryID, + TH.ParentID, + CONVERT(nvarchar(max), CategoryHierarchy.Path + ' \ ' + TH.Name) AS Path, + level = level + 1, + CategoryHierarchy.SortOrderCount + (CONVERT(bigint, CONVERT(varchar, TH.SortOrder) + REPLICATE('0', 10-level))) AS 'SortOrderCount' + FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category TH INNER JOIN + CategoryHierarchy ON CategoryHierarchy.CategoryID = TH.ParentID +) + +SELECT + SortOrderCount, + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE('.',(level-1)*2) + c.[Name] as 'NameIndented', + c.[Image], + c.[Description], + c.[SortOrder], + c.[InheritSecurity], + c.[CategorySecurityType], + c.[MetaTitle], + c.[MetaDescription], + c.[MetaKeywords], + ch.[level], + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 AND (@authorId IS NULL OR a.AuthorID = @authorID) AND (@ShowPending IS NOT NULL OR (a.StartDate IS NULL OR a.StartDate < GetDate()))) as 'NumberofArticles' +FROM + CategoryHierarchy ch INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON ch.CategoryID = c.CategoryID +ORDER BY + CASE WHEN @SortType = 0 THEN CAST(ch.SortOrderCount AS VARCHAR) ELSE ch.Path END +GO + +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page +ALTER COLUMN PageText nvarchar(max) +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddPage +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddPage + @ArticleID int, + @Title nvarchar(255), + @PageText nvarchar(max), + @SortOrder int +AS + +declare @count int + +select @count = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page where ArticleID = @ArticleID) + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page ( + [ArticleID], + [Title], + [PageText], + [SortOrder] +) VALUES ( + @ArticleID, + @Title, + @PageText, + @count +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID +GO + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdatePage +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_UpdatePage + @PageID int, + @ArticleID int, + @Title nvarchar(255), + @PageText nvarchar(max), + @SortOrder int +AS + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page SET + [ArticleID] = @ArticleID, + [Title] = @Title, + [PageText] = @PageText, + [SortOrder] = @SortOrder +WHERE + [PageID] = @PageID + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = @ArticleID +GO diff --git a/Providers/DataProvider/SqlDataProvider/00.08.05.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.08.05.SqlDataProvider new file mode 100755 index 0000000..9f700b0 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.08.05.SqlDataProvider @@ -0,0 +1,62 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @AuthorID int, + @ShowPending bit, + @SortType int +AS + +;WITH CategoryHierarchy AS +( + SELECT + CategoryID, + ParentID, + CONVERT(nvarchar(max), Name) AS Path, + 1 as level, + (SortOrder+1) * (CONVERT(bigint, '1' + REPLICATE('0', 10))) AS 'SortOrderCount' + FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE + ParentID = -1 + AND + ModuleID = @ModuleID + + UNION ALL + + SELECT + TH.CategoryID, + TH.ParentID, + CONVERT(nvarchar(max), CategoryHierarchy.Path + ' \ ' + TH.Name) AS Path, + level = level + 1, + CategoryHierarchy.SortOrderCount + (CONVERT(bigint, CONVERT(varchar, TH.SortOrder) + REPLICATE('0', 10-level))) AS 'SortOrderCount' + FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category TH INNER JOIN + CategoryHierarchy ON CategoryHierarchy.CategoryID = TH.ParentID +) + +SELECT + SortOrderCount, + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE('.',(level-1)*2) + c.[Name] as 'NameIndented', + c.[Image], + c.[Description], + c.[SortOrder], + c.[InheritSecurity], + c.[CategorySecurityType], + c.[MetaTitle], + c.[MetaDescription], + c.[MetaKeywords], + ch.[level], + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 AND (@authorId IS NULL OR a.AuthorID = @authorID) AND (@ShowPending IS NOT NULL OR (a.StartDate IS NULL OR a.StartDate < GetDate()))) as 'NumberofArticles' +FROM + CategoryHierarchy ch INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON ch.CategoryID = c.CategoryID +ORDER BY + CASE WHEN @SortType = 0 THEN CAST(ch.SortOrderCount AS VARCHAR) ELSE ch.Path END +GO + diff --git a/Providers/DataProvider/SqlDataProvider/00.08.06.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.08.06.SqlDataProvider new file mode 100755 index 0000000..e0798c0 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.08.06.SqlDataProvider @@ -0,0 +1,62 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @AuthorID int, + @ShowPending bit, + @SortType int +AS + +;WITH CategoryHierarchy AS +( + SELECT + CategoryID, + ParentID, + CONVERT(nvarchar(max), Name) AS Path, + 1 as level, + (SortOrder+1) * (CONVERT(bigint, '1' + REPLICATE('0', 10))) AS 'SortOrderCount' + FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE + ParentID = -1 + AND + ModuleID = @ModuleID + + UNION ALL + + SELECT + TH.CategoryID, + TH.ParentID, + CONVERT(nvarchar(max), CategoryHierarchy.Path + ' \ ' + TH.Name) AS Path, + level = level + 1, + CategoryHierarchy.SortOrderCount + (CONVERT(bigint, CONVERT(varchar, (TH.SortOrder+1)) + REPLICATE('0', 10-(level*2)))) AS 'SortOrderCount' + FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category TH INNER JOIN + CategoryHierarchy ON CategoryHierarchy.CategoryID = TH.ParentID +) + +SELECT + SortOrderCount, + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE('.',(level-1)*2) + c.[Name] as 'NameIndented', + c.[Image], + c.[Description], + c.[SortOrder], + c.[InheritSecurity], + c.[CategorySecurityType], + c.[MetaTitle], + c.[MetaDescription], + c.[MetaKeywords], + ch.[level], + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 AND (@authorId IS NULL OR a.AuthorID = @authorID) AND (@ShowPending IS NOT NULL OR (a.StartDate IS NULL OR a.StartDate < GetDate()))) as 'NumberofArticles' +FROM + CategoryHierarchy ch INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON ch.CategoryID = c.CategoryID +ORDER BY + CASE WHEN @SortType = 0 THEN CAST(ch.SortOrderCount AS VARCHAR) ELSE ch.Path END +GO + diff --git a/Providers/DataProvider/SqlDataProvider/00.09.02.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.09.02.SqlDataProvider new file mode 100755 index 0000000..0658855 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.09.02.SqlDataProvider @@ -0,0 +1,109 @@ + +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddArticle + @AuthorID int, + @ApproverID int, + @CreatedDate datetime, + @LastUpdate datetime, + @Title nvarchar(255), + @Summary ntext, + @IsApproved bit, + @NumberOfViews int, + @IsDraft bit, + @StartDate DateTime, + @EndDate DateTime, + @ModuleID int, + @ImageUrl nvarchar(255), + @IsFeatured bit, + @LastUpdateID int, + @Url nvarchar(255), + @IsSecure bit, + @IsNewWindow bit, + @MetaTitle nvarchar(200), + @MetaDescription nvarchar(500), + @MetaKeywords nvarchar(500), + @PageHeadText nvarchar(500), + @ShortUrl nvarchar(50), + @RssGuid nvarchar(255) +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article ( + [AuthorID], + [ApproverID], + [CreatedDate], + [LastUpdate], + [Title], + [Summary], + [IsApproved], + [NumberOfViews], + [IsDraft], + [StartDate], + [EndDate], + [ModuleID], + [ImageUrl], + [IsFeatured], + [LastUpdateID], + [Url], + [IsSecure], + [IsNewWindow], + [MetaTitle], + [MetaDescription], + [MetaKeywords], + [PageHeadText], + [ShortUrl], + [RssGuid] +) VALUES ( + @AuthorID, + @ApproverID, + @CreatedDate, + @LastUpdate, + @Title, + @Summary, + @IsApproved, + @NumberOfViews, + @IsDraft, + @StartDate, + @EndDate, + @ModuleID, + @ImageUrl, + @IsFeatured, + @LastUpdateID, + @Url, + @IsSecure, + @IsNewWindow, + @MetaTitle, + @MetaDescription, + @MetaKeywords, + @PageHeadText, + @ShortUrl, + @RssGuid +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [PageCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Page Page where Page.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [Rating] = (select AVG(rating) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [RatingCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Rating Rating where Rating.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [ImageCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Image i where i.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [FileCount] = (select COUNT(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_File f where f.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID) +WHERE [ArticleID] = SCOPE_IDENTITY() +GO \ No newline at end of file diff --git a/Providers/DataProvider/SqlDataProvider/00.09.05.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.09.05.SqlDataProvider new file mode 100755 index 0000000..c8f499c --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.09.05.SqlDataProvider @@ -0,0 +1,71 @@ +ALTER TABLE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_HandoutArticle ADD CONSTRAINT + PK_{objectQualifier}DnnForge_NewsArticles_HandoutArticle PRIMARY KEY CLUSTERED + ( + HandoutID, + ArticleID + ) ON [PRIMARY] + +GO + +ALTER PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_AddComment + @ArticleID int, + @CreatedDate datetime, + @UserID int, + @Comment ntext, + @RemoteAddress nvarchar(50) , + @Type int, + @TrackbackUrl nvarchar(255), + @TrackbackTitle nvarchar(255), + @TrackbackBlogName nvarchar(255), + @TrackbackExcerpt ntext, + @AnonymousName nvarchar(255), + @AnonymousEmail nvarchar(255), + @AnonymousURL nvarchar(255), + @NotifyMe bit, + @IsApproved bit, + @ApprovedBy int +AS + +INSERT INTO {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment ( + [ArticleID], + [CreatedDate], + [UserID], + [Comment], + [RemoteAddress], + [Type], + [TrackbackUrl], + [TrackbackTitle], + [TrackbackBlogName], + [TrackbackExcerpt], + [AnonymousName], + [AnonymousEmail], + [AnonymousURL], + [NotifyMe], + [IsApproved], + [ApprovedBy] +) VALUES ( + @ArticleID, + @CreatedDate, + @UserID, + @Comment, + @RemoteAddress, + @Type, + @TrackbackUrl, + @TrackbackTitle, + @TrackbackBlogName, + @TrackbackExcerpt, + @AnonymousName, + @AnonymousEmail, + @AnonymousURL, + @NotifyMe, + @IsApproved, + @ApprovedBy +) + +select SCOPE_IDENTITY() + +UPDATE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article +SET [CommentCount] = (select count(*) from {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Comment Comment where Comment.ArticleID = {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article.ArticleID and Comment.IsApproved = 1) +WHERE ArticleID = @ArticleID +GO + diff --git a/Providers/DataProvider/SqlDataProvider/00.09.11.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/00.09.11.SqlDataProvider new file mode 100755 index 0000000..0cd4155 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/00.09.11.SqlDataProvider @@ -0,0 +1,61 @@ +DROP PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll +GO + +CREATE PROCEDURE {databaseOwner}{objectQualifier}DnnForge_NewsArticles_GetCategoryListAll + @ModuleID int, + @AuthorID int, + @ShowPending bit, + @SortType int +AS + +;WITH CategoryHierarchy AS +( + SELECT + CategoryID, + ParentID, + CONVERT(nvarchar(max), Name) AS Path, + 1 as level, + (SortOrder+1) * (CONVERT(bigint, '1' + REPLICATE('0', 15))) AS 'SortOrderCount' + FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category + WHERE + ParentID = -1 + AND + ModuleID = @ModuleID + + UNION ALL + + SELECT + TH.CategoryID, + TH.ParentID, + CONVERT(nvarchar(max), CategoryHierarchy.Path + ' \ ' + TH.Name) AS Path, + level = level + 1, + CategoryHierarchy.SortOrderCount + 1 + (CONVERT(bigint, CONVERT(varchar, TH.SortOrder) + REPLICATE('0', 15-level*2))) AS 'SortOrderCount' + FROM + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category TH INNER JOIN + CategoryHierarchy ON CategoryHierarchy.CategoryID = TH.ParentID +) + +SELECT + SortOrderCount, + c.[CategoryID], + c.[ParentID], + c.[ModuleID], + c.[Name], + REPLICATE('.',(level-1)*2) + c.[Name] as 'NameIndented', + c.[Image], + c.[Description], + c.[SortOrder], + c.[InheritSecurity], + c.[CategorySecurityType], + c.[MetaTitle], + c.[MetaDescription], + c.[MetaKeywords], + ch.[level], + (SELECT COUNT(*) FROM {databaseOwner}{objectQualifier}DnnForge_NewsArticles_ArticleCategories ac INNER JOIN {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Article a ON ac.ArticleID = a.ArticleID WHERE ac.CategoryID = c.CategoryID AND a.IsDraft = 0 AND a.IsApproved = 1 AND (@authorId IS NULL OR a.AuthorID = @authorID) AND (@ShowPending IS NOT NULL OR (a.StartDate IS NULL OR a.StartDate < GetDate()))) as 'NumberofArticles' +FROM + CategoryHierarchy ch INNER JOIN + {databaseOwner}{objectQualifier}DnnForge_NewsArticles_Category c ON ch.CategoryID = c.CategoryID +ORDER BY + CASE WHEN @SortType = 0 THEN CAST(ch.SortOrderCount AS VARCHAR) ELSE ch.Path END +GO \ No newline at end of file diff --git a/Providers/DataProvider/SqlDataProvider/My Project/AssemblyInfo.vb b/Providers/DataProvider/SqlDataProvider/My Project/AssemblyInfo.vb new file mode 100755 index 0000000..249403e --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/My Project/AssemblyInfo.vb @@ -0,0 +1,34 @@ +Imports System +Imports System.Reflection +Imports System.Runtime.InteropServices + +' General Information about an assembly is controlled through the following +' set of attributes. Change these attribute values to modify the information +' associated with an assembly. + +' Review the values of the assembly attributes + + + + + + + + + + +'The following GUID is for the ID of the typelib if this project is exposed to COM + + +' Version information for an assembly consists of the following four values: +' +' Major Version +' Minor Version +' Build Number +' Revision +' +' You can specify all the values or you can default the Build and Revision Numbers +' by using the '*' as shown below: + + + diff --git a/Providers/DataProvider/SqlDataProvider/SqlDataProvider.vb b/Providers/DataProvider/SqlDataProvider/SqlDataProvider.vb new file mode 100755 index 0000000..16049d2 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/SqlDataProvider.vb @@ -0,0 +1,585 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2005 +' by Scott McCulloch ( smcculloch@iinet.net.au ) ( http://www.smcculloch.net ) +' + +Imports System +Imports System.Configuration +Imports System.Data +Imports Microsoft.ApplicationBlocks.Data + +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities +Imports System.Web.UI.WebControls + +Namespace Ventrian.NewsArticles + + Public Class SqlDataProvider + + Inherits DataProvider + +#Region " Private Members " + + Private Const ProviderType As String = "data" + + Private _providerConfiguration As Framework.Providers.ProviderConfiguration = Framework.Providers.ProviderConfiguration.GetProviderConfiguration(ProviderType) + Private _connectionString As String + Private _providerPath As String + Private _objectQualifier As String + Private _databaseOwner As String + +#End Region + +#Region " Constructors " + + Public Sub New() + + ' Read the configuration specific information for this provider + Dim objProvider As Framework.Providers.Provider = CType(_providerConfiguration.Providers(_providerConfiguration.DefaultProvider), Framework.Providers.Provider) + + _connectionString = DotNetNuke.Common.Utilities.Config.GetConnectionString() + + _providerPath = objProvider.Attributes("providerPath") + + _objectQualifier = objProvider.Attributes("objectQualifier") + If _objectQualifier <> "" And _objectQualifier.EndsWith("_") = False Then + _objectQualifier += "_" + End If + + _databaseOwner = objProvider.Attributes("databaseOwner") + If _databaseOwner <> "" And _databaseOwner.EndsWith(".") = False Then + _databaseOwner += "." + End If + + End Sub + +#End Region + +#Region " Properties " + + Public ReadOnly Property ConnectionString() As String + Get + Return _connectionString + End Get + End Property + + Public ReadOnly Property ProviderPath() As String + Get + Return _providerPath + End Get + End Property + + Public ReadOnly Property ObjectQualifier() As String + Get + Return _objectQualifier + End Get + End Property + + Public ReadOnly Property DatabaseOwner() As String + Get + Return _databaseOwner + End Get + End Property + +#End Region + +#Region " Public Methods " + + Private Function GetNull(ByVal Field As Object) As Object + Return DotNetNuke.Common.Utilities.Null.GetNull(Field, DBNull.Value) + End Function + +#Region " Article Methods " + + Public Overrides Function GetArticleListByApproved(ByVal moduleID As Integer, ByVal isApproved As Boolean) As IDataReader + If (isApproved) Then + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetArticleListBySearchCriteria", GetNull(moduleID), DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, isApproved, False, DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, "StartDate", "DESC", DBNull.Value, DBNull.Value), IDataReader) + Else + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetArticleListBySearchCriteria", GetNull(moduleID), DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, isApproved, False, DBNull.Value, DBNull.Value, True, DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, DBNull.Value, "StartDate", "DESC", DBNull.Value, DBNull.Value), IDataReader) + End If + + End Function + + Public Overrides Function GetArticleListBySearchCriteria(ByVal moduleID As Integer, ByVal currentDate As DateTime, ByVal agedDate As DateTime, ByVal categoryID As Integer(), ByVal matchAll As Boolean, ByVal categoryIDExclude As Integer(), ByVal maxCount As Integer, ByVal pageNumber As Integer, ByVal pageSize As Integer, ByVal sortBy As String, ByVal sortDirection As String, ByVal isApproved As Boolean, ByVal isDraft As Boolean, ByVal keywords As String, ByVal authorID As Integer, ByVal showPending As Boolean, ByVal showExpired As Boolean, ByVal showFeaturedOnly As Boolean, ByVal showNotFeaturedOnly As Boolean, ByVal showSecuredOnly As Boolean, ByVal showNotSecuredOnly As Boolean, ByVal articleIDs As String, ByVal tagID As Integer(), ByVal matchAllTag As Boolean, ByVal rssGuid As String, ByVal customFieldID As Integer, ByVal customValue As String, ByVal linkFilter As String) As IDataReader + Dim categories As String = DotNetNuke.Common.Utilities.Null.NullString + Dim categoryIDCount As Integer = Null.NullInteger + + If Not (categoryID Is Nothing) Then + For Each category As Integer In categoryID + If Not (categories = DotNetNuke.Common.Utilities.Null.NullString) Then + categories = categories & "," + End If + categories = categories & category.ToString() + Next + + If (matchAll) Then + categoryIDCount = categoryID.Length - 1 + End If + End If + + Dim tags As String = DotNetNuke.Common.Utilities.Null.NullString + Dim tagIDCount As Integer = Null.NullInteger + + If Not (tagID Is Nothing) Then + For Each tag As Integer In tagID + If Not (tags = DotNetNuke.Common.Utilities.Null.NullString) Then + tags = tags & "," + End If + tags = tags & tag.ToString() + Next + + If (matchAllTag) Then + tagIDCount = tagID.Length - 1 + End If + End If + + Dim categoriesExclude As String = DotNetNuke.Common.Utilities.Null.NullString + If Not (categoryIDExclude Is Nothing) Then + For Each category As Integer In categoryIDExclude + If Not (categoriesExclude = DotNetNuke.Common.Utilities.Null.NullString) Then + categoriesExclude = categoriesExclude & "," + End If + categoriesExclude = categoriesExclude & category.ToString() + Next + End If + + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetArticleListBySearchCriteria", moduleID, GetNull(currentDate), GetNull(agedDate), GetNull(categories), GetNull(categoryIDCount), GetNull(categoriesExclude), GetNull(maxCount), GetNull(pageNumber), GetNull(pageSize), sortBy, sortDirection, isApproved, isDraft, GetNull(keywords), GetNull(authorID), GetNull(showPending), GetNull(showExpired), showFeaturedOnly, showNotFeaturedOnly, showSecuredOnly, showNotSecuredOnly, GetNull(articleIDs), GetNull(tags), GetNull(tagIDCount), GetNull(rssGuid), GetNull(customFieldID), GetNull(customValue), GetNull(linkFilter)), IDataReader) + End Function + + Public Overrides Function GetArticle(ByVal articleID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetArticle", articleID), IDataReader) + End Function + + Public Overrides Function GetArticleCategories(ByVal articleID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetArticleCategories", articleID), IDataReader) + End Function + + Public Overrides Function GetNewsArchive(ByVal moduleID As Integer, ByVal categoryID As Integer(), ByVal categoryIDExclude As Integer(), ByVal authorID As Integer, ByVal groupBy As String, ByVal showPending As Boolean) As IDataReader + Dim categories As String = DotNetNuke.Common.Utilities.Null.NullString + + If Not (categoryID Is Nothing) Then + For Each category As Integer In categoryID + If Not (categories = DotNetNuke.Common.Utilities.Null.NullString) Then + categories = categories & "," + End If + categories = categories & category.ToString() + Next + End If + + Dim categoriesExclude As String = DotNetNuke.Common.Utilities.Null.NullString + + If Not (categoryIDExclude Is Nothing) Then + For Each category As Integer In categoryIDExclude + If Not (categoriesExclude = DotNetNuke.Common.Utilities.Null.NullString) Then + categoriesExclude = categoriesExclude & "," + End If + categoriesExclude = categoriesExclude & category.ToString() + Next + End If + + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetNewsArchive", moduleID, GetNull(categories), GetNull(categoriesExclude), GetNull(authorID), groupBy, GetNull(showPending)), IDataReader) + End Function + + Public Overrides Sub DeleteArticle(ByVal articleID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_DeleteArticle", articleID) + End Sub + + Public Overrides Sub DeleteArticleCategories(ByVal articleID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_DeleteArticleCategories", articleID) + End Sub + + Public Overrides Function AddArticle(ByVal authorID As Integer, ByVal approverID As Integer, ByVal createdDate As DateTime, ByVal lastUpdate As DateTime, ByVal title As String, ByVal summary As String, ByVal isApproved As Boolean, ByVal numberOfViews As Integer, ByVal isDraft As Boolean, ByVal startDate As DateTime, ByVal endDate As DateTime, ByVal moduleID As Integer, ByVal imageUrl As String, ByVal isFeatured As Boolean, ByVal lastUpdateID As Integer, ByVal url As String, ByVal isSecure As Boolean, ByVal isNewWindow As Boolean, ByVal metaTitle As String, ByVal metaDescription As String, ByVal metaKeywords As String, ByVal pageHeadText As String, ByVal shortUrl As String, ByVal rssGuid As String) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddArticle", authorID, approverID, createdDate, lastUpdate, title, GetNull(summary), isApproved, numberOfViews, isDraft, GetNull(startDate), GetNull(endDate), moduleID, GetNull(imageUrl), isFeatured, GetNull(lastUpdateID), GetNull(url), isSecure, isNewWindow, GetNull(metaTitle), GetNull(metaDescription), GetNull(metaKeywords), GetNull(pageHeadText), GetNull(shortUrl), GetNull(rssGuid)), Integer) + End Function + + Public Overrides Sub AddArticleCategory(ByVal articleID As Integer, ByVal categoryID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddArticleCategory", articleID, categoryID) + End Sub + + Public Overrides Sub UpdateArticle(ByVal articleID As Integer, ByVal authorID As Integer, ByVal approverID As Integer, ByVal createdDate As DateTime, ByVal lastUpdate As DateTime, ByVal title As String, ByVal summary As String, ByVal isApproved As Boolean, ByVal numberOfViews As Integer, ByVal isDraft As Boolean, ByVal startDate As DateTime, ByVal endDate As DateTime, ByVal moduleID As Integer, ByVal imageUrl As String, ByVal isFeatured As Boolean, ByVal lastUpdateID As Integer, ByVal url As String, ByVal isSecure As Boolean, ByVal isNewWindow As Boolean, ByVal metaTitle As String, ByVal metaDescription As String, ByVal metaKeywords As String, ByVal pageHeadText As String, ByVal shortUrl As String, ByVal rssGuid As String) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_UpdateArticle", articleID, authorID, approverID, createdDate, lastUpdate, title, GetNull(summary), isApproved, numberOfViews, isDraft, GetNull(startDate), GetNull(endDate), moduleID, GetNull(imageUrl), isFeatured, GetNull(lastUpdateID), GetNull(url), isSecure, isNewWindow, GetNull(metaTitle), GetNull(metaDescription), GetNull(metaKeywords), GetNull(pageHeadText), GetNull(shortUrl), GetNull(rssGuid)) + End Sub + + Public Overrides Sub UpdateArticleCount(ByVal articleID As Integer, ByVal numberOfViews As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_UpdateArticleCount", articleID, numberOfViews) + End Sub + + Public Overrides Function SecureCheck(ByVal portalID As Integer, ByVal articleID As Integer, ByVal userID As Integer) As Boolean + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_SecureCheck", portalID, articleID, userID), Boolean) + End Function +#End Region + +#Region " Author Methods " + + Public Overrides Function GetAuthorList(ByVal moduleID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetAuthorList", moduleID), IDataReader) + End Function + + Public Overrides Function GetAuthorStatistics(ByVal moduleID As Integer, ByVal categoryID As Integer(), ByVal categoryIDExclude As Integer(), ByVal authorID As Integer, ByVal sortBy As String, ByVal showPending As Boolean) As IDataReader + Dim categories As String = DotNetNuke.Common.Utilities.Null.NullString + + If Not (categoryID Is Nothing) Then + For Each category As Integer In categoryID + If Not (categories = DotNetNuke.Common.Utilities.Null.NullString) Then + categories = categories & "," + End If + categories = categories & category.ToString() + Next + End If + + Dim categoriesExclude As String = DotNetNuke.Common.Utilities.Null.NullString + + If Not (categoryIDExclude Is Nothing) Then + For Each category As Integer In categoryIDExclude + If Not (categoriesExclude = DotNetNuke.Common.Utilities.Null.NullString) Then + categoriesExclude = categoriesExclude & "," + End If + categoriesExclude = categoriesExclude & category.ToString() + Next + End If + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetAuthorStatistics", moduleID, GetNull(categories), GetNull(categoriesExclude), GetNull(authorID), sortBy, GetNull(showPending)), IDataReader) + End Function + +#End Region + +#Region " Category Methods " + + Public Overrides Function GetCategoryList(ByVal moduleID As Integer, ByVal parentID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetCategoryList", moduleID, parentID), IDataReader) + End Function + + Public Overrides Function GetCategoryListAll(ByVal moduleID As Integer, ByVal authorID As Integer, ByVal showPending As Boolean, ByVal sortType As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetCategoryListAll", moduleID, GetNull(authorID), GetNull(showPending), sortType), IDataReader) + End Function + + Public Overrides Function GetCategory(ByVal categoryID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetCategory", categoryID), IDataReader) + End Function + + Public Overrides Sub DeleteCategory(ByVal categoryID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_DeleteCategory", categoryID) + End Sub + + Public Overrides Function AddCategory(ByVal moduleID As Integer, ByVal parentID As Integer, ByVal name As String, ByVal image As String, ByVal description As String, ByVal sortOrder As Integer, ByVal inheritSecurity As Boolean, ByVal categorySecurityType As Integer, ByVal metaTitle As String, ByVal metaDescription As String, ByVal metaKeywords As String) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddCategory", moduleID, parentID, name, image, GetNull(description), sortOrder, inheritSecurity, categorySecurityType, GetNull(metaTitle), GetNull(metaDescription), GetNull(metaKeywords)), Integer) + End Function + + Public Overrides Sub UpdateCategory(ByVal categoryID As Integer, ByVal moduleID As Integer, ByVal parentID As Integer, ByVal name As String, ByVal image As String, ByVal description As String, ByVal sortOrder As Integer, ByVal inheritSecurity As Boolean, ByVal categorySecurityType As Integer, ByVal metaTitle As String, ByVal metaDescription As String, ByVal metaKeywords As String) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_UpdateCategory", categoryID, moduleID, parentID, name, image, GetNull(description), sortOrder, inheritSecurity, categorySecurityType, GetNull(metaTitle), GetNull(metaDescription), GetNull(metaKeywords)) + End Sub +#End Region + +#Region " Comment Methods " + Public Overrides Function GetCommentList(ByVal moduleID As Integer, ByVal articleID As Integer, ByVal isApproved As Boolean, ByVal direction As SortDirection, ByVal maxCount As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetCommentList", moduleID, GetNull(articleID), isApproved, direction, GetNull(maxCount)), IDataReader) + End Function + + Public Overrides Function GetComment(ByVal commentID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetComment", commentID), IDataReader) + End Function + + Public Overrides Sub DeleteComment(ByVal commentID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_DeleteComment", commentID) + End Sub + + Public Overrides Function AddComment(ByVal articleID As Integer, ByVal createdDate As DateTime, ByVal userID As Integer, ByVal comment As String, ByVal remoteAddress As String, ByVal type As Integer, ByVal trackbackUrl As String, ByVal trackbackTitle As String, ByVal trackbackBlogName As String, ByVal trackbackExcerpt As String, ByVal anonymousName As String, ByVal anonymousEmail As String, ByVal anonymousURL As String, ByVal notifyMe As Boolean, ByVal isApproved As Boolean, ByVal approvedBy As Integer) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddComment", articleID, createdDate, userID, comment, GetNull(remoteAddress), type, GetNull(trackbackUrl), GetNull(trackbackTitle), GetNull(trackbackBlogName), GetNull(trackbackExcerpt), GetNull(anonymousName), GetNull(anonymousEmail), GetNull(anonymousURL), notifyMe, isApproved, GetNull(approvedBy)), Integer) + End Function + + Public Overrides Sub UpdateComment(ByVal commentID As Integer, ByVal articleID As Integer, ByVal userID As Integer, ByVal comment As String, ByVal remoteAddress As String, ByVal type As Integer, ByVal trackbackUrl As String, ByVal trackbackTitle As String, ByVal trackbackBlogName As String, ByVal trackbackExcerpt As String, ByVal anonymousName As String, ByVal anonymousEmail As String, ByVal anonymousURL As String, ByVal notifyMe As Boolean, ByVal isApproved As Boolean, ByVal approvedBy As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_UpdateComment", commentID, articleID, userID, comment, GetNull(remoteAddress), type, GetNull(trackbackUrl), GetNull(trackbackTitle), GetNull(trackbackBlogName), GetNull(trackbackExcerpt), GetNull(anonymousName), GetNull(anonymousEmail), GetNull(anonymousURL), notifyMe, isApproved, GetNull(approvedBy)) + End Sub +#End Region + +#Region " Custom Field Methods " + Public Overrides Function GetCustomField(ByVal customFieldID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetCustomField", customFieldID), IDataReader) + End Function + + Public Overrides Function GetCustomFieldList(ByVal moduleID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetCustomFieldList", moduleID), IDataReader) + End Function + + Public Overrides Sub DeleteCustomField(ByVal customFieldID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_DeleteCustomField", customFieldID) + End Sub + + Public Overrides Function AddCustomField(ByVal moduleID As Integer, ByVal name As String, ByVal fieldType As Integer, ByVal fieldElements As String, ByVal defaultValue As String, ByVal caption As String, ByVal captionHelp As String, ByVal isRequired As Boolean, ByVal isVisible As Boolean, ByVal sortOrder As Integer, ByVal validationType As Integer, ByVal length As Integer, ByVal regularExpression As String) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddCustomField", moduleID, name, fieldType, GetNull(fieldElements), GetNull(defaultValue), GetNull(caption), GetNull(captionHelp), isRequired, isVisible, sortOrder, validationType, length, GetNull(regularExpression)), Integer) + End Function + + Public Overrides Sub UpdateCustomField(ByVal customFieldID As Integer, ByVal moduleID As Integer, ByVal name As String, ByVal fieldType As Integer, ByVal fieldElements As String, ByVal defaultValue As String, ByVal caption As String, ByVal captionHelp As String, ByVal isRequired As Boolean, ByVal isVisible As Boolean, ByVal sortOrder As Integer, ByVal validationType As Integer, ByVal length As Integer, ByVal regularExpression As String) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_UpdateCustomField", customFieldID, moduleID, name, fieldType, GetNull(fieldElements), GetNull(defaultValue), GetNull(caption), GetNull(captionHelp), isRequired, isVisible, sortOrder, validationType, length, GetNull(regularExpression)) + End Sub +#End Region + +#Region " Custom Value Methods " + + Public Overrides Function GetCustomValueList(ByVal articleID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetCustomValueList", articleID), IDataReader) + End Function + + Public Overrides Sub DeleteCustomValue(ByVal articleID As Integer, ByVal customFieldID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_DeleteCustomValue", articleID, customFieldID) + End Sub + + Public Overrides Function AddCustomValue(ByVal articleID As Integer, ByVal customFieldID As Integer, ByVal customValue As String) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddCustomValue", articleID, customFieldID, customValue), Integer) + End Function + + Public Overrides Sub UpdateCustomValue(ByVal customValueID As Integer, ByVal articleID As Integer, ByVal customFieldID As Integer, ByVal customValue As String) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_UpdateCustomValue", customValueID, articleID, customFieldID, customValue) + End Sub + +#End Region + +#Region " Feed Methods " + + Public Overrides Function AddFeed(ByVal moduleID As Integer, ByVal title As String, ByVal url As String, ByVal userID As Integer, ByVal autoFeature As Boolean, ByVal isActive As Boolean, ByVal dateMode As Integer, ByVal autoExpire As Integer, ByVal autoExpireUnit As Integer) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FeedAdd", moduleID, title, url, userID, autoFeature, isActive, dateMode, GetNull(autoExpire), GetNull(autoExpireUnit)), Integer) + End Function + + Public Overrides Sub UpdateFeed(ByVal feedID As Integer, ByVal moduleID As Integer, ByVal title As String, ByVal url As String, ByVal userID As Integer, ByVal autoFeature As Boolean, ByVal isActive As Boolean, ByVal dateMode As Integer, ByVal autoExpire As Integer, ByVal autoExpireUnit As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FeedUpdate", feedID, moduleID, title, url, userID, autoFeature, isActive, dateMode, GetNull(autoExpire), GetNull(autoExpireUnit)) + End Sub + + Public Overrides Sub DeleteFeed(ByVal feedID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FeedDelete", feedID) + End Sub + + Public Overrides Function GetFeed(ByVal feedID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FeedGet", feedID), IDataReader) + End Function + + Public Overrides Function GetFeedList(ByVal moduleID As Integer, ByVal showActiveOnly As Boolean) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FeedList", moduleID, showActiveOnly), IDataReader) + End Function + + Public Overrides Sub AddFeedCategory(ByVal feedID As Integer, ByVal categoryID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FeedCategoryAdd", feedID, categoryID) + End Sub + + Public Overrides Function GetFeedCategoryList(ByVal feedID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FeedCategoryList", feedID), IDataReader) + End Function + + Public Overrides Sub DeleteFeedCategory(ByVal feedID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FeedCategoryDelete", feedID) + End Sub + +#End Region + +#Region " File Methods " + + Public Overrides Function AddFile(ByVal articleID As Integer, ByVal title As String, ByVal fileName As String, ByVal extension As String, ByVal size As Integer, ByVal contentType As String, ByVal folder As String, ByVal sortOrder As Integer, ByVal fileGuid As String) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FileAdd", GetNull(articleID), GetNull(title), GetNull(fileName), GetNull(extension), GetNull(size), GetNull(contentType), GetNull(folder), sortOrder, GetNull(fileGuid)), Integer) + End Function + + Public Overrides Sub UpdateFile(ByVal fileID As Integer, ByVal articleID As Integer, ByVal title As String, ByVal fileName As String, ByVal extension As String, ByVal size As Integer, ByVal contentType As String, ByVal folder As String, ByVal sortOrder As Integer, ByVal fileGuid As String) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FileUpdate", fileID, GetNull(articleID), GetNull(title), GetNull(fileName), GetNull(extension), GetNull(size), GetNull(contentType), GetNull(folder), sortOrder, GetNull(fileGuid)) + End Sub + + Public Overrides Sub DeleteFile(ByVal fileID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FileDelete", fileID) + End Sub + + Public Overrides Function GetFile(ByVal fileID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FileGet", fileID), IDataReader) + End Function + + Public Overrides Function GetFileList(ByVal articleID As Integer, ByVal fileGuid As String) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_FileList", GetNull(articleID), GetNull(fileGuid)), IDataReader) + End Function + +#End Region + +#Region " Image Methods " + + Public Overrides Function AddImage(ByVal articleID As Integer, ByVal title As String, ByVal fileName As String, ByVal extension As String, ByVal size As Integer, ByVal width As Integer, ByVal height As Integer, ByVal contentType As String, ByVal folder As String, ByVal sortOrder As Integer, ByVal imageGuid As String, ByVal description As String) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_ImageAdd", GetNull(articleID), GetNull(title), GetNull(fileName), GetNull(extension), GetNull(size), GetNull(width), GetNull(height), GetNull(contentType), GetNull(folder), sortOrder, GetNull(imageGuid), GetNull(description)), Integer) + End Function + + Public Overrides Sub UpdateImage(ByVal imageID As Integer, ByVal articleID As Integer, ByVal title As String, ByVal fileName As String, ByVal extension As String, ByVal size As Integer, ByVal width As Integer, ByVal height As Integer, ByVal contentType As String, ByVal folder As String, ByVal sortOrder As Integer, ByVal imageGuid As String, ByVal description As String) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_ImageUpdate", imageID, GetNull(articleID), GetNull(title), GetNull(fileName), GetNull(extension), GetNull(size), GetNull(width), GetNull(height), GetNull(contentType), GetNull(folder), sortOrder, GetNull(imageGuid), GetNull(description)) + End Sub + + Public Overrides Sub DeleteImage(ByVal imageID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_ImageDelete", imageID) + End Sub + + Public Overrides Function GetImage(ByVal imageID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_ImageGet", imageID), IDataReader) + End Function + + Public Overrides Function GetImageList(ByVal articleID As Integer, ByVal imageGuid As String) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_ImageList", GetNull(articleID), GetNull(imageGuid)), IDataReader) + End Function + +#End Region + +#Region " Mirror Article Methods " + + Public Overrides Sub AddMirrorArticle(ByVal articleID As Integer, ByVal linkedArticleID As Integer, ByVal linkedPortalID As Integer, ByVal autoUpdate As Boolean) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddMirrorArticle", articleID, linkedArticleID, linkedPortalID, autoUpdate) + End Sub + + Public Overrides Function GetMirrorArticle(ByVal articleID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetMirrorArticle", articleID), IDataReader) + End Function + + Public Overrides Function GetMirrorArticleList(ByVal linkedArticleID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetMirrorArticleList", linkedArticleID), IDataReader) + End Function + +#End Region + +#Region " Page Methods " + Public Overrides Function GetPageList(ByVal articleID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetPageList", articleID), IDataReader) + End Function + + Public Overrides Function GetPage(ByVal pageID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetPage", pageID), IDataReader) + End Function + + Public Overrides Sub DeletePage(ByVal pageID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_DeletePage", pageID) + End Sub + + Public Overrides Function AddPage(ByVal articleID As Integer, ByVal title As String, ByVal pageText As String, ByVal sortOrder As Integer) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddPage", articleID, title, pageText, sortOrder), Integer) + End Function + + Public Overrides Sub UpdatePage(ByVal pageID As Integer, ByVal articleID As Integer, ByVal title As String, ByVal pageText As String, ByVal sortOrder As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_UpdatePage", pageID, articleID, title, pageText, sortOrder) + End Sub +#End Region + +#Region " EmailTemplate Methods " + Public Overrides Function GetEmailTemplate(ByVal templateID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_EmailTemplateGet", templateID), IDataReader) + End Function + + Public Overrides Function GetEmailTemplateByName(ByVal moduleID As Integer, ByVal name As String) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_EmailTemplateGetByName", moduleID, name), IDataReader) + End Function + + Public Overrides Function ListEmailTemplate(ByVal moduleID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_EmailTemplateList", moduleID), IDataReader) + End Function + + Public Overrides Function AddEmailTemplate(ByVal moduleID As Integer, ByVal name As String, ByVal subject As String, ByVal template As String) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_EmailTemplateAdd", moduleID, name, subject, template), Integer) + End Function + + Public Overrides Sub UpdateEmailTemplate(ByVal templateID As Integer, ByVal moduleID As Integer, ByVal name As String, ByVal subject As String, ByVal template As String) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_EmailTemplateUpdate", templateID, moduleID, name, subject, template) + End Sub + + Public Overrides Sub DeleteEmailTemplate(ByVal templateID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_EmailTemplateDelete", templateID) + End Sub +#End Region + +#Region " Rating Methods " + + Public Overrides Function AddRating(ByVal articleID As Integer, ByVal userID As Integer, ByVal createdDate As DateTime, ByVal rating As Double) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_RatingAdd", articleID, userID, createdDate, GetNull(rating)), Integer) + End Function + + Public Overrides Function GetRating(ByVal articleID As Integer, ByVal userID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_RatingGet", articleID, userID), IDataReader) + End Function + + Public Overrides Function GetRatingByID(ByVal ratingID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_RatingGetByID", ratingID), IDataReader) + End Function + + Public Overrides Sub DeleteRating(ByVal ratingID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_RatingDelete", ratingID) + End Sub + +#End Region + +#Region " Rating Methods " + + Public Overrides Function AddHandout(ByVal moduleID As Integer, ByVal userID As Integer, ByVal name As String, ByVal description As String) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddHandout", moduleID, userID, name, GetNull(description)), Integer) + End Function + + Public Overrides Sub AddHandoutArticle(ByVal handoutID As Integer, ByVal articleID As Integer, ByVal sortOrder As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_AddHandoutArticle", handoutID, articleID, sortOrder) + End Sub + + Public Overrides Sub DeleteHandout(ByVal handoutID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_DeleteHandout", handoutID) + End Sub + + Public Overrides Sub DeleteHandoutArticleList(ByVal ratingID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_DeleteHandoutArticleList", ratingID) + End Sub + + Public Overrides Function GetHandout(ByVal handoutID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetHandout", handoutID), IDataReader) + End Function + + Public Overrides Function GetHandoutList(ByVal userID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetHandoutList", userID), IDataReader) + End Function + + Public Overrides Function GetHandoutArticleList(ByVal handoutID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_GetHandoutArticleList", handoutID), IDataReader) + End Function + + Public Overrides Sub UpdateHandout(ByVal handoutID As Integer, ByVal moduleID As Integer, ByVal userID As Integer, ByVal name As String, ByVal description As String) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_UpdateHandout", handoutID, moduleID, userID, name, GetNull(description)) + End Sub + +#End Region + +#Region " Tag Methods " + + Public Overrides Function GetTag(ByVal tagID As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_TagGet", tagID), IDataReader) + End Function + + Public Overrides Function GetTagByName(ByVal moduleID As Integer, ByVal name As String) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_TagGetByName", moduleID, name), IDataReader) + End Function + + Public Overrides Function ListTag(ByVal moduleID As Integer, ByVal maxCount As Integer) As IDataReader + Return CType(SqlHelper.ExecuteReader(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_TagList", moduleID, GetNull(maxCount)), IDataReader) + End Function + + Public Overrides Function AddTag(ByVal moduleID As Integer, ByVal name As String, ByVal nameLowered As String) As Integer + Return CType(SqlHelper.ExecuteScalar(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_TagAdd", moduleID, name, nameLowered), Integer) + End Function + + Public Overrides Sub UpdateTag(ByVal tagID As Integer, ByVal moduleID As Integer, ByVal name As String, ByVal nameLowered As String, ByVal usages As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_TagUpdate", tagID, moduleID, name, nameLowered, usages) + End Sub + + Public Overrides Sub DeleteTag(ByVal tagID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_TagDelete", tagID) + End Sub + + Public Overrides Sub AddArticleTag(ByVal articleID As Integer, ByVal tagID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_ArticleTagAdd", articleID, tagID) + End Sub + + Public Overrides Sub DeleteArticleTag(ByVal articleID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_ArticleTagDelete", articleID) + End Sub + + Public Overrides Sub DeleteArticleTagByTag(ByVal tagID As Integer) + SqlHelper.ExecuteNonQuery(ConnectionString, DatabaseOwner & ObjectQualifier & "DnnForge_NewsArticles_ArticleTagDeleteByTag", tagID) + End Sub + +#End Region + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Providers/DataProvider/SqlDataProvider/Uninstall.SqlDataProvider b/Providers/DataProvider/SqlDataProvider/Uninstall.SqlDataProvider new file mode 100755 index 0000000000000000000000000000000000000000..894308beac5f8aa7b2d9ca414e4ff76b4d8858cc GIT binary patch literal 19240 zcmdU0+iuf95S?cv{vmG^gpl|E9@1P&P)S2?5>Hh~(o#q-N>ZRg{dM5XPFCJ^)(%Lh zKKtO-cGl~&XV1*+W&HcsrJPGkX7WQWWhpBhE!n}}napuaaHl0NaGc9RZsZDQQ~89m zS15Cj;|5n>)+P1X@A4T}3mh%fIK|&LIKonA?*5Jp<(d3Mi80oc&eJW4zgud$*ckHcU=~h-uX>0bti2m=cxoNFg>VT!L zoZxN`Eq%=XZ-e2fyhqDmHkIoNyu{=nOS>t zIzEAaFt0f)DYygwaR>jTKARK!5j@`n7}W!IT%?%DS5mBfcnXby<~KO`^cX`;u=c&j zYW|EJrT41b{oaK>Rii5$tc(sYY8<=K8M7r7D08r-0xh>S6*#%=slb_oMfG9rIwJ{{ z%Ic>KDR=LCKFyZ6nGE&GjkE)=uW{+Z&8Y7&mbbZfUa0fs+oCP&sKDD?-I$=MIiSZ@ zR&ZLmO`}Ys>LWS~-Rjf;D>1|Wu-0-4Th_Vd0(PvcV0CM4N0_6|QEr9xFdh3XN#}Tm zu1w1sO!5!DDw)MPTLPhzjMb-W0Zds8t(-dYG#{H;pO)L+fb{` z8TV<6YbuU1VoGtDX02&IWp>oTny&7n=?>v3{OTOnte$lfv93(&I@**p7K9!)C#I`# zv-54Em^9Pe5xEYz`rrJRFA(R(e1V+PbB7~}wAS;&y^Zgt#uxv>Ed$0hk41J0$B5&t zTZ5Ro9q&~Xx4DtVBfHSTcyNcFAqSqT@y2YYA_x!b7Q1ucJB2iNrn$8dj-;yOjJ zU~6V?x(=gx&+(oMmwF9AdKk%Vg55z+iFZOLwg%^1k&vVrK-^EB?{>@&ib^*Eczv=7wZPqL^o)gq%Q*bdJs=KZYx@%Au zWt-N&S5EjPRNM>fElBBz*IydinBn`4F>W!6Y+4^4ukPAuCWL19u(LbDDE9(bd2v>I zk32Bvqu-Ee{q`vb6^EGlwVa9|yedwi^*?2LW8^RDT(jfy7&SlH@)_A%m5)_g zFO>26e#nhykGqXo|C~7Lc-Hgqf+@6~X?BI=;utaJK914yv01%8!G|^O>)3;)SEZWoe_roX TKl^Q-xwyCa)EMh;bItA#za6}z literal 0 HcmV?d00001 diff --git a/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.sln b/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.sln new file mode 100755 index 0000000..8641cf0 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.sln @@ -0,0 +1,20 @@ + +Microsoft Visual Studio Solution File, Format Version 10.00 +# Visual Studio 2008 +Project("{F184B08F-C81C-45F6-A57F-5ABD9991F28F}") = "Ventrian.NewsArticles.SqlDataProvider", "Ventrian.NewsArticles.SqlDataProvider.vbproj", "{D1901326-AD43-466F-942D-AA796EA58D8E}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {D1901326-AD43-466F-942D-AA796EA58D8E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {D1901326-AD43-466F-942D-AA796EA58D8E}.Debug|Any CPU.Build.0 = Debug|Any CPU + {D1901326-AD43-466F-942D-AA796EA58D8E}.Release|Any CPU.ActiveCfg = Release|Any CPU + {D1901326-AD43-466F-942D-AA796EA58D8E}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.suo b/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.suo new file mode 100755 index 0000000000000000000000000000000000000000..e532a6a3cd6fd0244d9e9d62639038d2ca11b073 GIT binary patch literal 13312 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 KsGQ~t1OEV2AD;98 literal 0 HcmV?d00001 diff --git a/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.v11.suo b/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.v11.suo new file mode 100755 index 0000000000000000000000000000000000000000..e532a6a3cd6fd0244d9e9d62639038d2ca11b073 GIT binary patch literal 13312 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 KsGQ~t1OEV2AD;98 literal 0 HcmV?d00001 diff --git a/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.vbproj b/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.vbproj new file mode 100755 index 0000000..b1b0253 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.vbproj @@ -0,0 +1,267 @@ + + + + Local + 9.0.21022 + 2.0 + {D1901326-AD43-466F-942D-AA796EA58D8E} + Debug + AnyCPU + + + + + Ventrian.NewsArticles.SqlDataProvider + + + None + JScript + Grid + IE50 + false + Library + Binary + On + Off + + + + + + + Windows + + + 3.5 + v3.5 + + publish\ + true + Disk + false + Foreground + 7 + Days + false + false + true + 0 + 1.0.0.%2a + false + false + true + + + ..\..\..\..\..\bin\ + DnnForge.NewsArticles.SqlDataProvider.xml + 285212672 + + + + + true + true + true + false + false + false + false + 1 + 42016,42017,42018,42019,42032,42353,42354,42355 + full + + + ..\..\..\..\..\bin\ + DnnForge.NewsArticles.SqlDataProvider.xml + 285212672 + + + + + false + true + false + true + false + false + false + 1 + 42016,42017,42018,42019,42032,42353,42354,42355 + none + + + + False + ..\..\..\..\..\bin\DotNetNuke.dll + False + + + False + ..\..\..\..\..\bin\Microsoft.ApplicationBlocks.Data.dll + False + + + System + + + + System.Data + + + System.Drawing + + + System.Web + + + System.XML + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Code + + + + + {25F6A930-34CD-4730-8324-D234D4637898} + Ventrian.NewsArticles + False + + + + + False + .NET Framework 3.5 SP1 Client Profile + false + + + False + .NET Framework 3.5 SP1 + true + + + + + + + + + + \ No newline at end of file diff --git a/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.vbproj.user b/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.vbproj.user new file mode 100755 index 0000000..dcf0c09 --- /dev/null +++ b/Providers/DataProvider/SqlDataProvider/Ventrian.NewsArticles.SqlDataProvider.vbproj.user @@ -0,0 +1,66 @@ + + + + 7.10.3077 + Debug + AnyCPU + C:\Projects\DotNetNuke\Sites\DotNetNuke311\bin\;D:\Projects\DotNetNuke\Sites\DotNetNuke311\bin\ + + + + + 0 + ProjectFiles + 0 + + + + + + + en-US + false + + + false + false + false + false + false + + + Project + + + + + + + + + + + false + + + false + false + false + false + false + + + Project + + + + + + + + + + + false + + \ No newline at end of file diff --git a/Providers/FileProvider/CoreFileProvider.vb b/Providers/FileProvider/CoreFileProvider.vb new file mode 100755 index 0000000..aff6975 --- /dev/null +++ b/Providers/FileProvider/CoreFileProvider.vb @@ -0,0 +1,144 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Services.FileSystem +Imports System.IO +Imports DotNetNuke.Entities.Modules + +Namespace Ventrian.NewsArticles + + Public Class CoreFileProvider + + Inherits FileProvider + +#Region " Public Methods " + + Public Overrides Function AddFile(ByVal articleID As Integer, ByVal moduleID As Integer, ByVal objPostedFile As System.Web.HttpPostedFile) As Integer + + Dim objFile As New FileInfo + + objFile.ArticleID = articleID + objFile.FileName = objPostedFile.FileName + objFile.SortOrder = 0 + + Dim filesList As List(Of FileInfo) = GetFiles(articleID) + + If (filesList.Count > 0) Then + objFile.SortOrder = CType(filesList(filesList.Count - 1), FileInfo).SortOrder + 1 + End If + + Dim objPortalSettings As PortalSettings = PortalController.GetCurrentPortalSettings() + + Dim folder As String = "" + + Dim objModuleController As New ModuleController() + Dim objSettings As Hashtable = objModuleController.GetModuleSettings(moduleID) + + Dim folderID As Integer = Null.NullInteger + If (IsNumeric(HttpContext.Current.Request.Form("FolderID"))) Then + folderID = Convert.ToInt32(HttpContext.Current.Request.Form("FolderID")) + End If + + If (folderID <> Null.NullInteger) Then + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(objPortalSettings.PortalId, folderID) + If (objFolder IsNot Nothing) Then + folder = objFolder.FolderPath + End If + End If + + objFile.Folder = folder + objFile.ContentType = objPostedFile.ContentType + + If (objFile.FileName.Split("."c).Length > 0) Then + objFile.Extension = objFile.FileName.Split("."c)(objFile.FileName.Split("."c).Length - 1) + + If (objFile.Extension.ToLower() = "jpg") Then + objFile.ContentType = "image/jpeg" + End If + If (objFile.Extension.ToLower() = "gif") Then + objFile.ContentType = "image/gif" + End If + If (objFile.Extension.ToLower() = "txt") Then + objFile.ContentType = "text/plain" + End If + If (objFile.Extension.ToLower() = "html") Then + objFile.ContentType = "text/html" + End If + If (objFile.Extension.ToLower() = "mp3") Then + objFile.ContentType = "audio/mpeg" + End If + + End If + objFile.Title = objFile.FileName.Replace("." & objFile.Extension, "") + + Dim filePath As String = objPortalSettings.HomeDirectoryMapPath & folder.Replace("/", "\") + + If Not (Directory.Exists(filePath)) Then + Directory.CreateDirectory(filePath) + End If + + If (File.Exists(filePath & objFile.FileName)) Then + For i As Integer = 1 To 100 + If (File.Exists(filePath & i.ToString() & "_" & objFile.FileName) = False) Then + objFile.FileName = i.ToString() & "_" & objFile.FileName + Exit For + End If + Next + End If + + objFile.Size = objPostedFile.ContentLength + objPostedFile.SaveAs(filePath & objFile.FileName) + + Dim objFileController As New FileController + objFile.FileID = objFileController.Add(objFile) + + If (articleID > 0) Then + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(articleID) + objArticle.FileCount = objArticle.FileCount + 1 + objArticleController.UpdateArticle(objArticle) + End If + + Return objFile.FileID + + End Function + + Public Overrides Function AddFile(ByVal articleID As Integer, ByVal moduleID As Integer, ByVal objPostedFile As HttpPostedFile, ByVal providerParams As Object) As Integer + Return AddFile(articleID, moduleID, objPostedFile) + End Function + + Public Overrides Function AddExistingFile(ByVal articleID As Integer, ByVal moduleID As Integer, ByVal providerParams As Object) As Integer + Throw New NotImplementedException() + End Function + + Public Overrides Sub DeleteFile(ByVal articleID As Integer, ByVal fileID As Integer) + Dim objFileController As New FileController() + objFileController.Delete(fileID) + End Sub + + Public Overrides Function GetFile(ByVal fileID As Integer) As FileInfo + Dim objFileController As New FileController() + Dim objFile As FileInfo = objFileController.Get(fileID) + objFile.Link = PortalController.GetCurrentPortalSettings().HomeDirectory() & objFile.Folder & objFile.FileName + Return objFile + End Function + + Public Overrides Function GetFiles(ByVal articleID As Integer) As System.Collections.Generic.List(Of FileInfo) + Dim objFileController As New FileController() + Dim objFiles As List(Of FileInfo) = objFileController.GetFileList(articleID, Null.NullString()) + For Each objFile As FileInfo In objFiles + objFile.Link = PortalController.GetCurrentPortalSettings().HomeDirectory() & objFile.Folder & objFile.FileName + Next + Return objFiles + End Function + + Public Overrides Sub UpdateFile(ByVal objFile As FileInfo) + Dim objFileController As New FileController() + objFileController.Update(objFile) + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Providers/FileProvider/CoreFileProvider2.vb b/Providers/FileProvider/CoreFileProvider2.vb new file mode 100755 index 0000000..2c3f728 --- /dev/null +++ b/Providers/FileProvider/CoreFileProvider2.vb @@ -0,0 +1,144 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Services.FileSystem +Imports System.IO +Imports DotNetNuke.Entities.Modules + +Namespace Ventrian.NewsArticles + + Public Class CoreFileProvider2 + + Inherits FileProvider + +#Region " Public Methods " + + Public Overrides Function AddFile(ByVal articleID As Integer, ByVal moduleID As Integer, ByVal objPostedFile As System.Web.HttpPostedFile) As Integer + + Dim objFile As New FileInfo + + objFile.ArticleID = articleID + objFile.FileName = objPostedFile.FileName + objFile.SortOrder = 0 + + Dim filesList As List(Of FileInfo) = GetFiles(articleID) + + If (filesList.Count > 0) Then + objFile.SortOrder = CType(filesList(filesList.Count - 1), FileInfo).SortOrder + 1 + End If + + Dim objPortalSettings As PortalSettings = PortalController.GetCurrentPortalSettings() + + Dim folder As String = "" + + Dim objModuleController As New ModuleController() + Dim objSettings As Hashtable = objModuleController.GetModuleSettings(moduleID) + + If (objSettings.ContainsKey(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) Then + If (IsNumeric(objSettings(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING))) Then + Dim folderID As Integer = Convert.ToInt32(objSettings(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(objPortalSettings.PortalId, folderID) + If (objFolder IsNot Nothing) Then + folder = objFolder.FolderPath + End If + End If + End If + + objFile.Folder = folder + objFile.ContentType = objPostedFile.ContentType + + If (objFile.FileName.Split("."c).Length > 0) Then + objFile.Extension = objFile.FileName.Split("."c)(objFile.FileName.Split("."c).Length - 1) + + If (objFile.Extension.ToLower() = "jpg") Then + objFile.ContentType = "image/jpeg" + End If + If (objFile.Extension.ToLower() = "gif") Then + objFile.ContentType = "image/gif" + End If + If (objFile.Extension.ToLower() = "txt") Then + objFile.ContentType = "text/plain" + End If + If (objFile.Extension.ToLower() = "html") Then + objFile.ContentType = "text/html" + End If + If (objFile.Extension.ToLower() = "mp3") Then + objFile.ContentType = "audio/mpeg" + End If + + End If + objFile.Title = objFile.FileName.Replace("." & objFile.Extension, "") + + Dim filePath As String = objPortalSettings.HomeDirectoryMapPath & folder.Replace("/", "\") + + If Not (Directory.Exists(filePath)) Then + Directory.CreateDirectory(filePath) + End If + + If (File.Exists(filePath & objFile.FileName)) Then + For i As Integer = 1 To 100 + If (File.Exists(filePath & i.ToString() & "_" & objFile.FileName) = False) Then + objFile.FileName = i.ToString() & "_" & objFile.FileName + Exit For + End If + Next + End If + + objFile.Size = objPostedFile.ContentLength + objPostedFile.SaveAs(filePath & objFile.FileName) + + Dim objFileController As New FileController + objFile.FileID = objFileController.Add(objFile) + + If (articleID <> Null.NullInteger) Then + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(articleID) + If (objArticle IsNot Nothing) Then + objArticle.FileCount = objArticle.FileCount + 1 + objArticleController.UpdateArticle(objArticle) + End If + End If + + Return objFile.FileID + + End Function + + Public Overrides Function AddFile(ByVal articleID As Integer, ByVal moduleID As Integer, ByVal objPostedFile As HttpPostedFile, ByVal providerParams As Object) As Integer + Return AddFile(articleID, moduleID, objPostedFile) + End Function + + Public Overrides Function AddExistingFile(ByVal articleID As Integer, ByVal moduleID As Integer, ByVal providerParams As Object) As Integer + Throw New NotImplementedException() + End Function + + Public Overrides Sub DeleteFile(ByVal articleID As Integer, ByVal fileID As Integer) + Dim objFileController As New FileController() + objFileController.Delete(fileID) + End Sub + + Public Overrides Function GetFile(ByVal fileID As Integer) As FileInfo + Dim objFileController As New FileController() + Dim objFile As FileInfo = objFileController.Get(fileID) + objFile.Link = PortalController.GetCurrentPortalSettings().HomeDirectory() & objFile.Folder & objFile.FileName & "1" + Return objFile + End Function + + Public Overrides Function GetFiles(ByVal articleID As Integer) As System.Collections.Generic.List(Of FileInfo) + Dim objFileController As New FileController() + Dim objFiles As List(Of FileInfo) = objFileController.GetFileList(articleID, Null.NullString()) + For Each objFile As FileInfo In objFiles + objFile.Link = PortalController.GetCurrentPortalSettings().HomeDirectory() & objFile.Folder & objFile.FileName & "1" + Next + Return objFiles + End Function + + Public Overrides Sub UpdateFile(ByVal objFile As FileInfo) + Dim objFileController As New FileController() + objFileController.Update(objFile) + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Providers/FileProvider/FileController.vb b/Providers/FileProvider/FileController.vb new file mode 100755 index 0000000..2ebf5a5 --- /dev/null +++ b/Providers/FileProvider/FileController.vb @@ -0,0 +1,85 @@ +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public Class FileController + + Public Shared Sub ClearCache(ByVal articleID As Integer) + + Dim itemsToRemove As New List(Of String)() + + Dim enumerator As IDictionaryEnumerator = HttpContext.Current.Cache.GetEnumerator() + While enumerator.MoveNext() + If enumerator.Key.ToString().ToLower().Contains("ventrian-newsarticles-files-" & articleID.ToString()) Then + itemsToRemove.Add(enumerator.Key.ToString()) + End If + End While + + For Each itemToRemove As String In itemsToRemove + DataCache.RemoveCache(itemToRemove.Replace("DNN_", "")) + Next + + End Sub + +#Region " Public Methods " + + Public Function [Get](ByVal fileID As Integer) As FileInfo + + Return CType(CBO.FillObject(DataProvider.Instance().GetFile(fileID), GetType(FileInfo)), FileInfo) + + End Function + + Public Function GetFileList(ByVal articleID As Integer, ByVal fileGuid As String) As List(Of FileInfo) + + If (articleID = Null.NullInteger) Then + Return CBO.FillCollection(Of FileInfo)(DataProvider.Instance().GetFileList(articleID, fileGuid)) + Else + Dim cacheKey As String = "ventrian-newsarticles-files-" & articleID.ToString() & "-" & fileGuid.ToString() + + Dim objFiles As List(Of FileInfo) = CType(DataCache.GetCache(cacheKey), List(Of FileInfo)) + + If (objFiles Is Nothing) Then + objFiles = CBO.FillCollection(Of FileInfo)(DataProvider.Instance().GetFileList(articleID, fileGuid)) + DataCache.SetCache(cacheKey, objFiles) + End If + + Return objFiles + End If + + End Function + + Public Function Add(ByVal objFile As FileInfo) As Integer + + Dim fileID As Integer = CType(DataProvider.Instance().AddFile(objFile.ArticleID, objFile.Title, objFile.FileName, objFile.Extension, objFile.Size, objFile.ContentType, objFile.Folder, objFile.SortOrder, objFile.FileGuid), Integer) + + FileController.ClearCache(objFile.ArticleID) + ArticleController.ClearArticleCache(objFile.ArticleID) + + Return fileID + + End Function + + Public Sub Update(ByVal objFile As FileInfo) + + DataProvider.Instance().UpdateFile(objFile.FileID, objFile.ArticleID, objFile.Title, objFile.FileName, objFile.Extension, objFile.Size, objFile.ContentType, objFile.Folder, objFile.SortOrder, objFile.FileGuid) + + FileController.ClearCache(objFile.ArticleID) + + End Sub + + Public Sub Delete(ByVal fileID As Integer) + + Dim objFile As FileInfo = [Get](fileID) + + If (objFile IsNot Nothing) Then + DataProvider.Instance().DeleteFile(fileID) + FileController.ClearCache(objFile.ArticleID) + End If + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/Providers/FileProvider/FileInfo.vb b/Providers/FileProvider/FileInfo.vb new file mode 100755 index 0000000..cf886d5 --- /dev/null +++ b/Providers/FileProvider/FileInfo.vb @@ -0,0 +1,129 @@ +Imports DotNetNuke.Entities.Portals + +Namespace Ventrian.NewsArticles + + Public Class FileInfo + +#Region " Private Members " + + Dim _fileID As Integer + Dim _articleID As Integer + + Dim _title As String + Dim _fileName As String + Dim _extension As String + Dim _size As Integer + Dim _contentType As String + Dim _folder As String + Dim _sortOrder As Integer + Dim _fileGuid As String + Dim _link As String + +#End Region + +#Region " Public Properties " + + Public Property FileID() As Integer + Get + Return _fileID + End Get + Set(ByVal value As Integer) + _fileID = value + End Set + End Property + + Public Property ArticleID() As Integer + Get + Return _articleID + End Get + Set(ByVal value As Integer) + _articleID = value + End Set + End Property + + Public Property Title() As String + Get + Return _title + End Get + Set(ByVal value As String) + _title = value + End Set + End Property + + Public Property FileName() As String + Get + Return _fileName + End Get + Set(ByVal value As String) + _fileName = value + End Set + End Property + + Public Property Extension() As String + Get + Return _extension + End Get + Set(ByVal value As String) + _extension = value + End Set + End Property + + Public Property Size() As Integer + Get + Return _size + End Get + Set(ByVal value As Integer) + _size = value + End Set + End Property + + Public Property ContentType() As String + Get + Return _contentType + End Get + Set(ByVal value As String) + _contentType = value + End Set + End Property + + Public Property Folder() As String + Get + Return _folder + End Get + Set(ByVal value As String) + _folder = value + End Set + End Property + + Public Property SortOrder() As Integer + Get + Return _sortOrder + End Get + Set(ByVal value As Integer) + _sortOrder = value + End Set + End Property + + Public Property FileGuid() As String + Get + Return _fileGuid + End Get + Set(ByVal value As String) + _fileGuid = value + End Set + End Property + + Public Property Link() As String + Get + Return _link + End Get + Set(ByVal value As String) + _link = value + End Set + End Property + +#End Region + + End Class + +End Namespace diff --git a/Providers/FileProvider/FileProvider.vb b/Providers/FileProvider/FileProvider.vb new file mode 100755 index 0000000..78f377c --- /dev/null +++ b/Providers/FileProvider/FileProvider.vb @@ -0,0 +1,49 @@ +Imports DotNetNuke +Imports DotNetNuke.Common.Utilities + +Namespace Ventrian.NewsArticles + + Public MustInherit Class FileProvider + +#Region " Shared/Static Methods " + + ' singleton reference to the instantiated object + Private Shared objProvider As FileProvider = Nothing + + ' constructor + Shared Sub New() + CreateProvider() + End Sub + + ' dynamically create provider + Private Shared Sub CreateProvider() + If (ConfigurationManager.AppSettings("NewsArticlesFileProvider") IsNot Nothing) Then + objProvider = CType(Framework.Reflection.CreateObject(ConfigurationManager.AppSettings("NewsArticlesFileProvider").ToString(), "Ventrian_NaFileProvider"), FileProvider) + Else + objProvider = CType(Framework.Reflection.CreateObject("Ventrian.NewsArticles.CoreFileProvider", "Ventrian_NaFileProvider"), FileProvider) + End If + End Sub + + ' return the provider + Public Shared Shadows Function Instance() As FileProvider + Return objProvider + End Function + +#End Region + +#Region " Abstract methods " + + Public MustOverride Function AddFile(ByVal articleID As Integer, ByVal moduleID As Integer, ByVal objPostedFile As System.Web.HttpPostedFile) As Integer + Public MustOverride Function AddFile(ByVal articleID As Integer, ByVal moduleID As Integer, ByVal objPostedFile As System.Web.HttpPostedFile, ByVal providerParams As Object) As Integer + Public MustOverride Function AddExistingFile(ByVal articleID As Integer, ByVal moduleID As Integer, ByVal providerParams As Object) As Integer + Public MustOverride Sub DeleteFile(ByVal articleID As Integer, ByVal fileID As Integer) + Public MustOverride Function GetFile(ByVal fileID As Integer) As FileInfo + Public MustOverride Function GetFiles(ByVal articleID As Integer) As List(Of FileInfo) + Public MustOverride Sub UpdateFile(ByVal objFile As FileInfo) + + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Resources.zip b/Resources.zip new file mode 100755 index 0000000000000000000000000000000000000000..e1c72a6fcf164157e832e4e375c2f11ed91fe4e3 GIT binary patch literal 309000 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

>P?28>yAI1 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 + + + App_LocalResources/ + Archives.ascx.resx + + + App_LocalResources/ + NewsSearch.ascx.resx + + + App_LocalResources/ + PostComment.ascx.resx + + + App_LocalResources/ + PostRating.ascx.resx + + + App_LocalResources/ + SharedResources.resx + + + App_LocalResources/ + ucAdminOptions.ascx.resx + + + App_LocalResources/ + ucApproveArticles.ascx.resx + + + App_LocalResources/ + ucApproveComments.ascx.resx + + + App_LocalResources/ + ucEditCategories.ascx.resx + + + App_LocalResources/ + ucEditCategory.ascx.resx + + + App_LocalResources/ + ucEditComment.ascx.resx + + + App_LocalResources/ + ucEditCustomField.ascx.resx + + + App_LocalResources/ + ucEditCustomFields.ascx.resx + + + App_LocalResources/ + ucEditPage.ascx.resx + + + App_LocalResources/ + ucEditPages.ascx.resx + + + App_LocalResources/ + ucEditPageSortOrder.ascx.resx + + + App_LocalResources/ + ucEditTag.ascx.resx + + + App_LocalResources/ + ucEditTags.ascx.resx + + + App_LocalResources/ + ucEmailTemplates.ascx.resx + + + App_LocalResources/ + ucImportFeed.ascx.resx + + + App_LocalResources/ + ucImportFeeds.ascx.resx + + + App_LocalResources/ + ucMyArticles.ascx.resx + + + App_LocalResources/ + ucNotAuthenticated.ascx.resx + + + App_LocalResources/ + ucNotAuthorized.ascx.resx + + + App_LocalResources/ + ucSubmitNews.ascx.resx + + + App_LocalResources/ + ucSubmitNewsComplete.ascx.resx + + + App_LocalResources/ + ucTemplateEditor.ascx.resx + + + App_LocalResources/ + ucViewOptions.ascx.resx + + + App_LocalResources/ + UploadFiles.ascx.resx + + + App_LocalResources/ + UploadImages.ascx.resx + + + App_LocalResources/ + ViewArchive.ascx.resx + + + App_LocalResources/ + ViewArticle.ascx.resx + + + App_LocalResources/ + ViewAuthor.ascx.resx + + + App_LocalResources/ + ViewCategory.ascx.resx + + + App_LocalResources/ + ViewSearch.ascx.resx + + + App_LocalResources/ + ViewTag.ascx.resx + + + Controls/ + Listing.ascx + + + Controls/ + PostComment.ascx + + + Controls/ + PostRating.ascx + + + Controls/ + SWFUploader.ashx + + + Controls/ + SWFUploaderFiles.ashx + + + Controls/ + UploadFiles.ascx + + + Controls/ + UploadImages.ascx + + + Images/Admin/ + Categories.gif + + + Images/Admin/ + MainOptions.gif + + + Images/Admin/ + Templates.gif + + + Images/ + appearance.png + + + Images/ + details.png + + + Images/ + left_both.gif + + + Images/Lightbox/ + lightbox-ico-loading.gif + + + Images/ + linkto.png + + + Images/ + publishing.png + + + Images/Rating/ + stars-0-0.gif + + + Images/Rating/ + stars-0-5.gif + + + Images/Rating/ + stars-1-0.gif + + + Images/Rating/ + stars-1-5.gif + + + Images/Rating/ + stars-2-0.gif + + + Images/Rating/ + stars-2-5.gif + + + Images/Rating/ + stars-3-0.gif + + + Images/Rating/ + stars-3-5.gif + + + Images/Rating/ + stars-4-0.gif + + + Images/Rating/ + stars-4-5.gif + + + Images/Rating/ + stars-5-0.gif + + + Images/ + right_both.gif + + + Images/ + rssbutton.gif + + + Images/SmartThinker/ + articleadd.png + + + Images/SmartThinker/ + commentadd.png + + + Images/SmartThinker/ + rateadd.png + + + Images/ + spacer.gif + + + Images/ + summary.png + + + Images/ + tab_background.gif + + + Images/Uploader/ + cancelbutton.gif + + + Images/Uploader/ + error.gif + + + Images/Uploader/ + toobig.gif + + + Images/Uploader/ + uploadlimit.gif + + + Images/Uploader/ + XPButtonNoText_160x22.png + + + Images/Uploader/ + zerobyte.gif + + + Includes/ColorPicker/ + ColorPicker.js + + + Includes/Lightbox/ + jquery-1.3.2.min.js + + + Includes/Lightbox/ + jquery.lightbox-0.4.js + + + Includes/Lightbox/ + jquery.lightbox-0.4.pack.js + + + Includes/Uploader/ + handlers.00.07.61.js + + + Includes/Uploader/ + jquery-1.3.2.min.js + + + Includes/Uploader/ + swfupload.00.07.61.js + + + Includes/Uploader/ + swfupload.00.07.61.swf + + + Includes/ + VentrianValidators.js + + + Tracking/ + Trackback.aspx + + + Tracking/ + Pingback.ashx + + + + ucNotAuthorized.ascx + + + + ucSubmitNews.ascx + + + + ucSubmitNewsComplete.ascx + + + + ucTemplateEditor.ascx + + + + ucViewOptions.ascx + + + + ViewArchive.ascx + + + + ViewArticle.ascx + + + + ViewAuthor.ascx + + + + ViewCategory.ascx + + + + ViewCurrent.ascx + + + + ViewSearch.ascx + + + + ViewTag.ascx + + + + Archives.ascx + + + + NewsArticles.ascx + + + + ucAdminOptions.ascx + + + + ucApproveArticles.ascx + + + + ucApproveComments.ascx + + + + ucEditCategories.ascx + + + + ucEditCategory.ascx + + + + ucEditComment.ascx + + + + ucEditCustomField.ascx + + + + ucEditCustomFields.ascx + + + + ucEditPage.ascx + + + + ucEditPages.ascx + + + + ucEditPageSortOrder.ascx + + + + ucEditTag.ascx + + + + ucEditTags.ascx + + + + ucEmailTemplates.ascx + + + + ucHeader.ascx + + + + ucImportFeed.ascx + + + + ucImportFeeds.ascx + + + + ucMyArticles.ascx + + + + ucNotAuthenticated.ascx + + + + web.config + + + + module.css + + + + icon_comment.gif + + + + icon_xml.gif + + + Includes/Shadowbox/ + close.png + + + Includes/Shadowbox/ + loading.gif + + + Includes/Shadowbox/ + next.png + + + Includes/Shadowbox/ + pause.png + + + Includes/Shadowbox/ + play.png + + + Includes/Shadowbox/ + previous.png + + + Includes/Shadowbox/ + shadowbox.css + + + Includes/Shadowbox/ + shadowbox.js + + + + ImageHandler.ashx + + + + Print.aspx + + + + Rss.aspx + + + + RssComments.aspx + + + + NewsSearch.ascx + + + + NewsSearchOptions.ascx + + + API/MetaWebLog/ + Handler.ashx + + + API/MetaWebLog/ + wlwmanifest.xml + + + API/ + Rsd.ashx + + + Templates/Default/ + Comment.Footer.html + + + Templates/Default/ + Comment.Header.html + + + Templates/Default/ + Comment.Item.html + + + Templates/Default/Images/ + icon_comment.gif + + + Templates/Default/ + Listing.Empty.html + + + Templates/Default/ + Listing.Featured.html + + + Templates/Default/ + Listing.Featured.xml + + + Templates/Default/ + Listing.Footer.html + + + Templates/Default/ + Listing.Footer.xml + + + Templates/Default/ + Listing.Header.html + + + Templates/Default/ + Listing.Item.html + + + Templates/Default/ + Listing.Item.xml + + + Templates/Default/ + Menu.Item.html + + + Templates/Default/ + Print.Footer.html + + + Templates/Default/ + Print.Header.html + + + Templates/Default/ + Print.Item.html + + + Templates/Default/ + Template.css + + + Templates/Default/ + View.Footer.html + + + Templates/Default/ + View.Header.html + + + Templates/Default/ + View.Item.html + + + Templates/Default/ + View.Item.xml + + + Templates/Default/ + View.PageHeader.Html + + + Templates/Default/ + View.Title.Html + + + Templates/Standard/ + Category.Child.html + + + Templates/Standard/ + Category.html + + + Templates/Standard/ + Comment.Item.html + + + Templates/Standard/ + File.Footer.Html + + + Templates/Standard/ + File.Header.Html + + + Templates/Standard/ + File.Item.Html + + + Templates/Standard/ + Handout.Cover.html + + + Templates/Standard/ + Handout.End.html + + + Templates/Standard/ + Handout.Footer.html + + + Templates/Standard/ + Handout.Header.html + + + Templates/Standard/ + Handout.Item.html + + + Templates/Standard/ + Image.Footer.Html + + + Templates/Standard/ + Image.Header.Html + + + Templates/Standard/ + Image.Item.Html + + + Templates/Standard/Images/ + 01.gif + + + Templates/Standard/Images/ + 02.gif + + + Templates/Standard/Images/ + 03.gif + + + Templates/Standard/Images/ + 04.gif + + + Templates/Standard/Images/ + 05.gif + + + Templates/Standard/Images/ + 06.gif + + + Templates/Standard/Images/ + 07.gif + + + Templates/Standard/Images/ + 08.gif + + + Templates/Standard/Images/ + 09.gif + + + Templates/Standard/Images/ + 10.gif + + + Templates/Standard/Images/ + 11.gif + + + Templates/Standard/Images/ + 12.gif + + + Templates/Standard/Images/ + rssbutton.gif + + + Templates/Standard/ + Listing.Empty.html + + + Templates/Standard/ + Listing.Featured.html + + + Templates/Standard/ + Listing.Footer.html + + + Templates/Standard/ + Listing.Header.html + + + Templates/Standard/ + Listing.Item.html + + + Templates/Standard/ + Menu.Item.html + + + Templates/Standard/ + Print.Item.html + + + Templates/Standard/ + Related.Footer.html + + + Templates/Standard/ + Related.Header.html + + + Templates/Standard/ + Related.Item.html + + + Templates/Standard/ + Rss.Comment.Footer.html + + + Templates/Standard/ + Rss.Comment.Header.html + + + Templates/Standard/ + Rss.Comment.Item.html + + + Templates/Standard/ + Rss.Footer.html + + + Templates/Standard/ + Rss.Header.html + + + Templates/Standard/ + Rss.Item.html + + + Templates/Standard/ + Template.css + + + Templates/Standard/ + View.Description.html + + + Templates/Standard/ + View.Item.html + + + Templates/Standard/ + View.Keyword.html + + + Templates/Standard/ + View.PageHeader.Html + + + Templates/Standard/ + View.Title.Html + + + \ No newline at end of file diff --git a/ResourcesLatestArticles.zip b/ResourcesLatestArticles.zip new file mode 100755 index 0000000000000000000000000000000000000000..290a5ca52380f9e85e85837a0691140cceb7f924 GIT binary patch literal 18003 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 literal 0 HcmV?d00001 diff --git a/ResourcesLatestComments.zip b/ResourcesLatestComments.zip new file mode 100755 index 0000000000000000000000000000000000000000..546573847899b6dd232c1d182efd96424ee13bbe GIT binary patch literal 5445 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 >!4pHq*xqN0@G5pJU_o7$6(8Aa^0f;*scXxA# z5kcsS^wnf3*%6=ac}STS;h<>ffX;VR)H5D!5>0IOz2CW(Qy&LrsbMB7!~p;rZ~*}7 zYp(tC|LS*$StktHGYH*A4Uw&ay5!5}#o1{r5gb}MI8%H`yTPiG10$u>)PzYdfj}hF zxoRLhwp#1emRaf#%ob+g;_}kQ@5FE*M4K_oD96R$@o{I%4bR!a{YuX4w|sgFcGEdg z_@hpnv7aUxNY%kzRCgt2T}(f=qlHlGl7lO8LF$fr;>l)W7Fy=TL>ms<;&_u_Dk$1E|3q(uw5rgHvhoxO`4--kNt-r6>Q*HCC{EI=Lw_yDfFJJ|USoWb$T-$QpQ z{vpIYQMA~Nwi{Di(R!O+htOg4StptSkr|l~(U;ZRiz|&0OP?QEk>T2t;UG=$(dNC| zJq%M6U{h6uJfBPU)W8qk-|Blv;{E;MgrgDrQ5fu@NA+VD-t2Oh8}lPTO9>%HFeTZ1 z&-|?^#Qd1l^igA|aJr7ya9_e_1Z40*GEYS8R%zuY?nW;1xOJhy*P48I--pZcfATYm zVAtT_zzVI^p&!Zm^=muK|7=<4S}dhIVUmk_*P%_n4lVh=g!a$I#Pi8l`wl^1%iBfi z&=<8QLFq!l2o0-E*Qvr?B&k&dTVaj=C)1sTQ(|eSGF^*iBDRI#;MQP{_clV_sZAn( z;ED6FD6;n%MA|7h8@|gY-$hDt`{GmT2!p%n)@KUToDUdJZ_4(t-h50o(Nr@q;y|p% zl)fW2{UJeG_M$aeq73L3Ae;1OAY&o}+fp~$_ba9|+{_I-*A~=`Zsc{jaVNly zLwUjA&7t^SH{BN_2z}utl&AZ^ti16V>T4D0PeJAVDWjKbGcgfjU%3Ja zk!`HNu;&B`mQm?D1U?iEkQ0N?;ver?z5|2f_GUG#tIM1M*BmuTj7 zfBL_Q{(hzZoSgj9X8!BI|6UE)eo6nO4I}+ewSo9Ahj0MbQ=9Up(9Y%_oNq(1&zdR+ z{@#DL^Y5woyB)3TO#NpK`ZH1g#Q=NxWr#`d-@^ZGNJpLE+Iau~|N8N}&iTRHzux`< D+Q+Bx literal 0 HcmV?d00001 diff --git a/Rss.aspx b/Rss.aspx new file mode 100755 index 0000000..060e84d --- /dev/null +++ b/Rss.aspx @@ -0,0 +1 @@ +<%@ Page Language="vb" AutoEventWireup="false" CodeBehind="Rss.aspx.vb" Inherits="Ventrian.NewsArticles.Rss" %> diff --git a/Rss.aspx.designer.vb b/Rss.aspx.designer.vb new file mode 100755 index 0000000..ec34203 --- /dev/null +++ b/Rss.aspx.designer.vb @@ -0,0 +1,17 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class Rss + End Class +End Namespace diff --git a/Rss.aspx.vb b/Rss.aspx.vb new file mode 100755 index 0000000..8ceb995 --- /dev/null +++ b/Rss.aspx.vb @@ -0,0 +1,882 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.IO +Imports System.Xml + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Entities.Tabs +Imports DotNetNuke.Framework +Imports System.Net + +Namespace Ventrian.NewsArticles + + Partial Public Class Rss + Inherits System.Web.UI.Page + +#Region " Private Members " + + Private m_articleIDs As String = Null.NullString + Private m_count As Integer = Null.NullInteger + Private m_categoryID() As Integer = Nothing + Private m_categoryIDExclude() As Integer = Nothing + Private m_tabID As Integer = Null.NullInteger + Private m_TabInfo As DotNetNuke.Entities.Tabs.TabInfo + Private m_moduleID As Integer = Null.NullInteger + Private m_authorID As Integer = Null.NullInteger + Private m_featuredOnly As Boolean = False + Private m_matchAll As Boolean = False + Private m_notFeaturedOnly As Boolean = False + Private m_securedOnly As Boolean = False + Private m_notSecuredOnly As Boolean = False + Private m_showExpired As Boolean = False + Private m_sortBy As String = ArticleConstants.DEFAULT_SORT_BY + Private m_sortDirection As String = ArticleConstants.DEFAULT_SORT_DIRECTION + Private m_tagID() As Integer = Nothing + Private m_tagMatch As Boolean = False + + Private m_month As Integer = Null.NullInteger + Private m_year As Integer = Null.NullInteger + + Private _template As String = "Standard" + + Private _enableSyndicationEnclosures As Boolean = True + Private _enableSyndicationHtml As Boolean = False + Private _enclosureType As SyndicationEnclosureType = SyndicationEnclosureType.Attachment + Private _syndicationSummaryLength As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub ReadQueryString() + + If (Request("TabID") <> "") Then + + If (IsNumeric(Request("TabID"))) Then + + m_tabID = Convert.ToInt32(Request("TabID")) + + Dim objTabController As New TabController + m_TabInfo = objTabController.GetTab(m_tabID, Globals.GetPortalSettings().PortalId, False) + + End If + + End If + + If (Request("ModuleID") <> "") Then + + If (IsNumeric(Request("ModuleID"))) Then + + m_moduleID = Convert.ToInt32(Request("ModuleID")) + + End If + + End If + + If (Request("CategoryID") <> "") Then + + Dim categories As String() = Request("CategoryID").ToString().Split(Convert.ToChar(",")) + + If (categories.Length > 0) Then + ReDim m_categoryID(categories.Length - 1) + For i As Integer = 0 To categories.Length - 1 + m_categoryID(i) = Convert.ToInt32(categories(i)) + Next + End If + + End If + + If (Request("CategoryIDExclude") <> "") Then + + Dim categories As String() = Request("CategoryIDExclude").ToString().Split(Convert.ToChar(",")) + + If (categories.Length > 0) Then + ReDim m_categoryIDExclude(categories.Length - 1) + For i As Integer = 0 To categories.Length - 1 + m_categoryIDExclude(i) = Convert.ToInt32(categories(i)) + Next + End If + + End If + + If (Request("MaxCount") <> "") Then + + If (IsNumeric(Request("MaxCount"))) Then + + m_count = Convert.ToInt32(Request("MaxCount")) + + End If + + End If + + If (Request("AuthorID") <> "") Then + + If (IsNumeric(Request("AuthorID"))) Then + + m_authorID = Convert.ToInt32(Request("AuthorID")) + + End If + + End If + + If (Request("FeaturedOnly") <> "") Then + + m_featuredOnly = Convert.ToBoolean(Request("FeaturedOnly")) + + End If + + If (Request("NotFeaturedOnly") <> "") Then + + m_notFeaturedOnly = Convert.ToBoolean(Request("NotFeaturedOnly")) + + End If + + If (Request("ShowExpired") <> "") Then + m_showExpired = Convert.ToBoolean(Request("ShowExpired")) + End If + + If (Request("SecuredOnly") <> "") Then + m_securedOnly = Convert.ToBoolean(Request("SecuredOnly")) + End If + + If (Request("NotSecuredOnly") <> "") Then + m_notSecuredOnly = Convert.ToBoolean(Request("NotSecuredOnly")) + End If + + If (Request("ArticleIDs") <> "") Then + m_articleIDs = Request("ArticleIDs") + End If + + If (Request("SortBy") <> "") Then + + m_sortBy = Request("SortBy").ToString() + + End If + + If (Request("SortDirection") <> "") Then + + m_sortDirection = Request("SortDirection").ToString() + + End If + + If (Request("Month") <> "") Then + If (IsNumeric(Request("Month"))) Then + m_month = Convert.ToInt32(Request("Month")) + End If + End If + + If (Request("Year") <> "") Then + If (IsNumeric(Request("Year"))) Then + m_year = Convert.ToInt32(Request("Year")) + End If + End If + + If (Request("MatchTag") <> "") Then + If (Request("MatchTag") = "1") Then + m_tagMatch = True + End If + End If + + If (Request("TagIDs") <> "") Then + Dim tagIDs() As String = Request("TagIDs").Split(","c) + If (tagIDs.Length > 0) Then + Dim tags As New List(Of Integer) + For Each tag As String In tagIDs + If (IsNumeric(tag)) Then + tags.Add(Convert.ToInt32(tag)) + End If + Next + m_tagID = tags.ToArray() + End If + End If + + If (Request("Tags") <> "") Then + Dim tags As New List(Of Integer) + For Each tag As String In Request("Tags").Split("|"c) + If (tag <> "") Then + Dim objTagController As New TagController() + Dim objTag As TagInfo = objTagController.Get(m_moduleID, Server.UrlDecode(tag).ToLower()) + If (objTag IsNot Nothing) Then + tags.Add(objTag.TagID) + Else + If (m_tagMatch) Then + tags.Add(Null.NullInteger) + End If + End If + End If + Next + If (tags.Count > 0) Then + m_tagID = tags.ToArray() + End If + End If + + End Sub + + Private Function GetParentPortal(ByVal sportalalias As String) As String + If (sportalalias.IndexOf("localhost") < 0) Then + If (sportalalias.IndexOf("/") > 0) Then + sportalalias = sportalalias.Substring(0, sportalalias.IndexOf("/")) + End If + End If + + GetParentPortal = sportalalias + End Function + + Private Function FormatTitle(ByVal title As String) As String + + Return OnlyAlphaNumericChars(title) & ".aspx" + + End Function + + Public Function OnlyAlphaNumericChars(ByVal OrigString As String) As String + '*********************************************************** + 'INPUT: Any String + 'OUTPUT: The Input String with all non-alphanumeric characters + ' removed + 'EXAMPLE Debug.Print OnlyAlphaNumericChars("Hello World!") + 'output = "HelloWorld") + 'NOTES: Not optimized for speed and will run slow on long + ' strings. If you plan on using long strings, consider + ' using alternative method of appending to output string, + ' such as the method at + ' http://www.freevbcode.com/ShowCode.Asp?ID=154 + '*********************************************************** + Dim lLen As Integer + Dim sAns As String = "" + Dim lCtr As Integer + Dim sChar As String + + OrigString = Trim(OrigString) + lLen = Len(OrigString) + For lCtr = 1 To lLen + sChar = Mid(OrigString, lCtr, 1) + If IsAlphaNumeric(Mid(OrigString, lCtr, 1)) Then + sAns = sAns & sChar + End If + Next + + OnlyAlphaNumericChars = sAns + + End Function + + Private Function IsAlphaNumeric(ByVal sChr As String) As Boolean + IsAlphaNumeric = sChr Like "[0-9A-Za-z]" + End Function + + Private Sub ProcessHeaderFooter(ByRef objPlaceHolder As ControlCollection, ByVal templateArray As String()) + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(templateArray(iPtr).ToString())) + + If iPtr < templateArray.Length - 1 Then + + Select Case templateArray(iPtr + 1) + + Case "PORTALNAME" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & iPtr.ToString()) + objLiteral.Text = Server.HtmlEncode(PortalController.GetCurrentPortalSettings().PortalName) + objPlaceHolder.Add(objLiteral) + + Case "PORTALURL" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & iPtr.ToString()) + objLiteral.Text = Server.HtmlEncode(AddHTTP(PortalController.GetCurrentPortalSettings().PortalAlias.HTTPAlias)) + objPlaceHolder.Add(objLiteral) + + End Select + + End If + + Next + + End Sub + + Private Function ProcessItem(ByVal item As String) As String + + If (item.Contains("<")) Then + ' already encoded? + Return item + End If + Return Server.HtmlEncode(item) + + End Function + + Private Sub ProcessItem(ByRef objPlaceHolder As ControlCollection, ByVal templateArray As String(), ByVal objArticle As ArticleInfo, ByVal articleSettings As ArticleSettings, ByVal objTab As TabInfo) + + Dim portalSettings As PortalSettings = PortalController.GetCurrentPortalSettings() + + Dim enclosureLink As String = "" + Dim enclosureType As String = "" + Dim enclosureLength As String = "" + + If (_enableSyndicationEnclosures) Then + If (_enclosureType = SyndicationEnclosureType.Attachment) Then + If (objArticle.FileCount > 0 Or objArticle.Url.ToLower().StartsWith("http://") Or objArticle.Url.ToLower().StartsWith("https://")) Then + If (objArticle.FileCount > 0) Then + + Dim objFileController As New FileController() + Dim objFiles As List(Of FileInfo) = objFileController.GetFileList(objArticle.ArticleID, "") + + If (objFiles.Count > 0) Then + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + enclosureLink = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & portalSettings.HomeDirectory & objFiles(0).Folder & objFiles(0).FileName) + Else + enclosureLink = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & portalSettings.HomeDirectory & objFiles(0).Folder & objFiles(0).FileName) + End If + enclosureType = objFiles(0).ContentType + enclosureLength = objFiles(0).Size.ToString() + End If + + Else + If (objArticle.Url.ToLower().StartsWith("http://") Or objArticle.Url.ToLower().StartsWith("https://")) Then + + Dim objFileInfo As Hashtable = CType(DataCache.GetCache("NA-" & objArticle.Url), Hashtable) + + If (objFileInfo Is Nothing) Then + + objFileInfo = New Hashtable + + Try + + Dim Url As New Uri(objArticle.Url) + + Dim myHttpWebRequest As HttpWebRequest = DirectCast(WebRequest.Create(Url), HttpWebRequest) + Dim myHttpWebResponse As HttpWebResponse = DirectCast(myHttpWebRequest.GetResponse(), HttpWebResponse) + + objFileInfo.Add("ContentType", myHttpWebResponse.ContentType) + objFileInfo.Add("ContentLength", myHttpWebResponse.ContentLength) + + myHttpWebResponse.Close() + + Catch + End Try + + DataCache.SetCache("NA-" & objArticle.Url, objFileInfo) + + End If + + If (objFileInfo.Count > 0) Then + enclosureLink = objArticle.Url + enclosureType = objFileInfo("ContentType").ToString() + enclosureLength = objFileInfo("ContentLength").ToString() + End If + End If + End If + End If + Else + If (objArticle.ImageCount > 0) Then + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString()) + + If (objImages.Count > 0) Then + + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + enclosureLink = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & portalSettings.HomeDirectory & objImages(0).Folder & objImages(0).FileName) + Else + enclosureLink = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & portalSettings.HomeDirectory & objImages(0).Folder & objImages(0).FileName) + End If + + enclosureType = objImages(0).ContentType + enclosureLength = objImages(0).Size.ToString() + End If + End If + End If + End If + + Dim hasEnclosure As Boolean = False + + If (enclosureLink <> "") Then + hasEnclosure = True + End If + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(templateArray(iPtr).ToString())) + + If iPtr < templateArray.Length - 1 Then + + Select Case templateArray(iPtr + 1) + + Case "ARTICLELINK" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + Dim pageID As Integer = Null.NullInteger + If (articleSettings.SyndicationLinkType = SyndicationLinkType.Attachment And (objArticle.Url <> "" Or objArticle.FileCount > 0)) Then + If (objArticle.FileCount > 0) Then + Dim objFileController As New FileController() + Dim objFiles As List(Of FileInfo) = objFileController.GetFileList(objArticle.ArticleID, "") + + If (objFiles.Count > 0) Then + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + objLiteral.Text = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & portalSettings.HomeDirectory & objFiles(0).Folder & objFiles(0).FileName).Replace("&", "&") + Else + objLiteral.Text = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & portalSettings.HomeDirectory & objFiles(0).Folder & objFiles(0).FileName).Replace("&", "&") + End If + End If + Else + objLiteral.Text = DotNetNuke.Common.Globals.LinkClick(objArticle.Url, m_tabID, objArticle.ModuleID, False).Replace("&", "&") + If (objLiteral.Text.ToLower().StartsWith("http") = False) Then + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + objLiteral.Text = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & objLiteral.Text) + Else + objLiteral.Text = AddHTTP(System.Web.HttpContext.Current.Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & objLiteral.Text) + End If + End If + End If + Else + objLiteral.Text = Common.GetArticleLink(objArticle, m_TabInfo, articleSettings, False).Replace("&", "&") + End If + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "COMMENTLINK" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = Common.GetArticleLink(objArticle, m_TabInfo, articleSettings, False).Replace("&", "&") & "#Comments" + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "DESCRIPTION" + Dim description As String = "" + If (Common.StripTags(Server.HtmlDecode(objArticle.Summary)) <> "") Then + If (_enableSyndicationHtml) Then + description = ProcessItem(Common.ProcessPostTokens(Server.HtmlDecode(objArticle.Summary), m_TabInfo, articleSettings)) + Else + If (_syndicationSummaryLength <> Null.NullInteger) Then + Dim summary As String = Common.ProcessPostTokens(Common.StripTags(Server.HtmlDecode(objArticle.Summary)), m_TabInfo, articleSettings) + If (summary.Length > _syndicationSummaryLength) Then + description = ProcessItem(Common.ProcessPostTokens(Common.StripTags(Server.HtmlDecode(objArticle.Summary)), m_TabInfo, articleSettings).Substring(0, _syndicationSummaryLength) & "...") + Else + description = ProcessItem(Common.ProcessPostTokens(Common.StripTags(Server.HtmlDecode(objArticle.Summary)), m_TabInfo, articleSettings)) + End If + Else + description = ProcessItem(Common.ProcessPostTokens(Common.StripTags(Server.HtmlDecode(objArticle.Summary)), m_TabInfo, articleSettings)) + End If + End If + Else + If (_enableSyndicationHtml) Then + description = ProcessItem(Common.ProcessPostTokens(Server.HtmlDecode(objArticle.Body), m_TabInfo, articleSettings)) + Else + If (_syndicationSummaryLength <> Null.NullInteger) Then + Dim summary As String = ProcessItem(Common.ProcessPostTokens(Common.StripTags(Server.HtmlDecode(objArticle.Body)), m_TabInfo, articleSettings)) + If (summary.Length > _syndicationSummaryLength) Then + description = ProcessItem(Common.ProcessPostTokens(Common.StripTags(Server.HtmlDecode(objArticle.Body)), m_TabInfo, articleSettings).Substring(0, _syndicationSummaryLength) & "...") + Else + description = ProcessItem(Common.ProcessPostTokens(Common.StripTags(Server.HtmlDecode(objArticle.Body)), m_TabInfo, articleSettings)) + End If + Else + description = ProcessItem(Common.ProcessPostTokens(Common.StripTags(Server.HtmlDecode(objArticle.Body)), m_TabInfo, articleSettings)) + End If + End If + End If + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = description + objPlaceHolder.Add(objLiteral) + + Case "DETAILS" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + If (objArticle.PageCount > 0) Then + Dim pageID As Integer = Null.NullInteger + If (IsNumeric(Request("PageID"))) Then + pageID = Convert.ToInt32(Request("PageID")) + End If + If (pageID = Null.NullInteger) Then + objLiteral.Text = ProcessItem(Common.ProcessPostTokens(objArticle.Body, objTab, articleSettings)) + Else + Dim pageController As New PageController + Dim pageList As ArrayList = pageController.GetPageList(objArticle.ArticleID) + For Each objPage As PageInfo In pageList + If (objPage.PageID = pageID) Then + objLiteral.Text = ProcessItem(Common.ProcessPostTokens(objPage.PageText, objTab, articleSettings)) + Exit For + End If + Next + If (objLiteral.Text = Null.NullString) Then + objLiteral.Text = ProcessItem(Common.ProcessPostTokens(objArticle.Body, objTab, articleSettings)) + End If + End If + End If + objPlaceHolder.Add(objLiteral) + + Case "ENCLOSURELENGTH" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = enclosureLength + objPlaceHolder.Add(objLiteral) + + Case "ENCLOSURELINK" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = enclosureLink.Replace("&", "&").Replace("&", "&").Replace(" ", "%20") + objPlaceHolder.Add(objLiteral) + + Case "ENCLOSURETYPE" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = enclosureType + objPlaceHolder.Add(objLiteral) + + Case "GUID" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = "f1397696-738c-4295-afcd-943feb885714:" & objArticle.ArticleID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "HASENCLOSURE" + If (hasEnclosure = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASENCLOSURE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASENCLOSURE" + ' Do Nothing + + Case "IMAGELINK" + If (objArticle.ImageUrl <> "") Then + Dim objLiteral As New Literal + objLiteral.Text = objArticle.ImageUrl + objPlaceHolder.Add(objLiteral) + Else + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString()) + + If (objImages.Count > 0) Then + Dim objLiteral As New Literal + objLiteral.Text = AddHTTP(Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & portalSettings.HomeDirectory & objImages(0).Folder & objImages(0).FileName) + objPlaceHolder.Add(objLiteral) + End If + End If + + Case "PUBLISHDATE" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = objArticle.StartDate.ToUniversalTime().ToString("r") + objPlaceHolder.Add(objLiteral) + + Case "SUMMARY" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = ProcessItem(Common.ProcessPostTokens(objArticle.Summary, objTab, articleSettings)) + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + + Case "TITLE" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = Server.HtmlEncode(objArticle.Title) + objPlaceHolder.Add(objLiteral) + + Case "TITLEURL" + + Dim title As String = Common.FormatTitle(objArticle.Title, articleSettings) + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = Server.HtmlEncode(title) + objPlaceHolder.Add(objLiteral) + + Case "TRACKBACKLINK" + + Dim link As String = "" + If (System.Web.HttpContext.Current.Request.Url.Port = 80) Then + link = AddHTTP(Request.Url.Host & Me.ResolveUrl("Tracking/Trackback.aspx?ArticleID=" & objArticle.ArticleID.ToString() & "&PortalID=" & portalSettings.PortalId.ToString() & "&TabID=" & portalSettings.ActiveTab.TabID.ToString()).Replace(" ", "%20")) + Else + link = AddHTTP(Request.Url.Host & ":" & System.Web.HttpContext.Current.Request.Url.Port.ToString() & Me.ResolveUrl("Tracking/Trackback.aspx?ArticleID=" & objArticle.ArticleID.ToString() & "&PortalID=" & portalSettings.PortalId.ToString() & "&TabID=" & portalSettings.ActiveTab.TabID.ToString()).Replace(" ", "%20")) + End If + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = link + objPlaceHolder.Add(objLiteral) + + Case Else + + If (templateArray(iPtr + 1).ToUpper().StartsWith("DETAILS:")) Then + Dim length As Integer = Convert.ToInt32(templateArray(iPtr + 1).Substring(8, templateArray(iPtr + 1).Length - 8)) + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + If (StripHtml(Server.HtmlDecode(objArticle.Body)).TrimStart().Length > length) Then + objLiteral.Text = ProcessItem(Common.ProcessPostTokens(Left(StripHtml(Server.HtmlDecode(objArticle.Body)).TrimStart(), length), objTab, articleSettings) & "...") + Else + objLiteral.Text = ProcessItem(Common.ProcessPostTokens(Left(StripHtml(Server.HtmlDecode(objArticle.Body)).TrimStart(), length), objTab, articleSettings)) + End If + + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("SUMMARY:")) Then + Dim summary As String = objArticle.Summary + If (IsNumeric(templateArray(iPtr + 1).Substring(8, templateArray(iPtr + 1).Length - 8))) Then + Dim length As Integer = Convert.ToInt32(templateArray(iPtr + 1).Substring(8, templateArray(iPtr + 1).Length - 8)) + If (StripHtml(Server.HtmlDecode(objArticle.Summary)).TrimStart().Length > length) Then + summary = ProcessItem(Common.ProcessPostTokens(Left(StripHtml(Server.HtmlDecode(objArticle.Summary)).TrimStart(), length), objTab, articleSettings) & "...") + Else + summary = ProcessItem(Common.ProcessPostTokens(Left(StripHtml(Server.HtmlDecode(objArticle.Summary)).TrimStart(), length), objTab, articleSettings)) + End If + End If + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteral.Text = summary + objLiteral.EnableViewState = False + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + Dim objLiteralOther As New Literal + objLiteralOther.ID = Globals.CreateValidID("Rss-" & objArticle.ArticleID.ToString() & iPtr.ToString()) + objLiteralOther.Text = "[" & templateArray(iPtr + 1) & "]" + objLiteralOther.EnableViewState = False + objPlaceHolder.Add(objLiteralOther) + + End Select + + End If + + Next + + End Sub + + Private Function RenderControlToString(ByVal ctrl As Control) As String + + Dim sb As New StringBuilder() + Dim tw As New IO.StringWriter(sb) + Dim hw As New HtmlTextWriter(tw) + + ctrl.RenderControl(hw) + + Return sb.ToString() + + End Function + + Private Function StripHtml(ByVal html As String) As String + + Dim pattern As String = "<(.|\n)*?>" + Return Regex.Replace(html, pattern, String.Empty) + + End Function + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + ReadQueryString() + + Dim displayType As DisplayType = displayType.UserName + Dim launchLinks As Boolean = False + Dim showPending As Boolean = False + + Dim _portalSettings As PortalSettings = CType(HttpContext.Current.Items("PortalSettings"), PortalSettings) + Dim objModuleController As New ModuleController + Dim objModule As ModuleInfo = objModuleController.GetModule(m_moduleID, m_tabID) + Dim articleSettings As ArticleSettings + + If Not (objModule Is Nothing) Then + Dim objTabController As New TabController() + Dim objTab As TabInfo = objTabController.GetTab(objModule.TabID, _portalSettings.PortalId, False) + + Dim settings As Hashtable = objModuleController.GetModuleSettings(objModule.ModuleID) + settings = PortalSettings.GetTabModuleSettings(objModule.TabModuleID, settings) + articleSettings = New ArticleSettings(settings, _portalSettings, objModule) + If (settings.Contains(ArticleConstants.LAUNCH_LINKS)) Then + launchLinks = Convert.ToBoolean(settings(ArticleConstants.LAUNCH_LINKS).ToString()) + End If + If (settings.Contains(ArticleConstants.TEMPLATE_SETTING)) Then + _template = settings(ArticleConstants.TEMPLATE_SETTING).ToString() + End If + If (settings.Contains(ArticleConstants.ENABLE_SYNDICATION_ENCLOSURES_SETTING)) Then + _enableSyndicationEnclosures = Convert.ToBoolean(settings(ArticleConstants.ENABLE_SYNDICATION_ENCLOSURES_SETTING).ToString()) + End If + If (settings.Contains(ArticleConstants.SYNDICATION_ENCLOSURE_TYPE)) Then + _enclosureType = CType(System.Enum.Parse(GetType(SyndicationEnclosureType), settings(ArticleConstants.SYNDICATION_ENCLOSURE_TYPE).ToString()), SyndicationEnclosureType) + End If + If (settings.Contains(ArticleConstants.ENABLE_SYNDICATION_HTML_SETTING)) Then + _enableSyndicationHtml = Convert.ToBoolean(settings(ArticleConstants.ENABLE_SYNDICATION_HTML_SETTING).ToString()) + End If + Dim settingsModule As Hashtable = objModuleController.GetModuleSettings(objModule.ModuleID) + If (settingsModule.Contains(ArticleConstants.SYNDICATION_SUMMARY_LENGTH)) Then + _syndicationSummaryLength = Convert.ToInt32(settingsModule(ArticleConstants.SYNDICATION_SUMMARY_LENGTH).ToString()) + End If + If (settings.Contains(ArticleConstants.SHOW_PENDING_SETTING)) Then + showPending = Convert.ToBoolean(settings(ArticleConstants.SHOW_PENDING_SETTING).ToString()) + End If + If (settings.Contains(ArticleConstants.DISPLAY_MODE)) Then + displayType = CType(System.Enum.Parse(GetType(DisplayType), settings(ArticleConstants.DISPLAY_MODE).ToString()), DisplayType) + End If + If (m_count = Null.NullInteger) Then + If (settings.Contains(ArticleConstants.SYNDICATION_MAX_COUNT)) Then + Try + m_count = Convert.ToInt32(settings(ArticleConstants.SYNDICATION_MAX_COUNT).ToString()) + Catch + m_count = 50 + End Try + Else + m_count = 50 + End If + End If + If (m_categoryID Is Nothing) Then + If (settings.Contains(ArticleConstants.CATEGORIES_SETTING & m_tabID.ToString())) Then + If Not (settings(ArticleConstants.CATEGORIES_SETTING & m_tabID.ToString()).ToString = Null.NullString Or settings(ArticleConstants.CATEGORIES_SETTING & m_tabID.ToString()).ToString = "-1") Then + Dim categories As String() = settings(ArticleConstants.CATEGORIES_SETTING & m_tabID.ToString()).ToString().Split(","c) + Dim cats As New List(Of Integer) + + For Each category As String In categories + If (IsNumeric(category)) Then + cats.Add(Convert.ToInt32(category)) + End If + Next + + m_categoryID = cats.ToArray() + End If + End If + End If + + If (m_categoryID IsNot Nothing) Then + If (m_categoryID.Length > 0) Then + If (settings.Contains(ArticleConstants.MATCH_OPERATOR_SETTING)) Then + Dim objMatchOperator As MatchOperatorType = CType(System.Enum.Parse(GetType(MatchOperatorType), settings(ArticleConstants.MATCH_OPERATOR_SETTING).ToString()), MatchOperatorType) + If (objMatchOperator = MatchOperatorType.MatchAll) Then + m_matchAll = True + End If + End If + + If (Request("MatchCat") <> "" And Request("CategoryID") <> "") Then + m_matchAll = True + End If + End If + End If + + Dim objLayoutController As New LayoutController(_portalSettings, articleSettings, objModule, Page) + 'Dim objLayoutController As New LayoutController(_portalSettings, articleSettings, Me, False, m_tabID, m_moduleID, objModule.TabModuleID, _portalSettings.PortalId, Null.NullInteger, Null.NullInteger, "Rss-" & m_tabID.ToString()) + + Dim layoutHeader As LayoutInfo = LayoutController.GetLayout(articleSettings, objModule, Page, LayoutType.Rss_Header_Html) + Dim layoutItem As LayoutInfo = LayoutController.GetLayout(articleSettings, objModule, Page, LayoutType.Rss_Item_Html) + Dim layoutFooter As LayoutInfo = LayoutController.GetLayout(articleSettings, objModule, Page, LayoutType.Rss_Footer_Html) + + Dim phRSS As New PlaceHolder + + Response.ContentType = "text/xml" + Response.ContentEncoding = Encoding.UTF8 + + ProcessHeaderFooter(phRSS.Controls, layoutHeader.Tokens) + + Dim agedDate As DateTime = Null.NullDate + Dim startDate As DateTime = DateTime.Now.AddMinutes(1) + If (m_year <> Null.NullInteger AndAlso m_month <> Null.NullInteger) Then + agedDate = New DateTime(m_year, m_month, 1) + startDate = agedDate.AddMonths(1).AddSeconds(-1) + End If + + If (m_categoryID Is Nothing) Then + + ' Permission to view category? + Dim objCategoryController As New CategoryController + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(m_moduleID, Null.NullInteger) + Dim checkCategory = False + + Dim excludeCategories As New List(Of Integer) + For Each objCategory As CategoryInfo In objCategories + If (objCategory.InheritSecurity = False And objCategory.CategorySecurityType = CategorySecurityType.Restrict) Then + excludeCategories.Add(objCategory.CategoryID) + End If + Next + If (excludeCategories.Count > 0) Then + m_categoryIDExclude = excludeCategories.ToArray() + End If + + For Each objCategory As CategoryInfo In objCategories + If (objCategory.InheritSecurity = False And objCategory.CategorySecurityType = CategorySecurityType.Loose) Then + checkCategory = True + End If + Next + + If (checkCategory) Then + If (m_categoryID Is Nothing) Then + Dim includeCategories As New List(Of Integer) + + For Each objCategory As CategoryInfo In objCategories + If (objCategory.InheritSecurity) Then + includeCategories.Add(objCategory.CategoryID) + End If + Next + + If (includeCategories.Count > 0) Then + includeCategories.Add(-1) + End If + + m_categoryID = includeCategories.ToArray() + Else + Dim includeCategories As New List(Of Integer) + + For Each i As Integer In m_categoryID + For Each objCategory As CategoryInfo In objCategories + If (i = objCategory.CategoryID) Then + If (objCategory.InheritSecurity) Then + includeCategories.Add(objCategory.CategoryID) + End If + End If + Next + Next + + m_categoryID = includeCategories.ToArray() + End If + End If + + End If + + Dim objArticleController As New ArticleController + Dim articleList As List(Of ArticleInfo) = objArticleController.GetArticleList(m_moduleID, startDate, agedDate, m_categoryID, m_matchAll, m_categoryIDExclude, m_count, 1, m_count, m_sortBy, m_sortDirection, True, False, Null.NullString, m_authorID, showPending, m_showExpired, m_featuredOnly, m_notFeaturedOnly, m_securedOnly, m_notSecuredOnly, m_articleIDs, m_tagID, m_tagMatch, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, Null.NullInteger) + + For Each objArticle As ArticleInfo In articleList + + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + + Dim phItem As New PlaceHolder + ProcessItem(phItem.Controls, layoutItem.Tokens, objArticle, articleSettings, objTab) + objLayoutController.ProcessArticleItem(phRSS.Controls, RenderControlToString(phItem).Split(delimiter), objArticle) + + Next + + ProcessHeaderFooter(phRSS.Controls, layoutFooter.Tokens) + + Response.Write(RenderControlToString(phRSS)) + + End If + + Response.End() + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/RssComments.aspx b/RssComments.aspx new file mode 100755 index 0000000..6bdd9c1 --- /dev/null +++ b/RssComments.aspx @@ -0,0 +1 @@ +<%@ Page Language="vb" AutoEventWireup="false" CodeBehind="RssComments.aspx.vb" Inherits="Ventrian.NewsArticles.RssComments" %> diff --git a/RssComments.aspx.designer.vb b/RssComments.aspx.designer.vb new file mode 100755 index 0000000..b44364d --- /dev/null +++ b/RssComments.aspx.designer.vb @@ -0,0 +1,17 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class RssComments + End Class +End Namespace diff --git a/RssComments.aspx.vb b/RssComments.aspx.vb new file mode 100755 index 0000000..bcfc079 --- /dev/null +++ b/RssComments.aspx.vb @@ -0,0 +1,232 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.Text +Imports System.Web + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Portals + +Namespace Ventrian.NewsArticles + + Partial Public Class RssComments + Inherits Page + +#Region " Private Members " + + Private m_articleID As Integer = Null.NullInteger + Private m_tabID As Integer = Null.NullInteger + Private m_TabInfo As DotNetNuke.Entities.Tabs.TabInfo + Private m_moduleID As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub ProcessHeaderFooter(ByRef objPlaceHolder As ControlCollection, ByVal templateArray As String()) + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(templateArray(iPtr).ToString())) + + If iPtr < templateArray.Length - 1 Then + + Select Case templateArray(iPtr + 1) + + Case "PORTALEMAIL" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & iPtr.ToString()) + objLiteral.Text = PortalController.GetCurrentPortalSettings().Email + objPlaceHolder.Add(objLiteral) + + Case "PORTALNAME" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & iPtr.ToString()) + objLiteral.Text = Server.HtmlEncode(PortalController.GetCurrentPortalSettings().PortalName) + objPlaceHolder.Add(objLiteral) + + Case "PORTALURL" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Rss-" & iPtr.ToString()) + objLiteral.Text = Server.HtmlEncode(AddHTTP(PortalController.GetCurrentPortalSettings().PortalAlias.HTTPAlias)) + objPlaceHolder.Add(objLiteral) + + End Select + + End If + + Next + + End Sub + + Private Sub ProcessItem(ByRef objPlaceHolder As ControlCollection, ByVal templateArray As String(), ByVal objArticle As ArticleInfo, ByVal objComment As CommentInfo, ByVal articleSettings As ArticleSettings) + + Dim portalSettings As PortalSettings = PortalController.GetCurrentPortalSettings() + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(templateArray(iPtr).ToString())) + + If iPtr < templateArray.Length - 1 Then + + Select Case templateArray(iPtr + 1) + + Case "CREATEDATE" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("RssComment-" & objComment.CommentID.ToString() & iPtr.ToString()) + objLiteral.Text = objComment.CreatedDate.ToUniversalTime().ToString("r") + objPlaceHolder.Add(objLiteral) + + Case "DESCRIPTION" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("RssComment-" & objComment.CommentID.ToString() & iPtr.ToString()) + objLiteral.Text = Server.HtmlEncode(objComment.Comment) + objPlaceHolder.Add(objLiteral) + + Case "GUID" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("RssComment-" & objComment.CommentID.ToString() & iPtr.ToString()) + objLiteral.Text = "f1397696-738c-4295-afcd-943feb885714:" & objComment.CommentID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "TITLE" + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("RssComment-" & objComment.CommentID.ToString() & iPtr.ToString()) + objLiteral.Text = Server.HtmlEncode(objArticle.Title) + objPlaceHolder.Add(objLiteral) + + Case Else + + Dim objLiteralOther As New Literal + objLiteralOther.ID = Globals.CreateValidID("RssComment-" & objComment.CommentID.ToString() & iPtr.ToString()) + objLiteralOther.Text = "[" & templateArray(iPtr + 1) & "]" + objLiteralOther.EnableViewState = False + objPlaceHolder.Add(objLiteralOther) + + End Select + + End If + + Next + + End Sub + + Private Sub ReadQueryString() + + If (Request("ArticleID") <> "") Then + If (IsNumeric(Request("ArticleID"))) Then + m_articleID = Convert.ToInt32(Request("ArticleID")) + End If + End If + + If (Request("TabID") <> "") Then + If (IsNumeric(Request("TabID"))) Then + m_tabID = Convert.ToInt32(Request("TabID")) + Dim objTabController As New DotNetNuke.Entities.Tabs.TabController + m_TabInfo = objTabController.GetTab(m_tabID, Globals.GetPortalSettings().PortalId, False) + End If + End If + + If (Request("ModuleID") <> "") Then + If (IsNumeric(Request("ModuleID"))) Then + m_moduleID = Convert.ToInt32(Request("ModuleID")) + End If + End If + + End Sub + + Private Function RenderControlToString(ByVal ctrl As Control) As String + + Dim sb As New StringBuilder() + Dim tw As New IO.StringWriter(sb) + Dim hw As New HtmlTextWriter(tw) + + ctrl.RenderControl(hw) + + Return sb.ToString() + + End Function + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + ReadQueryString() + + Dim launchLinks As Boolean = False + Dim enableSyndicationHtml As Boolean = False + + Dim _portalSettings As PortalSettings = CType(HttpContext.Current.Items("PortalSettings"), PortalSettings) + Dim objModuleController As New ModuleController + Dim objModule As ModuleInfo = objModuleController.GetModule(m_moduleID, m_tabID) + Dim articleSettings As ArticleSettings + + If Not (objModule Is Nothing) Then + Dim settings As Hashtable = objModuleController.GetTabModuleSettings(objModule.TabModuleID) + articleSettings = New ArticleSettings(settings, _portalSettings, objModule) + If (settings.Contains(ArticleConstants.LAUNCH_LINKS)) Then + launchLinks = Convert.ToBoolean(settings(ArticleConstants.LAUNCH_LINKS).ToString()) + End If + If (settings.Contains(ArticleConstants.ENABLE_SYNDICATION_HTML_SETTING)) Then + enableSyndicationHtml = Convert.ToBoolean(settings(ArticleConstants.ENABLE_SYNDICATION_HTML_SETTING).ToString()) + End If + If (settings.Contains(ArticleConstants.DISPLAY_MODE)) Then + End If + + Response.ContentType = "text/xml" + Response.ContentEncoding = Encoding.UTF8 + + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = objArticleController.GetArticle(m_articleID) + + Dim objLayoutController As New LayoutController(_portalSettings, articleSettings, objModule, Page) + ' Dim objLayoutController As New LayoutController(_portalSettings, articleSettings, Me, False, m_tabID, m_moduleID, objModule.TabModuleID, _portalSettings.PortalId, Null.NullInteger, Null.NullInteger, "RssComment-" & m_tabID.ToString()) + + Dim layoutHeader As LayoutInfo = LayoutController.GetLayout(articleSettings, objModule, Page, LayoutType.Rss_Comment_Header_Html) + Dim layoutItem As LayoutInfo = LayoutController.GetLayout(articleSettings, objModule, Page, LayoutType.Rss_Comment_Item_Html) + Dim layoutFooter As LayoutInfo = LayoutController.GetLayout(articleSettings, objModule, Page, (LayoutType.Rss_Comment_Footer_Html)) + + Dim phRSS As New PlaceHolder + + ProcessHeaderFooter(phRSS.Controls, layoutHeader.Tokens) + + Dim objCommentController As CommentController = New CommentController + Dim commentList As List(Of CommentInfo) = objCommentController.GetCommentList(m_moduleID, m_articleID, True, SortDirection.Ascending, Null.NullInteger) + + For Each objComment As CommentInfo In commentList + + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + + Dim phItem As New PlaceHolder + ProcessItem(phItem.Controls, layoutItem.Tokens, objArticle, objComment, articleSettings) + + objLayoutController.ProcessComment(phRSS.Controls, objArticle, objComment, RenderControlToString(phItem).Split(delimiter)) + Next + + ProcessHeaderFooter(phRSS.Controls, layoutFooter.Tokens) + + Response.Write(RenderControlToString(phRSS)) + + End If + + Response.End() + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Templates/Default/Comment.Footer.html b/Templates/Default/Comment.Footer.html new file mode 100755 index 0000000..5f28270 --- /dev/null +++ b/Templates/Default/Comment.Footer.html @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/Templates/Default/Comment.Header.html b/Templates/Default/Comment.Header.html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/Default/Comment.Item.html b/Templates/Default/Comment.Item.html new file mode 100755 index 0000000..cf01d7d --- /dev/null +++ b/Templates/Default/Comment.Item.html @@ -0,0 +1,36 @@ + + + + + + + + +
+ comment [ISCOMMENT]By + [HASANONYMOUSURL][/HASANONYMOUSURL][AUTHOR][HASANONYMOUSURL][/HASANONYMOUSURL][/ISCOMMENT] [ISTRACKBACK]By [TRACKBACKBLOGNAME][/ISTRACKBACK] @ + [CREATEDATE] [CREATETIME] [RATING] [DELETE] +
+ + + + +
+ + + + +
+ + [ISCOMMENT][COMMENT][/ISCOMMENT] + [ISTRACKBACK] + Comments from the following blog entry: [TRACKBACKTITLE], located at: [TRACKBACKURL] + [/ISTRACKBACK] + [ISPINGBACK] + Comments from the following blog entry: [PINGBACKURL] + [/ISPINGBACK] + +
+
+
+


diff --git a/Templates/Default/Images/icon_comment.gif b/Templates/Default/Images/icon_comment.gif new file mode 100755 index 0000000000000000000000000000000000000000..50ea05e7e03dc0320a8c95a249b1c0b3692d61c5 GIT binary patch literal 148 zcmZ?wbhEHb6krfw*v!E2|NsB{{|>!;`SR0;CAV(fI&<&)!>GyDBa1Oj_DZ zhWdI2h8h1DnHa!8@h1zb2m>#J4u}UbgMr0S;DqPuz0;SRm9!2MiZ~dqdU(;g2G51l ytvfI6+VUWp_ke=;EEXm8pNyO=&P)MT0tP}yFI7woT76whkV~gPyUCM +[RESX:NoArticles] \ No newline at end of file diff --git a/Templates/Default/Listing.Featured.html b/Templates/Default/Listing.Featured.html new file mode 100755 index 0000000..0f2145a --- /dev/null +++ b/Templates/Default/Listing.Featured.html @@ -0,0 +1,50 @@ + + + + + +
+ + + + + + + +
[PUBLISHSTARTDATE]
+ + + + + + + + +
[IMAGETHUMB:100] + [EDIT] [TITLE] +
+ By [AUTHOR] @ [PUBLISHSTARTTIME] :: [VIEWCOUNT] Views [HASCOMMENTSENABLED]:: + [COMMENTCOUNT] Comments [/HASCOMMENTSENABLED][HASRATINGSENABLED] :: [RATING][/HASRATINGSENABLED][HASCATEGORIES] :: [CATEGORIES][/HASCATEGORIES] +
+ + + + +
+ + + + + [HASMOREDETAIL:150] + + + + [/HASMOREDETAIL:150] +
+ [HASSUMMARY][SUMMARY][/HASSUMMARY][HASNOSUMMARY][DETAILS:150][/HASNOSUMMARY] +
Read + More..
+
+
+
+
diff --git a/Templates/Default/Listing.Featured.xml b/Templates/Default/Listing.Featured.xml new file mode 100755 index 0000000..3490293 --- /dev/null +++ b/Templates/Default/Listing.Featured.xml @@ -0,0 +1,23 @@ + + + [CREATEDATE] + + + FormatString + D + + + + + [EDIT] + + + ToolTip + Edit this Article + + + + + [TITLE] + + diff --git a/Templates/Default/Listing.Footer.html b/Templates/Default/Listing.Footer.html new file mode 100755 index 0000000..98ac2d6 --- /dev/null +++ b/Templates/Default/Listing.Footer.html @@ -0,0 +1,4 @@ + +[HASMULTIPLEPAGES] +[PAGER] +[/HASMULTIPLEPAGES] \ No newline at end of file diff --git a/Templates/Default/Listing.Footer.xml b/Templates/Default/Listing.Footer.xml new file mode 100755 index 0000000..de5b658 --- /dev/null +++ b/Templates/Default/Listing.Footer.xml @@ -0,0 +1,11 @@ + + + [CURRENTPAGE] + + + FormatString + D + + + + diff --git a/Templates/Default/Listing.Header.html b/Templates/Default/Listing.Header.html new file mode 100755 index 0000000..7996a8e --- /dev/null +++ b/Templates/Default/Listing.Header.html @@ -0,0 +1 @@ + diff --git a/Templates/Default/Listing.Item.html b/Templates/Default/Listing.Item.html new file mode 100755 index 0000000..3a55dd9 --- /dev/null +++ b/Templates/Default/Listing.Item.html @@ -0,0 +1,50 @@ + + + + + +
+ + + + + + + +
[PUBLISHSTARTDATE]
+ + + + + + + + +
[IMAGETHUMB:100] + [EDIT] [TITLE] +
+ By [AUTHOR] @ [PUBLISHSTARTTIME] :: [VIEWCOUNT] Views [HASCOMMENTSENABLED]:: + [COMMENTCOUNT] Comments [/HASCOMMENTSENABLED][HASRATINGSENABLED] :: [RATING][/HASRATINGSENABLED][HASCATEGORIES] :: [CATEGORIES][/HASCATEGORIES] +
+ + + + +
+ + + + + [HASMOREDETAIL:150] + + + + [/HASMOREDETAIL:150] +
+ [HASSUMMARY][SUMMARY][/HASSUMMARY][HASNOSUMMARY][DETAILS:150][/HASNOSUMMARY] +
Read + More..
+
+
+
+
diff --git a/Templates/Default/Listing.Item.xml b/Templates/Default/Listing.Item.xml new file mode 100755 index 0000000..3490293 --- /dev/null +++ b/Templates/Default/Listing.Item.xml @@ -0,0 +1,23 @@ + + + [CREATEDATE] + + + FormatString + D + + + + + [EDIT] + + + ToolTip + Edit this Article + + + + + [TITLE] + + diff --git a/Templates/Default/Menu.Item.html b/Templates/Default/Menu.Item.html new file mode 100755 index 0000000..04ffa0e --- /dev/null +++ b/Templates/Default/Menu.Item.html @@ -0,0 +1,26 @@ + +

+ [RESX:CurrentArticles] + | + [RESX:Archives] + | + [RESX:Search] + [ISSUBMITTER] +
+ [RESX:MyArticles] + | + [RESX:CreateArticle] + [/ISSUBMITTER] + [ISAPPROVER] + | + [RESX:ApproveArticles] +[HASCOMMENTSENABLED] + | + [RESX:ApproveComments] +[/HASCOMMENTSENABLED] + [/ISAPPROVER] + [ISADMIN] + | + [RESX:AdminOptions] + [/ISADMIN] +

diff --git a/Templates/Default/Print.Footer.html b/Templates/Default/Print.Footer.html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/Default/Print.Header.html b/Templates/Default/Print.Header.html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/Default/Print.Item.html b/Templates/Default/Print.Item.html new file mode 100755 index 0000000..ab60bc6 --- /dev/null +++ b/Templates/Default/Print.Item.html @@ -0,0 +1,42 @@ + + + + + +
+ + + + + + + +
[PUBLISHSTARTDATE]
+ + + + + + + + +
[IMAGE] + [TITLE] +
+ By [AUTHOR] @ [PUBLISHSTARTTIME] :: [VIEWCOUNT] Views [HASCOMMENTSENABLED]:: + [COMMENTCOUNT] Comments [/HASCOMMENTSENABLED][HASRATINGSENABLED] :: [RATING][/HASRATINGSENABLED][HASCATEGORIES] :: [CATEGORIES][/HASCATEGORIES] +
+ + + + +
+ + + + +
[PAGETEXT]
+
+
+
+
diff --git a/Templates/Default/Template.css b/Templates/Default/Template.css new file mode 100755 index 0000000..0e86ec3 --- /dev/null +++ b/Templates/Default/Template.css @@ -0,0 +1,177 @@ +/* News Articles Custom Styles */ +.articleTitle { font-size : 14px; font-weight : bolder; color : #006600; } +.articleTable { background-color: black; margin: 0px; } +.articleTopCell { background-color: #336699; color: white; font-weight: bold; padding: 6px; height: 25px; } +.articleTopCell .NormalBold { color: #FFF; } +.articleContentCell { color: black; padding: 6px; background-color: #FEFEFE; } +.articleTextCell { color: black; padding: 6px; background-color: #FFFFCC; } +.articleIconCell { background-color: #D0D0D0; width: 20px; } +.articleFooterCell { color: #FFFFFF; padding: 3px; background-color: #336699; height: 25px; } +.articleFooterCell .NormalBold { color: #FFF; } +.featuredTopCell { background-color: #336699; color: white; font-weight: bold; padding: 6px; height: 25px; } + +A.Normal.MenuTop:link { + text-decoration: underline; +} + +A.Normal.MenuTop:visited { + text-decoration: underline; +} + +A.Normal.MenuTop:active { + text-decoration: underline; +} + +A.Normal.MenuTop:hover { + text-decoration: underline; + color: #ff0000; +} + +A.Normal.MenuTopSelected:link { + text-decoration: underline; + color: #ff0000; +} + +A.Normal.MenuTopSelected:visited { + text-decoration: underline; + color: #ff0000; +} + +A.Normal.MenuTopSelected:active { + text-decoration: underline; + color: #ff0000; +} + +A.Normal.MenuTopSelected:hover { + text-decoration: underline; + color: #ff0000; +} + + +/* Photo Area */ + +.articleImageList li +{ + display: inline; + float: left; + margin-left:10px; + margin-right:10px; + margin-top:10px; +} + +/** + * jQuery lightBox plugin + * This jQuery plugin was inspired and based on Lightbox 2 by Lokesh Dhakar (http://www.huddletogether.com/projects/lightbox2/) + * and adapted to me for use like a plugin from jQuery. + * @name jquery-lightbox-0.4.css + * @author Leandro Vieira Pinho - http://leandrovieira.com + * @version 0.4 + * @date November 17, 2007 + * @category jQuery plugin + * @copyright (c) 2007 Leandro Vieira Pinho (leandrovieira.com) + * @license CC Attribution-No Derivative Works 2.5 Brazil - http://creativecommons.org/licenses/by-nd/2.5/br/deed.en_US + * @example Visit http://leandrovieira.com/projects/jquery/lightbox/ for more informations about this jQuery plugin + */ +#jquery-overlay { + position: absolute; + top: 0; + left: 0; + z-index: 90; + width: 100%; + height: 500px; +} +#jquery-lightbox { + position: absolute; + top: 0; + left: 0; + width: 100%; + z-index: 100; + text-align: center; + line-height: 0; +} +#jquery-lightbox a img { border: none; } +#lightbox-container-image-box { + position: relative; + background-color: #fff; + width: 250px; + height: 250px; + margin: 0 auto; +} +#lightbox-container-image { padding: 10px; } +#lightbox-loading { + position: absolute; + top: 40%; + left: 0%; + height: 25%; + width: 100%; + text-align: center; + line-height: 0; +} + +#lightbox-container-image-data-box { + background-color: #fff; + margin:0pt auto; + overflow: auto; + font-family:Verdana,Helvetica,sans-serif; + font-size:10px; + font-size-adjust:none; + font-style:normal; + font-variant:normal; + font-weight:normal; + line-height:1.4em; +} + +#lightbox-container-image-data { + padding: 0 10px; +} + +#lightbox-container-image-details { + float:left; + text-align:left; + width:70%; +} + +#lightbox-container-image-details-caption +{ + font-weight: bold; +} + +#lightbox-container-image-details-currentNumber +{ + clear:left; + display:block; +} + +#lightbox-container-image-details-currentNumber a, lightbox-container-image-details-currentNumber a:hover +{ + border-bottom:medium none; + color:#151410; + text-decoration:underline; +} + +#lightbox-container-image-details-nav { + clear:left; + display:block; + padding:0pt 0pt 10px; +} + +#lightbox-container-image-details-nav a, #lightbox-container-image-details-nav a:hover { + border-bottom:medium none; + color:#151410; + text-decoration:underline; +} + +#lightbox-container-image-details-nav-btnPrev +{ + margin:0pt 8px 0pt 0pt; +} + +#lightbox-image-details-close-btnClose { + float: right; +} + +#lightbox-image-details-close a, #lightbox-image-details-close a:hover { + border-bottom:medium none; + color:#151410; + text-decoration:underline; +} \ No newline at end of file diff --git a/Templates/Default/View.Footer.html b/Templates/Default/View.Footer.html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/Default/View.Header.html b/Templates/Default/View.Header.html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/Default/View.Item.html b/Templates/Default/View.Item.html new file mode 100755 index 0000000..3289688 --- /dev/null +++ b/Templates/Default/View.Item.html @@ -0,0 +1,116 @@ + + + + + + +
+ + + + + + + +
+ [PUBLISHSTARTDATE]
+ + + + + + + + + +
[IMAGE] + [EDIT] [TITLE]
+ By [AUTHOR] @ [PUBLISHSTARTTIME] :: [VIEWCOUNT] Views [HASCOMMENTSENABLED]:: + [COMMENTCOUNT] Comments [/HASCOMMENTSENABLED][HASRATINGSENABLED] :: [RATING][/HASRATINGSENABLED][HASCATEGORIES] :: [CATEGORIES][/HASCATEGORIES] +
[PRINT] 
+ + + + +
+ + + + + [HASLINK] + + + + [/HASLINK] +
[PAGETEXT]
Read + More..
+
+
+
+
+ +[HASMULTIPLEPAGES] +
+ + + + + + + + +
+ [LINKPREVIOUS] | [LINKNEXT] +
+
+[/HASMULTIPLEPAGES] +[HASIMAGES] +
+ + + + + + + +
Images
+ [IMAGES] +
+
+[/HASIMAGES] +[ISRATEABLE] +
+ + + + + + + +
Rating
+ [POSTRATING] +
+
+[/ISRATEABLE] + + + + + + +
+ + + + + + + +
Comments
+[COMMENTS] + +[POSTCOMMENT] +
+
\ No newline at end of file diff --git a/Templates/Default/View.Item.xml b/Templates/Default/View.Item.xml new file mode 100755 index 0000000..c3e8d6e --- /dev/null +++ b/Templates/Default/View.Item.xml @@ -0,0 +1,11 @@ + + + [PUBLISHSTARTDATE] + + + FormatString + D + + + + diff --git a/Templates/Default/View.PageHeader.Html b/Templates/Default/View.PageHeader.Html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/Default/View.Title.Html b/Templates/Default/View.Title.Html new file mode 100755 index 0000000..b7ee51a --- /dev/null +++ b/Templates/Default/View.Title.Html @@ -0,0 +1 @@ +[TITLE] > [SITETITLE] \ No newline at end of file diff --git a/Templates/JWPlayer/Category.Child.html b/Templates/JWPlayer/Category.Child.html new file mode 100755 index 0000000..57f89d6 --- /dev/null +++ b/Templates/JWPlayer/Category.Child.html @@ -0,0 +1,6 @@ +[ISDEPTHABS:3] +
  • [NAME]
  • +[/ISDEPTHABS:3] +[ISNOTDEPTHABS:3] +
  • [NAME]
  • +[/ISNOTDEPTHABS:3] diff --git a/Templates/JWPlayer/Category.html b/Templates/JWPlayer/Category.html new file mode 100755 index 0000000..302e4c6 --- /dev/null +++ b/Templates/JWPlayer/Category.html @@ -0,0 +1,15 @@ +

    [NAME]

    +[DESCRIPTION] +[HASIMAGE]YES[/HASIMAGE] +[HASNOIMAGE]NO[/HASNOIMAGE] +Image: [IMAGETHUMB:100:100] [IMAGE] +
    +
      +[ISDEPTHABS:2] +[CHILDCATEGORIES:2] +[/ISDEPTHABS:2] +[ISNOTDEPTHABS:2] +[CHILDCATEGORIES:1] +[/ISNOTDEPTHABS:2] +
    +
    diff --git a/Templates/JWPlayer/Comment.Item.html b/Templates/JWPlayer/Comment.Item.html new file mode 100755 index 0000000..cd6817c --- /dev/null +++ b/Templates/JWPlayer/Comment.Item.html @@ -0,0 +1,11 @@ + +
    +
    [AUTHOR]
    +
    +
    + # [HASANONYMOUSURL][/HASANONYMOUSURL][AUTHOR][HASANONYMOUSURL][/HASANONYMOUSURL] [EDIT] +
    +
    [CREATEDATE] [CREATETIME]
    + [COMMENT] +
    +
    diff --git a/Templates/JWPlayer/File.Footer.Html b/Templates/JWPlayer/File.Footer.Html new file mode 100755 index 0000000..ca97522 --- /dev/null +++ b/Templates/JWPlayer/File.Footer.Html @@ -0,0 +1 @@ + diff --git a/Templates/JWPlayer/File.Header.Html b/Templates/JWPlayer/File.Header.Html new file mode 100755 index 0000000..5971365 --- /dev/null +++ b/Templates/JWPlayer/File.Header.Html @@ -0,0 +1 @@ +
      diff --git a/Templates/JWPlayer/File.Item.Html b/Templates/JWPlayer/File.Item.Html new file mode 100755 index 0000000..c3993ef --- /dev/null +++ b/Templates/JWPlayer/File.Item.Html @@ -0,0 +1,3 @@ +
    • + [TITLE] ([SIZE]) +
    • diff --git a/Templates/JWPlayer/Handout.Cover.html b/Templates/JWPlayer/Handout.Cover.html new file mode 100755 index 0000000..7393cb9 --- /dev/null +++ b/Templates/JWPlayer/Handout.Cover.html @@ -0,0 +1,10 @@ + + + + +
      + [LOGO]
      +

      [NAME]


      + [DESCRIPTION] +
      +
       
      diff --git a/Templates/JWPlayer/Handout.End.html b/Templates/JWPlayer/Handout.End.html new file mode 100755 index 0000000..5f28270 --- /dev/null +++ b/Templates/JWPlayer/Handout.End.html @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/Templates/JWPlayer/Handout.Footer.html b/Templates/JWPlayer/Handout.Footer.html new file mode 100755 index 0000000..5f28270 --- /dev/null +++ b/Templates/JWPlayer/Handout.Footer.html @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/Templates/JWPlayer/Handout.Header.html b/Templates/JWPlayer/Handout.Header.html new file mode 100755 index 0000000..734380e --- /dev/null +++ b/Templates/JWPlayer/Handout.Header.html @@ -0,0 +1,9 @@ + + + + + +
      [LOGO] +

      [NAME]

      +
      +
      diff --git a/Templates/JWPlayer/Handout.Item.html b/Templates/JWPlayer/Handout.Item.html new file mode 100755 index 0000000..59171e6 --- /dev/null +++ b/Templates/JWPlayer/Handout.Item.html @@ -0,0 +1,19 @@ +
      + +
      +
      [PUBLISHSTARTDATE:dd]
      +
      + + + +
      + [DETAILS] +
      + + [HASCATEGORIES] +
      + Posted in: [CATEGORIES] +
      + [/HASCATEGORIES] + +
      diff --git a/Templates/JWPlayer/Image.Footer.Html b/Templates/JWPlayer/Image.Footer.Html new file mode 100755 index 0000000..ca97522 --- /dev/null +++ b/Templates/JWPlayer/Image.Footer.Html @@ -0,0 +1 @@ +
    diff --git a/Templates/JWPlayer/Image.Header.Html b/Templates/JWPlayer/Image.Header.Html new file mode 100755 index 0000000..ce64b98 --- /dev/null +++ b/Templates/JWPlayer/Image.Header.Html @@ -0,0 +1 @@ +
      diff --git a/Templates/JWPlayer/Image.Item.Html b/Templates/JWPlayer/Image.Item.Html new file mode 100755 index 0000000..3a9c1cd --- /dev/null +++ b/Templates/JWPlayer/Image.Item.Html @@ -0,0 +1,3 @@ +
    • + [ISITEMINDEX:1]YES1[/ISITEMINDEX:1][IMAGETHUMB:125:125] +
    • diff --git a/Templates/JWPlayer/Images/01.gif b/Templates/JWPlayer/Images/01.gif new file mode 100755 index 0000000000000000000000000000000000000000..7a14861f8a1e8354962e6abe9b4b0518531c461d GIT binary patch literal 1204 zcmb`^hf^2E-o!CEh{T~^X836Bod3o<>loS6&010l~q+$5{aa`y1J&Orna`WuCA`WzP_QM zp|P>Csi~>Cxw)mKrM0zHDwVdiwY9gmcXV`gc6N4kb;)G1?(XiMo}S*`-oC!R{{H@f zfq}unLAhM6P$-6mhK7fSM@B|QM@PrT#>U6TCnhE)Cnu+-rlzN-XJ%$*XJ_Z;=9Eh1 z{QSI1rCL~6SX^9OT3T9OUS3^YU0YjQUtizY*x20M+}hgO-riQL)jK;oySux4dwcu) z`|sbsKR7t}@ZrPZ;o;HI(ed%|$;rv->FL?onMR}e=YNIPT)r7bC5KZVf|NhNN8~VS zFyZ%*aB?vIK?weFFn~USoYMuO0Nlr^k7vL|O>|Uj9E~3T7lTO$0MEF@q}Y_?=V_^b zzi@vEWWD0Bxk)*%7-j-E@Qn`AOjuM>R$N+GE-n$6#S0uT0Nli?0nllYHn%pm%bGeI z1a)S%7RClB?9kiM@sY9N>8VNELAn5EW&Rn6TUuG$SY2OMZ*SoiXaeiwlhZTJ*_Y42 ziKihc)|a6DU>bQTo*8cd^WsG0s`OEK3%XC$cBpYMM`H5I1_c}UlRl}{ zzeaTPVv^yF&`=QxjdYS|zL0R_qIYg|J-s|%kmzm>qk5k*9?FTDqD z?VC%8*XJckcy+2}3e4=nE!P5|w8{O>@0q@_+&JK#`u!(~%30#M+UoKiF%- zoxw176vW(0#lV;gNvL!<1%i42C#n*zvg|LQJV0L>@|skb$8d=Bp*{6y%&U@ISm=19 zJGkfIj&w7+ou7JNpN~P_aW2eD{aGE&FueQeFVsXzAi0fo|4$tYmSf7jf=rBQ<}JOT z$Zi3XLQqVBeq~OUT!NqBa<+wOp&JmT6+}V6G2TKx@fH6^NP@#81bUTZXwAEu#*5Xv z0vfd=K&;i8FrVdY1Gf}`ZJ*4TX+aSFG<0W4$zF6 z49hNw@XA-a+BpNRG=0XRU57F8A%9ac{iOaH!l#eqrGr j*HI~NGhmhowwq25*rwP~ZJfFVg1l^pg<2+tf`H4vefNy6 literal 0 HcmV?d00001 diff --git a/Templates/JWPlayer/Images/02.gif b/Templates/JWPlayer/Images/02.gif new file mode 100755 index 0000000000000000000000000000000000000000..5e5c7b58175f34e29a6a92536576b43bc541b02c GIT binary patch literal 1650 zcmds$i#rnt0Ki9!MGr*jOKu$Hxsbj~-SyQXMRy-vU0vnQ^U`^bqLNoK@|x$#c`T11 zHnTBoGuv!lGtAg#W42)<6NNmRtAFEu-|zeV2S3;ASI;^5SOKg63KHNeq2;8|a&j1w z9QL-Ou&^+^f)ZZQ8Bs}%sG`BD>9FdqN41)h{B9MZ5({w$bO0)dWIc-fn`6z^Pl55C=@Cd&rQS)#Ws(| zHuGP6mB5Q5@Se8{>+0&_TKS0tK|Y+Jy;3QF8k@8jVgQO~8qK3uyc6m&}qyJaL2sjx>zCX#uMf?g z>+kQ!aOax1au$n)SwBxKJn*i9{0<6O)sZ ztm$R3SUfc~C6P#^QmITPo1UJYnVFHxe|}c=g*&4Hn!K-*Ecpc);4!GH#gU}cDA;*wzs#pcE0TF?0ot1 zMWs^h{=YC$8C`(|_(TQxgMFWZLwsNXL6;)KqI`lNeqoTuK>(9Ypqdt77hv=4lyA=f zKq|oQKBH?`B<&^W@DU&Yz`c}ma4$4gfbeyGrDypw5ZPqflX>DqTtlh{yiW&UXn*(Z zo@%#3$Q{BB%QGk4^Um)tcFqF=w2$75QLhEunj1p?lxDj2yME^N((??kQgBY7CVZ zC`FBIa4{}0-Nd!=_U@T+zcblvQkGu|qtf+|F}r--Fkf@n$mJzaS88IUz#RV}P^GN6 z?3a?^<$&!?qETG54VHhcTE@eFL0oteUSyY(x2W7nBSkkh z+!Lw^4otWlpYX`rM8ohwc;a4g3dnS?{xxq?pv6U`Y|p`F!6o1U#{{1Mdx&?X`Z+5E zH46j|r)Fy!f~(Yk`cBjwb&w7&hv_RFXzzFNs~os-%%~^a2u77^91m{D=|1)_ z-(JHo@EOPD=so`k7Xy&zh?_O0ZA8nuzM;a+s;&g~+Oitq&~H(ZtfysxjQx~$sw|40 zcJj?#mTl;J%8uh^_qD0-@Jc91aYGgs`(`~UHNyBEC8}~z6_(X?3 z0y<_JjpJi(f}pwi?u+fMLY$VdlBgYqou_*?wy*P^p{)Xx+o7GkUdOd`)DJ5gZLpaD(G&(*Sy{0qItyU%aGe$*vU zdKH}QA=7}yBa+;#-Zd|N7KM{aUt5F&)SL|-u5wZx%u7ZS5t9j;kPXR8YZGUEZz{*t jG}FwHHjQwFY|iAnX6Y6eJ;ZFvOZ>7p3S_*o4&cIn^%wP} literal 0 HcmV?d00001 diff --git a/Templates/JWPlayer/Images/03.gif b/Templates/JWPlayer/Images/03.gif new file mode 100755 index 0000000000000000000000000000000000000000..722f2917897614837a5f029d947705b3ccbdce0f GIT binary patch literal 1679 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 literal 0 HcmV?d00001 diff --git a/Templates/JWPlayer/Images/05.gif b/Templates/JWPlayer/Images/05.gif new file mode 100755 index 0000000000000000000000000000000000000000..55c43377d16205b0c9a7edc9aa3fc9cbbad7afd1 GIT binary patch literal 1671 zcmd7R3p*1E0LJlQGTD)B9?9*@jx=G$RLEs5x7j*YDI&GmR!(%Iv(_mhx#pe}q9ue( znB*|ohGtAwBB5v#xmE6$G-rK_^M8Jy;C-Ig1MhBUPuU6B2^ePp6qysj7#}Un5iMJV zqguOswQT*i?DEsvt#C{Mvd15?Cjer19AXy;u~#?&aSYt*a1!c3hB^nBxCCt9OM&jC zz#J(sC-PRuAebW+=A=M_xdiDs)3vcQeH`7ugJ$7=8sSN^bUS0{{ujbM#E1}VMGQvc z&mxE+=s(Y32#&e!#m9E-~|jRe5X(NZXbr#k;~|#42qV7J4x>tVlZbftsJ0`a>wxpz_tgMX1 zNnx|um6eq>H8tgp_c$C*ZEfwdXV0F#$giubd)i!3UtizQ(9qb}$mMdInwnm`c+uS4 z%;WL+e7-;+;ELE>QDsX@OH;?w*4Eaxwl zVzIcZtE;_-+uqak>eZ``x6R$%-5tHn5{cyX>(_7Iyy@xb>Fw?9>+5^>?p=R>|NHmv z2L=WP2M33ShCY1w@bTlv;o;$tk&#cIK1rognN0R+d~kGhbZl&FbmHUq`1sh=$oQ0W zVq#))a&ls3bZTm9dU|?hX6EbHuiw6X`~Lm=?Ck8^+}!;9{KCS*;^N}c($ezs^2*A} z>gwvs+Va}k+7CtRYwPRlKY#v|%jFvz8;U{xKN-sn_J`3am*_Nj&=vSuN*Fx^8-D&0 zB?Lu1kNP_VV7v-c+6>qLSp0g*ug?HLa=?bVfoBzq9|MBv00G!uY@DVl?pl9(kZUZ| z`v8ztjS!|78b($mNMb}P0GujwM5)*-8|7O^G{cw@ZX1Dfix5D-eH}bg*-pjhOE=3Y z5wUnID+!-(#9Gj$>~qW5;ppWk^q&WOxEZUw)CrH6*-$6PJ8%n`u!VP>CJKF_cVV2Om6c(FjIe;PF-U zwd?n7+IG)+(^mVNv#MZSQaUU^n*`_r>f)%kK(L$Xo$3%QjGq9(lBFuh8_}(LzUeH! znx-Avm~7qG&rA6Y&61@$+EnqFb&Jvb_Btqnk(IG{-mf7gsZTSi7`KlH+NyW?PNrZ zyc78dY$MdACO>QebC8dkro#w3KxKvEvT~h}>FV;jaz(`_3=+zEOZ z1g`C21cW|&$%2+zce+lopLbhO#b%(KL&Sf_3-Zocm(&u#+*w9mCHeu}r=w|Xj4)#( z@R3^al)W3DnyAV0zE@9dit%hwa=AZk^Spmwb(@wICdoiQe0|0yh6$-@FLQ>04Nl)r zo-5Ch%*J&hg@y6IhfBoPR*~RBkP#@uMqE{)b9Ujir+$P6Jk~Wxou!tdoNV1;L0#By^KN80u6KvxO{0KloJ?ieq#jUX_B8D=4AppThr-b#RJNghojWw zd(icsLGgx>$jn4!Sv^i27w>^u9nCsiDKw1GLf}nV37MpAta#Mgm!i8U2X|&k<=SM$ P^8yF=Dxv08EMV_{e{e}I literal 0 HcmV?d00001 diff --git a/Templates/JWPlayer/Images/06.gif b/Templates/JWPlayer/Images/06.gif new file mode 100755 index 0000000000000000000000000000000000000000..bc81f14722187ab93530362f78e9e6e4d9375f7e GIT binary patch literal 1668 zcmd6mi#OAI0KmW7m9So>B&2y}T1%soZjXzrnB04vQn}UbM06{8#44{4k;keP?dm~t zd!Wc;cGj9~BV(rK74jaL$Bf3zhTr$re{nzO^A~*1`M8r0IPLPY19m{_55ChG1iCJQ zFBd^~Fz5*ey&<441oVf3flx3Q1|(r%=n@#d1iprYk#GRd0tscgGy;r9fH4Xfr+|se zKz13(uYjqmVEQVMMQSS|fh<}VMu6EUpp5=53SKf%#h_rgDU1a3u_$#cP{*PsoxOCa;Ha*6;=f#@oPnJWO5zuUqBhNTwak#KU`zFw1U^ z?gTUKVb+$y!a|t21K!^avmJ_yi{Zl^B_$=u<2_3``(V!AZ%+@w+loS z6%|OnJIr@yFc_7UmGId?CX>lxvDj=jEb^Uy?f358JNU|1RT2naALnp5b8pV8-khtd zs+uheegFQwru1)h*@f!rYIXTVq%4rj{@) z?S~H^>gwtc_7#CZfUvLD*VjW%6y(G-G&Bf>!p6o%kw}E_ZZtJDef;?G)2B~jvADUp zxuvD0wY3!y(xLEvdwcum&!0OwIyyT$ySlodIRDF+FWueUJv}|Wy}f;Xef|CY0|Ntt zgM$)@WN2t;czAeZWJD^Jj*X3tkB?7GOvq%i$;nB%Tn;BXrlzK*r>B=D`@Vhqrcfx5 zY01pY%ji%UyO2!cQezc>6J zVvd;p8Xo9J2@JsbN8y6~!UKbxBSI;DLBunm#LGdzT&;!D0}v2?obuxtpo0LYYwA&& z$4k;NFw_DAZO$pHmbu1u()`_$vE<*h^2#g(w>EB!dz~syCa(rRyVwq*pL^1Y$CzGt z2b+VL#1#*%Dzvz3O^!sOJ5fHPpYrymSt$R^qLOon99)!3eu@Eczkh0hOELyq?7%jR zDm(J}=&Mt#JzLMUcxIV7CHh{%93%F!BKjp&K^?;5i8fChH+V&s4s1@v z!3L8SujVzFXFpom%!!&Yws^cf!_2idbAEJrFVSasRI9lGwKjljJ#_#MV?AZj<9}LK+ z^B=4_)#OwE%XR*ZC4Eb@^6gJc&&9#CzL~1M_5zKU zY!u)t&`+Y=j1!;73 z0hgw`_5nb9n1v;vyo|lMnakGTz5*XToHOv%2E)z|0}^#@=)Q-@)>$4{vK7r)p<|hD zn^)-n)ndq3OKNMw(OH*T#IlQIb9wP+0C4M&o` zrI^7N+7;&cr*6q(>{|hgnw`pJ<_vW zJ6UP1VK=p?{-h5LUuS!`s7!3!NF~)}Cwk-gP9~Ggn%}p0;p6l&MHM~ajb0=^Em3UC zqn-$PE7f)ova4AOa;9|dp04ZDwuADj7Ms=#t3?eajG^9lsI+SN`WQJefv^}_!_UQJ z7-0{~!bnd}-Yu)^wW(Q-*_1>bCmxo0mp2HGVpFhN9`)!M2M6d^)G-*mo91V6TIt)k zFYIQ;ZtM3t5-5v29qVgmvuQ*=E>qOzb1Ycd-e7CsX&mpINZuTed#1aUJ&zvkI`=Y% znO8LIm$H$1QlX2d;sP27tkLpDx4u}_RPpW)|Wots_mX{DntpC6*Ro9!|V qEEp76-ajWHyY8aM)zZA1M2*y_{k&$Z;AIJW%&1ZxJ%K`j-TwiHL7Ni* literal 0 HcmV?d00001 diff --git a/Templates/JWPlayer/Images/07.gif b/Templates/JWPlayer/Images/07.gif new file mode 100755 index 0000000000000000000000000000000000000000..a11c68e62d2e659b13e90aac3b10f6c499680e24 GIT binary patch literal 1658 zcmd6m`BTzq0LEX;jI?ReOs&kmqM0Y*W-D#SqB)sIW#`t8GpnW6c4(`1+Ll=x9&KZ* zlDR^pR#Hl-V2G%IA|QB|;u&6fD=LUke&4nKVn6fD^W*c&Gap~S{luN2&cGQA6TuP` z3Pq6yI?_RBI_Sy(-4xJ60liPb=S-l?1XL=u?-`)cX#H7WAPWrs3x=}6mu%2aT`^1r zBQ!8d17pv@I2}y90Iy!Xf|+0{2TbG|P3HntE||z$$zU*M^1$p%pne4=Uz=%O1I=qp zVPPT61MvAqZ9WD*w`MY#3k-~o0dx$E{tX7^gRgHfiv<|?5?5SYtYKP~l$1awfJ_4x ziv<~5Aj1JNoY-tOEU+&vErmrUuxORG#E!$^!1r5KY$9Z>gDeY_ZN=qsVX;$rc{%*B z8L|jG9uKnIAqPP@_9$mdMMcGY84R7w2MYG0LhstzTCrG+R{O#l zUx`ElMFCQ&w63mBCX+2lLbZ}`wKPgDmuscxq4ZRJeLbxEwV|OwFFU7`UC_xcH8wUj zH8tt$BhmVBO+#FBbF;oNwxy*7HePCNZG}yj(55J~`O2qHpU{?TXzNn0x3#swk2l-f z+u_GJg+kHM(Sf!<=gww5?(XU7>Fw?P{P{E5LxDXRN~N-|udlzqe_&u>aB%R; zmoLM^!=t04V`F3ESw=x{rc_Ox5dRp6h$F~ORxRUu|=)-MTdvRhKC_%ZX%aM zqr)$fVxnS0FXGQe;jdln|qCY!{$Th|6yk|_S`=65yarOBk(VQuo$ z$>}n>SHLrG{UPfg=}smd&+@Jo+rJC7OQIV3jdy-XYbwhNUz_DmyYv=47oC`DD}7+^ z%k1XF42Y?RkE#y@Iru$E$F7e&N_KLtJddt9HV~nB6t=xZdp-*7hK2PuVFi;bwthwHPb4cNDHzbw??%&-1MwY=LN0yr(L=5Zj z} zz1H0B5rO}$C16|JSdIxDz1Lut;*yAXBonglycuWm?l`|8Sgx}-Ce+4uju%zn&aNWl zAm;wtL^zj1X5GA5GPT0|>;$V7cPwxl9Z|2`))_4;{J^`7o5BxexfFij5EFv7PDGAJ z7K@bqVxFcq#g%tM)y1sh-HHp?V9*ut{+)=Euuo`W8T`n>k!0=87A2a-i!9@k)o1P-*u?> literal 0 HcmV?d00001 diff --git a/Templates/JWPlayer/Images/08.gif b/Templates/JWPlayer/Images/08.gif new file mode 100755 index 0000000000000000000000000000000000000000..469d88664c69c2886eece0f6238f3d848c8cf6b1 GIT binary patch literal 1680 zcmcJO|6kH~0>|H|sVHvF)VYV2r1nKZG{0nB%?Dw(u&jsex^CUIOFCV<$+D8>cD5d+ zIrGsscQ$9GJ-FP;F7=YoV`_?kpaOzl5J3<`@+&CvMZWrZul*5w{`C6g_1p7#DC?s= zdnq`819RcvEj2YY_4W0SA3uKj^y%~G&nH@ef&rATz$6o>+CX!2v$`EjwS$(H7R~>G zmIbDN0lE$_(*YO^hQ1TLdi6@z<@crwFqzER*PyMfZLS-%x3|ytfQ25g$ObGHYpE9) zIH04W!@%|J?Cf0TffXJw@X%ddU8X+p`t@rgKcu_6+bjS*Jw4Wb0J(t8X4?jUZ2;BV z+iMvNunq>=g(wb(;}D^^T&`0LY@+v^Vib?ZbBR$<2p~Ta@}t~CD4Y2GzP>&_pAUzC zOY*KjAb^80{r&xL1i%q5lXMRhZ5OC45z`-Kq!fWV;G@O2*-j& zA`z5@LRlChi-59lII>+V7Q@kaI377PGz8_*a4ZSRv2bkHs_bKlM1siQe$%B=DI8CQ z6F4}YhA41Qv15367%Jl7+dYv46+59K5z6Y0ud-B~C3B zPJc2vISHr#>Y6^UQmNExwM$2H=>CPwfKyk=d`1+2ZNx zX`N07=e~h+B{MTK$ovgBU#i#ZXJ==T#j3fvIb^8@G1M$9EG#ZAx{Qpar6q&GU^E(` zsR^3?x4gW(va$lr9VU}$b#>KjHbZNl#bQBhQmfVKSyR|-HfSGPTU%RqXrW`$Znr~+ zYTYpdol_2n!|8OoTrR}D;&!_cj|uUZJsuCT?p$AAhlmp*ZUjLfgl`4={n&y;WnRjs z(DL)JXTQOINx76?KrAYxQ3?qEC?s4i09%|sr~m)~{{OgR0^`4wezAUWYcb+N&JGk%Y$o?8((xvNev6qVgb4O`nM z)jts4X8-dK-piNHk)<7Bo!PGJhr1i2KL|PakU^}boVA<7@EBI&8Fu+8-xt}2q%&75 z4&28bdy&!j_YKAClApryw7QGmKlO_W$7`8iTf7MF%L$S;q{{2hhd1v0(-U?s<-B>I z`jom?Hn_GuxIIP?6OVfTC&9fQkgcM zYUYFuP^*OjJLy;*Iu7SmzO{gvLkft!Db=2dW$q~T$6hn_`fb)X#`;Blu8s92p2X&D z*cck$yCH;ZI-8&Mkv7gJhh$>k4@zaTf57aZ|LldPRkDBdi^^r!`r`LiMPC^^?iWd| zrSKy@rM8xbog@$QLXKcB`UDeA^s=C9L%i`WdOdM3rPli z7tci8#R<Trx|VX+=_4S?Ed!+dRf?I%oA_Y zRZ}u1`4&IHt}06ZZvZBeCFSKrR_2ZPkf??jQ4%loykq)iWCn)t@h7?0(Zt$|;@As~&stoIP0#MWM}H|GxD8D1-C-k3vpE>-`xRi# Bylnsg literal 0 HcmV?d00001 diff --git a/Templates/JWPlayer/Images/09.gif b/Templates/JWPlayer/Images/09.gif new file mode 100755 index 0000000000000000000000000000000000000000..b2b6c96854bc6b6d1a361b87f86cf8998769853d GIT binary patch literal 1654 zcmdUu`#aMM0EfSGISln=Gnd@9nY*pYlu{khDVm<-ak@R7b6nCz<+6z7K66*O(}g4C zaIzh-t=WbR8MYV|V#IPVx!>n9r~ZudKJWAS{qw_n#_hDj5g#kS3YfeHeCIB(Cm7HS z0W=8!j8VNw70BAG-jrpNgET9$teL=7|5G)=9 zBY|KEAXp**BZFW>6}?0S?Uc(jra54lHu5TJ{V3ww1^#o?|MB6e`*E$x7 z&elgKm|_#mY?D#8ImWiR@PlMaT$Twg-5i&PvVUxOxX|)wp_Sv)?^++r#-7NwJyD4L zxd7)}VDFN1_*9XdOM%1bV*Ari9oo0qiZd50@mDL( zUwh^G$3K^E)LgwuzaB#OC)C}%&$tyz3kaj%4QJkspal^bfyDZtNLFxUeP|3PEUw`} zd}BDNkw|7mCN@PT<>%+OkRKNn74g$@i;IgZDk_Bee^ymhQ79BDm0DX{TUS>{qtWPe zI)lMrGMOwEi_K z^XI|A!J(lcu~_3PL1@$rQ(l8K3l$;nBnRJt@V zH9bB3?c2BIDe272%h#Rq+}!;9{KCS*;^N}c($ezs^2*AJYqy0*3^ zTU}jWU*Fi+kjZ4*GTG+l=GNBM_V)J9&W>Cz-`(B){{8<8LT=zf@b?MzzYg~$!tePI z{O>s34+{0UgYgT(gxvuUG9{22unXAyDCI{pfT|qW1sk~5l<*Q%q1s9S@WCl*ud;L0 zK&J1hM2Ph{rII&D{v$)fnCcXdgbroENI9hh^y+Lr<`To*(#{N@vtQ$xmqgKNzpitH z0#?y$s=MTPDsuITSE^gl{){QtlO*LQ$RnN^-aTdQA2qF6H-@b)zW&wZmtt+4%r7}Z z8y7>1)(^*As}GzXq-?pMPv#sBP&Kk~Sa{Tutlp2!C`;O7{+mc^%~4dIZu$2uWdf+$ z4%@}O9ujhrMN8MQ^E`0Uxg6&oZ+5=Ys!Y-f_BMB)YKvCNofS8ow^;NwanHo~xxa|m z>As$Vh(2lv9@Ene^JbNhRY3}^59Y6y$}ba_Ow(an@WSUaA|Drsr(T?YdmKoyW^=>x z+CVIil!(6Us_6pr%JtwW9iiCslpYQc)SwVA9T0Y(*R3%{-5U|g`@C@ol8Ui|$cYqt z1n#S7afr)Jv!PbTDS%roOcZc^DO`|&K`@Y-C!Hz-IsJ6o33N)^jhp2P!E&?lYNO@A zvAyH2CK=e$6l5xj)Q(8f^>js$HIOOrxb3lIiNU~v=$X3NUPk0cIrVAnJ zHZ>ecnss$e?OChJLf^BNWf{mci$ zCkfDR$Mx_wG4gsfD|wj>X`dPUR;QH0oY<6NbYP)wn1;L0zSXeSvIVB9R|xo;)!(_ExSJ}rme0YkG=z*e&Yt;|9np0MK-Isd> zsF0ZpswPin;xkREn2_|MYvHr>{)j*VU;lwdtt%=|gOrJ^q)9rhgZb!naR}Q}4RMcV zn|#PP)rkN$PlD&JkCJr)nPb6B#2F(pN}`GaXCY+cxt9WE|K|G9CMI5l&&ejA`=K_c KN>!8q$NvBjaa&&i literal 0 HcmV?d00001 diff --git a/Templates/JWPlayer/Images/10.gif b/Templates/JWPlayer/Images/10.gif new file mode 100755 index 0000000000000000000000000000000000000000..fdbe321a0b575f2b03912258d2cf3705557057be GIT binary patch literal 1664 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 literal 0 HcmV?d00001 diff --git a/Templates/JWPlayer/Listing.Empty.html b/Templates/JWPlayer/Listing.Empty.html new file mode 100755 index 0000000..ec72a5b --- /dev/null +++ b/Templates/JWPlayer/Listing.Empty.html @@ -0,0 +1,2 @@ + +[RESX:NoArticles] \ No newline at end of file diff --git a/Templates/JWPlayer/Listing.Featured.html b/Templates/JWPlayer/Listing.Featured.html new file mode 100755 index 0000000..5f28270 --- /dev/null +++ b/Templates/JWPlayer/Listing.Featured.html @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/Templates/JWPlayer/Listing.Footer.html b/Templates/JWPlayer/Listing.Footer.html new file mode 100755 index 0000000..89c972c --- /dev/null +++ b/Templates/JWPlayer/Listing.Footer.html @@ -0,0 +1,4 @@ + +[HASMULTIPLEPAGES] +[PAGER] +[/HASMULTIPLEPAGES] diff --git a/Templates/JWPlayer/Listing.Header.html b/Templates/JWPlayer/Listing.Header.html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/JWPlayer/Listing.Item.html b/Templates/JWPlayer/Listing.Item.html new file mode 100755 index 0000000..6513fd0 --- /dev/null +++ b/Templates/JWPlayer/Listing.Item.html @@ -0,0 +1,32 @@ +[PRINT]
      + +
      +
      [PUBLISHSTARTDATE:dd]
      +
      +

      [EDIT][TITLE]

      + + +
      + [HASIMAGE]
      [IMAGETHUMB:100]
      [/HASIMAGE] + [HASSUMMARY][SUMMARY][/HASSUMMARY][HASNOSUMMARY][DETAILS:150][/HASNOSUMMARY] + [ISRSSITEM]

      [Read the rest of this article...]

      [/ISRSSITEM] + [ISNOTRSSITEM] + [HASMOREDETAIL:150] +

      [Read the rest of this article...]

      + [/HASMOREDETAIL:150][/ISNOTRSSITEM][TAGS] +
      + + [HASCATEGORIES] +
      + Posted in: [CATEGORIES] +
      + [/HASCATEGORIES] + +
      + Actions: + E-mail | + Permalink | + [HASCOMMENTSENABLED]Comments ([COMMENTCOUNT]) [ISSYNDICATIONENABLED]RSS comment feed[/ISSYNDICATIONENABLED] [/HASCOMMENTSENABLED] +
      + +
      diff --git a/Templates/JWPlayer/Menu.Item.html b/Templates/JWPlayer/Menu.Item.html new file mode 100755 index 0000000..fd0a277 --- /dev/null +++ b/Templates/JWPlayer/Menu.Item.html @@ -0,0 +1,35 @@ + +
      + [ISSYNDICATIONENABLED] + + + 25 Latest Articles + + + [/ISSYNDICATIONENABLED] + [RESX:CurrentArticles] + | + [RESX:Archives] + | + [RESX:Search] + + [ISSUBMITTER] +
      + [RESX:MyArticles] + | + [RESX:CreateArticle] + [/ISSUBMITTER] + [ISAPPROVER] + | + [RESX:ApproveArticles] + [HASCOMMENTSENABLED] + | + [RESX:ApproveComments] + [/HASCOMMENTSENABLED] + [/ISAPPROVER] + [ISADMIN] + | + [RESX:AdminOptions] + [/ISADMIN] +
      + diff --git a/Templates/JWPlayer/Print.Item.html b/Templates/JWPlayer/Print.Item.html new file mode 100755 index 0000000..368ed52 --- /dev/null +++ b/Templates/JWPlayer/Print.Item.html @@ -0,0 +1,45 @@ + +
      + +
      +
      [PUBLISHSTARTDATE:dd]
      +
      + + + +
      + [HASIMAGE]
      [IMAGETHUMB:100]
      [/HASIMAGE] + [PAGETEXT] +
      + + [HASMULTIPLEPAGES] +
      + Pages: [CURRENTPAGE] of [PAGECOUNT][HASPREVPAGE] [LINKPREVIOUS][/HASPREVPAGE][HASNEXTPAGE] [LINKNEXT][/HASNEXTPAGE] +
      + [/HASMULTIPLEPAGES] + + [HASCATEGORIES] +
      + Posted in: [CATEGORIES] +
      + [/HASCATEGORIES] + +
      + Actions: + E-mail | + Permalink | + [HASCOMMENTSENABLED]Comments ([COMMENTCOUNT]) RSS comment feed | [/HASCOMMENTSENABLED] + Kick it! | + DZone it! | + del.icio.us +
      + +
      + +[HASCOMMENTSENABLED] +
      +

      Comments

      + [HASCOMMENTS][COMMENTS][/HASCOMMENTS] + [HASNOCOMMENTS]There are currently no comments, be the first to post one.[/HASNOCOMMENTS] +
      +[/HASCOMMENTSENABLED] diff --git a/Templates/JWPlayer/Related.Footer.html b/Templates/JWPlayer/Related.Footer.html new file mode 100755 index 0000000..0b70308 --- /dev/null +++ b/Templates/JWPlayer/Related.Footer.html @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Templates/JWPlayer/Related.Header.html b/Templates/JWPlayer/Related.Header.html new file mode 100755 index 0000000..ebce010 --- /dev/null +++ b/Templates/JWPlayer/Related.Header.html @@ -0,0 +1,2 @@ + +
      \ No newline at end of file diff --git a/Templates/JWPlayer/Related.Item.html b/Templates/JWPlayer/Related.Item.html new file mode 100755 index 0000000..6fd6988 --- /dev/null +++ b/Templates/JWPlayer/Related.Item.html @@ -0,0 +1,3 @@ + +[TITLE] +[DETAILS:150]
      diff --git a/Templates/JWPlayer/Rss.Comment.Footer.html b/Templates/JWPlayer/Rss.Comment.Footer.html new file mode 100755 index 0000000..49cf466 --- /dev/null +++ b/Templates/JWPlayer/Rss.Comment.Footer.html @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Templates/JWPlayer/Rss.Comment.Header.html b/Templates/JWPlayer/Rss.Comment.Header.html new file mode 100755 index 0000000..a528d93 --- /dev/null +++ b/Templates/JWPlayer/Rss.Comment.Header.html @@ -0,0 +1,6 @@ + + + [PORTALNAME] + [PORTALURL] + [PORTALEMAIL] + [PORTALEMAIL] diff --git a/Templates/JWPlayer/Rss.Comment.Item.html b/Templates/JWPlayer/Rss.Comment.Item.html new file mode 100755 index 0000000..7fb2076 --- /dev/null +++ b/Templates/JWPlayer/Rss.Comment.Item.html @@ -0,0 +1,9 @@ + + [AUTHOR] + Comment by [AUTHOR] on '[TITLE]' + [COMMENTLINK] + [CREATEDATE] + [GUID] + [DESCRIPTION] + [COMMENTLINK] + \ No newline at end of file diff --git a/Templates/JWPlayer/Rss.Footer.html b/Templates/JWPlayer/Rss.Footer.html new file mode 100755 index 0000000..17b5ac2 --- /dev/null +++ b/Templates/JWPlayer/Rss.Footer.html @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/Templates/JWPlayer/Rss.Header.html b/Templates/JWPlayer/Rss.Header.html new file mode 100755 index 0000000..451ef4b --- /dev/null +++ b/Templates/JWPlayer/Rss.Header.html @@ -0,0 +1,6 @@ + + + [PORTALNAME] + [PORTALURL] + RSS feeds for [PORTALNAME] + 60 \ No newline at end of file diff --git a/Templates/JWPlayer/Rss.Item.html b/Templates/JWPlayer/Rss.Item.html new file mode 100755 index 0000000..4602234 --- /dev/null +++ b/Templates/JWPlayer/Rss.Item.html @@ -0,0 +1,13 @@ + + [COMMENTLINK] + [COMMENTCOUNT] + [COMMENTRSS] + [TRACKBACKLINK] + [TITLE] + [IMAGELINK] + [DETAILSDATA] + [CATEGORIESNOLINK] - [AUTHOR] + [PUBLISHDATE] + [GUID] + [HASENCLOSURE][/HASENCLOSURE] + \ No newline at end of file diff --git a/Templates/JWPlayer/Template.css b/Templates/JWPlayer/Template.css new file mode 100755 index 0000000..bced75e --- /dev/null +++ b/Templates/JWPlayer/Template.css @@ -0,0 +1,361 @@ +.article +{ + clear: both; + text-align: left; + margin-bottom : 25px; +} + +.articleHeadline h1 { + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; +} + +.articleAuthor { + margin-top:5px; +} + +.articleCalendar { + float: left; + margin-right: 6px; + width: 42px; + height: 42px; +} + +.articleCalendarIcon-01 { + background: url('images/01.gif'); +} + +.articleCalendarIcon-02 { + background: url('images/02.gif'); +} + +.articleCalendarIcon-03 { + background: url('images/03.gif'); +} + +.articleCalendarIcon-04 { + background: url('images/04.gif'); +} + +.articleCalendarIcon-05 { + background: url('images/05.gif'); +} + +.articleCalendarIcon-06 { + background: url('images/06.gif'); +} + +.articleCalendarIcon-07 { + background: url('images/07.gif'); +} + +.articleCalendarIcon-08 { + background: url('images/08.gif'); +} + +.articleCalendarIcon-09 { + background: url('images/09.gif'); +} + +.articleCalendarIcon-10 { + background: url('images/10.gif'); +} + +.articleCalendarIcon-11 { + background: url('images/11.gif'); +} + +.articleCalendarIcon-12 { + background: url('images/12.gif'); +} + +.articleCalendarDay { + font-family:Trebuchet MS,Verdana,Arial,Helvetica,sans-serif; + font-size:17px; + font-weight: bold; + color: #000; + width: 42px; + text-align:center; + padding-top: 15px; +} + +.articleEntry { + margin: 10px 5px; +} + +.articleRelated { + margin: 10px 5px; +} + +.articleRelated a { + display:block; + margin-top:5px; +} + +.articleImage { + margin : 2px 10px 4px 4px; + float : left; +} + +.articlePaging { + border-bottom:1px dotted #D8D8D8; + padding-bottom : 2px; + margin-bottom : 2px; +} + +.articleCategories { + border-bottom:1px dotted #D8D8D8; + margin-bottom:2px; + padding-bottom:2px; +} + +.related h2 +{ + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.postRating h2 +{ + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.articleComments { + text-align: left; +} + +.articleComments h2 { + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.articleComment { + margin : 5px 0 0px 0; + padding : 5px; + min-height : 100px; + height:auto !important; + height:100px; +} + +.articleCommentGravatar { + margin : 2px 10px 4px 4px; + float : left; +} + +.articleCommentContent { + text-align: left; + padding:0px 5px 10px 5px; +} + +.articleCommentAuthor { +} + +.articleCommentDate { + border-bottom:1px dotted #D8D8D8; + margin-bottom:2px; + padding-bottom:2px; +} + +.articleImages { + text-align: left; +} + +.articleImages h2 { + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.articleFiles { + text-align: left; +} + +.articleFiles h2 { + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.postComment +{ + text-align: left; +} + +.postComment p, .postComment div +{ + padding:2px 10px; + margin: 0px; +} + +.postComment h2 +{ + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.postComment input +{ + width: 150px; +} + +.postComment #notify input +{ + width: 20px; +} + +.postComment textarea +{ + width: 450px; + height: 150px; +} + +/* Photo Area */ + +.articleImageList li +{ + display: inline; + float: left; + margin-left:10px; + margin-right:10px; + margin-top:10px; +} + +/* File Area */ + +.articleFileList li +{ + display: inline; + float: left; + margin-left:10px; + margin-right:10px; + margin-top:10px; +} + +/** + * jQuery lightBox plugin + * This jQuery plugin was inspired and based on Lightbox 2 by Lokesh Dhakar (http://www.huddletogether.com/projects/lightbox2/) + * and adapted to me for use like a plugin from jQuery. + * @name jquery-lightbox-0.4.css + * @author Leandro Vieira Pinho - http://leandrovieira.com + * @version 0.4 + * @date November 17, 2007 + * @category jQuery plugin + * @copyright (c) 2007 Leandro Vieira Pinho (leandrovieira.com) + * @license CC Attribution-No Derivative Works 2.5 Brazil - http://creativecommons.org/licenses/by-nd/2.5/br/deed.en_US + * @example Visit http://leandrovieira.com/projects/jquery/lightbox/ for more informations about this jQuery plugin + */ +#jquery-overlay { + position: absolute; + top: 0; + left: 0; + z-index: 3000; + width: 100%; + height: 500px; +} +#jquery-lightbox { + position: absolute; + top: 0; + left: 0; + width: 100%; + z-index: 5000; + text-align: center; + line-height: 0; +} +#jquery-lightbox a img { border: none; } +#lightbox-container-image-box { + position: relative; + background-color: #fff; + width: 250px; + height: 250px; + margin: 0 auto; +} +#lightbox-container-image { padding: 10px; } +#lightbox-loading { + position: absolute; + top: 40%; + left: 0%; + height: 25%; + width: 100%; + text-align: center; + line-height: 0; +} + +#lightbox-container-image-data-box { + background-color: #fff; + margin:0pt auto; + overflow: auto; + font-family:Verdana,Helvetica,sans-serif; + font-size:10px; + font-size-adjust:none; + font-style:normal; + font-variant:normal; + font-weight:normal; + line-height:1.4em; +} + +#lightbox-container-image-data { + padding: 0 10px; +} + +#lightbox-container-image-details { + float:left; + text-align:left; + width:70%; +} + +#lightbox-container-image-details-caption +{ + font-weight: bold; +} + +#lightbox-container-image-details-currentNumber +{ + clear:left; + display:block; +} + +#lightbox-container-image-details-currentNumber a, lightbox-container-image-details-currentNumber a:hover +{ + border-bottom:medium none; + color:#151410; + text-decoration:underline; +} + +#lightbox-container-image-details-nav { + clear:left; + display:block; + padding:0pt 0pt 10px; +} + +#lightbox-container-image-details-nav a, #lightbox-container-image-details-nav a:hover { + border-bottom:medium none; + color:#151410; + text-decoration:underline; +} + +#lightbox-container-image-details-nav-btnPrev +{ + margin:0pt 8px 0pt 0pt; +} + +#lightbox-image-details-close-btnClose { + float: right; +} + +#lightbox-image-details-close a, #lightbox-image-details-close a:hover { + border-bottom:medium none; + color:#151410; + text-decoration:underline; +} \ No newline at end of file diff --git a/Templates/JWPlayer/View.Description.html b/Templates/JWPlayer/View.Description.html new file mode 100755 index 0000000..17d701f --- /dev/null +++ b/Templates/JWPlayer/View.Description.html @@ -0,0 +1 @@ +[SUMMARY:150] \ No newline at end of file diff --git a/Templates/JWPlayer/View.Item.html b/Templates/JWPlayer/View.Item.html new file mode 100755 index 0000000..7099e7b --- /dev/null +++ b/Templates/JWPlayer/View.Item.html @@ -0,0 +1,102 @@ + +
      + +
      +
      [PUBLISHSTARTDATE:dd]
      +
      +

      [EDIT][TITLE]

      + + +
      + [PAGETEXT] + [HASCUSTOMFIELDS][CUSTOMFIELDS][/HASCUSTOMFIELDS] + [HASLINK] +

      [Read More...]

      + [/HASLINK] +
      + + [HASMULTIPLEPAGES] +
      + Pages: [CURRENTPAGE] of [PAGECOUNT][HASPREVPAGE] [LINKPREVIOUS][/HASPREVPAGE][HASNEXTPAGE] [LINKNEXT][/HASNEXTPAGE] +
      + [/HASMULTIPLEPAGES] + + [HASCATEGORIES] +
      + Posted in: [CATEGORIES] +
      + [/HASCATEGORIES] + +
      + Actions: + E-mail | + Permalink | + [HASCOMMENTSENABLED]Comments ([COMMENTCOUNT]) [ISSYNDICATIONENABLED]RSS comment feed[/ISSYNDICATIONENABLED] [/HASCOMMENTSENABLED] +
      + +
      + +[HASIMAGES] +
      +

      Related Images

      +
      [IMAGES]
      +
      +[/HASIMAGES] + +[HASFILES] +
      +

      Related Files

      + [FILES] +
      +[/HASFILES] + +[HASRELATED] + +[/HASRELATED] + +[ISRATEABLE] +
      +

      Post Rating

      + [POSTRATING] +
      +[/ISRATEABLE] + +[HASCOMMENTSENABLED] +
      +

      Comments

      + [HASCOMMENTS][COMMENTS][/HASCOMMENTS] + [HASNOCOMMENTS]There are currently no comments, be the first to post one![/HASNOCOMMENTS] +
      + +
      +

      Post Comment

      + [POSTCOMMENT] +
      +[/HASCOMMENTSENABLED] + + + + + diff --git a/Templates/JWPlayer/View.Keyword.html b/Templates/JWPlayer/View.Keyword.html new file mode 100755 index 0000000..10a1b4b --- /dev/null +++ b/Templates/JWPlayer/View.Keyword.html @@ -0,0 +1 @@ +[CATEGORIESNOLINK] [TAGSNOLINK] \ No newline at end of file diff --git a/Templates/JWPlayer/View.PageHeader.Html b/Templates/JWPlayer/View.PageHeader.Html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/JWPlayer/View.Title.Html b/Templates/JWPlayer/View.Title.Html new file mode 100755 index 0000000..b7ee51a --- /dev/null +++ b/Templates/JWPlayer/View.Title.Html @@ -0,0 +1 @@ +[TITLE] > [SITETITLE] \ No newline at end of file diff --git a/Templates/Standard/Category.Child.html b/Templates/Standard/Category.Child.html new file mode 100755 index 0000000..57f89d6 --- /dev/null +++ b/Templates/Standard/Category.Child.html @@ -0,0 +1,6 @@ +[ISDEPTHABS:3] +
    • [NAME]
    • +[/ISDEPTHABS:3] +[ISNOTDEPTHABS:3] +
    • [NAME]
    • +[/ISNOTDEPTHABS:3] diff --git a/Templates/Standard/Category.html b/Templates/Standard/Category.html new file mode 100755 index 0000000..302e4c6 --- /dev/null +++ b/Templates/Standard/Category.html @@ -0,0 +1,15 @@ +

      [NAME]

      +[DESCRIPTION] +[HASIMAGE]YES[/HASIMAGE] +[HASNOIMAGE]NO[/HASNOIMAGE] +Image: [IMAGETHUMB:100:100] [IMAGE] +
      +
        +[ISDEPTHABS:2] +[CHILDCATEGORIES:2] +[/ISDEPTHABS:2] +[ISNOTDEPTHABS:2] +[CHILDCATEGORIES:1] +[/ISNOTDEPTHABS:2] +
      +
      diff --git a/Templates/Standard/Comment.Item.html b/Templates/Standard/Comment.Item.html new file mode 100755 index 0000000..cd6817c --- /dev/null +++ b/Templates/Standard/Comment.Item.html @@ -0,0 +1,11 @@ + +
      +
      [AUTHOR]
      +
      +
      + # [HASANONYMOUSURL][/HASANONYMOUSURL][AUTHOR][HASANONYMOUSURL][/HASANONYMOUSURL] [EDIT] +
      +
      [CREATEDATE] [CREATETIME]
      + [COMMENT] +
      +
      diff --git a/Templates/Standard/File.Footer.Html b/Templates/Standard/File.Footer.Html new file mode 100755 index 0000000..ca97522 --- /dev/null +++ b/Templates/Standard/File.Footer.Html @@ -0,0 +1 @@ +
    diff --git a/Templates/Standard/File.Header.Html b/Templates/Standard/File.Header.Html new file mode 100755 index 0000000..5971365 --- /dev/null +++ b/Templates/Standard/File.Header.Html @@ -0,0 +1 @@ +
      diff --git a/Templates/Standard/File.Item.Html b/Templates/Standard/File.Item.Html new file mode 100755 index 0000000..c3993ef --- /dev/null +++ b/Templates/Standard/File.Item.Html @@ -0,0 +1,3 @@ +
    • + [TITLE] ([SIZE]) +
    • diff --git a/Templates/Standard/Handout.Cover.html b/Templates/Standard/Handout.Cover.html new file mode 100755 index 0000000..7393cb9 --- /dev/null +++ b/Templates/Standard/Handout.Cover.html @@ -0,0 +1,10 @@ + + + + +
      + [LOGO]
      +

      [NAME]


      + [DESCRIPTION] +
      +
       
      diff --git a/Templates/Standard/Handout.End.html b/Templates/Standard/Handout.End.html new file mode 100755 index 0000000..5f28270 --- /dev/null +++ b/Templates/Standard/Handout.End.html @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/Templates/Standard/Handout.Footer.html b/Templates/Standard/Handout.Footer.html new file mode 100755 index 0000000..5f28270 --- /dev/null +++ b/Templates/Standard/Handout.Footer.html @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/Templates/Standard/Handout.Header.html b/Templates/Standard/Handout.Header.html new file mode 100755 index 0000000..734380e --- /dev/null +++ b/Templates/Standard/Handout.Header.html @@ -0,0 +1,9 @@ + + + + + +
      [LOGO] +

      [NAME]

      +
      +
      diff --git a/Templates/Standard/Handout.Item.html b/Templates/Standard/Handout.Item.html new file mode 100755 index 0000000..59171e6 --- /dev/null +++ b/Templates/Standard/Handout.Item.html @@ -0,0 +1,19 @@ +
      + +
      +
      [PUBLISHSTARTDATE:dd]
      +
      + + + +
      + [DETAILS] +
      + + [HASCATEGORIES] +
      + Posted in: [CATEGORIES] +
      + [/HASCATEGORIES] + +
      diff --git a/Templates/Standard/Image.Footer.Html b/Templates/Standard/Image.Footer.Html new file mode 100755 index 0000000..ca97522 --- /dev/null +++ b/Templates/Standard/Image.Footer.Html @@ -0,0 +1 @@ +
    diff --git a/Templates/Standard/Image.Header.Html b/Templates/Standard/Image.Header.Html new file mode 100755 index 0000000..ce64b98 --- /dev/null +++ b/Templates/Standard/Image.Header.Html @@ -0,0 +1 @@ +
      diff --git a/Templates/Standard/Image.Item.Html b/Templates/Standard/Image.Item.Html new file mode 100755 index 0000000..35ae347 --- /dev/null +++ b/Templates/Standard/Image.Item.Html @@ -0,0 +1,3 @@ +
    • + [IMAGETHUMB:125:125] +
    • diff --git a/Templates/Standard/Images/01.gif b/Templates/Standard/Images/01.gif new file mode 100755 index 0000000000000000000000000000000000000000..7a14861f8a1e8354962e6abe9b4b0518531c461d GIT binary patch literal 1204 zcmb`^hf^2E-o!CEh{T~^X836Bod3o<>loS6&010l~q+$5{aa`y1J&Orna`WuCA`WzP_QM zp|P>Csi~>Cxw)mKrM0zHDwVdiwY9gmcXV`gc6N4kb;)G1?(XiMo}S*`-oC!R{{H@f zfq}unLAhM6P$-6mhK7fSM@B|QM@PrT#>U6TCnhE)Cnu+-rlzN-XJ%$*XJ_Z;=9Eh1 z{QSI1rCL~6SX^9OT3T9OUS3^YU0YjQUtizY*x20M+}hgO-riQL)jK;oySux4dwcu) z`|sbsKR7t}@ZrPZ;o;HI(ed%|$;rv->FL?onMR}e=YNIPT)r7bC5KZVf|NhNN8~VS zFyZ%*aB?vIK?weFFn~USoYMuO0Nlr^k7vL|O>|Uj9E~3T7lTO$0MEF@q}Y_?=V_^b zzi@vEWWD0Bxk)*%7-j-E@Qn`AOjuM>R$N+GE-n$6#S0uT0Nli?0nllYHn%pm%bGeI z1a)S%7RClB?9kiM@sY9N>8VNELAn5EW&Rn6TUuG$SY2OMZ*SoiXaeiwlhZTJ*_Y42 ziKihc)|a6DU>bQTo*8cd^WsG0s`OEK3%XC$cBpYMM`H5I1_c}UlRl}{ zzeaTPVv^yF&`=QxjdYS|zL0R_qIYg|J-s|%kmzm>qk5k*9?FTDqD z?VC%8*XJckcy+2}3e4=nE!P5|w8{O>@0q@_+&JK#`u!(~%30#M+UoKiF%- zoxw176vW(0#lV;gNvL!<1%i42C#n*zvg|LQJV0L>@|skb$8d=Bp*{6y%&U@ISm=19 zJGkfIj&w7+ou7JNpN~P_aW2eD{aGE&FueQeFVsXzAi0fo|4$tYmSf7jf=rBQ<}JOT z$Zi3XLQqVBeq~OUT!NqBa<+wOp&JmT6+}V6G2TKx@fH6^NP@#81bUTZXwAEu#*5Xv z0vfd=K&;i8FrVdY1Gf}`ZJ*4TX+aSFG<0W4$zF6 z49hNw@XA-a+BpNRG=0XRU57F8A%9ac{iOaH!l#eqrGr j*HI~NGhmhowwq25*rwP~ZJfFVg1l^pg<2+tf`H4vefNy6 literal 0 HcmV?d00001 diff --git a/Templates/Standard/Images/02.gif b/Templates/Standard/Images/02.gif new file mode 100755 index 0000000000000000000000000000000000000000..5e5c7b58175f34e29a6a92536576b43bc541b02c GIT binary patch literal 1650 zcmds$i#rnt0Ki9!MGr*jOKu$Hxsbj~-SyQXMRy-vU0vnQ^U`^bqLNoK@|x$#c`T11 zHnTBoGuv!lGtAg#W42)<6NNmRtAFEu-|zeV2S3;ASI;^5SOKg63KHNeq2;8|a&j1w z9QL-Ou&^+^f)ZZQ8Bs}%sG`BD>9FdqN41)h{B9MZ5({w$bO0)dWIc-fn`6z^Pl55C=@Cd&rQS)#Ws(| zHuGP6mB5Q5@Se8{>+0&_TKS0tK|Y+Jy;3QF8k@8jVgQO~8qK3uyc6m&}qyJaL2sjx>zCX#uMf?g z>+kQ!aOax1au$n)SwBxKJn*i9{0<6O)sZ ztm$R3SUfc~C6P#^QmITPo1UJYnVFHxe|}c=g*&4Hn!K-*Ecpc);4!GH#gU}cDA;*wzs#pcE0TF?0ot1 zMWs^h{=YC$8C`(|_(TQxgMFWZLwsNXL6;)KqI`lNeqoTuK>(9Ypqdt77hv=4lyA=f zKq|oQKBH?`B<&^W@DU&Yz`c}ma4$4gfbeyGrDypw5ZPqflX>DqTtlh{yiW&UXn*(Z zo@%#3$Q{BB%QGk4^Um)tcFqF=w2$75QLhEunj1p?lxDj2yME^N((??kQgBY7CVZ zC`FBIa4{}0-Nd!=_U@T+zcblvQkGu|qtf+|F}r--Fkf@n$mJzaS88IUz#RV}P^GN6 z?3a?^<$&!?qETG54VHhcTE@eFL0oteUSyY(x2W7nBSkkh z+!Lw^4otWlpYX`rM8ohwc;a4g3dnS?{xxq?pv6U`Y|p`F!6o1U#{{1Mdx&?X`Z+5E zH46j|r)Fy!f~(Yk`cBjwb&w7&hv_RFXzzFNs~os-%%~^a2u77^91m{D=|1)_ z-(JHo@EOPD=so`k7Xy&zh?_O0ZA8nuzM;a+s;&g~+Oitq&~H(ZtfysxjQx~$sw|40 zcJj?#mTl;J%8uh^_qD0-@Jc91aYGgs`(`~UHNyBEC8}~z6_(X?3 z0y<_JjpJi(f}pwi?u+fMLY$VdlBgYqou_*?wy*P^p{)Xx+o7GkUdOd`)DJ5gZLpaD(G&(*Sy{0qItyU%aGe$*vU zdKH}QA=7}yBa+;#-Zd|N7KM{aUt5F&)SL|-u5wZx%u7ZS5t9j;kPXR8YZGUEZz{*t jG}FwHHjQwFY|iAnX6Y6eJ;ZFvOZ>7p3S_*o4&cIn^%wP} literal 0 HcmV?d00001 diff --git a/Templates/Standard/Images/03.gif b/Templates/Standard/Images/03.gif new file mode 100755 index 0000000000000000000000000000000000000000..722f2917897614837a5f029d947705b3ccbdce0f GIT binary patch literal 1679 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 literal 0 HcmV?d00001 diff --git a/Templates/Standard/Images/05.gif b/Templates/Standard/Images/05.gif new file mode 100755 index 0000000000000000000000000000000000000000..55c43377d16205b0c9a7edc9aa3fc9cbbad7afd1 GIT binary patch literal 1671 zcmd7R3p*1E0LJlQGTD)B9?9*@jx=G$RLEs5x7j*YDI&GmR!(%Iv(_mhx#pe}q9ue( znB*|ohGtAwBB5v#xmE6$G-rK_^M8Jy;C-Ig1MhBUPuU6B2^ePp6qysj7#}Un5iMJV zqguOswQT*i?DEsvt#C{Mvd15?Cjer19AXy;u~#?&aSYt*a1!c3hB^nBxCCt9OM&jC zz#J(sC-PRuAebW+=A=M_xdiDs)3vcQeH`7ugJ$7=8sSN^bUS0{{ujbM#E1}VMGQvc z&mxE+=s(Y32#&e!#m9E-~|jRe5X(NZXbr#k;~|#42qV7J4x>tVlZbftsJ0`a>wxpz_tgMX1 zNnx|um6eq>H8tgp_c$C*ZEfwdXV0F#$giubd)i!3UtizQ(9qb}$mMdInwnm`c+uS4 z%;WL+e7-;+;ELE>QDsX@OH;?w*4Eaxwl zVzIcZtE;_-+uqak>eZ``x6R$%-5tHn5{cyX>(_7Iyy@xb>Fw?9>+5^>?p=R>|NHmv z2L=WP2M33ShCY1w@bTlv;o;$tk&#cIK1rognN0R+d~kGhbZl&FbmHUq`1sh=$oQ0W zVq#))a&ls3bZTm9dU|?hX6EbHuiw6X`~Lm=?Ck8^+}!;9{KCS*;^N}c($ezs^2*A} z>gwvs+Va}k+7CtRYwPRlKY#v|%jFvz8;U{xKN-sn_J`3am*_Nj&=vSuN*Fx^8-D&0 zB?Lu1kNP_VV7v-c+6>qLSp0g*ug?HLa=?bVfoBzq9|MBv00G!uY@DVl?pl9(kZUZ| z`v8ztjS!|78b($mNMb}P0GujwM5)*-8|7O^G{cw@ZX1Dfix5D-eH}bg*-pjhOE=3Y z5wUnID+!-(#9Gj$>~qW5;ppWk^q&WOxEZUw)CrH6*-$6PJ8%n`u!VP>CJKF_cVV2Om6c(FjIe;PF-U zwd?n7+IG)+(^mVNv#MZSQaUU^n*`_r>f)%kK(L$Xo$3%QjGq9(lBFuh8_}(LzUeH! znx-Avm~7qG&rA6Y&61@$+EnqFb&Jvb_Btqnk(IG{-mf7gsZTSi7`KlH+NyW?PNrZ zyc78dY$MdACO>QebC8dkro#w3KxKvEvT~h}>FV;jaz(`_3=+zEOZ z1g`C21cW|&$%2+zce+lopLbhO#b%(KL&Sf_3-Zocm(&u#+*w9mCHeu}r=w|Xj4)#( z@R3^al)W3DnyAV0zE@9dit%hwa=AZk^Spmwb(@wICdoiQe0|0yh6$-@FLQ>04Nl)r zo-5Ch%*J&hg@y6IhfBoPR*~RBkP#@uMqE{)b9Ujir+$P6Jk~Wxou!tdoNV1;L0#By^KN80u6KvxO{0KloJ?ieq#jUX_B8D=4AppThr-b#RJNghojWw zd(icsLGgx>$jn4!Sv^i27w>^u9nCsiDKw1GLf}nV37MpAta#Mgm!i8U2X|&k<=SM$ P^8yF=Dxv08EMV_{e{e}I literal 0 HcmV?d00001 diff --git a/Templates/Standard/Images/06.gif b/Templates/Standard/Images/06.gif new file mode 100755 index 0000000000000000000000000000000000000000..bc81f14722187ab93530362f78e9e6e4d9375f7e GIT binary patch literal 1668 zcmd6mi#OAI0KmW7m9So>B&2y}T1%soZjXzrnB04vQn}UbM06{8#44{4k;keP?dm~t zd!Wc;cGj9~BV(rK74jaL$Bf3zhTr$re{nzO^A~*1`M8r0IPLPY19m{_55ChG1iCJQ zFBd^~Fz5*ey&<441oVf3flx3Q1|(r%=n@#d1iprYk#GRd0tscgGy;r9fH4Xfr+|se zKz13(uYjqmVEQVMMQSS|fh<}VMu6EUpp5=53SKf%#h_rgDU1a3u_$#cP{*PsoxOCa;Ha*6;=f#@oPnJWO5zuUqBhNTwak#KU`zFw1U^ z?gTUKVb+$y!a|t21K!^avmJ_yi{Zl^B_$=u<2_3``(V!AZ%+@w+loS z6%|OnJIr@yFc_7UmGId?CX>lxvDj=jEb^Uy?f358JNU|1RT2naALnp5b8pV8-khtd zs+uheegFQwru1)h*@f!rYIXTVq%4rj{@) z?S~H^>gwtc_7#CZfUvLD*VjW%6y(G-G&Bf>!p6o%kw}E_ZZtJDef;?G)2B~jvADUp zxuvD0wY3!y(xLEvdwcum&!0OwIyyT$ySlodIRDF+FWueUJv}|Wy}f;Xef|CY0|Ntt zgM$)@WN2t;czAeZWJD^Jj*X3tkB?7GOvq%i$;nB%Tn;BXrlzK*r>B=D`@Vhqrcfx5 zY01pY%ji%UyO2!cQezc>6J zVvd;p8Xo9J2@JsbN8y6~!UKbxBSI;DLBunm#LGdzT&;!D0}v2?obuxtpo0LYYwA&& z$4k;NFw_DAZO$pHmbu1u()`_$vE<*h^2#g(w>EB!dz~syCa(rRyVwq*pL^1Y$CzGt z2b+VL#1#*%Dzvz3O^!sOJ5fHPpYrymSt$R^qLOon99)!3eu@Eczkh0hOELyq?7%jR zDm(J}=&Mt#JzLMUcxIV7CHh{%93%F!BKjp&K^?;5i8fChH+V&s4s1@v z!3L8SujVzFXFpom%!!&Yws^cf!_2idbAEJrFVSasRI9lGwKjljJ#_#MV?AZj<9}LK+ z^B=4_)#OwE%XR*ZC4Eb@^6gJc&&9#CzL~1M_5zKU zY!u)t&`+Y=j1!;73 z0hgw`_5nb9n1v;vyo|lMnakGTz5*XToHOv%2E)z|0}^#@=)Q-@)>$4{vK7r)p<|hD zn^)-n)ndq3OKNMw(OH*T#IlQIb9wP+0C4M&o` zrI^7N+7;&cr*6q(>{|hgnw`pJ<_vW zJ6UP1VK=p?{-h5LUuS!`s7!3!NF~)}Cwk-gP9~Ggn%}p0;p6l&MHM~ajb0=^Em3UC zqn-$PE7f)ova4AOa;9|dp04ZDwuADj7Ms=#t3?eajG^9lsI+SN`WQJefv^}_!_UQJ z7-0{~!bnd}-Yu)^wW(Q-*_1>bCmxo0mp2HGVpFhN9`)!M2M6d^)G-*mo91V6TIt)k zFYIQ;ZtM3t5-5v29qVgmvuQ*=E>qOzb1Ycd-e7CsX&mpINZuTed#1aUJ&zvkI`=Y% znO8LIm$H$1QlX2d;sP27tkLpDx4u}_RPpW)|Wots_mX{DntpC6*Ro9!|V qEEp76-ajWHyY8aM)zZA1M2*y_{k&$Z;AIJW%&1ZxJ%K`j-TwiHL7Ni* literal 0 HcmV?d00001 diff --git a/Templates/Standard/Images/07.gif b/Templates/Standard/Images/07.gif new file mode 100755 index 0000000000000000000000000000000000000000..a11c68e62d2e659b13e90aac3b10f6c499680e24 GIT binary patch literal 1658 zcmd6m`BTzq0LEX;jI?ReOs&kmqM0Y*W-D#SqB)sIW#`t8GpnW6c4(`1+Ll=x9&KZ* zlDR^pR#Hl-V2G%IA|QB|;u&6fD=LUke&4nKVn6fD^W*c&Gap~S{luN2&cGQA6TuP` z3Pq6yI?_RBI_Sy(-4xJ60liPb=S-l?1XL=u?-`)cX#H7WAPWrs3x=}6mu%2aT`^1r zBQ!8d17pv@I2}y90Iy!Xf|+0{2TbG|P3HntE||z$$zU*M^1$p%pne4=Uz=%O1I=qp zVPPT61MvAqZ9WD*w`MY#3k-~o0dx$E{tX7^gRgHfiv<|?5?5SYtYKP~l$1awfJ_4x ziv<~5Aj1JNoY-tOEU+&vErmrUuxORG#E!$^!1r5KY$9Z>gDeY_ZN=qsVX;$rc{%*B z8L|jG9uKnIAqPP@_9$mdMMcGY84R7w2MYG0LhstzTCrG+R{O#l zUx`ElMFCQ&w63mBCX+2lLbZ}`wKPgDmuscxq4ZRJeLbxEwV|OwFFU7`UC_xcH8wUj zH8tt$BhmVBO+#FBbF;oNwxy*7HePCNZG}yj(55J~`O2qHpU{?TXzNn0x3#swk2l-f z+u_GJg+kHM(Sf!<=gww5?(XU7>Fw?P{P{E5LxDXRN~N-|udlzqe_&u>aB%R; zmoLM^!=t04V`F3ESw=x{rc_Ox5dRp6h$F~ORxRUu|=)-MTdvRhKC_%ZX%aM zqr)$fVxnS0FXGQe;jdln|qCY!{$Th|6yk|_S`=65yarOBk(VQuo$ z$>}n>SHLrG{UPfg=}smd&+@Jo+rJC7OQIV3jdy-XYbwhNUz_DmyYv=47oC`DD}7+^ z%k1XF42Y?RkE#y@Iru$E$F7e&N_KLtJddt9HV~nB6t=xZdp-*7hK2PuVFi;bwthwHPb4cNDHzbw??%&-1MwY=LN0yr(L=5Zj z} zz1H0B5rO}$C16|JSdIxDz1Lut;*yAXBonglycuWm?l`|8Sgx}-Ce+4uju%zn&aNWl zAm;wtL^zj1X5GA5GPT0|>;$V7cPwxl9Z|2`))_4;{J^`7o5BxexfFij5EFv7PDGAJ z7K@bqVxFcq#g%tM)y1sh-HHp?V9*ut{+)=Euuo`W8T`n>k!0=87A2a-i!9@k)o1P-*u?> literal 0 HcmV?d00001 diff --git a/Templates/Standard/Images/08.gif b/Templates/Standard/Images/08.gif new file mode 100755 index 0000000000000000000000000000000000000000..469d88664c69c2886eece0f6238f3d848c8cf6b1 GIT binary patch literal 1680 zcmcJO|6kH~0>|H|sVHvF)VYV2r1nKZG{0nB%?Dw(u&jsex^CUIOFCV<$+D8>cD5d+ zIrGsscQ$9GJ-FP;F7=YoV`_?kpaOzl5J3<`@+&CvMZWrZul*5w{`C6g_1p7#DC?s= zdnq`819RcvEj2YY_4W0SA3uKj^y%~G&nH@ef&rATz$6o>+CX!2v$`EjwS$(H7R~>G zmIbDN0lE$_(*YO^hQ1TLdi6@z<@crwFqzER*PyMfZLS-%x3|ytfQ25g$ObGHYpE9) zIH04W!@%|J?Cf0TffXJw@X%ddU8X+p`t@rgKcu_6+bjS*Jw4Wb0J(t8X4?jUZ2;BV z+iMvNunq>=g(wb(;}D^^T&`0LY@+v^Vib?ZbBR$<2p~Ta@}t~CD4Y2GzP>&_pAUzC zOY*KjAb^80{r&xL1i%q5lXMRhZ5OC45z`-Kq!fWV;G@O2*-j& zA`z5@LRlChi-59lII>+V7Q@kaI377PGz8_*a4ZSRv2bkHs_bKlM1siQe$%B=DI8CQ z6F4}YhA41Qv15367%Jl7+dYv46+59K5z6Y0ud-B~C3B zPJc2vISHr#>Y6^UQmNExwM$2H=>CPwfKyk=d`1+2ZNx zX`N07=e~h+B{MTK$ovgBU#i#ZXJ==T#j3fvIb^8@G1M$9EG#ZAx{Qpar6q&GU^E(` zsR^3?x4gW(va$lr9VU}$b#>KjHbZNl#bQBhQmfVKSyR|-HfSGPTU%RqXrW`$Znr~+ zYTYpdol_2n!|8OoTrR}D;&!_cj|uUZJsuCT?p$AAhlmp*ZUjLfgl`4={n&y;WnRjs z(DL)JXTQOINx76?KrAYxQ3?qEC?s4i09%|sr~m)~{{OgR0^`4wezAUWYcb+N&JGk%Y$o?8((xvNev6qVgb4O`nM z)jts4X8-dK-piNHk)<7Bo!PGJhr1i2KL|PakU^}boVA<7@EBI&8Fu+8-xt}2q%&75 z4&28bdy&!j_YKAClApryw7QGmKlO_W$7`8iTf7MF%L$S;q{{2hhd1v0(-U?s<-B>I z`jom?Hn_GuxIIP?6OVfTC&9fQkgcM zYUYFuP^*OjJLy;*Iu7SmzO{gvLkft!Db=2dW$q~T$6hn_`fb)X#`;Blu8s92p2X&D z*cck$yCH;ZI-8&Mkv7gJhh$>k4@zaTf57aZ|LldPRkDBdi^^r!`r`LiMPC^^?iWd| zrSKy@rM8xbog@$QLXKcB`UDeA^s=C9L%i`WdOdM3rPli z7tci8#R<Trx|VX+=_4S?Ed!+dRf?I%oA_Y zRZ}u1`4&IHt}06ZZvZBeCFSKrR_2ZPkf??jQ4%loykq)iWCn)t@h7?0(Zt$|;@As~&stoIP0#MWM}H|GxD8D1-C-k3vpE>-`xRi# Bylnsg literal 0 HcmV?d00001 diff --git a/Templates/Standard/Images/09.gif b/Templates/Standard/Images/09.gif new file mode 100755 index 0000000000000000000000000000000000000000..b2b6c96854bc6b6d1a361b87f86cf8998769853d GIT binary patch literal 1654 zcmdUu`#aMM0EfSGISln=Gnd@9nY*pYlu{khDVm<-ak@R7b6nCz<+6z7K66*O(}g4C zaIzh-t=WbR8MYV|V#IPVx!>n9r~ZudKJWAS{qw_n#_hDj5g#kS3YfeHeCIB(Cm7HS z0W=8!j8VNw70BAG-jrpNgET9$teL=7|5G)=9 zBY|KEAXp**BZFW>6}?0S?Uc(jra54lHu5TJ{V3ww1^#o?|MB6e`*E$x7 z&elgKm|_#mY?D#8ImWiR@PlMaT$Twg-5i&PvVUxOxX|)wp_Sv)?^++r#-7NwJyD4L zxd7)}VDFN1_*9XdOM%1bV*Ari9oo0qiZd50@mDL( zUwh^G$3K^E)LgwuzaB#OC)C}%&$tyz3kaj%4QJkspal^bfyDZtNLFxUeP|3PEUw`} zd}BDNkw|7mCN@PT<>%+OkRKNn74g$@i;IgZDk_Bee^ymhQ79BDm0DX{TUS>{qtWPe zI)lMrGMOwEi_K z^XI|A!J(lcu~_3PL1@$rQ(l8K3l$;nBnRJt@V zH9bB3?c2BIDe272%h#Rq+}!;9{KCS*;^N}c($ezs^2*AJYqy0*3^ zTU}jWU*Fi+kjZ4*GTG+l=GNBM_V)J9&W>Cz-`(B){{8<8LT=zf@b?MzzYg~$!tePI z{O>s34+{0UgYgT(gxvuUG9{22unXAyDCI{pfT|qW1sk~5l<*Q%q1s9S@WCl*ud;L0 zK&J1hM2Ph{rII&D{v$)fnCcXdgbroENI9hh^y+Lr<`To*(#{N@vtQ$xmqgKNzpitH z0#?y$s=MTPDsuITSE^gl{){QtlO*LQ$RnN^-aTdQA2qF6H-@b)zW&wZmtt+4%r7}Z z8y7>1)(^*As}GzXq-?pMPv#sBP&Kk~Sa{Tutlp2!C`;O7{+mc^%~4dIZu$2uWdf+$ z4%@}O9ujhrMN8MQ^E`0Uxg6&oZ+5=Ys!Y-f_BMB)YKvCNofS8ow^;NwanHo~xxa|m z>As$Vh(2lv9@Ene^JbNhRY3}^59Y6y$}ba_Ow(an@WSUaA|Drsr(T?YdmKoyW^=>x z+CVIil!(6Us_6pr%JtwW9iiCslpYQc)SwVA9T0Y(*R3%{-5U|g`@C@ol8Ui|$cYqt z1n#S7afr)Jv!PbTDS%roOcZc^DO`|&K`@Y-C!Hz-IsJ6o33N)^jhp2P!E&?lYNO@A zvAyH2CK=e$6l5xj)Q(8f^>js$HIOOrxb3lIiNU~v=$X3NUPk0cIrVAnJ zHZ>ecnss$e?OChJLf^BNWf{mci$ zCkfDR$Mx_wG4gsfD|wj>X`dPUR;QH0oY<6NbYP)wn1;L0zSXeSvIVB9R|xo;)!(_ExSJ}rme0YkG=z*e&Yt;|9np0MK-Isd> zsF0ZpswPin;xkREn2_|MYvHr>{)j*VU;lwdtt%=|gOrJ^q)9rhgZb!naR}Q}4RMcV zn|#PP)rkN$PlD&JkCJr)nPb6B#2F(pN}`GaXCY+cxt9WE|K|G9CMI5l&&ejA`=K_c KN>!8q$NvBjaa&&i literal 0 HcmV?d00001 diff --git a/Templates/Standard/Images/10.gif b/Templates/Standard/Images/10.gif new file mode 100755 index 0000000000000000000000000000000000000000..fdbe321a0b575f2b03912258d2cf3705557057be GIT binary patch literal 1664 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 literal 0 HcmV?d00001 diff --git a/Templates/Standard/Listing.Empty.html b/Templates/Standard/Listing.Empty.html new file mode 100755 index 0000000..ec72a5b --- /dev/null +++ b/Templates/Standard/Listing.Empty.html @@ -0,0 +1,2 @@ + +[RESX:NoArticles] \ No newline at end of file diff --git a/Templates/Standard/Listing.Featured.html b/Templates/Standard/Listing.Featured.html new file mode 100755 index 0000000..5f28270 --- /dev/null +++ b/Templates/Standard/Listing.Featured.html @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/Templates/Standard/Listing.Footer.html b/Templates/Standard/Listing.Footer.html new file mode 100755 index 0000000..89c972c --- /dev/null +++ b/Templates/Standard/Listing.Footer.html @@ -0,0 +1,4 @@ + +[HASMULTIPLEPAGES] +[PAGER] +[/HASMULTIPLEPAGES] diff --git a/Templates/Standard/Listing.Header.html b/Templates/Standard/Listing.Header.html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/Standard/Listing.Item.html b/Templates/Standard/Listing.Item.html new file mode 100755 index 0000000..9dbcca6 --- /dev/null +++ b/Templates/Standard/Listing.Item.html @@ -0,0 +1,32 @@ +
      + +
      +
      [PUBLISHSTARTDATE:dd]
      +
      +

      [EDIT][TITLE]

      + + +
      + [HASIMAGE]
      [IMAGETHUMB:100]
      [/HASIMAGE] + [HASSUMMARY][SUMMARY][/HASSUMMARY][HASNOSUMMARY][DETAILS:150][/HASNOSUMMARY] + [ISRSSITEM]

      [Read the rest of this article...]

      [/ISRSSITEM] + [ISNOTRSSITEM] + [HASMOREDETAIL:150] +

      [Read the rest of this article...]

      + [/HASMOREDETAIL:150][/ISNOTRSSITEM][TAGS] +
      + + [HASCATEGORIES] +
      + Posted in: [CATEGORIES] +
      + [/HASCATEGORIES] + +
      + Actions: + E-mail | + Permalink | + [HASCOMMENTSENABLED]Comments ([COMMENTCOUNT]) [ISSYNDICATIONENABLED]RSS comment feed[/ISSYNDICATIONENABLED] [/HASCOMMENTSENABLED] +
      + +
      diff --git a/Templates/Standard/Menu.Item.html b/Templates/Standard/Menu.Item.html new file mode 100755 index 0000000..fd0a277 --- /dev/null +++ b/Templates/Standard/Menu.Item.html @@ -0,0 +1,35 @@ + +
      + [ISSYNDICATIONENABLED] + + + 25 Latest Articles + + + [/ISSYNDICATIONENABLED] + [RESX:CurrentArticles] + | + [RESX:Archives] + | + [RESX:Search] + + [ISSUBMITTER] +
      + [RESX:MyArticles] + | + [RESX:CreateArticle] + [/ISSUBMITTER] + [ISAPPROVER] + | + [RESX:ApproveArticles] + [HASCOMMENTSENABLED] + | + [RESX:ApproveComments] + [/HASCOMMENTSENABLED] + [/ISAPPROVER] + [ISADMIN] + | + [RESX:AdminOptions] + [/ISADMIN] +
      + diff --git a/Templates/Standard/Print.Item.html b/Templates/Standard/Print.Item.html new file mode 100755 index 0000000..368ed52 --- /dev/null +++ b/Templates/Standard/Print.Item.html @@ -0,0 +1,45 @@ + +
      + +
      +
      [PUBLISHSTARTDATE:dd]
      +
      + + + +
      + [HASIMAGE]
      [IMAGETHUMB:100]
      [/HASIMAGE] + [PAGETEXT] +
      + + [HASMULTIPLEPAGES] +
      + Pages: [CURRENTPAGE] of [PAGECOUNT][HASPREVPAGE] [LINKPREVIOUS][/HASPREVPAGE][HASNEXTPAGE] [LINKNEXT][/HASNEXTPAGE] +
      + [/HASMULTIPLEPAGES] + + [HASCATEGORIES] +
      + Posted in: [CATEGORIES] +
      + [/HASCATEGORIES] + +
      + Actions: + E-mail | + Permalink | + [HASCOMMENTSENABLED]Comments ([COMMENTCOUNT]) RSS comment feed | [/HASCOMMENTSENABLED] + Kick it! | + DZone it! | + del.icio.us +
      + +
      + +[HASCOMMENTSENABLED] +
      +

      Comments

      + [HASCOMMENTS][COMMENTS][/HASCOMMENTS] + [HASNOCOMMENTS]There are currently no comments, be the first to post one.[/HASNOCOMMENTS] +
      +[/HASCOMMENTSENABLED] diff --git a/Templates/Standard/Related.Footer.html b/Templates/Standard/Related.Footer.html new file mode 100755 index 0000000..0b70308 --- /dev/null +++ b/Templates/Standard/Related.Footer.html @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Templates/Standard/Related.Header.html b/Templates/Standard/Related.Header.html new file mode 100755 index 0000000..ebce010 --- /dev/null +++ b/Templates/Standard/Related.Header.html @@ -0,0 +1,2 @@ + +
      \ No newline at end of file diff --git a/Templates/Standard/Related.Item.html b/Templates/Standard/Related.Item.html new file mode 100755 index 0000000..6fd6988 --- /dev/null +++ b/Templates/Standard/Related.Item.html @@ -0,0 +1,3 @@ + +[TITLE] +[DETAILS:150]
      diff --git a/Templates/Standard/Rss.Comment.Footer.html b/Templates/Standard/Rss.Comment.Footer.html new file mode 100755 index 0000000..49cf466 --- /dev/null +++ b/Templates/Standard/Rss.Comment.Footer.html @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Templates/Standard/Rss.Comment.Header.html b/Templates/Standard/Rss.Comment.Header.html new file mode 100755 index 0000000..a528d93 --- /dev/null +++ b/Templates/Standard/Rss.Comment.Header.html @@ -0,0 +1,6 @@ + + + [PORTALNAME] + [PORTALURL] + [PORTALEMAIL] + [PORTALEMAIL] diff --git a/Templates/Standard/Rss.Comment.Item.html b/Templates/Standard/Rss.Comment.Item.html new file mode 100755 index 0000000..7fb2076 --- /dev/null +++ b/Templates/Standard/Rss.Comment.Item.html @@ -0,0 +1,9 @@ + + [AUTHOR] + Comment by [AUTHOR] on '[TITLE]' + [COMMENTLINK] + [CREATEDATE] + [GUID] + [DESCRIPTION] + [COMMENTLINK] + \ No newline at end of file diff --git a/Templates/Standard/Rss.Footer.html b/Templates/Standard/Rss.Footer.html new file mode 100755 index 0000000..17b5ac2 --- /dev/null +++ b/Templates/Standard/Rss.Footer.html @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/Templates/Standard/Rss.Header.html b/Templates/Standard/Rss.Header.html new file mode 100755 index 0000000..451ef4b --- /dev/null +++ b/Templates/Standard/Rss.Header.html @@ -0,0 +1,6 @@ + + + [PORTALNAME] + [PORTALURL] + RSS feeds for [PORTALNAME] + 60 \ No newline at end of file diff --git a/Templates/Standard/Rss.Item.html b/Templates/Standard/Rss.Item.html new file mode 100755 index 0000000..949be84 --- /dev/null +++ b/Templates/Standard/Rss.Item.html @@ -0,0 +1,13 @@ + + [COMMENTLINK] + [COMMENTCOUNT] + [COMMENTRSS] + [TRACKBACKLINK] + [TITLE] + [ARTICLELINK] + [DESCRIPTION] + [AUTHOR] + [PUBLISHDATE] + [GUID] + [HASENCLOSURE][/HASENCLOSURE] + diff --git a/Templates/Standard/Template.css b/Templates/Standard/Template.css new file mode 100755 index 0000000..bced75e --- /dev/null +++ b/Templates/Standard/Template.css @@ -0,0 +1,361 @@ +.article +{ + clear: both; + text-align: left; + margin-bottom : 25px; +} + +.articleHeadline h1 { + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; +} + +.articleAuthor { + margin-top:5px; +} + +.articleCalendar { + float: left; + margin-right: 6px; + width: 42px; + height: 42px; +} + +.articleCalendarIcon-01 { + background: url('images/01.gif'); +} + +.articleCalendarIcon-02 { + background: url('images/02.gif'); +} + +.articleCalendarIcon-03 { + background: url('images/03.gif'); +} + +.articleCalendarIcon-04 { + background: url('images/04.gif'); +} + +.articleCalendarIcon-05 { + background: url('images/05.gif'); +} + +.articleCalendarIcon-06 { + background: url('images/06.gif'); +} + +.articleCalendarIcon-07 { + background: url('images/07.gif'); +} + +.articleCalendarIcon-08 { + background: url('images/08.gif'); +} + +.articleCalendarIcon-09 { + background: url('images/09.gif'); +} + +.articleCalendarIcon-10 { + background: url('images/10.gif'); +} + +.articleCalendarIcon-11 { + background: url('images/11.gif'); +} + +.articleCalendarIcon-12 { + background: url('images/12.gif'); +} + +.articleCalendarDay { + font-family:Trebuchet MS,Verdana,Arial,Helvetica,sans-serif; + font-size:17px; + font-weight: bold; + color: #000; + width: 42px; + text-align:center; + padding-top: 15px; +} + +.articleEntry { + margin: 10px 5px; +} + +.articleRelated { + margin: 10px 5px; +} + +.articleRelated a { + display:block; + margin-top:5px; +} + +.articleImage { + margin : 2px 10px 4px 4px; + float : left; +} + +.articlePaging { + border-bottom:1px dotted #D8D8D8; + padding-bottom : 2px; + margin-bottom : 2px; +} + +.articleCategories { + border-bottom:1px dotted #D8D8D8; + margin-bottom:2px; + padding-bottom:2px; +} + +.related h2 +{ + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.postRating h2 +{ + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.articleComments { + text-align: left; +} + +.articleComments h2 { + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.articleComment { + margin : 5px 0 0px 0; + padding : 5px; + min-height : 100px; + height:auto !important; + height:100px; +} + +.articleCommentGravatar { + margin : 2px 10px 4px 4px; + float : left; +} + +.articleCommentContent { + text-align: left; + padding:0px 5px 10px 5px; +} + +.articleCommentAuthor { +} + +.articleCommentDate { + border-bottom:1px dotted #D8D8D8; + margin-bottom:2px; + padding-bottom:2px; +} + +.articleImages { + text-align: left; +} + +.articleImages h2 { + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.articleFiles { + text-align: left; +} + +.articleFiles h2 { + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.postComment +{ + text-align: left; +} + +.postComment p, .postComment div +{ + padding:2px 10px; + margin: 0px; +} + +.postComment h2 +{ + margin-bottom: 0px; + background-color:#F0F0F0; + border:1px dashed #C8C8C8; + padding-left: 5px; +} + +.postComment input +{ + width: 150px; +} + +.postComment #notify input +{ + width: 20px; +} + +.postComment textarea +{ + width: 450px; + height: 150px; +} + +/* Photo Area */ + +.articleImageList li +{ + display: inline; + float: left; + margin-left:10px; + margin-right:10px; + margin-top:10px; +} + +/* File Area */ + +.articleFileList li +{ + display: inline; + float: left; + margin-left:10px; + margin-right:10px; + margin-top:10px; +} + +/** + * jQuery lightBox plugin + * This jQuery plugin was inspired and based on Lightbox 2 by Lokesh Dhakar (http://www.huddletogether.com/projects/lightbox2/) + * and adapted to me for use like a plugin from jQuery. + * @name jquery-lightbox-0.4.css + * @author Leandro Vieira Pinho - http://leandrovieira.com + * @version 0.4 + * @date November 17, 2007 + * @category jQuery plugin + * @copyright (c) 2007 Leandro Vieira Pinho (leandrovieira.com) + * @license CC Attribution-No Derivative Works 2.5 Brazil - http://creativecommons.org/licenses/by-nd/2.5/br/deed.en_US + * @example Visit http://leandrovieira.com/projects/jquery/lightbox/ for more informations about this jQuery plugin + */ +#jquery-overlay { + position: absolute; + top: 0; + left: 0; + z-index: 3000; + width: 100%; + height: 500px; +} +#jquery-lightbox { + position: absolute; + top: 0; + left: 0; + width: 100%; + z-index: 5000; + text-align: center; + line-height: 0; +} +#jquery-lightbox a img { border: none; } +#lightbox-container-image-box { + position: relative; + background-color: #fff; + width: 250px; + height: 250px; + margin: 0 auto; +} +#lightbox-container-image { padding: 10px; } +#lightbox-loading { + position: absolute; + top: 40%; + left: 0%; + height: 25%; + width: 100%; + text-align: center; + line-height: 0; +} + +#lightbox-container-image-data-box { + background-color: #fff; + margin:0pt auto; + overflow: auto; + font-family:Verdana,Helvetica,sans-serif; + font-size:10px; + font-size-adjust:none; + font-style:normal; + font-variant:normal; + font-weight:normal; + line-height:1.4em; +} + +#lightbox-container-image-data { + padding: 0 10px; +} + +#lightbox-container-image-details { + float:left; + text-align:left; + width:70%; +} + +#lightbox-container-image-details-caption +{ + font-weight: bold; +} + +#lightbox-container-image-details-currentNumber +{ + clear:left; + display:block; +} + +#lightbox-container-image-details-currentNumber a, lightbox-container-image-details-currentNumber a:hover +{ + border-bottom:medium none; + color:#151410; + text-decoration:underline; +} + +#lightbox-container-image-details-nav { + clear:left; + display:block; + padding:0pt 0pt 10px; +} + +#lightbox-container-image-details-nav a, #lightbox-container-image-details-nav a:hover { + border-bottom:medium none; + color:#151410; + text-decoration:underline; +} + +#lightbox-container-image-details-nav-btnPrev +{ + margin:0pt 8px 0pt 0pt; +} + +#lightbox-image-details-close-btnClose { + float: right; +} + +#lightbox-image-details-close a, #lightbox-image-details-close a:hover { + border-bottom:medium none; + color:#151410; + text-decoration:underline; +} \ No newline at end of file diff --git a/Templates/Standard/View.Description.html b/Templates/Standard/View.Description.html new file mode 100755 index 0000000..17d701f --- /dev/null +++ b/Templates/Standard/View.Description.html @@ -0,0 +1 @@ +[SUMMARY:150] \ No newline at end of file diff --git a/Templates/Standard/View.Item.html b/Templates/Standard/View.Item.html new file mode 100755 index 0000000..c2c0b19 --- /dev/null +++ b/Templates/Standard/View.Item.html @@ -0,0 +1,78 @@ + +
      + +
      +
      [PUBLISHSTARTDATE:dd]
      +
      +

      [EDIT][TITLE]

      + + +
      + [PAGETEXT] + [HASCUSTOMFIELDS][CUSTOMFIELDS][/HASCUSTOMFIELDS] + [HASLINK] +

      [Read More...]

      + [/HASLINK] +
      + + [HASMULTIPLEPAGES] +
      + Pages: [CURRENTPAGE] of [PAGECOUNT][HASPREVPAGE] [LINKPREVIOUS][/HASPREVPAGE][HASNEXTPAGE] [LINKNEXT][/HASNEXTPAGE] +
      + [/HASMULTIPLEPAGES] + + [HASCATEGORIES] +
      + Posted in: [CATEGORIES] +
      + [/HASCATEGORIES] + +
      + Actions: + E-mail | + Permalink | + [HASCOMMENTSENABLED]Comments ([COMMENTCOUNT]) [ISSYNDICATIONENABLED]RSS comment feed[/ISSYNDICATIONENABLED] [/HASCOMMENTSENABLED] +
      + +
      + +[HASIMAGES] +
      +

      Related Images

      +
      [IMAGES]
      +
      +[/HASIMAGES] + +[HASFILES] +
      +

      Related Files

      + [FILES] +
      +[/HASFILES] + +[HASRELATED] + +[/HASRELATED] + +[ISRATEABLE] +
      +

      Post Rating

      + [POSTRATING] +
      +[/ISRATEABLE] + +[HASCOMMENTSENABLED] +
      +

      Comments

      + [HASCOMMENTS][COMMENTS][/HASCOMMENTS] + [HASNOCOMMENTS]There are currently no comments, be the first to post one![/HASNOCOMMENTS] +
      + +
      +

      Post Comment

      + [POSTCOMMENT] +
      +[/HASCOMMENTSENABLED] diff --git a/Templates/Standard/View.Keyword.html b/Templates/Standard/View.Keyword.html new file mode 100755 index 0000000..10a1b4b --- /dev/null +++ b/Templates/Standard/View.Keyword.html @@ -0,0 +1 @@ +[CATEGORIESNOLINK] [TAGSNOLINK] \ No newline at end of file diff --git a/Templates/Standard/View.PageHeader.Html b/Templates/Standard/View.PageHeader.Html new file mode 100755 index 0000000..e69de29 diff --git a/Templates/Standard/View.Title.Html b/Templates/Standard/View.Title.Html new file mode 100755 index 0000000..b7ee51a --- /dev/null +++ b/Templates/Standard/View.Title.Html @@ -0,0 +1 @@ +[TITLE] > [SITETITLE] \ No newline at end of file diff --git a/Tracking/Pingback.ashx b/Tracking/Pingback.ashx new file mode 100755 index 0000000..eabc830 --- /dev/null +++ b/Tracking/Pingback.ashx @@ -0,0 +1 @@ +<%@ WebHandler Language="VB" CodeBehind="Pingback.ashx.vb" Class="Ventrian.NewsArticles.Tracking.Pingback" %> diff --git a/Tracking/Trackback.aspx b/Tracking/Trackback.aspx new file mode 100755 index 0000000..f462211 --- /dev/null +++ b/Tracking/Trackback.aspx @@ -0,0 +1 @@ +<%@ Page Language="vb" AutoEventWireup="false" CodeBehind="Trackback.aspx.vb" Inherits="Ventrian.NewsArticles.Tracking.Trackback" %> \ No newline at end of file diff --git a/Uninstall.SqlDataProvider b/Uninstall.SqlDataProvider new file mode 100755 index 0000000000000000000000000000000000000000..a9f2f6ca175b4a87652466529f1d35fed9fe6900 GIT binary patch literal 20930 zcmeHP?M@pp5Zu45)OX-jLPBU%pfm~mMQM^!TD}xQ5vuy?ZD((>ZhdhsL85ppRp>}^ z7?>N+et5lie}4C5C?Dlmc5vvsuIx!qPVjyY=YGmeCbGow8ONQ>G2%h4@w$*-_~{MK zf5WFK#(a`{jJcEx`GUhn^f2~X`WUy6bDTSqBYc0rU+Un@662=$jX6G_;mizQhd8&u zm;OdPW=G!1TiFK!edWQu5B$p(+y}U#JB%n5f133%W@lFpUR@<#A8BN{b$lYXPgXN; zD7Xt%-@_hwwJ?H~r@*+tYgfKjpT3jYT_1L(zQg!ZhNY6mS9nR*wP$1fLAK3pE9J}vmf|0 zTjFNY>ysO47hYfE(s{MkdPFX7>y)xkm&>%G25vK!o#}7?h^P;AuXM0Zf*EXdc8u_oABs)2oJ3tc-N@^ zu2x%kv3hUf{WC9Ov&WLK>RM!g9?K@?y6ZAmCgfGyM8{)WHsc*sS(fOc(_YpQ-kH5= z9Y*_J<2@HH^%{QPt2@PYT*!|`)hI@NTjiirjF~<45Wa2)@m|%*q+NkyV7RLGxNMJm zlLhi3PsP1bSl<*?cv<)He7%?9#lKyQz4<6hlu z*Py!wZBaJ2{)2M-oiOn%uwOw+N4);h(8dfuuH?9N7MWWg0k7`bX(xns_pq~jj4byY zSb1@-_a0?nE=RwfX}$NU1QmPC{8~;$5MC9h(1u(|b3MKLY=SkUt~I-O)&4}ik5u~^ z*{`Y`tF&2Y;tlgq8qWcD2dn94lZ^j6ihu9+~O!|fqf^}5$*&+zd+MBj7p+l->Q*!4KJ;r4mYPV!d4I1fHE$TI^0 z!RvCLzhgrCMb$o=s>qM5eyRf>wz!Kc&K=p&^5I+GnZbuOp6fU&ruXCWTT<|Cd~CMY S{qr*y&o(1}@l!gQ2>${Trtl#E literal 0 HcmV?d00001 diff --git a/Ventrian.NewsArticles.sln b/Ventrian.NewsArticles.sln new file mode 100755 index 0000000..d5bbfa9 --- /dev/null +++ b/Ventrian.NewsArticles.sln @@ -0,0 +1,26 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 2012 +Project("{F184B08F-C81C-45F6-A57F-5ABD9991F28F}") = "Ventrian.NewsArticles", "Ventrian.NewsArticles.vbproj", "{25F6A930-34CD-4730-8324-D234D4637898}" +EndProject +Project("{F184B08F-C81C-45F6-A57F-5ABD9991F28F}") = "Ventrian.NewsArticles.SqlDataProvider", "Providers\DataProvider\SqlDataProvider\Ventrian.NewsArticles.SqlDataProvider.vbproj", "{D1901326-AD43-466F-942D-AA796EA58D8E}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {25F6A930-34CD-4730-8324-D234D4637898}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {25F6A930-34CD-4730-8324-D234D4637898}.Debug|Any CPU.Build.0 = Debug|Any CPU + {25F6A930-34CD-4730-8324-D234D4637898}.Release|Any CPU.ActiveCfg = Release|Any CPU + {25F6A930-34CD-4730-8324-D234D4637898}.Release|Any CPU.Build.0 = Release|Any CPU + {D1901326-AD43-466F-942D-AA796EA58D8E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {D1901326-AD43-466F-942D-AA796EA58D8E}.Debug|Any CPU.Build.0 = Debug|Any CPU + {D1901326-AD43-466F-942D-AA796EA58D8E}.Release|Any CPU.ActiveCfg = Release|Any CPU + {D1901326-AD43-466F-942D-AA796EA58D8E}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/Ventrian.NewsArticles.v11.suo b/Ventrian.NewsArticles.v11.suo new file mode 100755 index 0000000000000000000000000000000000000000..f358f8d8b2e0a4469fd50a88b1b6d5ff5008931c GIT binary patch literal 122368 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 BMZEw3 literal 0 HcmV?d00001 diff --git a/Ventrian.NewsArticles.vbproj b/Ventrian.NewsArticles.vbproj new file mode 100755 index 0000000..9fbfe53 --- /dev/null +++ b/Ventrian.NewsArticles.vbproj @@ -0,0 +1,1006 @@ + + + + + Debug + AnyCPU + 9.0.21022 + 2.0 + {25F6A930-34CD-4730-8324-D234D4637898} + {349c5851-65df-11da-9384-00065b846f21};{F184B08F-C81C-45F6-A57F-5ABD9991F28F} + Library + + + Ventrian.NewsArticles + Off + + + 3.5 + + + v3.5 + false + + + + + + + + true + full + true + true + ..\..\bin\ + Ventrian.xml + 41999,42016,42017,42018,42019,42020,42021,42022,42032,42036,42353,42354,42355 + + + + + pdbonly + false + true + true + bin\ + Ventrian.xml + 41999,42016,42017,42018,42019,42020,42021,42022,42032,42036,42353,42354,42355 + + + + + + + False + ..\..\..\..\DotNetNuke482\Website\Bin\DotNetNuke.dll + + + False + ..\..\bin\DotNetNuke.Web.Client.dll + + + + + + + + + + + + + + + + + False + + + + + + + + + + + + + + + + + + + + + + + + + + + + Handler.ashx + + + + + + + + + + + Rsd.ashx + + + ASPXCodeBehind + + + ASPXCodeBehind + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Component + + + + Component + + + + + + + + + + + + + SWFUploaderFiles.ashx + + + UploadFiles.ascx + + + UploadFiles.ascx + ASPXCodeBehind + + + Listing.ascx + + + Listing.ascx + ASPXCodeBehind + + + PostComment.ascx + + + PostComment.ascx + ASPXCodeBehind + + + PostRating.ascx + + + PostRating.ascx + ASPXCodeBehind + + + SWFUploader.ashx + + + UploadImages.ascx + + + UploadImages.ascx + ASPXCodeBehind + + + LatestComments.ascx + + + LatestComments.ascx + ASPXCodeBehind + + + LatestCommentsOptions.ascx + + + LatestCommentsOptions.ascx + ASPXCodeBehind + + + + + ucEditCategory.ascx + + + ucEditCategory.ascx + ASPXCodeBehind + + + ucEditComment.ascx + + + ucEditComment.ascx + ASPXCodeBehind + + + ucImportFeed.ascx + + + ucImportFeed.ascx + ASPXCodeBehind + + + ucImportFeeds.ascx + + + ucImportFeeds.ascx + ASPXCodeBehind + + + ViewTag.ascx + + + ViewTag.ascx + ASPXCodeBehind + + + NewsSearch.ascx + + + NewsSearch.ascx + ASPXCodeBehind + + + NewsSearchOptions.ascx + + + NewsSearchOptions.ascx + ASPXCodeBehind + + + ucEditCustomField.ascx + + + ucEditCustomField.ascx + ASPXCodeBehind + + + ucEditCustomFields.ascx + + + ucEditCustomFields.ascx + ASPXCodeBehind + + + ucEditTag.ascx + + + ucEditTag.ascx + ASPXCodeBehind + + + ucEditTags.ascx + + + ucEditTags.ascx + ASPXCodeBehind + + + ViewSearch.ascx + + + ViewSearch.ascx + ASPXCodeBehind + + + ImageHandler.ashx + + + LatestArticles.ascx + + + LatestArticles.ascx + ASPXCodeBehind + + + LatestArticlesOptions.ascx + + + LatestArticlesOptions.ascx + ASPXCodeBehind + + + + True + Application.myapp + + + True + True + Resources.resx + + + True + Settings.settings + True + + + NewsArchives.ascx + + + NewsArchives.ascx + ASPXCodeBehind + + + NewsArchivesOptions.ascx + + + NewsArchivesOptions.ascx + ASPXCodeBehind + + + NewsArticles.ascx + + + NewsArticles.ascx + ASPXCodeBehind + + + Print.aspx + + + Print.aspx + ASPXCodeBehind + + + + Rss.aspx + + + Rss.aspx + ASPXCodeBehind + + + RssComments.aspx + + + ASPXCodebehind + RssComments.aspx + + + ucAdminOptions.ascx + + + ucAdminOptions.ascx + ASPXCodeBehind + + + ucApproveArticles.ascx + + + ucApproveArticles.ascx + ASPXCodeBehind + + + ucApproveComments.ascx + + + ucApproveComments.ascx + ASPXCodeBehind + + + ViewArchive.ascx + + + ViewArchive.ascx + ASPXCodeBehind + + + ViewArticle.ascx + + + ViewArticle.ascx + ASPXCodeBehind + + + ViewAuthor.ascx + + + ViewAuthor.ascx + ASPXCodeBehind + + + Archives.ascx + + + Archives.ascx + ASPXCodeBehind + + + ViewCategory.ascx + + + ViewCategory.ascx + ASPXCodeBehind + + + ucEditCategories.ascx + + + ucEditCategories.ascx + ASPXCodeBehind + + + ucEditPage.ascx + + + ucEditPage.ascx + ASPXCodeBehind + + + ucEditPages.ascx + + + ucEditPages.ascx + ASPXCodeBehind + + + ucEditPageSortOrder.ascx + + + ucEditPageSortOrder.ascx + ASPXCodeBehind + + + ucEmailTemplates.ascx + + + ucEmailTemplates.ascx + ASPXCodeBehind + + + ucHeader.ascx + + + ucHeader.ascx + ASPXCodeBehind + + + ucMyArticles.ascx + + + ucMyArticles.ascx + ASPXCodeBehind + + + ViewCurrent.ascx + + + ViewCurrent.ascx + ASPXCodeBehind + + + ucNotAuthenticated.ascx + + + ucNotAuthenticated.ascx + ASPXCodeBehind + + + ucNotAuthorized.ascx + + + ucNotAuthorized.ascx + ASPXCodeBehind + + + ucSubmitNews.ascx + + + ucSubmitNews.ascx + ASPXCodeBehind + + + ucSubmitNewsComplete.ascx + + + ucSubmitNewsComplete.ascx + ASPXCodeBehind + + + ucTemplateEditor.ascx + + + ucTemplateEditor.ascx + ASPXCodeBehind + + + ucViewOptions.ascx + + + ucViewOptions.ascx + ASPXCodeBehind + + + True + True + Reference.map + + + + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + Designer + + + PingBackProxy.vb + Designer + + + PingProxy.vb + Designer + + + Designer + + + VbMyResourcesResXFileCodeGenerator + Resources.Designer.vb + My.Resources + Designer + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + MyApplicationCodeGenerator + Application.Designer.vb + + + SettingsSingleFileGenerator + My + Settings.Designer.vb + + + Designer + + + + + + + + + + + + + + MSDiscoCodeGenerator + Reference.vb + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Dynamic + Web References\wsStoryFeed\ + http://localhost/dotnetnuke482test/DesktopModules/Smart-Thinker%2520-%2520UserProfile/StoryFeed.asmx + + + + + MySettings + Ventrian_NewsArticles_wsStoryFeed_StoryFeedWS + + + + + 10.0 + $(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion) + + + + + + + + + + False + True + 55764 + / + http://localhost/DotNetNuke455 + True + http://localhost/DotNetNuke455 + False + False + + + False + + + + + \ No newline at end of file diff --git a/Ventrian.NewsArticles.vbproj.user b/Ventrian.NewsArticles.vbproj.user new file mode 100755 index 0000000..b8e4aa5 --- /dev/null +++ b/Ventrian.NewsArticles.vbproj.user @@ -0,0 +1,28 @@ + + + + + + + + + CurrentPage + True + False + False + False + + + + + + + + + False + True + + + + + \ No newline at end of file diff --git a/ViewArchive.ascx b/ViewArchive.ascx new file mode 100755 index 0000000..844d442 --- /dev/null +++ b/ViewArchive.ascx @@ -0,0 +1,11 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ViewArchive.ascx.vb" Inherits="Ventrian.NewsArticles.ViewArchive" %> +<%@ Register TagPrefix="Ventrian" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="Ventrian" TagName="Listing" Src="Controls\Listing.ascx"%> + +
      +

      + +

      +
      + + diff --git a/ViewArchive.ascx.designer.vb b/ViewArchive.ascx.designer.vb new file mode 100755 index 0000000..9ea7d76 --- /dev/null +++ b/ViewArchive.ascx.designer.vb @@ -0,0 +1,53 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewArchive + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblArchive control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblArchive As Global.System.Web.UI.WebControls.Label + + ''' + '''Listing1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Listing1 As Global.Ventrian.NewsArticles.Controls.Listing + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ViewArchive.ascx.vb b/ViewArchive.ascx.vb new file mode 100755 index 0000000..5bc6660 --- /dev/null +++ b/ViewArchive.ascx.vb @@ -0,0 +1,116 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2008 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewArchive + Inherits NewsArticleModuleBase + +#Region " Constants " + + Private Const PARAM_YEAR As String = "Year" + Private Const PARAM_MONTH As String = "Month" + +#End Region + +#Region " Private Members " + + Private _year As Integer = Null.NullInteger + Private _month As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub BindArchiveName() + + If (_month = Null.NullInteger AndAlso _year = Null.NullInteger) Then + ' No archive to view. + Response.Redirect(NavigateURL(), True) + End If + + If (_year = Null.NullInteger) Then + ' No archive to view. + Response.Redirect(NavigateURL(), True) + End If + + If (_month <> Null.NullInteger) Then + Dim entriesFrom As String = Localization.GetString("MonthYearEntries", LocalResourceFile) + Dim objDate As DateTime = New DateTime(_year, _month, 1) + If (entriesFrom.Contains("{0}") And entriesFrom.Contains("{1}")) Then + lblArchive.Text = String.Format(entriesFrom, objDate.ToString("MMMM"), objDate.ToString("yyyy")) + Else + If (entriesFrom.Contains("{0}")) Then + lblArchive.Text = String.Format(entriesFrom, objDate.ToString("MMMM")) + Else + lblArchive.Text = objDate.ToString("MMMM yyyy") + End If + End If + Me.BasePage.Title = objDate.ToString("MMMM yyyy") & " " & Localization.GetString("Archive", Me.LocalResourceFile) & " | " & Me.BasePage.Title + + Else + Dim entriesFrom As String = Localization.GetString("YearEntries", LocalResourceFile) + If (entriesFrom.Contains("{0}")) Then + lblArchive.Text = String.Format(entriesFrom, _year.ToString()) + Else + lblArchive.Text = _year.ToString() + End If + + Me.BasePage.Title = _year.ToString & " " & Localization.GetString("Archive", Me.LocalResourceFile) & " | " & Me.BasePage.Title + End If + + End Sub + + Private Sub ReadQueryString() + + If (Request(PARAM_YEAR) <> "" AndAlso IsNumeric(Request(PARAM_YEAR))) Then + _year = Convert.ToInt32(Request(PARAM_YEAR)) + End If + + If (Request(PARAM_MONTH) <> "" AndAlso IsNumeric(Request(PARAM_MONTH))) Then + _month = Convert.ToInt32(Request(PARAM_MONTH)) + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + Try + + ReadQueryString() + BindArchiveName() + + Listing1.Month = _month + Listing1.Year = _year + Listing1.ShowExpired = True + Listing1.MaxArticles = Null.NullInteger + Listing1.IsIndexed = False + + Listing1.BindListing() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ViewArticle.ascx b/ViewArticle.ascx new file mode 100755 index 0000000..bee8d82 --- /dev/null +++ b/ViewArticle.ascx @@ -0,0 +1,17 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ViewArticle.ascx.vb" Inherits="Ventrian.NewsArticles.ViewArticle" %> +<%@ Register TagPrefix="Ventrian" TagName="Header" Src="ucHeader.ascx" %> + + + + + + + \ No newline at end of file diff --git a/ViewArticle.ascx.designer.vb b/ViewArticle.ascx.designer.vb new file mode 100755 index 0000000..6107fe5 --- /dev/null +++ b/ViewArticle.ascx.designer.vb @@ -0,0 +1,62 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewArticle + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''litPingback control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litPingback As Global.System.Web.UI.WebControls.Literal + + ''' + '''litRDF control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents litRDF As Global.System.Web.UI.WebControls.Literal + + ''' + '''phArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phArticle As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ViewArticle.ascx.vb b/ViewArticle.ascx.vb new file mode 100755 index 0000000..ebb90ff --- /dev/null +++ b/ViewArticle.ascx.vb @@ -0,0 +1,411 @@ +Imports Ventrian.NewsArticles.Components.Common +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities + +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Security +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports System.Text +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewArticle + Inherits NewsArticleModuleBase + +#Region " Private Members " + + Private _articleID As Integer = Null.NullInteger + Private _pageID As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub BindArticle() + + If (_articleID = Null.NullInteger) Then + Response.Redirect(NavigateURL(), True) + End If + + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + + If (objArticle Is Nothing) Then + ' Article doesn't exist. + Response.Redirect(NavigateURL(), True) + End If + + Dim includeCategory As Boolean = False + If (ArticleSettings.CategoryBreadcrumb And Request("CategoryID") <> "") Then + includeCategory = True + End If + + Dim targetUrl As String = "" + If (_pageID <> Null.NullInteger) Then + Dim objPageController As New PageController() + Dim objPages As ArrayList = objPageController.GetPageList(objArticle.ArticleID) + + Dim pageFound As Boolean = False + For Each objPage As PageInfo In objPages + If (objPage.PageID = _pageID) Then + pageFound = True + End If + Next + If (pageFound = False) Then + ' redirect + Response.Status = "301 Moved Permanently" + Response.AddHeader("Location", Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False)) + Response.End() + End If + + targetUrl = Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False, "PageID=" & _pageID.ToString()) + Else + targetUrl = Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False) + End If + + If (ArticleSettings.UseCanonicalLink) Then + Dim litCanonical As New Literal + litCanonical.Text = "" + Me.BasePage.Header.Controls.Add(litCanonical) + End If + + If (objArticle.ModuleID <> Me.ModuleId) Then + ' Article in the wrong ModuleID + Response.Redirect(NavigateURL(), True) + End If + + ' Check Article Security + If (objArticle.IsSecure) Then + If (ArticleSettings.IsSecureEnabled = False) Then + If (ArticleSettings.SecureUrl <> "") Then + Dim url As String = Request.Url.ToString().Replace(AddHTTP(Request.Url.Host), "") + If (ArticleSettings.SecureUrl.IndexOf("?") <> -1) Then + Response.Redirect((ArticleSettings.SecureUrl & "&returnurl=" & Server.UrlEncode(url)).Replace("[ARTICLEID]", objArticle.ArticleID.ToString()), True) + Else + Response.Redirect((ArticleSettings.SecureUrl & "?returnurl=" & Server.UrlEncode(url)).Replace("[ARTICLEID]", objArticle.ArticleID.ToString()), True) + End If + Else + Response.Redirect(NavigateURL(Me.TabId), True) + End If + End If + End If + + ' Is Article Published? + If (objArticle.Status = StatusType.AwaitingApproval Or objArticle.Status = StatusType.Draft Or (objArticle.StartDate > DateTime.Now And ArticleSettings.ShowPending = False)) Then + If Not (ArticleSettings.IsAdmin() Or ArticleSettings.IsApprover() Or Me.UserId = objArticle.AuthorID) Then + Response.Redirect(NavigateURL(Me.TabId), True) + End If + End If + + If (objArticle.IsSecure) Then + If (ArticleSettings.SecureUrl <> "") Then + If (objArticleController.SecureCheck(PortalId, _articleID, UserId) = False And IsEditable = False And UserInfo.IsSuperUser = False And UserInfo.IsInRole("Administrators") = False) Then + Dim url As String = Request.Url.ToString().Replace(AddHTTP(Request.Url.Host), "") + If (ArticleSettings.SecureUrl.IndexOf("?") <> -1) Then + Response.Redirect((ArticleSettings.SecureUrl & "&returnurl=" & Server.UrlEncode(url)).Replace("[ARTICLEID]", objArticle.ArticleID.ToString()), True) + Else + Response.Redirect((ArticleSettings.SecureUrl & "?returnurl=" & Server.UrlEncode(url)).Replace("[ARTICLEID]", objArticle.ArticleID.ToString()), True) + End If + End If + End If + End If + + ' Permission to view category? + Dim objCategoryController As New CategoryController + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(ModuleId, Null.NullInteger) + + Dim objArticleCategories As ArrayList = objArticleController.GetArticleCategories(objArticle.ArticleID) + For Each objArticleCategory As CategoryInfo In objArticleCategories + For Each objCategory As CategoryInfo In objCategories + If (objCategory.CategoryID = objArticleCategory.CategoryID) Then + If (objCategory.InheritSecurity = False) Then + If (Request.IsAuthenticated) Then + + If (objCategory.CategorySecurityType = CategorySecurityType.Loose) Then + Dim doCheck As Boolean = True + ' Ensure there are no inherit security + For Each objCategoryOther As CategoryInfo In objArticleCategories + For Each objCategoryOther2 As CategoryInfo In objCategories + If (objCategoryOther.CategoryID = objCategoryOther2.CategoryID) Then + If (objCategoryOther2.InheritSecurity) Then + doCheck = False + Exit For + End If + End If + Next + Next + + If (doCheck) Then + If (Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString()) = False) Then + Response.Redirect(NavigateURL(Me.TabId), True) + End If + End If + End If + Else + If (Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (PortalSecurity.IsInRoles(Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString()) = False) Then + Response.Redirect(NavigateURL(Me.TabId), True) + End If + End If + End If + Else + If (objCategory.CategorySecurityType = CategorySecurityType.Loose) Then + Dim doCheck As Boolean = True + ' Ensure there are no inherit security + For Each objCategoryOther As CategoryInfo In objArticleCategories + For Each objCategoryOther2 As CategoryInfo In objCategories + If (objCategoryOther.CategoryID = objCategoryOther2.CategoryID) Then + If (objCategoryOther2.InheritSecurity) Then + doCheck = False + Exit For + End If + End If + Next + Next + + If (doCheck) Then + Response.Redirect(NavigateURL(Me.TabId), True) + End If + Else + Response.Redirect(NavigateURL(Me.TabId), True) + End If + End If + End If + End If + Next + Next + + ' Check module security + Dim objModuleController As New ModuleController + Dim objModule As ModuleInfo = objModuleController.GetModule(objArticle.ModuleID, Me.TabId) + + If Not (objModule Is Nothing) Then + If (DotNetNuke.Security.PortalSecurity.IsInRoles(objModule.AuthorizedViewRoles) = False) Then + Response.Redirect(NavigateURL(Me.TabId), True) + End If + End If + + ' Increment View Count + Dim cookie As HttpCookie = Request.Cookies("Article" & _articleID.ToString()) + If (cookie Is Nothing) Then + + objArticle.NumberOfViews = objArticle.NumberOfViews + 1 + objArticleController.UpdateArticleCount(objArticle.ArticleID, objArticle.NumberOfViews) + + cookie = New HttpCookie("Article" & _articleID.ToString()) + cookie.Value = "1" + cookie.Expires = DateTime.Now.AddMinutes(20) + Context.Response.Cookies.Add(cookie) + + End If + + Dim objLayoutController As New LayoutController(Me) + If (ArticleSettings.CategoryBreadcrumb & Request("CategoryID") <> "") Then + objLayoutController.IncludeCategory = True + End If + + Dim objLayoutItem As LayoutInfo = LayoutController.GetLayout(Me, LayoutType.View_Item_Html) + objLayoutController.ProcessArticleItem(phArticle.Controls, objLayoutItem.Tokens, objArticle) + + If (objArticle.MetaTitle <> "") Then + Me.BasePage.Title = objArticle.MetaTitle + Else + Dim objLayoutTitle As LayoutInfo = LayoutController.GetLayout(Me, LayoutType.View_Title_Html) + If (objLayoutTitle.Template <> "") Then + Dim phPageTitle As New PlaceHolder() + objLayoutController.ProcessArticleItem(phPageTitle.Controls, objLayoutTitle.Tokens, objArticle) + Me.BasePage.Title = RenderControlToString(phPageTitle) + End If + End If + + If (ArticleSettings.UniquePageTitles) Then + If (_pageID <> Null.NullInteger) Then + Me.BasePage.Title = Me.BasePage.Title & " " & _pageID.ToString() + End If + End If + + If (objArticle.MetaDescription <> "") Then + Me.BasePage.Description = objArticle.MetaDescription + Else + Dim objLayoutDescription As LayoutInfo = LayoutController.GetLayout(Me, LayoutType.View_Description_Html) + If (objLayoutDescription.Template <> "") Then + Dim phPageDescription As New PlaceHolder() + objLayoutController.ProcessArticleItem(phPageDescription.Controls, objLayoutDescription.Tokens, objArticle) + Me.BasePage.Description = RenderControlToString(phPageDescription) + End If + End If + + If (objArticle.MetaKeywords <> "") Then + Me.BasePage.KeyWords = objArticle.MetaKeywords + Else + Dim objLayoutKeyword As LayoutInfo = LayoutController.GetLayout(Me, LayoutType.View_Keyword_Html) + If (objLayoutKeyword.Template <> "") Then + Dim phPageKeyword As New PlaceHolder() + objLayoutController.ProcessArticleItem(phPageKeyword.Controls, objLayoutKeyword.Tokens, objArticle) + Me.BasePage.KeyWords = RenderControlToString(phPageKeyword) + End If + End If + + If (objArticle.PageHeadText <> "") Then + Dim litPageHeadText As New Literal() + litPageHeadText.Text = objArticle.PageHeadText + Me.BasePage.Header.Controls.Add(litPageHeadText) + End If + + Dim objLayoutPageHeader As LayoutInfo = LayoutController.GetLayout(Me, LayoutType.View_PageHeader_Html) + If (objLayoutPageHeader.Template <> "") Then + Dim phPageHeaderTitle As New PlaceHolder() + objLayoutController.ProcessArticleItem(phPageHeaderTitle.Controls, objLayoutPageHeader.Tokens, objArticle) + Me.BasePage.Header.Controls.Add(phPageHeaderTitle) + End If + + End Sub + + Private Sub ReadQueryString() + + If (ArticleSettings.UrlModeType = Components.Types.UrlModeType.Shorterned) Then + Try + If (IsNumeric(Request(ArticleSettings.ShortenedID))) Then + _articleID = Convert.ToInt32(Request(ArticleSettings.ShortenedID)) + End If + Catch + End Try + End If + + If (IsNumeric(Request("ArticleID"))) Then + _articleID = Convert.ToInt32(Request("ArticleID")) + End If + + If (IsNumeric(Request("PageID"))) Then + _pageID = Convert.ToInt32(Request("PageID")) + End If + + End Sub + + Private Function RenderControlToString(ByVal ctrl As Control) As String + + Dim sb As New StringBuilder() + Dim tw As New IO.StringWriter(sb) + Dim hw As New HtmlTextWriter(tw) + + ctrl.RenderControl(hw) + + Return sb.ToString() + + End Function + +#End Region + +#Region " Protected Methods " + + Protected Function GetArticleID() As String + + Return _articleID.ToString() + + End Function + + Protected Function GetLocalizedValue(ByVal key As String) As String + + Return Localization.GetString(key, Me.LocalResourceFile) + + End Function + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Initialization(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + Try + ReadQueryString() + BindArticle() + + If (Request("CategoryID") <> "" AndAlso IsNumeric(Request("CategoryID"))) Then + Dim _categoryID As Integer = Convert.ToInt32(Request("CategoryID")) + + Dim objCategoryController As New CategoryController + Dim objCategoriesAll As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(Me.ModuleId, Null.NullInteger, ArticleSettings.CategorySortType) + + For Each objCategory As CategoryInfo In objCategoriesAll + If (objCategory.CategoryID = _categoryID) Then + + If (ArticleSettings.FilterSingleCategory = objCategory.CategoryID) Then + Exit For + End If + + Dim path As String = "" + If (ArticleSettings.CategoryBreadcrumb) Then + Dim objTab As New DotNetNuke.Entities.Tabs.TabInfo + objTab.TabName = objCategory.Name + objTab.Url = Common.GetCategoryLink(TabId, ModuleId, objCategory.CategoryID.ToString(), objCategory.Name, ArticleSettings.LaunchLinks, ArticleSettings) + PortalSettings.ActiveTab.BreadCrumbs.Add(objTab) + + Dim parentID As Integer = objCategory.ParentID + Dim parentCount As Integer = 0 + + While parentID <> Null.NullInteger + For Each objParentCategory As CategoryInfo In objCategoriesAll + If (objParentCategory.CategoryID = parentID) Then + If (ArticleSettings.FilterSingleCategory = objParentCategory.CategoryID) Then + parentID = Null.NullInteger + Exit For + End If + Dim objParentTab As New DotNetNuke.Entities.Tabs.TabInfo + objParentTab.TabID = 10000 + objParentCategory.CategoryID + objParentTab.TabName = objParentCategory.Name + objParentTab.Url = Common.GetCategoryLink(TabId, ModuleId, objParentCategory.CategoryID.ToString(), objParentCategory.Name, ArticleSettings.LaunchLinks, ArticleSettings) + PortalSettings.ActiveTab.BreadCrumbs.Insert(PortalSettings.ActiveTab.BreadCrumbs.Count - 1 - parentCount, objParentTab) + + If (path.Length = 0) Then + path = " > " & objParentCategory.Name + Else + path = " > " & objParentCategory.Name & path + End If + + parentCount = parentCount + 1 + parentID = objParentCategory.ParentID + End If + Next + End While + End If + + If (ArticleSettings.IncludeInPageName) Then + HttpContext.Current.Items.Add("NA1-CategoryName", objCategory.Name) + End If + + Exit For + End If + Next + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub Page_PreRender(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.PreRender + + Try + + LoadStyleSheet() + + If (HttpContext.Current.Items.Contains("NA1-CategoryName")) Then + PortalSettings.ActiveTab.TabName = HttpContext.Current.Items("NA1-CategoryName").ToString() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ViewAuthor.ascx b/ViewAuthor.ascx new file mode 100755 index 0000000..94d6e38 --- /dev/null +++ b/ViewAuthor.ascx @@ -0,0 +1,9 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ViewAuthor.ascx.vb" Inherits="Ventrian.NewsArticles.ViewAuthor" %> +<%@ Register TagPrefix="Ventrian" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="Ventrian" TagName="Listing" Src="Controls/Listing.ascx"%> + +
      +

      +
      + + diff --git a/ViewAuthor.ascx.designer.vb b/ViewAuthor.ascx.designer.vb new file mode 100755 index 0000000..a3ad5d8 --- /dev/null +++ b/ViewAuthor.ascx.designer.vb @@ -0,0 +1,53 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewAuthor + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblAuthor As Global.System.Web.UI.WebControls.Label + + ''' + '''Listing1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Listing1 As Global.Ventrian.NewsArticles.Controls.Listing + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ViewAuthor.ascx.vb b/ViewAuthor.ascx.vb new file mode 100755 index 0000000..74b6824 --- /dev/null +++ b/ViewAuthor.ascx.vb @@ -0,0 +1,126 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewAuthor + Inherits NewsArticleModuleBase + +#Region " Constants " + + Private Const PARAM_AUTHOR_ID As String = "AuthorID" + +#End Region + +#Region " Private Members " + + Private _authorID As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub BindAuthorName() + + If (_authorID = Null.NullInteger) Then + ' Author not specified + Response.Redirect(NavigateURL(), True) + End If + + Dim objUserController As New UserController + Dim objUser As UserInfo = objUserController.GetUser(Me.PortalId, _authorID) + + If (objUser IsNot Nothing) Then + + If (objUser.PortalID <> Me.PortalId) Then + 'Author does not belong to this portal + Response.Redirect(NavigateURL(), True) + End If + + Dim name As String = "" + Select Case ArticleSettings.DisplayMode + Case DisplayType.FirstName + name = objUser.FirstName + Exit Select + + Case DisplayType.FullName + name = objUser.DisplayName + Exit Select + + Case DisplayType.LastName + name = objUser.LastName + Exit Select + + Case DisplayType.UserName + name = objUser.Username + Exit Select + End Select + + Dim entriesFrom As String = Localization.GetString("AuthorEntries", LocalResourceFile) + + If (entriesFrom.Contains("{0}")) Then + lblAuthor.Text = String.Format(entriesFrom, name) + Else + lblAuthor.Text = name + End If + + Me.BasePage.Title = name & " | " & PortalSettings.PortalName + Me.BasePage.Description = lblAuthor.Text + + Else + + ' Author not found. + Response.Redirect(NavigateURL(), True) + + End If + + End Sub + + Private Sub ReadQueryString() + + If (Request(PARAM_AUTHOR_ID) <> "" AndAlso IsNumeric(Request(PARAM_AUTHOR_ID))) Then + _authorID = Convert.ToInt32(Request(PARAM_AUTHOR_ID)) + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + Try + + ReadQueryString() + BindAuthorName() + + Listing1.Author = _authorID + Listing1.ShowExpired = True + Listing1.MaxArticles = Null.NullInteger + Listing1.IsIndexed = False + + Listing1.BindListing() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ViewCategory.ascx b/ViewCategory.ascx new file mode 100755 index 0000000..e89cd07 --- /dev/null +++ b/ViewCategory.ascx @@ -0,0 +1,7 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ViewCategory.ascx.vb" Inherits="Ventrian.NewsArticles.ViewCategory" %> +<%@ Register TagPrefix="Ventrian" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="Ventrian" TagName="Listing" Src="Controls/Listing.ascx"%> + + + + diff --git a/ViewCategory.ascx.designer.vb b/ViewCategory.ascx.designer.vb new file mode 100755 index 0000000..2bd70fe --- /dev/null +++ b/ViewCategory.ascx.designer.vb @@ -0,0 +1,53 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewCategory + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''phCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phCategory As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''Listing1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Listing1 As Global.Ventrian.NewsArticles.Controls.Listing + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ViewCategory.ascx.vb b/ViewCategory.ascx.vb new file mode 100755 index 0000000..cd8a775 --- /dev/null +++ b/ViewCategory.ascx.vb @@ -0,0 +1,1001 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization +Imports DotNetNuke.Security + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewCategory + Inherits NewsArticleModuleBase + +#Region " Constants " + + Private Const PARAM_CATEGORY_ID As String = "CategoryID" + +#End Region + +#Region " Private Members " + + Private _layoutController As LayoutController + Private _objCategoriesAll As List(Of CategoryInfo) + Private _categoryID As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub BindCategory() + + If (_categoryID = Null.NullInteger) Then + ' Category not specified + Return + End If + + Dim objCategoryController As New CategoryController + Dim objCategory As CategoryInfo = objCategoryController.GetCategory(_categoryID, ModuleId) + + If Not (objCategory Is Nothing) Then + + If (objCategory.ModuleID <> Me.ModuleId) Then + ' Category does not belong to this module. + Response.Redirect(NavigateURL(), True) + End If + + ProcessCategory(objCategory, phCategory.Controls) + + Else + + Response.Redirect(NavigateURL(), True) + + End If + + End Sub + + Private Sub ProcessCategoryChild(ByVal objCategory As CategoryInfo, ByRef objPlaceHolder As ControlCollection, ByVal moduleKey As String, ByVal templateArray As String(), ByVal level As Integer) + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(_layoutController.ProcessImages(templateArray(iPtr).ToString()))) + + If iPtr < templateArray.Length - 1 Then + Select Case templateArray(iPtr + 1) + + Case "ARTICLECOUNT" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = objCategory.NumberOfArticles.ToString() + objPlaceHolder.Add(objLiteral) + + Case "CATEGORYID" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = objCategory.CategoryID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "DEPTHABS" + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = objCategoryItem.Level.ToString() + objPlaceHolder.Add(objLiteral) + End If + Next + + Case "DEPTHREL" + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = (objCategoryItem.Level - level).ToString() + objPlaceHolder.Add(objLiteral) + End If + Next + + Case "DESCRIPTION" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = Server.HtmlDecode(objCategory.Description) + objPlaceHolder.Add(objLiteral) + + Case "HASIMAGE" + If (objCategory.Image = "") Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASIMAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASIMAGE" + ' Do Nothing + + Case "HASNOIMAGE" + If (objCategory.Image <> "") Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASNOIMAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOIMAGE" + ' Do Nothing + + Case "IMAGE" + If (objCategory.Image <> "") Then + + If (objCategory.Image.Split("="c).Length = 2) Then + If (IsNumeric(objCategory.Image.Split("="c)(1))) Then + Dim objFileController As New DotNetNuke.Services.FileSystem.FileController() + Dim objFile As DotNetNuke.Services.FileSystem.FileInfo = objFileController.GetFileById(Convert.ToInt32(objCategory.Image.Split("="c)(1)), PortalId) + + If (objFile IsNot Nothing) Then + Dim objImage As New Image + objImage.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objImage.ImageUrl = PortalSettings.HomeDirectory & objFile.Folder & objFile.FileName + objPlaceHolder.Add(objImage) + End If + End If + + End If + + End If + + Case "IMAGELINK" + If (objCategory.Image <> "") Then + + If (objCategory.Image.Split("="c).Length = 2) Then + If (IsNumeric(objCategory.Image.Split("="c)(1))) Then + Dim objFileController As New DotNetNuke.Services.FileSystem.FileController() + Dim objFile As DotNetNuke.Services.FileSystem.FileInfo = objFileController.GetFileById(Convert.ToInt32(objCategory.Image.Split("="c)(1)), PortalId) + + If (objFile IsNot Nothing) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = PortalSettings.HomeDirectory & objFile.Folder & objFile.FileName + objPlaceHolder.Add(objLiteral) + End If + End If + + End If + + End If + + + Case "LINK" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = Common.GetCategoryLink(TabId, ModuleId, objCategory.CategoryID.ToString(), objCategory.Name, ArticleSettings.LaunchLinks, ArticleSettings) + objPlaceHolder.Add(objLiteral) + + Case "METADESCRIPTION" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = objCategory.MetaDescription.ToString() + objPlaceHolder.Add(objLiteral) + + Case "NAME" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = objCategory.Name + objPlaceHolder.Add(objLiteral) + + Case "RSSLINK" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/RSS.aspx?TabID=" & TabId.ToString() & "&ModuleID=" & ModuleId.ToString() & "&CategoryID=" & objCategory.CategoryID.ToString()) + objPlaceHolder.Add(objLiteral) + + Case "ORDER" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = objCategory.SortOrder.ToString() + objPlaceHolder.Add(objLiteral) + + Case "VIEWS" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = objCategory.NumberOfViews.ToString() + objPlaceHolder.Add(objLiteral) + + Case Else + If (templateArray(iPtr + 1).ToUpper().StartsWith("DESCRIPTION:")) Then + + Dim description As String = Server.HtmlDecode(objCategory.Description) + If (IsNumeric(templateArray(iPtr + 1).Substring(12, templateArray(iPtr + 1).Length - 12))) Then + Dim length As Integer = Convert.ToInt32(templateArray(iPtr + 1).Substring(12, templateArray(iPtr + 1).Length - 12)) + If (StripHtml(Server.HtmlDecode(objCategory.Description)).TrimStart().Length > length) Then + description = Left(StripHtml(Server.HtmlDecode(objCategory.Description)).TrimStart(), length) & "..." + Else + description = Left(StripHtml(Server.HtmlDecode(objCategory.Description)).TrimStart(), length) + End If + End If + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID(moduleKey & "-" & iPtr.ToString()) + objLiteral.Text = description + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("IFORDER:")) Then + Dim depth As String = templateArray(iPtr + 1).Substring(8, templateArray(iPtr + 1).Length - 8) + Dim isOrder As Boolean = False + For Each item As String In depth.Split(","c) + If (IsNumeric(item)) Then + If (objCategory.SortOrder = Convert.ToInt32(item)) Then + isOrder = True + End If + End If + Next + + Dim endToken As String = "/" & templateArray(iPtr + 1) + If (isOrder = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("IFNOTORDER:")) Then + Dim depth As String = templateArray(iPtr + 1).Substring(11, templateArray(iPtr + 1).Length - 11) + Dim isOrder As Boolean = False + For Each item As String In depth.Split(","c) + If (IsNumeric(item)) Then + If (objCategory.SortOrder = Convert.ToInt32(item)) Then + isOrder = True + End If + End If + Next + + Dim endToken As String = "/" & templateArray(iPtr + 1) + If (isOrder = True) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + + If (templateArray(iPtr + 1).ToUpper().StartsWith("IMAGETHUMB:")) Then + + If (objCategory.Image <> "") Then + + If (objCategory.Image.Split("="c).Length = 2) Then + If (IsNumeric(objCategory.Image.Split("="c)(1))) Then + Dim objFileController As New DotNetNuke.Services.FileSystem.FileController() + Dim objFile As DotNetNuke.Services.FileSystem.FileInfo = objFileController.GetFileById(Convert.ToInt32(objCategory.Image.Split("="c)(1)), PortalId) + + If (objFile IsNot Nothing) Then + + Dim val As String = templateArray(iPtr + 1).Substring(11, templateArray(iPtr + 1).Length - 11) + If (val.IndexOf(":"c) = -1) Then + Dim length As Integer = Convert.ToInt32(val) + + Dim objImage As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImage.ImageUrl = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory & objFile.Folder) & "&FileName=" & Server.UrlEncode(objFile.FileName) & "&PortalID=" & PortalId.ToString() & "&q=1") + Else + objImage.ImageUrl = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory & objFile.Folder) & "&FileName=" & Server.UrlEncode(objFile.FileName) & "&PortalID=" & PortalId.ToString() & "&q=1&s=1") + End If + objImage.EnableViewState = False + objPlaceHolder.Add(objImage) + + Else + + Dim arr() As String = val.Split(":"c) + + Dim width As Integer = Convert.ToInt32(val.Split(":"c)(0)) + Dim height As Integer = Convert.ToInt32(val.Split(":"c)(1)) + + Dim objImage As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImage.ImageUrl = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory & objFile.Folder) & "&FileName=" & Server.UrlEncode(objFile.FileName) & "&PortalID=" & PortalId.ToString() & "&q=1") + Else + objImage.ImageUrl = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory & objFile.Folder) & "&FileName=" & Server.UrlEncode(objFile.FileName) & "&PortalID=" & PortalId.ToString() & "&q=1&s=1") + End If + objImage.EnableViewState = False + objPlaceHolder.Add(objImage) + + End If + + End If + End If + End If + End If + + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISDEPTHABS:")) Then + Dim depth As String = templateArray(iPtr + 1).Substring(11, templateArray(iPtr + 1).Length - 11) + Dim isDepth As Boolean = False + For Each item As String In depth.Split(","c) + If (IsNumeric(item)) Then + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + If (objCategoryItem.Level = Convert.ToInt32(item)) Then + isDepth = True + End If + End If + Next + End If + Next + + Dim endToken As String = "/" & templateArray(iPtr + 1) + If (isDepth = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISDEPTHREL:")) Then + Dim depth As String = templateArray(iPtr + 1).Substring(11, templateArray(iPtr + 1).Length - 11) + Dim isDepth As Boolean = False + For Each item As String In depth.Split(","c) + If (IsNumeric(item)) Then + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + If ((objCategoryItem.Level - level) = Convert.ToInt32(item)) Then + isDepth = True + End If + End If + Next + End If + Next + + Dim endToken As String = "/" & templateArray(iPtr + 1) + If (isDepth = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISNOTDEPTHABS:")) Then + Dim depth As String = templateArray(iPtr + 1).Substring(14, templateArray(iPtr + 1).Length - 14) + Dim isDepth As Boolean = False + For Each item As String In depth.Split(","c) + If (IsNumeric(item)) Then + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + If (objCategoryItem.Level = Convert.ToInt32(item)) Then + isDepth = True + End If + End If + Next + End If + Next + + Dim endToken As String = "/" & templateArray(iPtr + 1) + If (isDepth = True) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISNOTDEPTHREL:")) Then + Dim depth As String = templateArray(iPtr + 1).Substring(14, templateArray(iPtr + 1).Length - 14) + Dim isDepth As Boolean = False + For Each item As String In depth.Split(","c) + If (IsNumeric(item)) Then + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + If ((objCategoryItem.Level - level) = Convert.ToInt32(item)) Then + isDepth = True + End If + End If + Next + End If + Next + + Dim endToken As String = "/" & templateArray(iPtr + 1) + If (isDepth = True) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + End Select + End If + Next + + End Sub + + Private Sub ProcessCategory(ByVal objCategory As CategoryInfo, ByRef objPlaceHolder As ControlCollection) + + _layoutController = New LayoutController(Me) + Dim layoutCategory As LayoutInfo = LayoutController.GetLayout(Me, LayoutType.Category_Html) + Dim layoutCategoryChild As LayoutInfo = LayoutController.GetLayout(Me, LayoutType.Category_Child_Html) + Dim templateArray As String() = layoutCategory.Tokens + + Dim objCategoryController As New CategoryController + Dim objParentCategory As CategoryInfo = Nothing + + If (objCategory.ParentID <> Null.NullInteger) Then + objParentCategory = objCategoryController.GetCategory(objCategory.ParentID, ModuleId) + End If + + Dim objCategoriesChildren As List(Of CategoryInfo) = objCategoryController.GetCategories(Me.ModuleId, objCategory.CategoryID) + + For iPtr As Integer = 0 To templateArray.Length - 1 Step 2 + + objPlaceHolder.Add(New LiteralControl(_layoutController.ProcessImages(templateArray(iPtr).ToString()))) + + If iPtr < templateArray.Length - 1 Then + Select Case templateArray(iPtr + 1) + + Case "ARTICLECOUNT" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = objCategory.NumberOfArticles.ToString() + objPlaceHolder.Add(objLiteral) + + Case "CATEGORYLABEL" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + Dim entriesFrom As String = Localization.GetString("CategoryEntries", LocalResourceFile) + If (entriesFrom.Contains("{0}")) Then + objLiteral.Text = String.Format(entriesFrom, objCategory.Name) + Else + objLiteral.Text = objCategory.Name + End If + objPlaceHolder.Add(objLiteral) + + Case "CATEGORYID" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = objCategory.CategoryID.ToString() + objPlaceHolder.Add(objLiteral) + + Case "CHILDCATEGORIES" + If (objCategoriesChildren.Count > 0) Then + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + Dim i As Integer = 0 + For Each objCategoryChild As CategoryInfo In objCategoriesChildren + ProcessCategoryChild(objCategoryChild, objPlaceHolder, "ChildCategory-" & i.ToString() & "-" & iPtr.ToString(), layoutCategoryChild.Tokens, objCategoryItem.Level) + i = i + 1 + Next + End If + Next + End If + + Case "DESCRIPTION" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = Server.HtmlDecode(objCategory.Description) + objPlaceHolder.Add(objLiteral) + + Case "HASCHILDCATEGORIES" + If (objCategoriesChildren.Count = 0) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASCHILDCATEGORIES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASCHILDCATEGORIES" + ' Do Nothing + + Case "HASNOCHILDCATEGORIES" + If (objCategoriesChildren.Count > 0) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASNOCHILDCATEGORIES") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOCHILDCATEGORIES" + ' Do Nothing + + Case "HASNOPARENT" + If (objParentCategory IsNot Nothing) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASNOPARENT") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOPARENT" + ' Do Nothing + + Case "HASPARENT" + If (objParentCategory Is Nothing) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASPARENT") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASPARENT" + ' Do Nothing + + Case "HASIMAGE" + If (objCategory.Image = "") Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASIMAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASIMAGE" + ' Do Nothing + + Case "HASNOIMAGE" + If (objCategory.Image <> "") Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = "/HASNOIMAGE") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/HASNOIMAGE" + ' Do Nothing + + Case "IMAGE" + If (objCategory.Image <> "") Then + + If (objCategory.Image.Split("="c).Length = 2) Then + If (IsNumeric(objCategory.Image.Split("="c)(1))) Then + Dim objFileController As New DotNetNuke.Services.FileSystem.FileController() + Dim objFile As DotNetNuke.Services.FileSystem.FileInfo = objFileController.GetFileById(Convert.ToInt32(objCategory.Image.Split("="c)(1)), PortalId) + + If (objFile IsNot Nothing) Then + Dim objImage As New Image + objImage.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objImage.ImageUrl = PortalSettings.HomeDirectory & objFile.Folder & objFile.FileName + objPlaceHolder.Add(objImage) + End If + End If + + End If + + End If + + Case "IMAGELINK" + If (objCategory.Image <> "") Then + + If (objCategory.Image.Split("="c).Length = 2) Then + If (IsNumeric(objCategory.Image.Split("="c)(1))) Then + Dim objFileController As New DotNetNuke.Services.FileSystem.FileController() + Dim objFile As DotNetNuke.Services.FileSystem.FileInfo = objFileController.GetFileById(Convert.ToInt32(objCategory.Image.Split("="c)(1)), PortalId) + + If (objFile IsNot Nothing) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = PortalSettings.HomeDirectory & objFile.Folder & objFile.FileName + objPlaceHolder.Add(objLiteral) + End If + End If + + End If + + End If + + Case "LINK" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = Common.GetCategoryLink(TabId, ModuleId, objCategory.CategoryID.ToString(), objCategory.Name, ArticleSettings.LaunchLinks, ArticleSettings) + objPlaceHolder.Add(objLiteral) + + Case "METADESCRIPTION" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = objCategory.MetaDescription.ToString() + objPlaceHolder.Add(objLiteral) + + Case "NAME" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = objCategory.Name + objPlaceHolder.Add(objLiteral) + + Case "PARENTDESCRIPTION" + If (objParentCategory IsNot Nothing) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = Server.HtmlDecode(objParentCategory.Description) + objPlaceHolder.Add(objLiteral) + End If + + Case "PARENTLINK" + If (objParentCategory IsNot Nothing) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = Common.GetCategoryLink(TabId, ModuleId, objParentCategory.CategoryID.ToString(), objParentCategory.Name, ArticleSettings.LaunchLinks, ArticleSettings) + objPlaceHolder.Add(objLiteral) + End If + + Case "PARENTNAME" + If (objParentCategory IsNot Nothing) Then + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = objParentCategory.Name + objPlaceHolder.Add(objLiteral) + End If + + Case "RSSLINK" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/RSS.aspx?TabID=" & TabId.ToString() & "&ModuleID=" & ModuleId.ToString() & "&CategoryID=" & objCategory.CategoryID.ToString()) + objPlaceHolder.Add(objLiteral) + + Case "VIEWS" + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = objCategory.NumberOfViews.ToString() + objPlaceHolder.Add(objLiteral) + + Case Else + If (templateArray(iPtr + 1).ToUpper().StartsWith("CHILDCATEGORIES:")) Then + Dim count As String = templateArray(iPtr + 1).Substring(16, templateArray(iPtr + 1).Length - 16) + If (IsNumeric(count)) Then + Dim relativeLevel As Integer = Null.NullInteger + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + relativeLevel = objCategoryItem.Level + End If + Next + + Dim level As Integer = Null.NullInteger + Dim i As Integer = 0 + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (level <> Null.NullInteger AndAlso objCategoryItem.Level <= level) Then + Exit For + End If + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + level = objCategoryItem.Level + Else + If (level <> Null.NullInteger) Then + If (objCategoryItem.Level > level And ((objCategoryItem.Level - relativeLevel) <= Convert.ToInt32(count))) Then + ProcessCategoryChild(objCategoryItem, objPlaceHolder, "ChildCategory" & i.ToString() & "-" & iPtr.ToString(), layoutCategoryChild.Tokens(), relativeLevel) + i = i + 1 + End If + End If + End If + Next + End If + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("DESCRIPTION:")) Then + + Dim description As String = Server.HtmlDecode(objCategory.Description) + If (IsNumeric(templateArray(iPtr + 1).Substring(12, templateArray(iPtr + 1).Length - 12))) Then + Dim length As Integer = Convert.ToInt32(templateArray(iPtr + 1).Substring(12, templateArray(iPtr + 1).Length - 12)) + If (StripHtml(Server.HtmlDecode(objCategory.Description)).TrimStart().Length > length) Then + description = Left(StripHtml(Server.HtmlDecode(objCategory.Description)).TrimStart(), length) & "..." + Else + description = Left(StripHtml(Server.HtmlDecode(objCategory.Description)).TrimStart(), length) + End If + End If + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = description + objPlaceHolder.Add(objLiteral) + Exit Select + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISDEPTHABS:")) Then + Dim depth As String = templateArray(iPtr + 1).Substring(11, templateArray(iPtr + 1).Length - 11) + Dim isDepth As Boolean = False + For Each item As String In depth.Split(","c) + If (IsNumeric(item)) Then + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + If (objCategoryItem.Level = Convert.ToInt32(item)) Then + isDepth = True + End If + End If + Next + End If + Next + + Dim endToken As String = "/" & templateArray(iPtr + 1) + If (isDepth = False) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("ISNOTDEPTHABS:")) Then + Dim depth As String = templateArray(iPtr + 1).Substring(14, templateArray(iPtr + 1).Length - 14) + Dim isDepth As Boolean = False + For Each item As String In depth.Split(","c) + If (IsNumeric(item)) Then + For Each objCategoryItem As CategoryInfo In _objCategoriesAll + If (objCategoryItem.CategoryID = objCategory.CategoryID) Then + If (objCategoryItem.Level = Convert.ToInt32(item)) Then + isDepth = True + End If + End If + Next + End If + Next + + Dim endToken As String = "/" & templateArray(iPtr + 1) + If (isDepth = True) Then + While (iPtr < templateArray.Length - 1) + If (templateArray(iPtr + 1) = endToken) Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("IMAGETHUMB:")) Then + + If (objCategory.Image <> "") Then + + If (objCategory.Image.Split("="c).Length = 2) Then + If (IsNumeric(objCategory.Image.Split("="c)(1))) Then + Dim objFileController As New DotNetNuke.Services.FileSystem.FileController() + Dim objFile As DotNetNuke.Services.FileSystem.FileInfo = objFileController.GetFileById(Convert.ToInt32(objCategory.Image.Split("="c)(1)), PortalId) + + If (objFile IsNot Nothing) Then + + Dim val As String = templateArray(iPtr + 1).Substring(11, templateArray(iPtr + 1).Length - 11) + If (val.IndexOf(":"c) = -1) Then + Dim length As Integer = Convert.ToInt32(val) + + Dim objImage As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImage.ImageUrl = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory & objFile.Folder) & "&FileName=" & Server.UrlEncode(objFile.FileName) & "&PortalID=" & PortalId.ToString() & "&q=1") + Else + objImage.ImageUrl = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & length.ToString() & "&Height=" & length.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory & objFile.Folder) & "&FileName=" & Server.UrlEncode(objFile.FileName) & "&PortalID=" & PortalId.ToString() & "&q=1&s=1") + End If + objImage.EnableViewState = False + objPlaceHolder.Add(objImage) + + Else + + Dim arr() As String = val.Split(":"c) + + Dim width As Integer = Convert.ToInt32(val.Split(":"c)(0)) + Dim height As Integer = Convert.ToInt32(val.Split(":"c)(1)) + + Dim objImage As New Image + If (ArticleSettings.ImageThumbnailType = ThumbnailType.Proportion) Then + objImage.ImageUrl = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory & objFile.Folder) & "&FileName=" & Server.UrlEncode(objFile.FileName) & "&PortalID=" & PortalId.ToString() & "&q=1") + Else + objImage.ImageUrl = Page.ResolveUrl("~/DesktopModules/DnnForge - NewsArticles/ImageHandler.ashx?Width=" & width.ToString() & "&Height=" & height.ToString() & "&HomeDirectory=" & Server.UrlEncode(PortalSettings.HomeDirectory & objFile.Folder) & "&FileName=" & Server.UrlEncode(objFile.FileName) & "&PortalID=" & PortalId.ToString() & "&q=1&s=1") + End If + objImage.EnableViewState = False + objPlaceHolder.Add(objImage) + + End If + + End If + End If + End If + End If + + End If + + If (templateArray(iPtr + 1).ToUpper().StartsWith("PARENTDESCRIPTION:")) Then + + If (objParentCategory IsNot Nothing) Then + Dim description As String = Server.HtmlDecode(objParentCategory.Description) + If (IsNumeric(templateArray(iPtr + 1).Substring(18, templateArray(iPtr + 1).Length - 18))) Then + Dim length As Integer = Convert.ToInt32(templateArray(iPtr + 1).Substring(18, templateArray(iPtr + 1).Length - 18)) + If (StripHtml(Server.HtmlDecode(objParentCategory.Description)).TrimStart().Length > length) Then + description = Left(StripHtml(Server.HtmlDecode(objParentCategory.Description)).TrimStart(), length) & "..." + Else + description = Left(StripHtml(Server.HtmlDecode(objParentCategory.Description)).TrimStart(), length) + End If + End If + + Dim objLiteral As New Literal + objLiteral.ID = Globals.CreateValidID("Category-" & iPtr.ToString()) + objLiteral.Text = description + objPlaceHolder.Add(objLiteral) + Exit Select + End If + End If + + End Select + End If + + Next + + End Sub + + Private Sub ReadQueryString() + + If (Request(PARAM_CATEGORY_ID) <> "" AndAlso IsNumeric(Request(PARAM_CATEGORY_ID))) Then + _categoryID = Convert.ToInt32(Request(PARAM_CATEGORY_ID)) + Else + If (ArticleSettings.FilterSingleCategory <> Null.NullInteger) Then + _categoryID = ArticleSettings.FilterSingleCategory + End If + End If + + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + Try + + ReadQueryString() + + Dim objCategoryController As New CategoryController + _objCategoriesAll = objCategoryController.GetCategoriesAll(Me.ModuleId, Null.NullInteger, ArticleSettings.CategorySortType) + + If (Request("articleType") <> "" AndAlso Request("articleType").ToLower() = "categoryview") Then + + For Each objCategory As CategoryInfo In _objCategoriesAll + If (objCategory.CategoryID = _categoryID) Then + + If (ArticleSettings.FilterSingleCategory = objCategory.CategoryID) Then + Exit For + End If + + Dim path As String = "" + If (ArticleSettings.CategoryBreadcrumb) Then + Dim objTab As New DotNetNuke.Entities.Tabs.TabInfo + objTab.TabName = objCategory.Name + objTab.Url = Common.GetCategoryLink(TabId, ModuleId, objCategory.CategoryID.ToString(), objCategory.Name, ArticleSettings.LaunchLinks, ArticleSettings) + PortalSettings.ActiveTab.BreadCrumbs.Add(objTab) + + Dim parentID As Integer = objCategory.ParentID + Dim parentCount As Integer = 0 + + While parentID <> Null.NullInteger + For Each objParentCategory As CategoryInfo In _objCategoriesAll + If (objParentCategory.CategoryID = parentID) Then + If (ArticleSettings.FilterSingleCategory = objParentCategory.CategoryID) Then + parentID = Null.NullInteger + Exit For + End If + Dim objParentTab As New DotNetNuke.Entities.Tabs.TabInfo + objParentTab.TabID = 10000 + objParentCategory.CategoryID + objParentTab.TabName = objParentCategory.Name + objParentTab.Url = Common.GetCategoryLink(TabId, ModuleId, objParentCategory.CategoryID.ToString(), objParentCategory.Name, ArticleSettings.LaunchLinks, ArticleSettings) + PortalSettings.ActiveTab.BreadCrumbs.Insert(PortalSettings.ActiveTab.BreadCrumbs.Count - 1 - parentCount, objParentTab) + + If (path.Length = 0) Then + path = " > " & objParentCategory.Name + Else + path = " > " & objParentCategory.Name & path + End If + + parentCount = parentCount + 1 + parentID = objParentCategory.ParentID + End If + Next + End While + End If + + If (Request("articleType") <> "" AndAlso Request("articleType").ToLower() = "categoryview") Then + If (PortalSettings.ActiveTab.Title.Length = 0) Then + Me.BasePage.Title = Server.HtmlEncode(PortalSettings.PortalName & " > " & PortalSettings.ActiveTab.TabName & path & " > " & objCategory.Name) + Else + Me.BasePage.Title = Server.HtmlEncode(PortalSettings.ActiveTab.Title & path & " > " & objCategory.Name) + End If + + If (objCategory.MetaTitle <> "") Then + Me.BasePage.Title = objCategory.MetaTitle + End If + If (objCategory.MetaDescription <> "") Then + Me.BasePage.Description = objCategory.MetaDescription + End If + If (objCategory.MetaKeywords <> "") Then + Me.BasePage.KeyWords = objCategory.MetaKeywords + End If + + End If + + If (ArticleSettings.IncludeInPageName) Then + HttpContext.Current.Items.Add("NA-CategoryName", objCategory.Name) + End If + + Exit For + End If + Next + + End If + + BindCategory() + + Dim categories() As Integer = {_categoryID} + Listing1.FilterCategories = categories + If (ArticleSettings.FilterSingleCategory <> Null.NullInteger) Then + Listing1.ShowExpired = False + Else + Listing1.ShowExpired = True + End If + Listing1.MaxArticles = Null.NullInteger + Listing1.ShowMessage = False + + If (ArticleSettings.CategoryBreadcrumb AndAlso Request("CategoryID") <> "") Then + Listing1.IncludeCategory = True + End If + + Listing1.BindListing() + Listing1.BindArticles = False + Listing1.IsIndexed = False + + 'Listing1.BindListing() + + 'ucHeader1.ProcessMenu() + 'ucHeader2.ProcessMenu() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + End Sub + + Private Sub Page_PreRender(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.PreRender + + Try + + If (HttpContext.Current.Items.Contains("NA-CategoryName")) Then + PortalSettings.ActiveTab.TabName = HttpContext.Current.Items("NA-CategoryName").ToString() + End If + + Catch ex As Exception + + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ViewCurrent.ascx b/ViewCurrent.ascx new file mode 100755 index 0000000..c92a9ac --- /dev/null +++ b/ViewCurrent.ascx @@ -0,0 +1,6 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ViewCurrent.ascx.vb" Inherits="Ventrian.NewsArticles.ViewCurrent" %> +<%@ Register TagPrefix="Ventrian" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="Ventrian" TagName="Listing" Src="Controls/Listing.ascx"%> + + + \ No newline at end of file diff --git a/ViewCurrent.ascx.designer.vb b/ViewCurrent.ascx.designer.vb new file mode 100755 index 0000000..774e520 --- /dev/null +++ b/ViewCurrent.ascx.designer.vb @@ -0,0 +1,44 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewCurrent + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''ucListing1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucListing1 As Global.Ventrian.NewsArticles.Controls.Listing + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ViewCurrent.ascx.vb b/ViewCurrent.ascx.vb new file mode 100755 index 0000000..c773300 --- /dev/null +++ b/ViewCurrent.ascx.vb @@ -0,0 +1,18 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2008 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Services.Exceptions + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewCurrent + Inherits NewsArticleModuleBase + + End Class + +End Namespace \ No newline at end of file diff --git a/ViewSearch.ascx b/ViewSearch.ascx new file mode 100755 index 0000000..0b9c050 --- /dev/null +++ b/ViewSearch.ascx @@ -0,0 +1,13 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ViewSearch.ascx.vb" Inherits="Ventrian.NewsArticles.ViewSearch" %> +<%@ Register TagPrefix="Ventrian" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="Ventrian" TagName="Listing" Src="Controls/Listing.ascx"%> + +
      +

      + + + + +
      + + diff --git a/ViewSearch.ascx.designer.vb b/ViewSearch.ascx.designer.vb new file mode 100755 index 0000000..e85a6b2 --- /dev/null +++ b/ViewSearch.ascx.designer.vb @@ -0,0 +1,80 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewSearch + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblSearch control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSearch As Global.System.Web.UI.WebControls.Label + + ''' + '''pnlSearch control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSearch As Global.System.Web.UI.WebControls.Panel + + ''' + '''txtSearch control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtSearch As Global.System.Web.UI.WebControls.TextBox + + ''' + '''btnSearch control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents btnSearch As Global.System.Web.UI.WebControls.Button + + ''' + '''Listing1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Listing1 As Global.Ventrian.NewsArticles.Controls.Listing + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ViewSearch.ascx.vb b/ViewSearch.ascx.vb new file mode 100755 index 0000000..25199be --- /dev/null +++ b/ViewSearch.ascx.vb @@ -0,0 +1,135 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization +Imports DotNetNuke.Security + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewSearch + Inherits NewsArticleModuleBase + +#Region " Constants " + + Private Const PARAM_SEARCH_ID As String = "Search" + +#End Region + +#Region " Private Members " + + Private _searchText As String = Null.NullString + +#End Region + +#Region " Private Methods " + + Private Sub BindSearch() + + Me.BasePage.Title = "Search | " & Me.BasePage.Title + + If (_searchText = "") Then + lblSearch.Text = Localization.GetString("SearchArticles", Me.LocalResourceFile) + Listing1.BindArticles = False + Return + Else + Dim articlesFor As String = Localization.GetString("ArticlesFor", Me.LocalResourceFile) + If (articlesFor.Contains("{0}")) Then + lblSearch.Text = String.Format(articlesFor, _searchText) + Else + lblSearch.Text = articlesFor + End If + txtSearch.Text = _searchText + Listing1.SearchText = _searchText + Listing1.BindArticles = True + Listing1.BindListing() + Listing1.BindArticles = False + Return + End If + + End Sub + + Private Sub ReadQueryString() + + If (Request(PARAM_SEARCH_ID) <> "") Then + _searchText = Server.UrlDecode(Request(PARAM_SEARCH_ID)) + Dim objSecurity As New PortalSecurity + _searchText = objSecurity.InputFilter(_searchText, PortalSecurity.FilterFlag.NoScripting) + _searchText = StripTags(_searchText) + End If + + End Sub + + Function StripTags(ByVal html As String) As String + ' Remove HTML tags. + Return Regex.Replace(html, "<.*?>", "") + End Function + + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + Try + + Dim enumerator As IDictionaryEnumerator = HttpContext.Current.Cache.GetEnumerator() + Dim itemsToRemove As New List(Of String)() + + While enumerator.MoveNext() + If enumerator.Key.ToString().ToLower().Contains("ventrian-newsarticles-categories-" & ModuleId.ToString()) Then + itemsToRemove.Add(enumerator.Key.ToString()) + End If + End While + + For Each itemToRemove As String In itemsToRemove + DataCache.RemoveCache(itemToRemove.Replace("DNN_", "")) + Next + + enumerator = HttpContext.Current.Cache.GetEnumerator() + While enumerator.MoveNext() + If enumerator.Key.ToString().ToLower().Contains("ventrian-newsarticles-categories-" & ModuleId.ToString()) Then + Response.Write(enumerator.Key.ToString() & "
      ") + End If + End While + ReadQueryString() + Listing1.ShowExpired = True + Listing1.MaxArticles = Null.NullInteger + Listing1.IsIndexed = False + + BindSearch() + Page.SetFocus(txtSearch) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub btnSearch_Click(ByVal sender As Object, ByVal e As EventArgs) Handles btnSearch.Click + + Try + + If (txtSearch.Text.Trim() <> "") Then + Dim objSecurity As New PortalSecurity + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "Search", ArticleSettings, "Search=" & Server.UrlEncode(objSecurity.InputFilter(txtSearch.Text, PortalSecurity.FilterFlag.NoScripting))), True) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ViewTag.ascx b/ViewTag.ascx new file mode 100755 index 0000000..1eed063 --- /dev/null +++ b/ViewTag.ascx @@ -0,0 +1,9 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ViewTag.ascx.vb" Inherits="Ventrian.NewsArticles.ViewTag" %> +<%@ Register TagPrefix="Ventrian" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="Ventrian" TagName="Listing" Src="Controls/Listing.ascx"%> + +
      +

      +
      + + diff --git a/ViewTag.ascx.designer.vb b/ViewTag.ascx.designer.vb new file mode 100755 index 0000000..467fc9e --- /dev/null +++ b/ViewTag.ascx.designer.vb @@ -0,0 +1,53 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewTag + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblTag control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTag As Global.System.Web.UI.WebControls.Label + + ''' + '''Listing1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Listing1 As Global.Ventrian.NewsArticles.Controls.Listing + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ViewTag.ascx.vb b/ViewTag.ascx.vb new file mode 100755 index 0000000..89b1bb3 --- /dev/null +++ b/ViewTag.ascx.vb @@ -0,0 +1,104 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ViewTag + Inherits NewsArticleModuleBase + +#Region " Constants " + + Private Const PARAM_TAG As String = "Tag" + +#End Region + +#Region " Private Members " + + Private _tag As String = Null.NullString + +#End Region + +#Region " Private Methods " + + Private Sub BindTag() + + If (_tag = Null.NullString) Then + ' Author not specified + Response.Redirect(NavigateURL(), True) + End If + + Dim objTagController As New TagController + Dim objTag As TagInfo = objTagController.Get(Me.ModuleId, _tag.ToLower()) + + If (objTag IsNot Nothing) Then + + Dim entriesFrom As String = Localization.GetString("TagEntries", LocalResourceFile) + + If (entriesFrom.Contains("{0}")) Then + lblTag.Text = String.Format(entriesFrom, _tag) + Else + lblTag.Text = _tag + End If + + Me.BasePage.Title = _tag & " | " & PortalSettings.PortalName + Me.BasePage.Description = entriesFrom + + ' We never want to index the tag pages. + + + Else + + ' Author not found. + Response.Redirect(NavigateURL(), True) + + End If + + End Sub + + Private Sub ReadQueryString() + + If (Request(PARAM_TAG) <> "") Then + _tag = Server.UrlDecode(Request(PARAM_TAG)) + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + Try + + ReadQueryString() + BindTag() + + Listing1.Tag = _tag + Listing1.ShowExpired = True + Listing1.MaxArticles = Null.NullInteger + Listing1.IsIndexed = False + + Listing1.BindListing() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/Web References/wsStoryFeed/Reference.map b/Web References/wsStoryFeed/Reference.map new file mode 100755 index 0000000..6ed1313 --- /dev/null +++ b/Web References/wsStoryFeed/Reference.map @@ -0,0 +1,7 @@ + + + + + + + \ No newline at end of file diff --git a/Web References/wsStoryFeed/Reference.vb b/Web References/wsStoryFeed/Reference.vb new file mode 100755 index 0000000..4ad4606 --- /dev/null +++ b/Web References/wsStoryFeed/Reference.vb @@ -0,0 +1,208 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' Runtime Version:4.0.30319.17929 +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict Off +Option Explicit On + +Imports System +Imports System.ComponentModel +Imports System.Diagnostics +Imports System.Web.Services +Imports System.Web.Services.Protocols +Imports System.Xml.Serialization + +' +'This source code was auto-generated by Microsoft.VSDesigner, Version 4.0.30319.17929. +' +Namespace wsStoryFeed + + ''' + _ + Partial Public Class StoryFeedWS + Inherits System.Web.Services.Protocols.SoapHttpClientProtocol + + Private AddActionOperationCompleted As System.Threading.SendOrPostCallback + + Private AddActionIfNotExistsOperationCompleted As System.Threading.SendOrPostCallback + + Private useDefaultCredentialsSetExplicitly As Boolean + + ''' + Public Sub New() + MyBase.New + Me.Url = Global.My.MySettings.Default.Ventrian_NewsArticles_wsStoryFeed_StoryFeedWS + If (Me.IsLocalFileSystemWebService(Me.Url) = true) Then + Me.UseDefaultCredentials = true + Me.useDefaultCredentialsSetExplicitly = false + Else + Me.useDefaultCredentialsSetExplicitly = true + End If + End Sub + + Public Shadows Property Url() As String + Get + Return MyBase.Url + End Get + Set + If (((Me.IsLocalFileSystemWebService(MyBase.Url) = true) _ + AndAlso (Me.useDefaultCredentialsSetExplicitly = false)) _ + AndAlso (Me.IsLocalFileSystemWebService(value) = false)) Then + MyBase.UseDefaultCredentials = false + End If + MyBase.Url = value + End Set + End Property + + Public Shadows Property UseDefaultCredentials() As Boolean + Get + Return MyBase.UseDefaultCredentials + End Get + Set + MyBase.UseDefaultCredentials = value + Me.useDefaultCredentialsSetExplicitly = true + End Set + End Property + + ''' + Public Event AddActionCompleted As AddActionCompletedEventHandler + + ''' + Public Event AddActionIfNotExistsCompleted As AddActionIfNotExistsCompletedEventHandler + + ''' + _ + Public Function AddAction(ByVal actionType As Integer, ByVal relatedID As Integer, ByVal actionText As String, ByVal createdByUserID As Integer, ByVal key As String) As Integer + Dim results() As Object = Me.Invoke("AddAction", New Object() {actionType, relatedID, actionText, createdByUserID, key}) + Return CType(results(0),Integer) + End Function + + ''' + Public Overloads Sub AddActionAsync(ByVal actionType As Integer, ByVal relatedID As Integer, ByVal actionText As String, ByVal createdByUserID As Integer, ByVal key As String) + Me.AddActionAsync(actionType, relatedID, actionText, createdByUserID, key, Nothing) + End Sub + + ''' + Public Overloads Sub AddActionAsync(ByVal actionType As Integer, ByVal relatedID As Integer, ByVal actionText As String, ByVal createdByUserID As Integer, ByVal key As String, ByVal userState As Object) + If (Me.AddActionOperationCompleted Is Nothing) Then + Me.AddActionOperationCompleted = AddressOf Me.OnAddActionOperationCompleted + End If + Me.InvokeAsync("AddAction", New Object() {actionType, relatedID, actionText, createdByUserID, key}, Me.AddActionOperationCompleted, userState) + End Sub + + Private Sub OnAddActionOperationCompleted(ByVal arg As Object) + If (Not (Me.AddActionCompletedEvent) Is Nothing) Then + Dim invokeArgs As System.Web.Services.Protocols.InvokeCompletedEventArgs = CType(arg,System.Web.Services.Protocols.InvokeCompletedEventArgs) + RaiseEvent AddActionCompleted(Me, New AddActionCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)) + End If + End Sub + + ''' + _ + Public Function AddActionIfNotExists(ByVal actionType As Integer, ByVal relatedID As Integer, ByVal actionText As String, ByVal createdByUserID As Integer, ByVal addIfNotExistsOnly As Boolean, ByVal key As String) As Integer + Dim results() As Object = Me.Invoke("AddActionIfNotExists", New Object() {actionType, relatedID, actionText, createdByUserID, addIfNotExistsOnly, key}) + Return CType(results(0),Integer) + End Function + + ''' + Public Overloads Sub AddActionIfNotExistsAsync(ByVal actionType As Integer, ByVal relatedID As Integer, ByVal actionText As String, ByVal createdByUserID As Integer, ByVal addIfNotExistsOnly As Boolean, ByVal key As String) + Me.AddActionIfNotExistsAsync(actionType, relatedID, actionText, createdByUserID, addIfNotExistsOnly, key, Nothing) + End Sub + + ''' + Public Overloads Sub AddActionIfNotExistsAsync(ByVal actionType As Integer, ByVal relatedID As Integer, ByVal actionText As String, ByVal createdByUserID As Integer, ByVal addIfNotExistsOnly As Boolean, ByVal key As String, ByVal userState As Object) + If (Me.AddActionIfNotExistsOperationCompleted Is Nothing) Then + Me.AddActionIfNotExistsOperationCompleted = AddressOf Me.OnAddActionIfNotExistsOperationCompleted + End If + Me.InvokeAsync("AddActionIfNotExists", New Object() {actionType, relatedID, actionText, createdByUserID, addIfNotExistsOnly, key}, Me.AddActionIfNotExistsOperationCompleted, userState) + End Sub + + Private Sub OnAddActionIfNotExistsOperationCompleted(ByVal arg As Object) + If (Not (Me.AddActionIfNotExistsCompletedEvent) Is Nothing) Then + Dim invokeArgs As System.Web.Services.Protocols.InvokeCompletedEventArgs = CType(arg,System.Web.Services.Protocols.InvokeCompletedEventArgs) + RaiseEvent AddActionIfNotExistsCompleted(Me, New AddActionIfNotExistsCompletedEventArgs(invokeArgs.Results, invokeArgs.Error, invokeArgs.Cancelled, invokeArgs.UserState)) + End If + End Sub + + ''' + Public Shadows Sub CancelAsync(ByVal userState As Object) + MyBase.CancelAsync(userState) + End Sub + + Private Function IsLocalFileSystemWebService(ByVal url As String) As Boolean + If ((url Is Nothing) _ + OrElse (url Is String.Empty)) Then + Return false + End If + Dim wsUri As System.Uri = New System.Uri(url) + If ((wsUri.Port >= 1024) _ + AndAlso (String.Compare(wsUri.Host, "localHost", System.StringComparison.OrdinalIgnoreCase) = 0)) Then + Return true + End If + Return false + End Function + End Class + + ''' + _ + Public Delegate Sub AddActionCompletedEventHandler(ByVal sender As Object, ByVal e As AddActionCompletedEventArgs) + + ''' + _ + Partial Public Class AddActionCompletedEventArgs + Inherits System.ComponentModel.AsyncCompletedEventArgs + + Private results() As Object + + Friend Sub New(ByVal results() As Object, ByVal exception As System.Exception, ByVal cancelled As Boolean, ByVal userState As Object) + MyBase.New(exception, cancelled, userState) + Me.results = results + End Sub + + ''' + Public ReadOnly Property Result() As Integer + Get + Me.RaiseExceptionIfNecessary + Return CType(Me.results(0),Integer) + End Get + End Property + End Class + + ''' + _ + Public Delegate Sub AddActionIfNotExistsCompletedEventHandler(ByVal sender As Object, ByVal e As AddActionIfNotExistsCompletedEventArgs) + + ''' + _ + Partial Public Class AddActionIfNotExistsCompletedEventArgs + Inherits System.ComponentModel.AsyncCompletedEventArgs + + Private results() As Object + + Friend Sub New(ByVal results() As Object, ByVal exception As System.Exception, ByVal cancelled As Boolean, ByVal userState As Object) + MyBase.New(exception, cancelled, userState) + Me.results = results + End Sub + + ''' + Public ReadOnly Property Result() As Integer + Get + Me.RaiseExceptionIfNecessary + Return CType(Me.results(0),Integer) + End Get + End Property + End Class +End Namespace diff --git a/Web References/wsStoryFeed/StoryFeed.disco b/Web References/wsStoryFeed/StoryFeed.disco new file mode 100755 index 0000000..eed1961 --- /dev/null +++ b/Web References/wsStoryFeed/StoryFeed.disco @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/Web References/wsStoryFeed/StoryFeed.wsdl b/Web References/wsStoryFeed/StoryFeed.wsdl new file mode 100755 index 0000000..b696fcc --- /dev/null +++ b/Web References/wsStoryFeed/StoryFeed.wsdl @@ -0,0 +1,120 @@ + + + Smart-Thinker UserProfile StoryFeed + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Adds a Story to the Story Feed + + + + + Adds a Story to the Story Feed only if the RelatedID, CreatedID and ActionText do not already exist) + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Smart-Thinker UserProfile StoryFeed + + + + + + + + \ No newline at end of file diff --git a/icon_comment.gif b/icon_comment.gif new file mode 100755 index 0000000000000000000000000000000000000000..50ea05e7e03dc0320a8c95a249b1c0b3692d61c5 GIT binary patch literal 148 zcmZ?wbhEHb6krfw*v!E2|NsB{{|>!;`SR0;CAV(fI&<&)!>GyDBa1Oj_DZ zhWdI2h8h1DnHa!8@h1zb2m>#J4u}UbgMr0S;DqPuz0;SRm9!2MiZ~dqdU(;g2G51l ytvfI6+VUWp_ke=;EEXm8pNyO=&P)MT0tP}yFI7woT76whkV~gPyUCM-lBS^j_f@V`j(!Sbf>FCRROWBHQ8`u60;56P^* zzP!Ibujv2k;_nYGTqrVrzIWmO#~0^2GXH;e^=XUq|5lU#w+@~QWjUL!{QvF4=bIhHE>a}+pdsF%dZ5LD=| z#BIoD$fL)R)+MjaoZe*E(iZKfn$D=lZj>fa!mKi_xiu;<$&gLPH;q*xU1G(IRRQgO zEX>S3QX36fl}q%t&s^=V*~_0Uvgj}qhaSUrHfe2bE&ts{vGdtA*2!*S^4s2EsK(`Y r&xrl1FO#00(U<3bUyZoF{`+ZkFICdR^-y;+hp<-6iGqin3Jlf&%kitR literal 0 HcmV?d00001 diff --git a/module.css b/module.css new file mode 100755 index 0000000..dfbf47c --- /dev/null +++ b/module.css @@ -0,0 +1,108 @@ +/* Uploader Styles */ + +.pa_photolist li +{ + display: inline; + float: left; + margin-left: 10px; + margin-bottom: 10px; +} + +.progressWrapper +{ + width: 357px; + overflow: hidden; + background-color: #000; +} + +.progressContainer { + margin: 1px; + padding: 4px; + + border: solid 1px #E8E8E8; + background-color: #F7F7F7; + + overflow: hidden; +} + +.progressBarInProgress, +.progressBarComplete, +.progressBarError { + font-size: 0px; + width: 0%; + height: 2px; + background-color: blue; + text-align: left; + margin-top: 2px; + float: left; +} +.progressBarComplete { + width: 100%; + background-color: green; + visibility: hidden; +} +.progressBarError { + width: 100%; + background-color: red; + visibility: hidden; +} +.progressBarStatus { + margin-top: 2px; + text-align: left; + white-space: nowrap; +} +a.progressCancel, +a.progressCancel:link, +a.progressCancel:active, +a.progressCancel:visited, +a.progressCancel:hover +{ + font-size: 0px; + display: block; + height: 14px; + width: 14px; + + background-image: url(Images/Uploader/cancelbutton.gif); + background-repeat: no-repeat; + background-position: -14px 0px; + float: right; +} +a.progressCancel:hover +{ + background-position: 0px 0px; +} + +#ColorPickerDiv +{ + display: block; + display: none; + position: relative; + border: 1px solid #777; + background: #fff +} + +#ColorPickerDiv TD.color +{ + cursor: pointer; + font-size: xx-small; + font-family: 'Arial' , 'Microsoft Sans Serif'; +} +#ColorPickerDiv TD.color label +{ + cursor: pointer; +} + +.ColorPickerDivSample +{ + margin: 0px 0px 0px 4px; + border: solid 1px #000; + padding: 0px 10px; + position: relative; + cursor: pointer; +} + + +#tabs-myarticles +{ + padding-top: 10px; +} \ No newline at end of file diff --git a/ucAdminOptions.ascx b/ucAdminOptions.ascx new file mode 100755 index 0000000..e0c54ff --- /dev/null +++ b/ucAdminOptions.ascx @@ -0,0 +1,92 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucAdminOptions.ascx.vb" Inherits="Ventrian.NewsArticles.ucAdminOptions" %> +<%@ Register TagPrefix="Ventrian" TagName="Header" Src="ucHeader.ascx" %> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + + + +
      + +
      + + + +
      + +
      + + + +
      + +
      + + + +
      + +
      + + + +
      + +
      + + + +
      + +
      + + + +
      + +
      + + + diff --git a/ucAdminOptions.ascx.designer.vb b/ucAdminOptions.ascx.designer.vb new file mode 100755 index 0000000..111cf7b --- /dev/null +++ b/ucAdminOptions.ascx.designer.vb @@ -0,0 +1,179 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucAdminOptions + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblMainOptions control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblMainOptions As Global.System.Web.UI.WebControls.Label + + ''' + '''lblMainOptionsDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblMainOptionsDescription As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCategories As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCategoriesDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCategoriesDescription As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCustomFields control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCustomFields As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCustomFieldsDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCustomFieldsDescription As Global.System.Web.UI.WebControls.Label + + ''' + '''lblImportFeeds control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblImportFeeds As Global.System.Web.UI.WebControls.Label + + ''' + '''lblImportFeedsDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblImportFeedsDescription As Global.System.Web.UI.WebControls.Label + + ''' + '''lblTags control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTags As Global.System.Web.UI.WebControls.Label + + ''' + '''lblTagsDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTagsDescription As Global.System.Web.UI.WebControls.Label + + ''' + '''lblEmailTemplates control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblEmailTemplates As Global.System.Web.UI.WebControls.Label + + ''' + '''lblEmailTemplatesDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblEmailTemplatesDescription As Global.System.Web.UI.WebControls.Label + + ''' + '''trSiteTemplates control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trSiteTemplates As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''lblSiteTemplates control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSiteTemplates As Global.System.Web.UI.WebControls.Label + + ''' + '''lblSiteTemplatesDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSiteTemplatesDescription As Global.System.Web.UI.WebControls.Label + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''cmdImport control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdImport As Global.System.Web.UI.WebControls.LinkButton + End Class +End Namespace diff --git a/ucAdminOptions.ascx.vb b/ucAdminOptions.ascx.vb new file mode 100755 index 0000000..67605c4 --- /dev/null +++ b/ucAdminOptions.ascx.vb @@ -0,0 +1,233 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Security +Imports DotNetNuke.Services.Exceptions +Imports System.Xml + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucAdminOptions + Inherits NewsArticleModuleBase + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + trSiteTemplates.Visible = Me.UserInfo.IsSuperUser + If (Settings.Contains(ArticleConstants.PERMISSION_SITE_TEMPLATES_SETTING)) Then + If (Settings(ArticleConstants.PERMISSION_SITE_TEMPLATES_SETTING).ToString() <> "") Then + trSiteTemplates.Visible = PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_SITE_TEMPLATES_SETTING).ToString()) + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + Protected Sub cmdImport_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdImport.Click + + Dim file As String = PortalSettings.HomeDirectoryMapPath & "import.xml" + + Dim doc As New XmlDocument + doc.Load(file) + + Dim nsMgr As New XmlNamespaceManager(doc.NameTable) + nsMgr.AddNamespace("wp", "http://wordpress.org/export/1.2/") + nsMgr.AddNamespace("content", "http://purl.org/rss/1.0/modules/content/") + + Dim nodeRoot As XmlNode = doc.DocumentElement + + Dim objCategoriesNodes As XmlNodeList = nodeRoot.SelectNodes("/rss/channel/wp:category", nsMgr) + + Dim objCategoryController As New CategoryController() + + For Each objCategoryNode As XmlNode In objCategoriesNodes + + Dim objName As XmlNode = objCategoryNode.SelectSingleNode("wp:cat_name", nsMgr) + + Dim objCategoryInfo As New CategoryInfo + + objCategoryInfo.CategoryID = Null.NullInteger + objCategoryInfo.ModuleID = ModuleId + objCategoryInfo.ParentID = Null.NullInteger + objCategoryInfo.Name = objName.InnerText + objCategoryInfo.Description = "" + objCategoryInfo.InheritSecurity = True + objCategoryInfo.CategorySecurityType = 0 + + objCategoryInfo.MetaTitle = "" + objCategoryInfo.MetaDescription = "" + objCategoryInfo.MetaKeywords = "" + + objCategoryController.AddCategory(objCategoryInfo) + + Next + + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(ModuleId, Null.NullInteger) + + Dim objTagNodes As XmlNodeList = nodeRoot.SelectNodes("/rss/channel/wp:tag", nsMgr) + + Dim objTagController As New TagController() + + For Each objTagNode As XmlNode In objTagNodes + + Dim objName As XmlNode = objTagNode.SelectSingleNode("wp:tag_name", nsMgr) + + Dim objTag As New TagInfo + + objTag.ModuleID = Me.ModuleId + objTag.Name = objName.InnerText + objTag.NameLowered = objName.InnerText.ToLower() + + objTagController.Add(objTag) + + Next + + Dim objTags As ArrayList = objTagController.List(ModuleId, Null.NullInteger) + + Dim objArticleNodes As XmlNodeList = nodeRoot.SelectNodes("/rss/channel/item", nsMgr) + + Dim objArticleController As New ArticleController() + + For Each objArticleNode As XmlNode In objArticleNodes + + Dim objPostType As XmlNode = objArticleNode.SelectSingleNode("wp:post_type", nsMgr) + Dim objStatus As XmlNode = objArticleNode.SelectSingleNode("wp:status", nsMgr) + + If (objPostType.InnerText = "post" And objStatus.InnerText <> "draft") Then + + Dim objTitle As XmlNode = objArticleNode.SelectSingleNode("title", nsMgr) + + Dim objContent As XmlNode = objArticleNode.SelectSingleNode("content:encoded", nsMgr) + + Dim objPostID As XmlNode = objArticleNode.SelectSingleNode("wp:post_id", nsMgr) + Dim objPostDate As XmlNode = objArticleNode.SelectSingleNode("wp:post_date", nsMgr) + Dim dt As DateTime = DateTime.Parse(objPostDate.InnerText) + + Dim objArticle As New ArticleInfo + + objArticle.Title = objTitle.InnerText + objArticle.CreatedDate = dt + objArticle.StartDate = dt + + objArticle.Status = StatusType.Published + objArticle.CommentCount = 0 + objArticle.FileCount = 0 + objArticle.RatingCount = 0 + objArticle.Rating = 0 + objArticle.ShortUrl = "" + objArticle.MetaTitle = "" + objArticle.MetaDescription = "" + objArticle.MetaKeywords = "" + objArticle.PageHeadText = "" + objArticle.IsFeatured = False + objArticle.IsSecure = False + objArticle.LastUpdate = DateTime.Now + objArticle.LastUpdateID = Me.UserId + objArticle.ModuleID = Me.ModuleId + objArticle.AuthorID = Me.UserId + + objArticle.ArticleID = objArticleController.AddArticle(objArticle) + + Dim objPageController As New PageController() + Dim objPage As New PageInfo + objPage.PageText = objContent.InnerText + objPage.ArticleID = objArticle.ArticleID + objPage.Title = objArticle.Title + objPageController.AddPage(objPage) + + Dim objCategoryNodes As XmlNodeList = objArticleNode.SelectNodes("category", nsMgr) + + For Each objCategoryNode As XmlNode In objCategoryNodes + Select Case objCategoryNode.Attributes("domain").InnerText + + Case "post_tag" + + For Each objTag As TagInfo In objTags + If (objTag.Name.ToLower() = objCategoryNode.InnerText.ToLower()) Then + objTagController.Add(objArticle.ArticleID, objTag.TagID) + Exit For + End If + Next + Exit Select + + Case "category" + For Each objCategory As CategoryInfo In objCategories + If (objCategory.Name.ToLower() = objCategoryNode.InnerText.ToLower()) Then + objArticleController.AddArticleCategory(objArticle.ArticleID, objCategory.CategoryID) + Exit For + End If + Next + Exit Select + + End Select + Next + + Dim objCommentNodes As XmlNodeList = objArticleNode.SelectNodes("wp:comment", nsMgr) + + For Each objCommentNode As XmlNode In objCommentNodes + + Dim objAuthor As XmlNode = objCommentNode.SelectSingleNode("wp:comment_author", nsMgr) + Dim objAuthorEmail As XmlNode = objCommentNode.SelectSingleNode("wp:comment_author_email", nsMgr) + Dim objAuthorUrl As XmlNode = objCommentNode.SelectSingleNode("wp:comment_author_url", nsMgr) + Dim objAuthorIP As XmlNode = objCommentNode.SelectSingleNode("wp:comment_author_IP", nsMgr) + Dim objCommentContent As XmlNode = objCommentNode.SelectSingleNode("wp:comment_content", nsMgr) + Dim objCommentDate As XmlNode = objCommentNode.SelectSingleNode("wp:comment_date", nsMgr) + Dim dtComment As DateTime = DateTime.Parse(objCommentDate.InnerText) + + Dim objComment As New CommentInfo + objComment.ArticleID = objArticle.ArticleID + objComment.UserID = Null.NullInteger + objComment.AnonymousName = objAuthor.InnerText + objComment.AnonymousEmail = objAuthorEmail.InnerText + objComment.AnonymousURL = objAuthorUrl.InnerText + objComment.Comment = FilterInput(objCommentContent.InnerText) + objComment.RemoteAddress = objAuthorIP.InnerText + objComment.NotifyMe = False + objComment.Type = 0 + objComment.IsApproved = True + objComment.ApprovedBy = Me.UserId + objComment.CreatedDate = dtComment + + Dim objCommentController As New CommentController + objComment.CommentID = objCommentController.AddComment(objComment) + + objArticle.CommentCount = objArticle.CommentCount + 1 + objArticleController.UpdateArticle(objArticle) + Next + + End If + + Next + + End Sub + + Private Function FilterInput(ByVal stringToFilter As String) As String + + Dim objPortalSecurity As New PortalSecurity + + stringToFilter = objPortalSecurity.InputFilter(stringToFilter, PortalSecurity.FilterFlag.NoScripting) + + stringToFilter = Replace(stringToFilter, Chr(13), "") + stringToFilter = Replace(stringToFilter, ControlChars.Lf, "
      ") + + Return stringToFilter + + End Function + + End Class + +End Namespace \ No newline at end of file diff --git a/ucApproveArticles.ascx b/ucApproveArticles.ascx new file mode 100755 index 0000000..f72debf --- /dev/null +++ b/ucApproveArticles.ascx @@ -0,0 +1,60 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucApproveArticles.ascx.vb" Inherits="Ventrian.NewsArticles.ucApproveArticles" %> +<%@ Register TagPrefix="dnn" Namespace="DotNetNuke.UI.WebControls" Assembly="DotNetNuke" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + +

      + + + + + + + + + + + + + + + + + <%#GetAdjustedCreateDate(Container.DataItem)%> + + + + + + + + + + <%#GetAdjustedPublishDate(Container.DataItem)%> + + + + + + + + + + <%#DataBinder.Eval(Container.DataItem, "Title")%> + + + + + + + + + + + + + +

      +   + +

      + diff --git a/ucApproveArticles.ascx.designer.vb b/ucApproveArticles.ascx.designer.vb new file mode 100755 index 0000000..c9f74fb --- /dev/null +++ b/ucApproveArticles.ascx.designer.vb @@ -0,0 +1,89 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucApproveArticles + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblMyArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblMyArticles As Global.System.Web.UI.WebControls.Label + + ''' + '''grdArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdArticles As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''lblNoArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoArticles As Global.System.Web.UI.WebControls.Label + + ''' + '''ctlPagingControl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ctlPagingControl As Global.DotNetNuke.UI.WebControls.PagingControl + + ''' + '''cmdApproveSelected control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdApproveSelected As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdApproveAll control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdApproveAll As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''Header1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Header1 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucApproveArticles.ascx.vb b/ucApproveArticles.ascx.vb new file mode 100755 index 0000000..eb8ed17 --- /dev/null +++ b/ucApproveArticles.ascx.vb @@ -0,0 +1,365 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Security.Roles +Imports Ventrian.NewsArticles.Components.Social + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucApproveArticles + Inherits NewsArticleModuleBase + +#Region " Private Properties " + + Private ReadOnly Property CurrentPage() As Integer + Get + If (Request("Page") = Null.NullString And Request("CurrentPage") = Null.NullString) Then + Return 1 + Else + Try + If (Request("Page") <> Null.NullString) Then + Return Convert.ToInt32(Request("Page")) + Else + Return Convert.ToInt32(Request("CurrentPage")) + End If + Catch + Return 1 + End Try + End If + End Get + End Property + +#End Region + +#Region " Private Methods " + + Private Function IsInRole(ByVal roleName As String, ByVal roles As String()) As Boolean + + For Each role As String In roles + If (roleName = role) Then + Return True + End If + Next + + Return False + + End Function + + Private Sub BindArticles() + + Dim count As Integer = 0 + + Dim objArticleController As New ArticleController + + DotNetNuke.Services.Localization.Localization.LocalizeDataGrid(grdArticles, Me.LocalResourceFile) + + grdArticles.DataSource = objArticleController.GetArticleList(Me.ModuleId, Null.NullDate, Null.NullDate, Nothing, Null.NullBoolean, Nothing, Null.NullInteger, CurrentPage, 20, "StartDate", "DESC", False, Null.NullBoolean, Null.NullString, Null.NullInteger, True, True, Null.NullBoolean, Null.NullBoolean, False, False, Null.NullString, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, count) + grdArticles.DataBind() + + If (grdArticles.Items.Count = 0) Then + lblNoArticles.Visible = True + lblNoArticles.Text = DotNetNuke.Services.Localization.Localization.GetString("NoArticlesMessage.Text", LocalResourceFile) + grdArticles.Visible = False + + ctlPagingControl.Visible = False + Else + lblNoArticles.Visible = False + grdArticles.Visible = True + + ctlPagingControl.Visible = True + ctlPagingControl.TotalRecords = count + ctlPagingControl.PageSize = 20 + ctlPagingControl.CurrentPage = CurrentPage + ctlPagingControl.QuerystringParams = GetParams() + ctlPagingControl.TabID = TabId + ctlPagingControl.EnableViewState = False + End If + + End Sub + + Private Function GetParams() As String + + Dim params As String = "" + + If (Request("ctl") <> "") Then + If (Request("ctl").ToLower = "approvearticles") Then + params += "ctl=" & Request("ctl") & "&mid=" & ModuleId.ToString() + End If + End If + + If (Request("articleType") <> "") Then + If (Request("articleType").ToString().ToLower = "approvearticles") Then + params += "articleType=" & Request("articleType") + End If + End If + + Return params + + End Function + + Private Sub NotifyAuthor(ByVal objArticle As ArticleInfo) + + If (Settings.Contains(ArticleConstants.NOTIFY_APPROVAL_SETTING)) Then + If (Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_APPROVAL_SETTING))) Then + Dim objUserController As New UserController + Dim objUser As UserInfo = objUserController.GetUser(Me.PortalId, objArticle.AuthorID) + + Dim objEmailTemplateController As New EmailTemplateController + If Not (objUser Is Nothing) Then + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, EmailTemplateType.ArticleApproved, objUser.Membership.Email, ArticleSettings) + End If + + End If + End If + + End Sub + + Private Sub CheckSecurity() + + If (Request.IsAuthenticated = False) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthenticated", ArticleSettings), True) + End If + + If (ArticleSettings.IsApprover) Then + Return + End If + + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthorized", ArticleSettings), True) + + End Sub + +#End Region + +#Region " Protected Methods " + + Protected Function GetAdjustedCreateDate(ByVal objItem As Object) As String + + Dim objArticle As ArticleInfo = CType(objItem, ArticleInfo) + Return objArticle.CreatedDate.ToString("d") & " " & objArticle.CreatedDate.ToString("t") + + End Function + + Protected Function GetAdjustedPublishDate(ByVal objItem As Object) As String + + Dim objArticle As ArticleInfo = CType(objItem, ArticleInfo) + Return objArticle.StartDate.ToString("d") & " " & objArticle.StartDate.ToString("t") + + End Function + + Protected Function GetArticleLink(ByVal objItem As Object) As String + + Dim objArticle As ArticleInfo = CType(objItem, ArticleInfo) + Return Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False) + + End Function + + Protected Function GetEditUrl(ByVal articleID As String) As String + If (ArticleSettings.LaunchLinks) Then + Return Common.GetModuleLink(Me.TabId, Me.ModuleId, "Edit", ArticleSettings, "ArticleID=" & articleID, "returnurl=" & Server.UrlEncode(Request.Url.ToString())) + Else + Return Common.GetModuleLink(Me.TabId, Me.ModuleId, "SubmitNews", ArticleSettings, "ArticleID=" & articleID, "returnurl=" & Server.UrlEncode(Request.Url.ToString())) + End If + End Function + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + CheckSecurity() + + If IsPostBack = False Then + BindArticles() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdApproveSelected_OnClick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdApproveSelected.Click + + Try + + Dim objArticleController As New ArticleController + + For i As Integer = 0 To grdArticles.Items.Count - 1 + + Dim currentItem As DataGridItem = grdArticles.Items(i) + + If Not (currentItem.FindControl("chkArticle") Is Nothing) Then + Dim chkArticle As CheckBox = CType(currentItem.FindControl("chkArticle"), CheckBox) + + If (chkArticle.Checked) Then + Dim objArticle As ArticleInfo = objArticleController.GetArticle(Convert.ToInt32(grdArticles.DataKeys(i))) + + objArticle.Status = StatusType.Published + objArticleController.UpdateArticle(objArticle) + + NotifyAuthor(objArticle) + + If (ArticleSettings.EnableAutoTrackback) Then + Dim objNotifications As New Tracking.Notification + objNotifications.NotifyExternalSites(objArticle, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), Me.PortalSettings.PortalName) + End If + + If (ArticleSettings.EnableNotificationPing) Then + Dim objNotifications As New Tracking.Notification + objNotifications.NotifyWeblogs(AddHTTP(NavigateURL()), Me.PortalSettings.PortalName) + End If + + If (ArticleSettings.JournalIntegration) Then + Dim objJournal As New Journal + objJournal.AddArticleToJournal(objArticle, PortalId, TabId, Me.UserId, Null.NullInteger, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False)) + End If + + If (ArticleSettings.JournalIntegrationGroups) Then + + Dim objCategories As ArrayList = objArticleController.GetArticleCategories(objArticle.ArticleID) + + If (objCategories.Count > 0) Then + + Dim objRoleController As New RoleController() + + Dim objRoles As ArrayList = objRoleController.GetRoles() + For Each objRole As RoleInfo In objRoles + Dim roleAccess As Boolean = False + + If (objRole.SecurityMode = SecurityMode.SocialGroup Or objRole.SecurityMode = SecurityMode.Both) Then + + For Each objCategory As CategoryInfo In objCategories + + If (objCategory.InheritSecurity = False) Then + + If (objCategory.CategorySecurityType = CategorySecurityType.Loose) Then + roleAccess = False + Exit For + Else + If (Settings.Contains(objCategory.CategoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (IsInRole(objRole.RoleName, Settings(objCategory.CategoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString().Split(";"c))) Then + roleAccess = True + End If + End If + End If + + End If + + Next + + End If + + If (roleAccess) Then + Dim objJournal As New Journal + objJournal.AddArticleToJournal(objArticle, PortalId, TabId, Me.UserId, objRole.RoleID, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False)) + End If + + Next + + End If + + End If + + If (ArticleSettings.EnableSmartThinkerStoryFeed) Then + Dim objStoryFeed As New wsStoryFeed.StoryFeedWS + objStoryFeed.Url = DotNetNuke.Common.Globals.AddHTTP(Request.ServerVariables("HTTP_HOST") & Me.ResolveUrl("~/DesktopModules/Smart-Thinker%20-%20UserProfile/StoryFeed.asmx")) + + Dim val As String = GetSharedResource("StoryFeed-AddArticle") + + val = val.Replace("[AUTHOR]", objArticle.AuthorDisplayName) + val = val.Replace("[AUTHORID]", objArticle.AuthorID.ToString()) + val = val.Replace("[ARTICLELINK]", Common.GetArticleLink(objArticle, Me.PortalSettings.ActiveTab, ArticleSettings, False)) + val = val.Replace("[ARTICLETITLE]", objArticle.Title) + + Try + objStoryFeed.AddAction(80, objArticle.ArticleID, val, objArticle.AuthorID, "VE6457624576460436531768") + Catch + End Try + End If + + If (ArticleSettings.EnableActiveSocialFeed) Then + If (ArticleSettings.ActiveSocialSubmitKey <> "") Then + If IO.File.Exists(HttpContext.Current.Server.MapPath("~/bin/active.modules.social.dll")) Then + Dim ai As Object = Nothing + Dim asm As System.Reflection.Assembly + Dim ac As Object = Nothing + Try + asm = System.Reflection.Assembly.Load("Active.Modules.Social") + ac = asm.CreateInstance("Active.Modules.Social.API.Journal") + If Not ac Is Nothing Then + ac.AddProfileItem(New Guid(ArticleSettings.ActiveSocialSubmitKey), objArticle.AuthorID, Common.GetArticleLink(objArticle, Me.PortalSettings.ActiveTab, ArticleSettings, False), objArticle.Title, objArticle.Summary, objArticle.Body, 1, "") + End If + Catch ex As Exception + End Try + End If + End If + End If + + End If + + End If + + Next + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "ApproveArticles", ArticleSettings), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdApproveAll_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdApproveAll.Click + + Try + + Dim objArticleController As New ArticleController + + For i As Integer = 0 To grdArticles.Items.Count - 1 + + Dim currentItem As DataGridItem = grdArticles.Items(i) + Dim objArticle As ArticleInfo = objArticleController.GetArticle(Convert.ToInt32(grdArticles.DataKeys(i))) + + objArticle.Status = StatusType.Published + objArticleController.UpdateArticle(objArticle) + + NotifyAuthor(objArticle) + + If (ArticleSettings.EnableAutoTrackback) Then + Dim objNotifications As New Tracking.Notification + objNotifications.NotifyExternalSites(objArticle, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), Me.PortalSettings.PortalName) + End If + + If (ArticleSettings.EnableNotificationPing) Then + Dim objNotifications As New Tracking.Notification + objNotifications.NotifyWeblogs(AddHTTP(NavigateURL()), Me.PortalSettings.PortalName) + End If + + Next + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "ApproveArticles", ArticleSettings), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/ucApproveComments.ascx b/ucApproveComments.ascx new file mode 100755 index 0000000..b50f796 --- /dev/null +++ b/ucApproveComments.ascx @@ -0,0 +1,72 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucApproveComments.ascx.vb" Inherits="Ventrian.NewsArticles.ucApproveComments" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
       
      + <%#GetTitle(Container.DataItem)%><%# GetAuthor(Container.DataItem) %><%#GetWebsite(Container.DataItem)%><%#DataBinder.Eval(Container.DataItem, "CreatedDate", "{0:d}")%><%#DataBinder.Eval(Container.DataItem, "RemoteAddress")%>
      Comment: <%#DataBinder.Eval(Container.DataItem, "Comment")%>

      + +
      + +

      + +   + +

      + diff --git a/ucApproveComments.ascx.designer.vb b/ucApproveComments.ascx.designer.vb new file mode 100755 index 0000000..8e2d9ed --- /dev/null +++ b/ucApproveComments.ascx.designer.vb @@ -0,0 +1,71 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucApproveComments + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''rptApproveComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rptApproveComments As Global.System.Web.UI.WebControls.Repeater + + ''' + '''lblNoComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoComments As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdApprove control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdApprove As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdReject control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdReject As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''Header1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Header1 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucApproveComments.ascx.vb b/ucApproveComments.ascx.vb new file mode 100755 index 0000000..68527a8 --- /dev/null +++ b/ucApproveComments.ascx.vb @@ -0,0 +1,386 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports Ventrian.NewsArticles.Components.Social + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucApproveComments + Inherits NewsArticleModuleBase + +#Region " Private Methods " + + Private Sub BindComments() + + Dim objCommentController As New CommentController + rptApproveComments.DataSource = objCommentController.GetCommentList(Me.ModuleId, Null.NullInteger, False, SortDirection.Ascending, Null.NullInteger) + rptApproveComments.DataBind() + + If (rptApproveComments.Items.Count = 0) Then + rptApproveComments.Visible = False + lblNoComments.Visible = True + End If + + End Sub + + Private Sub CheckSecurity() + + If (Request.IsAuthenticated = False) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthenticated", ArticleSettings), True) + End If + + If (ArticleSettings.IsApprover) Then + Return + End If + + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthorized", ArticleSettings), True) + + End Sub + + Private Sub NotifyAuthor(ByVal objComment As CommentInfo) + + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(objComment.ArticleID) + + If Not (objArticle Is Nothing) Then + Dim objEmailTemplateController As New EmailTemplateController + + Try + ' Don't send it to the author if it's their own comment. + If (objArticle.AuthorID <> objComment.UserID) Then + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentNotification, ArticleSettings) + End If + Catch ex As Exception + Dim objEventLog As New DotNetNuke.Services.Log.EventLog.EventLogController + + Dim objUserController As New DotNetNuke.Entities.Users.UserController + Dim objUser As DotNetNuke.Entities.Users.UserInfo = objUserController.GetUser(Me.PortalId, objArticle.AuthorID) + + Dim sendTo As String = "" + If Not (objUser Is Nothing) Then + sendTo = objUser.Membership.Email + End If + objEventLog.AddLog("News Articles Email Failure", "Failure to send [Author Comment] to '" & sendTo & "' from '" & Me.PortalSettings.Email, PortalSettings, -1, DotNetNuke.Services.Log.EventLog.EventLogController.EventLogType.ADMIN_ALERT) + End Try + + End If + + End Sub + +#End Region + +#Region " Protected Methods " + + Protected Function GetAuthor(ByVal obj As Object) As String + + Dim objComment As CommentInfo = CType(obj, CommentInfo) + If Not (objComment Is Nothing) Then + If (objComment.UserID <> Null.NullInteger) Then + Return objComment.AuthorUserName + Else + Return objComment.AnonymousName + End If + Else + Return "" + End If + + End Function + + Protected Function GetArticleUrl(ByVal obj As Object) As String + + Dim objComment As CommentInfo = CType(obj, CommentInfo) + If Not (objComment Is Nothing) Then + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(objComment.ArticleID) + + If (objArticle IsNot Nothing) Then + Return Common.GetArticleLink(objArticle, Me.PortalSettings.ActiveTab, Me.ArticleSettings, False) + End If + End If + + Return "" + + End Function + + Protected Function GetEditCommentUrl(ByVal commentID As String) As String + + Return Common.GetModuleLink(TabId, ModuleId, "EditComment", ArticleSettings, "CommentID=" & commentID, "ReturnUrl=" & Server.UrlEncode(Request.RawUrl)) + + End Function + + Protected Function GetTitle(ByVal obj As Object) As String + + Dim objComment As CommentInfo = CType(obj, CommentInfo) + If Not (objComment Is Nothing) Then + + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(objComment.ArticleID) + + If (objArticle IsNot Nothing) Then + Return objArticle.Title + End If + End If + + Return "" + + End Function + + Protected Function GetWebsite(ByVal obj As Object) As String + + Dim objComment As CommentInfo = CType(obj, CommentInfo) + If Not (objComment Is Nothing) Then + If (objComment.AnonymousURL <> "") Then + Return "" & objComment.AnonymousURL & "" + End If + End If + Return "" + + End Function + +#End Region + +#Region " Event Handlers " + + Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load + + Try + + CheckSecurity() + + If (Page.IsPostBack = False) Then + BindComments() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub rptApproveComments_OnItemDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.RepeaterItemEventArgs) Handles rptApproveComments.ItemDataBound + + If (e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem) Then + + Dim objComment As CommentInfo = CType(e.Item.DataItem, CommentInfo) + If (objComment IsNot Nothing) Then + Dim chkSelected As CheckBox = CType(e.Item.FindControl("chkSelected"), CheckBox) + chkSelected.Attributes.Add("CommentID", objComment.CommentID.ToString()) + End If + + End If + + End Sub + + Protected Sub cmdApprove_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdApprove.Click + + For Each item As RepeaterItem In rptApproveComments.Items + If (item.ItemType = ListItemType.Item Or item.ItemType = ListItemType.AlternatingItem) Then + Dim chkSelected As CheckBox = CType(item.FindControl("chkSelected"), CheckBox) + If Not (chkSelected Is Nothing) Then + If (chkSelected.Checked) Then + Dim commentID As Integer = Convert.ToInt32(chkSelected.Attributes("CommentID").ToString()) + Dim objCommentController As New CommentController() + Dim objComment As CommentInfo = objCommentController.GetComment(commentID) + If Not (objComment Is Nothing) Then + objComment.IsApproved = True + objComment.ApprovedBy = Me.UserId + objCommentController.UpdateComment(objComment) + + Dim objEmailTemplateController As New EmailTemplateController() + If (ArticleSettings.NotifyAuthorOnApproval) Then + NotifyAuthor(objComment) + End If + + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(objComment.ArticleID) + + If Not (objArticle Is Nothing) Then + + If (ArticleSettings.EnableActiveSocialFeed And objComment.UserID <> Null.NullInteger) Then + If (ArticleSettings.ActiveSocialCommentKey <> "") Then + If IO.File.Exists(HttpContext.Current.Server.MapPath("~/bin/active.modules.social.dll")) Then + Dim ai As Object = Nothing + Dim asm As System.Reflection.Assembly + Dim ac As Object = Nothing + Try + asm = System.Reflection.Assembly.Load("Active.Modules.Social") + ac = asm.CreateInstance("Active.Modules.Social.API.Journal") + If Not ac Is Nothing Then + ac.AddProfileItem(New Guid(ArticleSettings.ActiveSocialCommentKey), objComment.UserID, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle.Title, objComment.Comment, objComment.Comment, 1, "") + End If + Catch ex As Exception + End Try + End If + End If + End If + + If (Request.IsAuthenticated) Then + If (ArticleSettings.JournalIntegration) Then + Dim objJournal As New Journal + objJournal.AddCommentToJournal(objArticle, objComment, PortalId, TabId, UserId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False)) + End If + End If + + If (ArticleSettings.EnableSmartThinkerStoryFeed And objComment.UserID <> Null.NullInteger) Then + Dim objStoryFeed As New wsStoryFeed.StoryFeedWS + objStoryFeed.Url = DotNetNuke.Common.Globals.AddHTTP(Request.ServerVariables("HTTP_HOST") & Me.ResolveUrl("~/DesktopModules/Smart-Thinker%20-%20UserProfile/StoryFeed.asmx")) + + Dim val As String = GetSharedResource("StoryFeed-AddComment") + + Dim delimStr As String = "[]" + Dim delimiter As Char() = delimStr.ToCharArray() + Dim layoutArray As String() = val.Split(delimiter) + + Dim valResult As String = "" + + For iPtr As Integer = 0 To layoutArray.Length - 1 Step 2 + + valResult = valResult & layoutArray(iPtr) + + If iPtr < layoutArray.Length - 1 Then + Select Case layoutArray(iPtr + 1) + + Case "ARTICLEID" + valResult = valResult & objComment.ArticleID.ToString() + + Case "AUTHORID" + valResult = valResult & objComment.UserID.ToString() + + Case "AUTHOR" + If (objComment.UserID = Null.NullInteger) Then + valResult = valResult & objComment.AnonymousName + Else + valResult = valResult & objComment.AuthorDisplayName + End If + + Case "ARTICLELINK" + valResult = valResult & Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False) + + Case "ARTICLETITLE" + valResult = valResult & objArticle.Title + + Case "ISANONYMOUS" + If (objComment.UserID <> Null.NullInteger) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISANONYMOUS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISANONYMOUS" + ' Do Nothing + + Case "ISNOTANONYMOUS" + If (objComment.UserID <> Null.NullInteger) Then + While (iPtr < layoutArray.Length - 1) + If (layoutArray(iPtr + 1) = "/ISNOTANONYMOUS") Then + Exit While + End If + iPtr = iPtr + 1 + End While + End If + + Case "/ISNOTANONYMOUS" + ' Do Nothing + + End Select + End If + Next + + Try + objStoryFeed.AddAction(81, objComment.CommentID, valResult, objComment.UserID, "VE6457624576460436531768") + Catch + End Try + + End If + + If (ArticleSettings.NotifyEmailOnComment <> "") Then + For Each email As String In ArticleSettings.NotifyEmailOnComment.Split(Convert.ToChar(";")) + If (email <> "") Then + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentNotification, ArticleSettings, email) + End If + Next + End If + + If (ArticleSettings.NotifyAuthorOnApproval) Then + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentApproved, ArticleSettings) + End If + + Dim objMailList As New Hashtable + + Dim objComments As List(Of CommentInfo) = objCommentController.GetCommentList(Me.ModuleId, objComment.ArticleID, True, SortDirection.Ascending, Null.NullInteger) + + For Each objNotifyComment As CommentInfo In objComments + If (objNotifyComment.CommentID <> objComment.CommentID And objNotifyComment.NotifyMe) Then + If (objNotifyComment.UserID = Null.NullInteger) Then + If (objNotifyComment.AnonymousEmail <> "") Then + Try + If (objMailList.Contains(objNotifyComment.AnonymousEmail) = False) Then + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentNotification, ArticleSettings, objNotifyComment.AnonymousEmail) + objMailList.Add(objNotifyComment.AnonymousEmail, objNotifyComment.AnonymousEmail) + End If + Catch ex As Exception + Dim objEventLog As New DotNetNuke.Services.Log.EventLog.EventLogController + objEventLog.AddLog("News Articles Email Failure", "Failure to send [Anon Comment] to '" & objNotifyComment.AnonymousEmail & "' from '" & Me.PortalSettings.Email, PortalSettings, -1, DotNetNuke.Services.Log.EventLog.EventLogController.EventLogType.ADMIN_ALERT) + End Try + End If + Else + If (objNotifyComment.AuthorEmail <> "") Then + Try + If (objNotifyComment.UserID <> objComment.UserID) Then + If (objMailList.Contains(objNotifyComment.UserID.ToString()) = False) Then + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, objComment, EmailTemplateType.CommentNotification, ArticleSettings, objNotifyComment.AuthorEmail) + objMailList.Add(objNotifyComment.UserID.ToString(), objNotifyComment.UserID.ToString()) + End If + End If + Catch ex As Exception + Dim objEventLog As New DotNetNuke.Services.Log.EventLog.EventLogController + objEventLog.AddLog("News Articles Email Failure", "Failure to send [Author Comment] to '" & objNotifyComment.AuthorEmail & "' from '" & Me.PortalSettings.Email, PortalSettings, -1, DotNetNuke.Services.Log.EventLog.EventLogController.EventLogType.ADMIN_ALERT) + End Try + End If + End If + + End If + Next + End If + + End If + End If + End If + End If + Next + + Response.Redirect(Request.RawUrl, True) + + End Sub + + Protected Sub cmdReject_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdReject.Click + + For Each item As RepeaterItem In rptApproveComments.Items + If (item.ItemType = ListItemType.Item Or item.ItemType = ListItemType.AlternatingItem) Then + Dim chkSelected As CheckBox = CType(item.FindControl("chkSelected"), CheckBox) + If Not (chkSelected Is Nothing) Then + If (chkSelected.Checked) Then + Dim commentID As Integer = Convert.ToInt32(chkSelected.Attributes("CommentID").ToString()) + Dim objCommentController As New CommentController() + Dim objComment As CommentInfo = objCommentController.GetComment(commentID) + If Not (objComment Is Nothing) Then + objCommentController.DeleteComment(objComment.CommentID, objComment.ArticleID) + End If + End If + End If + End If + Next + + Response.Redirect(Request.RawUrl, True) + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucEditCategories.ascx b/ucEditCategories.ascx new file mode 100755 index 0000000..d9475f9 --- /dev/null +++ b/ucEditCategories.ascx @@ -0,0 +1,85 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditCategories.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditCategories" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="HelpButton" Src="~/controls/HelpButtonControl.ascx" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + +
      + + + + + + + + + +
      + + + + + + + + +
      + + +   + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + Move Category +
      +
      + + + +
      + + + +
       
      + Actions +
      +
      + + + +
      + + + +
      +
      +
      +
      + +

      +   +

      + diff --git a/ucEditCategories.ascx.designer.vb b/ucEditCategories.ascx.designer.vb new file mode 100755 index 0000000..7867739 --- /dev/null +++ b/ucEditCategories.ascx.designer.vb @@ -0,0 +1,206 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditCategories + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''plParentCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plParentCategory As Global.System.Web.UI.UserControl + + ''' + '''drpParentCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpParentCategory As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plChildCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plChildCategories As Global.System.Web.UI.UserControl + + ''' + '''lblNoCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoCategories As Global.System.Web.UI.WebControls.Label + + ''' + '''pnlSortOrder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSortOrder As Global.System.Web.UI.WebControls.Panel + + ''' + '''lstChildCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstChildCategories As Global.System.Web.UI.WebControls.ListBox + + ''' + '''lblCategoryUpdated control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCategoryUpdated As Global.System.Web.UI.WebControls.Label + + ''' + '''lblMoveCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblMoveCategory As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdUp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUp As Global.System.Web.UI.WebControls.ImageButton + + ''' + '''hbtnUpHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents hbtnUpHelp As Global.System.Web.UI.UserControl + + ''' + '''cmdDown control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdDown As Global.System.Web.UI.WebControls.ImageButton + + ''' + '''hbtnDownHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents hbtnDownHelp As Global.System.Web.UI.UserControl + + ''' + '''lblActions control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblActions As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdEdit control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdEdit As Global.System.Web.UI.WebControls.ImageButton + + ''' + '''hbtnEditHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents hbtnEditHelp As Global.System.Web.UI.UserControl + + ''' + '''cmdView control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdView As Global.System.Web.UI.WebControls.ImageButton + + ''' + '''hbtnViewHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents hbtnViewHelp As Global.System.Web.UI.UserControl + + ''' + '''cmdUpdateSortOrder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdateSortOrder As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdAddNewCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdAddNewCategory As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucEditCategories.ascx.vb b/ucEditCategories.ascx.vb new file mode 100755 index 0000000..f7229c6 --- /dev/null +++ b/ucEditCategories.ascx.vb @@ -0,0 +1,201 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditCategories + Inherits NewsArticleModuleBase + +#Region " Private Methods " + + Private Sub BindCategories() + + Dim objCategoryController As New CategoryController + + lstChildCategories.DataSource = objCategoryController.GetCategoriesAll(ModuleId, Convert.ToInt32(drpParentCategory.SelectedValue), Nothing, Null.NullInteger, 1, False, ArticleSettings.CategorySortType) + lstChildCategories.DataBind() + + If (lstChildCategories.Items.Count = 0) Then + pnlSortOrder.Visible = False + cmdUpdateSortOrder.Visible = False + lblNoCategories.Visible = True + Else + pnlSortOrder.Visible = True + cmdUpdateSortOrder.Visible = True + lblNoCategories.Visible = False + End If + + End Sub + + Private Sub BindParentCategories() + + Dim objCategoryController As New CategoryController + + drpParentCategory.DataSource = objCategoryController.GetCategoriesAll(ModuleId, Null.NullInteger, ArticleSettings.CategorySortType) + drpParentCategory.DataBind() + + drpParentCategory.Items.Insert(0, New ListItem(Localization.GetString("NoParentCategory", Me.LocalResourceFile), "-1")) + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + If (IsPostBack = False) Then + BindParentCategories() + BindCategories() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdAddNewCategory_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdAddNewCategory.Click + + Try + + If (drpParentCategory.SelectedValue <> "-1") Then + Response.Redirect(EditArticleUrl("EditCategory", "ParentID=" & drpParentCategory.SelectedValue), True) + Else + Response.Redirect(EditArticleUrl("EditCategory"), True) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdUpdateSortOrder_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdUpdateSortOrder.Click + + Dim objCategoryController As New CategoryController + + Dim index As Integer = 0 + For Each item As ListItem In lstChildCategories.Items + Dim objCategory As CategoryInfo = objCategoryController.GetCategory(Convert.ToInt32(item.Value), ModuleId) + + If Not (objCategory Is Nothing) Then + objCategory.SortOrder = index + objCategoryController.UpdateCategory(objCategory) + index = index + 1 + End If + Next + + lblCategoryUpdated.Visible = True + + Dim currentCategory As String = drpParentCategory.SelectedValue + BindParentCategories() + If (drpParentCategory.Items.FindByValue(currentCategory) IsNot Nothing) Then + drpParentCategory.SelectedValue = currentCategory + End If + + End Sub + + Protected Sub drpParentCategory_SelectedIndexChanged(ByVal sender As Object, ByVal e As EventArgs) Handles drpParentCategory.SelectedIndexChanged + + Try + + BindCategories() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdUp_Click(ByVal sender As Object, ByVal e As System.Web.UI.ImageClickEventArgs) Handles cmdUp.Click + + Try + + If (lstChildCategories.Items.Count > 1) Then + If (lstChildCategories.SelectedIndex > 0) Then + Dim objListItem As New ListItem + + objListItem.Value = lstChildCategories.SelectedItem.Value + objListItem.Text = lstChildCategories.SelectedItem.Text + + Dim index As Integer = lstChildCategories.SelectedIndex + + lstChildCategories.Items.RemoveAt(index) + lstChildCategories.Items.Insert(index - 1, objListItem) + lstChildCategories.SelectedIndex = index - 1 + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdDown_Click(ByVal sender As Object, ByVal e As System.Web.UI.ImageClickEventArgs) Handles cmdDown.Click + + Try + + If (lstChildCategories.Items.Count > 1) Then + If (lstChildCategories.SelectedIndex < (lstChildCategories.Items.Count - 1)) Then + Dim objListItem As New ListItem + + objListItem.Value = lstChildCategories.SelectedItem.Value + objListItem.Text = lstChildCategories.SelectedItem.Text + + Dim index As Integer = lstChildCategories.SelectedIndex + + lstChildCategories.Items.RemoveAt(index) + lstChildCategories.Items.Insert(index + 1, objListItem) + lstChildCategories.SelectedIndex = index + 1 + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdEdit_Click(ByVal sender As Object, ByVal e As System.Web.UI.ImageClickEventArgs) Handles cmdEdit.Click + + If (lstChildCategories.Items.Count > 0) Then + If Not (lstChildCategories.SelectedItem Is Nothing) Then + Response.Redirect(EditArticleUrl("EditCategory", "CategoryID=" & lstChildCategories.SelectedValue), True) + End If + End If + + End Sub + + Protected Sub cmdView_Click(ByVal sender As Object, ByVal e As System.Web.UI.ImageClickEventArgs) Handles cmdView.Click + + If (lstChildCategories.Items.Count > 0) Then + If Not (lstChildCategories.SelectedItem Is Nothing) Then + Dim objCategoryController As New CategoryController() + Dim objCategory As CategoryInfo = objCategoryController.GetCategory(Convert.ToInt32(lstChildCategories.SelectedValue), ModuleId) + + If (objCategory IsNot Nothing) Then + Response.Redirect(Common.GetCategoryLink(TabId, ModuleId, objCategory.CategoryID.ToString(), objCategory.Name, ArticleSettings.LaunchLinks, ArticleSettings), True) + End If + End If + End If + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/ucEditCategory.ascx b/ucEditCategory.ascx new file mode 100755 index 0000000..cbc3bb6 --- /dev/null +++ b/ucEditCategory.ascx @@ -0,0 +1,153 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditCategory.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditCategory" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="TextEditor" Src="~/controls/TextEditor.ascx"%> +<%@ Register TagPrefix="dnn" TagName="URL" Src="~/controls/URLControl.ascx" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + +
      + + + + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + + +
      + + +
      +
      +
      + +
      +
      + + + + + + + + + + + + + + +
      + +
      + + + + + + <%# DataBinder.Eval(Container.DataItem, "Text") %> + + + + +   +   + + + + + + + +   +   + + + + + + + +
      + +
      +
      +
      + + + + + + + + + + + + + + +
      + +
      + +
      + +
      +
      +
      +
      +

      + +   + +   + +

      + diff --git a/ucEditCategory.ascx.designer.vb b/ucEditCategory.ascx.designer.vb new file mode 100755 index 0000000..2a36f07 --- /dev/null +++ b/ucEditCategory.ascx.designer.vb @@ -0,0 +1,350 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditCategory + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''pnlSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSettings As Global.System.Web.UI.WebControls.Panel + + ''' + '''dshCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshCategory As Global.System.Web.UI.UserControl + + ''' + '''tblCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblCategory As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblCategoryHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCategoryHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plParent control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plParent As Global.System.Web.UI.UserControl + + ''' + '''drpParentCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpParentCategory As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''valInvalidParentCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valInvalidParentCategory As Global.System.Web.UI.WebControls.CustomValidator + + ''' + '''plName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plName As Global.System.Web.UI.UserControl + + ''' + '''txtName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtName As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valName As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''plDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plDescription As Global.System.Web.UI.UserControl + + ''' + '''txtDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtDescription As DotNetNuke.UI.UserControls.TextEditor + + ''' + '''plCategoryImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCategoryImage As Global.System.Web.UI.UserControl + + ''' + '''ctlIcon control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ctlIcon As DotNetNuke.UI.UserControls.UrlControl + + ''' + '''dshSecurity control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshSecurity As Global.System.Web.UI.UserControl + + ''' + '''tblSecurity control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSecurity As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plInheritSecurity control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plInheritSecurity As Global.System.Web.UI.UserControl + + ''' + '''chkInheritSecurity control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkInheritSecurity As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''trPermissions control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trPermissions As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plPermissions control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plPermissions As Global.System.Web.UI.UserControl + + ''' + '''grdCategoryPermissions control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdCategoryPermissions As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''trSecurityMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trSecurityMode As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plSecurityMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSecurityMode As Global.System.Web.UI.UserControl + + ''' + '''lstSecurityMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstSecurityMode As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''dshMeta control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshMeta As Global.System.Web.UI.UserControl + + ''' + '''tblMeta control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblMeta As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plMetaTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMetaTitle As Global.System.Web.UI.UserControl + + ''' + '''txtMetaTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtMetaTitle As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plMetaDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMetaDescription As Global.System.Web.UI.UserControl + + ''' + '''txtMetaDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtMetaDescription As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plMetaKeyWords control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMetaKeyWords As Global.System.Web.UI.UserControl + + ''' + '''txtMetaKeyWords control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtMetaKeyWords As Global.System.Web.UI.WebControls.TextBox + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdDelete control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdDelete As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucEditCategory.ascx.vb b/ucEditCategory.ascx.vb new file mode 100755 index 0000000..220ea6f --- /dev/null +++ b/ucEditCategory.ascx.vb @@ -0,0 +1,366 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization +Imports DotNetNuke.Security.Roles +Imports DotNetNuke.Entities.Modules + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditCategory + Inherits NewsArticleModuleBase + +#Region " Private Members " + + Private _categoryID As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub ReadQueryString() + + If (IsNumeric(Request("CategoryID"))) Then + _categoryID = Convert.ToInt32(Request("CategoryID")) + End If + + End Sub + + Private Sub BindCategory() + + If (_categoryID = Null.NullInteger) Then + cmdDelete.Visible = False + trPermissions.Visible = False + trSecurityMode.Visible = False + chkInheritSecurity.Checked = True + lstSecurityMode.SelectedIndex = 0 + Return + End If + + Dim objCategoryController As CategoryController = New CategoryController + Dim objCategoryInfo As CategoryInfo = objCategoryController.GetCategory(_categoryID, ModuleId) + + If Not (objCategoryInfo Is Nothing) Then + If (drpParentCategory.Items.FindByValue(objCategoryInfo.ParentID.ToString()) IsNot Nothing) Then + drpParentCategory.SelectedValue = objCategoryInfo.ParentID.ToString() + End If + txtName.Text = objCategoryInfo.Name + txtDescription.Text = objCategoryInfo.Description + ctlIcon.Url = objCategoryInfo.Image + cmdDelete.Visible = True + chkInheritSecurity.Checked = objCategoryInfo.InheritSecurity + trPermissions.Visible = Not chkInheritSecurity.Checked + trSecurityMode.Visible = Not chkInheritSecurity.Checked + lstSecurityMode.SelectedValue = Convert.ToInt32(objCategoryInfo.CategorySecurityType).ToString() + + txtMetaTitle.Text = objCategoryInfo.MetaTitle + txtMetaDescription.Text = objCategoryInfo.MetaDescription + txtMetaKeyWords.Text = objCategoryInfo.MetaKeywords + End If + + End Sub + + Private Sub BindParentCategories() + + Dim objCategoryController As New CategoryController() + drpParentCategory.DataSource = objCategoryController.GetCategoriesAll(Me.ModuleId, Null.NullInteger, ArticleSettings.CategorySortType) + drpParentCategory.DataBind() + + drpParentCategory.Items.Insert(0, New ListItem(Localization.GetString("NoParentCategory", Me.LocalResourceFile), Null.NullInteger.ToString())) + + If (Request("ParentID") <> "") Then + If (drpParentCategory.Items.FindByValue(Request("ParentID")) IsNot Nothing) Then + drpParentCategory.SelectedValue = Request("ParentID") + End If + End If + + End Sub + + Private Sub BindRoles() + + Dim objRole As New RoleController + Dim availableRoles As New ArrayList + Dim roles As ArrayList = objRole.GetPortalRoles(PortalId) + + If Not roles Is Nothing Then + For Each Role As RoleInfo In roles + availableRoles.Add(New ListItem(Role.RoleName, Role.RoleName)) + Next + End If + + grdCategoryPermissions.DataSource = availableRoles + grdCategoryPermissions.DataBind() + + End Sub + + Private Sub BindSecurityMode() + + For Each value As Integer In System.Enum.GetValues(GetType(CategorySecurityType)) + Dim li As New ListItem + li.Value = value + li.Text = Localization.GetString(System.Enum.GetName(GetType(CategorySecurityType), value), Me.LocalResourceFile) + lstSecurityMode.Items.Add(li) + Next + + End Sub + + Private Function IsInRole(ByVal roleName As String, ByVal roles As String()) As Boolean + + For Each role As String In roles + If (roleName = role) Then + Return True + End If + Next + + Return False + + End Function + + Private Sub SaveCategory() + + Dim objCategoryInfo As New CategoryInfo + + objCategoryInfo.CategoryID = _categoryID + objCategoryInfo.ModuleID = ModuleId + objCategoryInfo.ParentID = Convert.ToInt32(drpParentCategory.SelectedValue) + objCategoryInfo.Name = txtName.Text + objCategoryInfo.Description = txtDescription.Text + objCategoryInfo.Image = ctlIcon.Url + objCategoryInfo.InheritSecurity = chkInheritSecurity.Checked + objCategoryInfo.CategorySecurityType = lstSecurityMode.SelectedValue + + objCategoryInfo.MetaTitle = txtMetaTitle.Text + objCategoryInfo.MetaDescription = txtMetaDescription.Text + objCategoryInfo.MetaKeywords = txtMetaKeyWords.Text + + Dim objCategoryController As New CategoryController + + If (objCategoryInfo.CategoryID = Null.NullInteger) Then + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategories(ModuleId, objCategoryInfo.ParentID) + + objCategoryInfo.SortOrder = 0 + If (objCategories.Count > 0) Then + objCategoryInfo.SortOrder = CType(objCategories(objCategories.Count - 1), CategoryInfo).SortOrder + 1 + End If + objCategoryInfo.CategoryID = objCategoryController.AddCategory(objCategoryInfo) + Else + Dim objCategoryOld As CategoryInfo = objCategoryController.GetCategory(objCategoryInfo.CategoryID, ModuleId) + + If (objCategoryOld IsNot Nothing) Then + objCategoryInfo.SortOrder = objCategoryOld.SortOrder + If (objCategoryInfo.ParentID <> objCategoryOld.ParentID) Then + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategories(ModuleId, objCategoryInfo.ParentID) + If (objCategories.Count > 0) Then + objCategoryInfo.SortOrder = CType(objCategories(objCategories.Count - 1), CategoryInfo).SortOrder + 1 + End If + End If + End If + objCategoryController.UpdateCategory(objCategoryInfo) + End If + + Dim viewRoles As String = "" + Dim submitRoles As String = "" + + For Each item As DataGridItem In grdCategoryPermissions.Items + Dim role As String = grdCategoryPermissions.DataKeys(item.ItemIndex).ToString() + + Dim chkView As CheckBox = CType(item.FindControl("chkView"), CheckBox) + If (chkView.Checked) Then + If (viewRoles = "") Then + viewRoles = role + Else + viewRoles = viewRoles & ";" & role + End If + End If + + Dim chkSubmit As CheckBox = CType(item.FindControl("chkSubmit"), CheckBox) + If (chkSubmit.Checked) Then + If (submitRoles = "") Then + submitRoles = role + Else + submitRoles = submitRoles & ";" & role + End If + End If + Next + + Dim objModuleController As New ModuleController() + objModuleController.UpdateModuleSetting(Me.ModuleId, objCategoryInfo.CategoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING, viewRoles) + objModuleController.UpdateModuleSetting(Me.ModuleId, objCategoryInfo.CategoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_SUBMIT_SETTING, submitRoles) + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + ReadQueryString() + + If (IsPostBack = False) Then + BindSecurityMode() + BindRoles() + BindParentCategories() + BindCategory() + Page.SetFocus(txtName) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdUpdate.Click + + Try + + If (Page.IsValid) Then + + SaveCategory() + + Response.Redirect(EditArticleUrl("EditCategories"), True) + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(EditArticleUrl("EditCategories"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdDelete_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdDelete.Click + + Try + + Dim objCategoryController As New CategoryController + Dim objCategory As CategoryInfo = objCategoryController.GetCategory(_categoryID, ModuleId) + + If (objCategory IsNot Nothing) Then + + Dim objChildCategories As List(Of CategoryInfo) = objCategoryController.GetCategories(Me.ModuleId, _categoryID) + + For Each objChildCategory As CategoryInfo In objChildCategories + objChildCategory.ParentID = objCategory.ParentID + objCategoryController.UpdateCategory(objChildCategory) + Next + + objCategoryController.DeleteCategory(_categoryID, ModuleId) + + End If + + Response.Redirect(EditArticleUrl("EditCategories"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub valInvalidParentCategory_ServerValidate(ByVal source As System.Object, ByVal args As System.Web.UI.WebControls.ServerValidateEventArgs) Handles valInvalidParentCategory.ServerValidate + + Try + + If (_categoryID = Null.NullInteger Or drpParentCategory.SelectedValue = "-1") Then + args.IsValid = True + Return + End If + + Dim objCategoryController As New CategoryController + Dim objCategory As CategoryInfo = objCategoryController.GetCategory(Convert.ToInt32(drpParentCategory.SelectedValue), ModuleId) + + While Not objCategory Is Nothing + If (_categoryID = objCategory.CategoryID) Then + args.IsValid = False + Return + End If + objCategory = objCategoryController.GetCategory(objCategory.ParentID, objCategory.ModuleID) + End While + + args.IsValid = True + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub grdCategoryPermissions_ItemDataBound(ByVal sender As System.Object, ByVal e As System.Web.UI.WebControls.DataGridItemEventArgs) Handles grdCategoryPermissions.ItemDataBound + + Try + + If (e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem) Then + Dim objListItem As ListItem = CType(e.Item.DataItem, ListItem) + + If Not (objListItem Is Nothing) Then + + Dim role As String = CType(e.Item.DataItem, ListItem).Value + + Dim chkView As CheckBox = CType(e.Item.FindControl("chkView"), CheckBox) + Dim chkSubmit As CheckBox = CType(e.Item.FindControl("chkSubmit"), CheckBox) + + If (objListItem.Value = PortalSettings.AdministratorRoleName.ToString()) Then + chkView.Enabled = False + chkView.Checked = True + chkSubmit.Enabled = False + chkSubmit.Checked = True + Else + If (_categoryID <> Null.NullInteger) Then + If (Settings.Contains(_categoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + chkView.Checked = IsInRole(role, Settings(_categoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString().Split(";"c)) + End If + If (Settings.Contains(_categoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_SUBMIT_SETTING)) Then + chkSubmit.Checked = IsInRole(role, Settings(_categoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_SUBMIT_SETTING).ToString().Split(";"c)) + End If + End If + End If + + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub chkInheritSecurity_CheckedChanged(ByVal sender As Object, ByVal e As EventArgs) Handles chkInheritSecurity.CheckedChanged + + Try + + trPermissions.Visible = Not chkInheritSecurity.Checked + trSecurityMode.Visible = Not chkInheritSecurity.Checked + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucEditComment.ascx b/ucEditComment.ascx new file mode 100755 index 0000000..5853507 --- /dev/null +++ b/ucEditComment.ascx @@ -0,0 +1,71 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditComment.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditComment" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" Namespace="DotNetNuke.UI.WebControls" Assembly="DotNetNuke" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + + + +
      + + + + + + + + + + + + + + + + + + + + + + + +
      + + + + +
      + + + + + +
      + + + +
      + + + + +
      +
      +
      + +

      + +   + +   + +

      diff --git a/ucEditComment.ascx.designer.vb b/ucEditComment.ascx.designer.vb new file mode 100755 index 0000000..3a23f31 --- /dev/null +++ b/ucEditComment.ascx.designer.vb @@ -0,0 +1,215 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditComment + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''pnlSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSettings As Global.System.Web.UI.WebControls.Panel + + ''' + '''dshEditComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshEditComment As Global.System.Web.UI.UserControl + + ''' + '''tblEditComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblEditComment As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''trName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trName As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plName As Global.System.Web.UI.UserControl + + ''' + '''txtName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtName As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valName As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''trEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trEmail As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEmail As Global.System.Web.UI.UserControl + + ''' + '''txtEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtEmail As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valEmail As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valEmailIsValid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valEmailIsValid As Global.System.Web.UI.WebControls.RegularExpressionValidator + + ''' + '''trUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trUrl As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plUrl As Global.System.Web.UI.UserControl + + ''' + '''txtURL control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtURL As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plComment As Global.System.Web.UI.UserControl + + ''' + '''txtComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtComment As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valComment As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdDelete control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdDelete As Global.System.Web.UI.WebControls.LinkButton + End Class +End Namespace diff --git a/ucEditComment.ascx.vb b/ucEditComment.ascx.vb new file mode 100755 index 0000000..ff854b0 --- /dev/null +++ b/ucEditComment.ascx.vb @@ -0,0 +1,192 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2010 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Security + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditComment + Inherits NewsArticleModuleBase + +#Region " Private Members " + + Private _commentID As Integer = Null.NullInteger + Private _returnUrl As String = Null.NullString + +#End Region + +#Region " Private Methods " + + Private Sub BindComment() + + If (_commentID = Null.NullInteger) Then + Response.Redirect(NavigateURL(), True) + End If + + Dim objCommentController As New CommentController() + Dim objComment As CommentInfo = objCommentController.GetComment(_commentID) + + If (ArticleSettings.IsAdmin() = False And ArticleSettings.IsApprover() = False) Then + + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = objArticleController.GetArticle(objComment.ArticleID) + + If (objArticle Is Nothing) Then + Response.Redirect(NavigateURL(), True) + End If + + If (objArticle.AuthorID <> Me.UserId) Then + Response.Redirect(NavigateURL(), True) + End If + + End If + + If (objComment.UserID <> Null.NullInteger) Then + trName.Visible = False + trEmail.Visible = False + trUrl.Visible = False + Else + txtName.Text = objComment.AnonymousName + txtEmail.Text = objComment.AnonymousEmail + txtURL.Text = objComment.AnonymousURL + End If + + txtComment.Text = objComment.Comment.Replace("
      ", vbCrLf) + + End Sub + + Private Function FilterInput(ByVal stringToFilter As String) As String + + Dim objPortalSecurity As New PortalSecurity + + stringToFilter = objPortalSecurity.InputFilter(stringToFilter, PortalSecurity.FilterFlag.NoScripting) + + stringToFilter = Replace(stringToFilter, Chr(13), "") + stringToFilter = Replace(stringToFilter, ControlChars.Lf, "
      ") + + Return stringToFilter + + End Function + + Private Sub ReadQueryString() + + If (IsNumeric(Request("CommentID"))) Then + _commentID = Convert.ToInt32(Request("CommentID")) + End If + + If (Request("ReturnUrl") <> "") Then + _returnUrl = Request("ReturnUrl") + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load + + Try + + ReadQueryString() + + If IsPostBack = False Then + BindComment() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdUpdate_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdUpdate.Click + + Try + + If (Page.IsValid) Then + + + Dim objCommentController As New CommentController() + Dim objComment As CommentInfo = objCommentController.GetComment(_commentID) + + If (objComment IsNot Nothing) Then + + If (objComment.UserID = Null.NullInteger) Then + objComment.AnonymousName = txtName.Text + objComment.AnonymousEmail = txtEmail.Text + objComment.AnonymousURL = txtURL.Text + End If + + objComment.Comment = FilterInput(txtComment.Text) + objCommentController.UpdateComment(objComment) + + End If + + If (_returnUrl <> "") Then + Response.Redirect(_returnUrl, True) + Else + Response.Redirect(NavigateURL(), True) + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdCancel_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdCancel.Click + + Try + + If (_returnUrl <> "") Then + Response.Redirect(_returnUrl, True) + Else + Response.Redirect(NavigateURL(), True) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdDelete_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdDelete.Click + + Try + + Dim objCommentController As New CommentController() + Dim objComment As CommentInfo = objCommentController.GetComment(_commentID) + + If (objComment IsNot Nothing) Then + objCommentController.DeleteComment(_commentID, objComment.ArticleID) + End If + + If (_returnUrl <> "") Then + Response.Redirect(_returnUrl, True) + Else + Response.Redirect(NavigateURL(), True) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + + End Class + +End Namespace \ No newline at end of file diff --git a/ucEditCustomField.ascx b/ucEditCustomField.ascx new file mode 100755 index 0000000..43b06f0 --- /dev/null +++ b/ucEditCustomField.ascx @@ -0,0 +1,141 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditCustomField.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditCustomField" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + +
      + + + + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +
      + + +
      + + +
      + +
      + +
      + + + + + + +
      + +
      + +
      + + +
      +
      + + + + + + + + + + + + + + + + + + + + + +
      +
      + +
      + +
      + +
      +
      +
      +

      + +   + +   + +

      +
      \ No newline at end of file diff --git a/ucEditCustomField.ascx.designer.vb b/ucEditCustomField.ascx.designer.vb new file mode 100755 index 0000000..18a2728 --- /dev/null +++ b/ucEditCustomField.ascx.designer.vb @@ -0,0 +1,404 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditCustomField + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''dshCustomFieldDetails control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshCustomFieldDetails As Global.System.Web.UI.UserControl + + ''' + '''tblCustomFieldDetails control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblCustomFieldDetails As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblCustomFieldDetailsHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCustomFieldDetailsHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plName As Global.System.Web.UI.UserControl + + ''' + '''txtName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtName As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valName As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''plCaption control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCaption As Global.System.Web.UI.UserControl + + ''' + '''txtCaption control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtCaption As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valCaption control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valCaption As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''plCaptionHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCaptionHelp As Global.System.Web.UI.UserControl + + ''' + '''txtCaptionHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtCaptionHelp As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plFieldType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plFieldType As Global.System.Web.UI.UserControl + + ''' + '''drpFieldType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpFieldType As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''trFieldElements control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trFieldElements As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plFieldElements control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plFieldElements As Global.System.Web.UI.UserControl + + ''' + '''lstFieldElementType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstFieldElementType As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''pnlFieldElements control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlFieldElements As Global.System.Web.UI.WebControls.Panel + + ''' + '''txtFieldElements control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtFieldElements As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valFieldElements control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valFieldElements As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''lblFieldElementHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblFieldElementHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plDefaultValue control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plDefaultValue As Global.System.Web.UI.UserControl + + ''' + '''txtDefaultValue control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtDefaultValue As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plVisible control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plVisible As Global.System.Web.UI.UserControl + + ''' + '''chkVisible control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkVisible As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''trMaximumLength control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trMaximumLength As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plMaximumLength control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMaximumLength As Global.System.Web.UI.UserControl + + ''' + '''txtMaximumLength control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtMaximumLength As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valMaximumLengthIsNumber control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valMaximumLengthIsNumber As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''phRequired control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phRequired As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshRequiredDetails control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshRequiredDetails As Global.System.Web.UI.UserControl + + ''' + '''tblRequiredDetails control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblRequiredDetails As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblRequiredDetails control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblRequiredDetails As Global.System.Web.UI.WebControls.Label + + ''' + '''plRequired control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plRequired As Global.System.Web.UI.UserControl + + ''' + '''chkRequired control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkRequired As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plValidationType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plValidationType As Global.System.Web.UI.UserControl + + ''' + '''drpValidationType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpValidationType As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''trRegex control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trRegex As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plRegex control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plRegex As Global.System.Web.UI.UserControl + + ''' + '''txtRegex control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtRegex As Global.System.Web.UI.WebControls.TextBox + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdDelete control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdDelete As Global.System.Web.UI.WebControls.LinkButton + End Class +End Namespace diff --git a/ucEditCustomField.ascx.vb b/ucEditCustomField.ascx.vb new file mode 100755 index 0000000..1d6b816 --- /dev/null +++ b/ucEditCustomField.ascx.vb @@ -0,0 +1,298 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Components.CustomFields + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditCustomField + Inherits NewsArticleModuleBase + +#Region " Private Members " + + Private _customFieldID As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub AdjustFieldElements() + + Dim objFieldType As CustomFieldType = CType(System.Enum.Parse(GetType(CustomFieldValidationType), drpFieldType.SelectedIndex.ToString()), CustomFieldType) + + Select Case objFieldType + + Case CustomFieldType.CheckBox + phRequired.Visible = True + trMaximumLength.Visible = False + trFieldElements.Visible = False + + Case CustomFieldType.DropDownList + phRequired.Visible = True + trMaximumLength.Visible = False + trFieldElements.Visible = True + + Case CustomFieldType.MultiCheckBox + phRequired.Visible = True + trMaximumLength.Visible = False + trFieldElements.Visible = True + + Case CustomFieldType.MultiLineTextBox + phRequired.Visible = True + trMaximumLength.Visible = True + trFieldElements.Visible = False + + Case CustomFieldType.OneLineTextBox + phRequired.Visible = True + trMaximumLength.Visible = True + trFieldElements.Visible = False + + Case CustomFieldType.RadioButton + phRequired.Visible = True + trMaximumLength.Visible = False + trFieldElements.Visible = True + + Case CustomFieldType.RichTextBox + phRequired.Visible = True + trMaximumLength.Visible = False + trFieldElements.Visible = False + + End Select + + End Sub + + Private Sub AdjustValidationType() + + If (drpValidationType.SelectedValue = CType(CustomFieldValidationType.Regex, Integer).ToString()) Then + trRegex.Visible = True + Else + trRegex.Visible = False + End If + + End Sub + + Private Sub BindCustomField() + + If (_customFieldID = Null.NullInteger) Then + + AdjustFieldElements() + AdjustValidationType() + cmdDelete.Visible = False + + Else + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFieldInfo As CustomFieldInfo = objCustomFieldController.Get(_customFieldID) + + If Not (objCustomFieldInfo Is Nothing) Then + + txtName.Text = objCustomFieldInfo.Name + txtCaption.Text = objCustomFieldInfo.Caption + txtCaptionHelp.Text = objCustomFieldInfo.CaptionHelp + If Not (drpFieldType.Items.FindByValue(objCustomFieldInfo.FieldType.ToString()) Is Nothing) Then + drpFieldType.SelectedValue = objCustomFieldInfo.FieldType.ToString() + End If + txtFieldElements.Text = objCustomFieldInfo.FieldElements + AdjustFieldElements() + + txtDefaultValue.Text = objCustomFieldInfo.DefaultValue + chkVisible.Checked = objCustomFieldInfo.IsVisible + If (objCustomFieldInfo.Length <> Null.NullInteger) Then + txtMaximumLength.Text = objCustomFieldInfo.Length.ToString() + End If + + chkRequired.Checked = objCustomFieldInfo.IsRequired + If Not (drpValidationType.Items.FindByValue(CType(objCustomFieldInfo.ValidationType, Integer).ToString()) Is Nothing) Then + drpValidationType.SelectedValue = CType(objCustomFieldInfo.ValidationType, Integer).ToString() + End If + txtRegex.Text = objCustomFieldInfo.RegularExpression + AdjustValidationType() + + End If + + End If + + + End Sub + + Private Sub BindFieldTypes() + + For Each value As Integer In System.Enum.GetValues(GetType(CustomFieldType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(CustomFieldType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(CustomFieldType), value), Me.LocalResourceFile) + drpFieldType.Items.Add(li) + Next + + End Sub + + Private Sub BindValidationTypes() + + For Each value As Integer In System.Enum.GetValues(GetType(CustomFieldValidationType)) + Dim li As New ListItem + li.Value = value.ToString() + li.Text = Localization.GetString(System.Enum.GetName(GetType(CustomFieldValidationType), value), Me.LocalResourceFile) + drpValidationType.Items.Add(li) + Next + + End Sub + + Private Sub ReadQueryString() + + If Not (Request("CustomFieldID") Is Nothing) Then + _customFieldID = Convert.ToInt32(Request("CustomFieldID")) + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load + + Try + + ReadQueryString() + + If (Page.IsPostBack = False) Then + + BindFieldTypes() + BindValidationTypes() + BindCustomField() + + Page.SetFocus(txtName) + cmdDelete.Attributes.Add("onClick", "javascript:return confirm('" & Localization.GetString("Confirmation", LocalResourceFile) & "');") + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdUpdate.Click + + Try + + If (Page.IsValid) Then + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFieldInfo As New CustomFieldInfo + + objCustomFieldInfo.ModuleID = Me.ModuleId + + objCustomFieldInfo.Name = txtName.Text + objCustomFieldInfo.Caption = txtCaption.Text + objCustomFieldInfo.CaptionHelp = txtCaptionHelp.Text + objCustomFieldInfo.FieldType = CType(System.Enum.Parse(GetType(CustomFieldType), drpFieldType.SelectedIndex.ToString()), CustomFieldType) + objCustomFieldInfo.FieldElements = txtFieldElements.Text + + objCustomFieldInfo.DefaultValue = txtDefaultValue.Text + objCustomFieldInfo.IsVisible = chkVisible.Checked + If (txtMaximumLength.Text.Trim() = "") Then + objCustomFieldInfo.Length = Null.NullInteger + Else + objCustomFieldInfo.Length = Convert.ToInt32(txtMaximumLength.Text) + If (objCustomFieldInfo.Length <= 0) Then + objCustomFieldInfo.Length = Null.NullInteger + End If + End If + + objCustomFieldInfo.IsRequired = chkRequired.Checked + objCustomFieldInfo.ValidationType = CType(System.Enum.Parse(GetType(CustomFieldValidationType), drpValidationType.SelectedIndex.ToString()), CustomFieldValidationType) + objCustomFieldInfo.RegularExpression = txtRegex.Text + + If (_customFieldID = Null.NullInteger) Then + + Dim objCustomFields As ArrayList = objCustomFieldController.List(Me.ModuleId) + + If (objCustomFields.Count = 0) Then + objCustomFieldInfo.SortOrder = 0 + Else + objCustomFieldInfo.SortOrder = CType(objCustomFields(objCustomFields.Count - 1), CustomFieldInfo).SortOrder + 1 + End If + + objCustomFieldController.Add(objCustomFieldInfo) + + Else + + Dim objCustomFieldInfoOld As CustomFieldInfo = objCustomFieldController.Get(_customFieldID) + + objCustomFieldInfo.SortOrder = objCustomFieldInfoOld.SortOrder + objCustomFieldInfo.CustomFieldID = _customFieldID + objCustomFieldController.Update(objCustomFieldInfo) + + End If + + Response.Redirect(EditUrl("EditCustomFields"), True) + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(EditUrl("EditCustomFields"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdDelete_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdDelete.Click + + Try + + Dim objCustomFieldController As New CustomFieldController + objCustomFieldController.Delete(Me.ModuleId, _customFieldID) + + Response.Redirect(EditUrl("EditCustomFields"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub drpFieldType_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles drpFieldType.SelectedIndexChanged + + Try + + AdjustFieldElements() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub drpValidationType_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles drpValidationType.SelectedIndexChanged + + Try + + AdjustValidationType() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucEditCustomFields.ascx b/ucEditCustomFields.ascx new file mode 100755 index 0000000..59e7034 --- /dev/null +++ b/ucEditCustomFields.ascx @@ -0,0 +1,40 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditCustomFields.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditCustomFields" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + +
      + + + + + + + + + + + + + + + + + + + + + + + + +
      +
      +
      +
      +
      +
      +

      + +

      + diff --git a/ucEditCustomFields.ascx.designer.vb b/ucEditCustomFields.ascx.designer.vb new file mode 100755 index 0000000..e138280 --- /dev/null +++ b/ucEditCustomFields.ascx.designer.vb @@ -0,0 +1,53 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditCustomFields + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''grdCustomFields control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdCustomFields As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''lblNoCustomFields control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoCustomFields As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdAddCustomField control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdAddCustomField As Global.System.Web.UI.WebControls.LinkButton + End Class +End Namespace diff --git a/ucEditCustomFields.ascx.vb b/ucEditCustomFields.ascx.vb new file mode 100755 index 0000000..480ebfa --- /dev/null +++ b/ucEditCustomFields.ascx.vb @@ -0,0 +1,157 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Components.CustomFields + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditCustomFields + Inherits NewsArticleModuleBase + +#Region " Private Members " + + Dim _customFields As ArrayList + +#End Region + +#Region " Private Methods " + + Private Sub BindCustomFields() + + Localization.LocalizeDataGrid(grdCustomFields, Me.LocalResourceFile) + + Dim objCustomFieldController As New CustomFieldController() + + _customFields = objCustomFieldController.List(Me.ModuleId) + grdCustomFields.DataSource = _customFields + + grdCustomFields.DataBind() + + If (grdCustomFields.Items.Count = 0) Then + grdCustomFields.Visible = False + lblNoCustomFields.Visible = True + Else + grdCustomFields.Visible = True + lblNoCustomFields.Visible = False + End If + + End Sub + +#End Region + +#Region " Protected Methods " + + Protected Function GetCustomFieldEditUrl(ByVal customFieldID As String) As String + + Return EditArticleUrl("EditCustomField", "CustomFieldID=" & customFieldID) + + End Function + +#End Region + +#Region " Event Handlers " + + Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load + + If (Page.IsPostBack = False) Then + BindCustomFields() + End If + + End Sub + + Protected Sub cmdAddCustomField_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdAddCustomField.Click + + Response.Redirect(EditArticleUrl("EditCustomField"), True) + + End Sub + + Private Sub grdCustomFields_ItemDataBound(ByVal sender As System.Object, ByVal e As System.Web.UI.WebControls.DataGridItemEventArgs) Handles grdCustomFields.ItemDataBound + + If (e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem) Then + + Dim btnUp As ImageButton = CType(e.Item.FindControl("btnUp"), ImageButton) + Dim btnDown As ImageButton = CType(e.Item.FindControl("btnDown"), ImageButton) + + Dim objCustomField As CustomFieldInfo = CType(e.Item.DataItem, CustomFieldInfo) + + If Not (btnUp Is Nothing And btnDown Is Nothing) Then + + If (objCustomField.CustomFieldID = CType(_customFields(0), CustomFieldInfo).CustomFieldID) Then + btnUp.Visible = False + End If + + If (objCustomField.CustomFieldID = CType(_customFields(_customFields.Count - 1), CustomFieldInfo).CustomFieldID) Then + btnDown.Visible = False + End If + + btnUp.CommandArgument = objCustomField.CustomFieldID.ToString() + btnUp.CommandName = "Up" + + btnDown.CommandArgument = objCustomField.CustomFieldID.ToString() + btnDown.CommandName = "Down" + + End If + + End If + + End Sub + + Private Sub grdCustomFields_ItemCommand(ByVal sender As System.Object, ByVal e As System.Web.UI.WebControls.DataGridCommandEventArgs) Handles grdCustomFields.ItemCommand + + Dim objCustomFieldController As New CustomFieldController + _customFields = objCustomFieldController.List(Me.ModuleId) + + Dim customFieldID As Integer = Convert.ToInt32(e.CommandArgument) + + For i As Integer = 0 To _customFields.Count - 1 + + Dim objCustomField As CustomFieldInfo = CType(_customFields(i), CustomFieldInfo) + + If (customFieldID = objCustomField.CustomFieldID) Then + + If (e.CommandName = "Up") Then + + Dim objCustomFieldToSwap As CustomFieldInfo = CType(_customFields(i - 1), CustomFieldInfo) + + Dim sortOrder As Integer = objCustomField.SortOrder + Dim sortOrderPrevious As Integer = objCustomFieldToSwap.SortOrder + + objCustomField.SortOrder = sortOrderPrevious + objCustomFieldToSwap.SortOrder = sortOrder + + objCustomFieldController.Update(objCustomField) + objCustomFieldController.Update(objCustomFieldToSwap) + + End If + + + If (e.CommandName = "Down") Then + + Dim objCustomFieldToSwap As CustomFieldInfo = CType(_customFields(i + 1), CustomFieldInfo) + + Dim sortOrder As Integer = objCustomField.SortOrder + Dim sortOrderNext As Integer = objCustomFieldToSwap.SortOrder + + objCustomField.SortOrder = sortOrderNext + objCustomFieldToSwap.SortOrder = sortOrder + + objCustomFieldController.Update(objCustomField) + objCustomFieldController.Update(objCustomFieldToSwap) + + End If + + End If + + Next + + Response.Redirect(Request.RawUrl, True) + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucEditPage.ascx b/ucEditPage.ascx new file mode 100755 index 0000000..875aa07 --- /dev/null +++ b/ucEditPage.ascx @@ -0,0 +1,53 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditPage.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditPage" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="TextEditor" Src="~/controls/TextEditor.ascx"%> + +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + + +
      + + + + + + + + + + + + + + + + + + + + +
      + + + + +
      +
      + +
      +
      +
      +

      + +   + +   + +

      + + diff --git a/ucEditPage.ascx.designer.vb b/ucEditPage.ascx.designer.vb new file mode 100755 index 0000000..67e2923 --- /dev/null +++ b/ucEditPage.ascx.designer.vb @@ -0,0 +1,152 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditPage + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''pnlSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSettings As Global.System.Web.UI.WebControls.Panel + + ''' + '''dshPage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshPage As Global.System.Web.UI.UserControl + + ''' + '''tblPage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblPage As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblPageSettingsHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblPageSettingsHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTitle As Global.System.Web.UI.UserControl + + ''' + '''txtTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTitle As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valTitle As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''plSummary control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSummary As Global.System.Web.UI.UserControl + + ''' + '''txtSummary control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtSummary As Global.System.Web.UI.UserControl + + ''' + '''valSummary control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valSummary As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdDelete control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdDelete As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucEditPage.ascx.vb b/ucEditPage.ascx.vb new file mode 100755 index 0000000..c9c43ab --- /dev/null +++ b/ucEditPage.ascx.vb @@ -0,0 +1,199 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.UI.UserControls + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditPage + Inherits NewsArticleModuleBase + +#Region " Private Properties " + + Private ReadOnly Property Summary() As TextEditor + Get + Return CType(txtSummary, TextEditor) + End Get + End Property + +#End Region + +#Region " Private Members " + + Private _pageID As Integer = Null.NullInteger + Private _articleID As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub ReadQueryString() + + If (IsNumeric(Request("ArticleID"))) Then + _articleID = Convert.ToInt32(Request("ArticleID")) + End If + + If (IsNumeric(Request("PageID"))) Then + _pageID = Convert.ToInt32(Request("PageID")) + End If + + + End Sub + + Private Sub CheckSecurity() + + If (HasEditRights(_articleID, Me.ModuleId, Me.TabId) = False) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthorized", ArticleSettings), True) + End If + + End Sub + + Private Sub BindPage() + + If (_pageID = Null.NullInteger) Then + + cmdDelete.Visible = False + Else + + cmdDelete.Visible = True + cmdDelete.Attributes.Add("onClick", "javascript:return confirm('Are You Sure You Wish To Delete This Item ?');") + + Dim objPageController As New PageController + Dim objPage As PageInfo = objPageController.GetPage(_pageID) + + If Not (objPage Is Nothing) Then + txtTitle.Text = objPage.Title + Summary.Text = objPage.PageText + End If + + End If + + End Sub + + Private Sub SetTextEditor() + + Summary.Width = Unit.Parse(ArticleSettings.TextEditorWidth) + Summary.Height = Unit.Parse(ArticleSettings.TextEditorHeight) + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + ReadQueryString() + CheckSecurity() + + If (IsPostBack = False) Then + + BindPage() + SetTextEditor() + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdUpdate.Click + + Try + + If (Page.IsValid) Then + + Dim objPageController As PageController = New PageController + + Dim objPage As PageInfo = New PageInfo + + If (_pageID <> Null.NullInteger) Then + + objPage = objPageController.GetPage(_pageID) + + Else + + objPage = CType(CBO.InitializeObject(objPage, GetType(PageInfo)), PageInfo) + + End If + + objPage.Title = txtTitle.Text + objPage.PageText = Summary.Text + objPage.ArticleID = _articleID + + If (_pageID = Null.NullInteger) Then + + objPageController.AddPage(objPage) + + Else + + If (objPage.SortOrder = 0) Then + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + + If (objArticle IsNot Nothing) Then + If (objArticle.Title <> objPage.Title) Then + objArticle.Title = objPage.Title + objArticleController.UpdateArticle(objArticle) + End If + End If + End If + + objPageController.UpdatePage(objPage) + + End If + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "EditPages", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdDelete_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdDelete.Click + + Try + + Dim objPageController As New PageController + objPageController.DeletePage(_pageID) + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "EditPages", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "EditPages", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucEditPageSortOrder.ascx b/ucEditPageSortOrder.ascx new file mode 100755 index 0000000..f76142b --- /dev/null +++ b/ucEditPageSortOrder.ascx @@ -0,0 +1,57 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditPageSortOrder.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditPageSortOrder" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + + +
      + + + + + + + + + + + +
      + + + + + + +
      + + + + + + + + + + + +
      + +
      + +
      +
      +
      +
      +
      +

      + +   + +

      + + \ No newline at end of file diff --git a/ucEditPageSortOrder.ascx.designer.vb b/ucEditPageSortOrder.ascx.designer.vb new file mode 100755 index 0000000..032ae93 --- /dev/null +++ b/ucEditPageSortOrder.ascx.designer.vb @@ -0,0 +1,125 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditPageSortOrder + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''pnlSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSettings As Global.System.Web.UI.WebControls.Panel + + ''' + '''dshPage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshPage As Global.System.Web.UI.UserControl + + ''' + '''tblSortOrder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSortOrder As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblSortOrderHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSortOrderHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plSortOrder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSortOrder As Global.System.Web.UI.UserControl + + ''' + '''lstSortOrder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstSortOrder As Global.System.Web.UI.WebControls.ListBox + + ''' + '''upBtn control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents upBtn As Global.System.Web.UI.WebControls.ImageButton + + ''' + '''downBtn control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents downBtn As Global.System.Web.UI.WebControls.ImageButton + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucEditPageSortOrder.ascx.vb b/ucEditPageSortOrder.ascx.vb new file mode 100755 index 0000000..4d8beb6 --- /dev/null +++ b/ucEditPageSortOrder.ascx.vb @@ -0,0 +1,175 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditPageSortOrder + Inherits NewsArticleModuleBase + +#Region " Private Members " + + Private _articleID As Integer + +#End Region + +#Region " Private Methods " + + Private Sub ReadQueryString() + + If (IsNumeric(Request("ArticleID"))) Then + _articleID = Convert.ToInt32(Request("ArticleID")) + End If + + End Sub + + Private Sub CheckSecurity() + + If (HasEditRights(_articleID, Me.ModuleId, Me.TabId) = False) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthorized", ArticleSettings), True) + End If + + End Sub + + Private Sub BindOrder() + + Dim objPageController As PageController = New PageController + + lstSortOrder.DataSource = objPageController.GetPageList(_articleID) + lstSortOrder.DataBind() + + If (lstSortOrder.Items.Count = 0) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "EditPages", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + ReadQueryString() + + If (IsPostBack = False) Then + + CheckSecurity() + BindOrder() + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdUpdate.Click + + Try + + Dim objPageController As PageController = New PageController + + For i As Integer = 0 To lstSortOrder.Items.Count - 1 + + Dim objPage As PageInfo = objPageController.GetPage(Convert.ToInt32(lstSortOrder.Items(i).Value)) + objPage.SortOrder = i + objPageController.UpdatePage(objPage) + + Next + + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "EditPages", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "EditPages", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub upBtn_Click(ByVal sender As System.Object, ByVal e As System.Web.UI.ImageClickEventArgs) Handles upBtn.Click + + Try + + If (lstSortOrder.SelectedIndex <> -1) Then + + If (lstSortOrder.SelectedIndex <> 0) Then + + Dim tempIndex As Integer = lstSortOrder.SelectedIndex + + Dim newListItem As ListItem = New ListItem + + newListItem.Text = lstSortOrder.SelectedItem.Text + newListItem.Value = lstSortOrder.SelectedItem.Value + + lstSortOrder.Items.RemoveAt(tempIndex) + + lstSortOrder.Items.Insert(tempIndex - 1, newListItem) + lstSortOrder.SelectedIndex = tempIndex - 1 + + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub downBtn_Click(ByVal sender As System.Object, ByVal e As System.Web.UI.ImageClickEventArgs) Handles downBtn.Click + + Try + + If (lstSortOrder.SelectedIndex <> -1) Then + + If (lstSortOrder.SelectedIndex <> lstSortOrder.Items.Count - 1) Then + + Dim tempIndex As Integer = lstSortOrder.SelectedIndex + + Dim newListItem As ListItem = New ListItem + + newListItem.Text = lstSortOrder.SelectedItem.Text + newListItem.Value = lstSortOrder.SelectedItem.Value + + lstSortOrder.Items.RemoveAt(tempIndex) + + lstSortOrder.Items.Insert(tempIndex + 1, newListItem) + lstSortOrder.SelectedIndex = tempIndex + 1 + + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + End Class + +End Namespace \ No newline at end of file diff --git a/ucEditPages.ascx b/ucEditPages.ascx new file mode 100755 index 0000000..6359a90 --- /dev/null +++ b/ucEditPages.ascx @@ -0,0 +1,28 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditPages.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditPages" %> +<%@ Import Namespace="DotNetNuke.Common" %> +<%@ Import Namespace="DotNetNuke.Common.Utilities" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + + + + + + + + + + + + +

      + + + + +

      + + \ No newline at end of file diff --git a/ucEditPages.ascx.designer.vb b/ucEditPages.ascx.designer.vb new file mode 100755 index 0000000..7c43f5b --- /dev/null +++ b/ucEditPages.ascx.designer.vb @@ -0,0 +1,98 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditPages + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTitle As Global.System.Web.UI.WebControls.Label + + ''' + '''grdPages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdPages As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''lblNoPages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoPages As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdAddPage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdAddPage As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdSortOrder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdSortOrder As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdSummary control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdSummary As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdSubmitApproval control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdSubmitApproval As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucEditPages.ascx.vb b/ucEditPages.ascx.vb new file mode 100755 index 0000000..1c7c9a5 --- /dev/null +++ b/ucEditPages.ascx.vb @@ -0,0 +1,215 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditPages + Inherits NewsArticleModuleBase + +#Region " Private Members " + + Private _articleID As Integer + +#End Region + +#Region " Private Methods " + + Private Sub ReadQueryString() + + If (IsNumeric(Request("ArticleID"))) Then + _articleID = Convert.ToInt32(Request("ArticleID")) + End If + + + End Sub + + Private Sub CheckSecurity() + + If (HasEditRights(_articleID, Me.ModuleId, Me.TabId) = False) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthorized", ArticleSettings), True) + End If + + End Sub + + Private Sub BindArticle() + + If (_articleID = Null.NullInteger) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthorized", ArticleSettings), True) + End If + + Dim objArticleController As ArticleController = New ArticleController + + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + + If (objArticle Is Nothing) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthorized", ArticleSettings), True) + End If + + lblTitle.Text = String.Format(DotNetNuke.Services.Localization.Localization.GetString("EditPages.Text", LocalResourceFile), objArticle.Title) + + If (objArticle.IsDraft) Then + cmdSubmitApproval.Visible = True + cmdSubmitApproval.Attributes.Add("onClick", "javascript:return confirm('" & DotNetNuke.Services.Localization.Localization.GetString("SubmitApproval.Text", LocalResourceFile) & "');") + Else + cmdSubmitApproval.Visible = False + End If + + End Sub + + Private Sub BindPages() + + Dim objPageController As PageController = New PageController + + DotNetNuke.Services.Localization.Localization.LocalizeDataGrid(grdPages, Me.LocalResourceFile) + + grdPages.DataSource = objPageController.GetPageList(_articleID) + grdPages.DataBind() + + If (grdPages.Items.Count > 0) Then + grdPages.Visible = True + lblNoPages.Visible = False + Else + grdPages.Visible = False + lblNoPages.Visible = True + lblNoPages.Text = DotNetNuke.Services.Localization.Localization.GetString("NoPagesMessage.Text", LocalResourceFile) + End If + + End Sub + +#End Region + +#Region " Protected Methods " + + Protected Function GetEditPageUrl(ByVal articleID As String, ByVal pageID As String) As String + + Return Common.GetModuleLink(TabId, ModuleId, "EditPage", ArticleSettings, "ArticleID=" & articleID, "PageID=" & pageID) + + End Function + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + Try + + ReadQueryString() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + CheckSecurity() + BindPages() + + If (IsPostBack = False) Then + BindArticle() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdAddPage_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdAddPage.Click + + Try + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "EditPage", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdSortOrder_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdSortOrder.Click + + Try + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "EditSortOrder", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdSummary_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdSummary.Click + + Try + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "SubmitNews", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdSubmitApproval_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdSubmitApproval.Click + + Try + + Dim objLogController As New DotNetNuke.Services.Log.EventLog.EventLogController + + Dim objController As New ArticleController + Dim objArticle As ArticleInfo = objController.GetArticle(_articleID) + + If Not (objArticle Is Nothing) Then + objArticle.Status = StatusType.AwaitingApproval + objController.UpdateArticle(objArticle) + + If (Settings.Contains(ArticleConstants.NOTIFY_SUBMISSION_SETTING)) Then + If (Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_SUBMISSION_SETTING)) = True) Then + Dim objEmailTemplateController As New EmailTemplateController + Dim emails As String = objEmailTemplateController.GetApproverDistributionList(ModuleId) + + For Each email As String In emails.Split(Convert.ToChar(";")) + If (email <> "") Then + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, EmailTemplateType.ArticleSubmission, email, ArticleSettings) + End If + Next + End If + End If + + If (Settings.Contains(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL)) Then + If (Settings(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL).ToString() <> "") Then + Dim objEmailTemplateController As New EmailTemplateController + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, EmailTemplateType.ArticleSubmission, Settings(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL).ToString(), ArticleSettings) + End If + End If + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "SubmitNewsComplete", ArticleSettings, "ArticleID=" & _articleID.ToString()), True) + + Else + ProcessModuleLoadException(Me, New Exception("Unable to Retrieve Article to Submit for Approval")) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucEditTag.ascx b/ucEditTag.ascx new file mode 100755 index 0000000..54268ec --- /dev/null +++ b/ucEditTag.ascx @@ -0,0 +1,44 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditTag.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditTag" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + +
      + + + + + + + + + + + +
      +
      + + +
      +
      +
      +

      + +   + +   + +

      diff --git a/ucEditTag.ascx.designer.vb b/ucEditTag.ascx.designer.vb new file mode 100755 index 0000000..dea361e --- /dev/null +++ b/ucEditTag.ascx.designer.vb @@ -0,0 +1,116 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditTag + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''pnlSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSettings As Global.System.Web.UI.WebControls.Panel + + ''' + '''dshTag control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshTag As Global.System.Web.UI.UserControl + + ''' + '''tblTag control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblTag As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblTagSettingsHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTagSettingsHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plName As Global.System.Web.UI.UserControl + + ''' + '''txtName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtName As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valName As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdDelete control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdDelete As Global.System.Web.UI.WebControls.LinkButton + End Class +End Namespace diff --git a/ucEditTag.ascx.vb b/ucEditTag.ascx.vb new file mode 100755 index 0000000..8d3c28b --- /dev/null +++ b/ucEditTag.ascx.vb @@ -0,0 +1,148 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditTag + Inherits NewsArticleModuleBase + + +#Region " Private Members " + + Private _tagID As Integer = Null.NullInteger + Private _photoCount As Integer = 0 + Private _albumCount As Integer = 0 + +#End Region + +#Region " Private Methods " + + Private Sub ReadQueryString() + + If Not (Request("TagID") Is Nothing) Then + _tagID = Convert.ToInt32(Request("TagID")) + End If + + End Sub + + Private Sub BindTag() + + If (_tagID = Null.NullInteger) Then + + cmdDelete.Visible = False + + Else + + cmdDelete.Visible = True + cmdDelete.Attributes.Add("onClick", "javascript:return confirm('" & Localization.GetString("Confirmation", LocalResourceFile) & "');") + + Dim objTagController As New TagController + Dim objTag As TagInfo = objTagController.Get(_tagID) + + If Not (objTag Is Nothing) Then + txtName.Text = objTag.Name + End If + + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + ReadQueryString() + + If (IsPostBack = False) Then + + BindTag() + txtName.Focus() + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdUpdate.Click + + + Try + + If (Page.IsValid) Then + + Dim objTagController As New TagController + + Dim objTag As TagInfo = objTagController.Get(ModuleId, txtName.Text) + If (objTag Is Nothing) Then + objTag = New TagInfo + + If (_tagID <> Null.NullInteger) Then + objTag = objTagController.Get(_tagID) + Else + objTag = CType(CBO.InitializeObject(objTag, GetType(TagInfo)), TagInfo) + End If + + objTag.ModuleID = Me.ModuleId + objTag.Name = txtName.Text + objTag.NameLowered = txtName.Text.ToLower() + + If (_tagID = Null.NullInteger) Then + objTagController.Add(objTag) + Else + objTagController.Update(objTag) + End If + End If + + Response.Redirect(EditUrl("EditTags"), True) + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdDelete_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdDelete.Click + + Try + + Dim objTagController As New TagController + objTagController.DeleteArticleTagByTag(_tagID) + objTagController.Delete(_tagID) + + Response.Redirect(EditUrl("EditTags"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(EditUrl("EditTags"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucEditTags.ascx b/ucEditTags.ascx new file mode 100755 index 0000000..d12f999 --- /dev/null +++ b/ucEditTags.ascx @@ -0,0 +1,20 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEditTags.ascx.vb" Inherits="Ventrian.NewsArticles.ucEditTags" %> +<%@ Import Namespace="DotNetNuke.Common" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + + + + + + + + + + +

      + +

      diff --git a/ucEditTags.ascx.designer.vb b/ucEditTags.ascx.designer.vb new file mode 100755 index 0000000..541b88c --- /dev/null +++ b/ucEditTags.ascx.designer.vb @@ -0,0 +1,53 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditTags + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''grdTags control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdTags As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''lblNoTags control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoTags As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdAddTag control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdAddTag As Global.System.Web.UI.WebControls.LinkButton + End Class +End Namespace diff --git a/ucEditTags.ascx.vb b/ucEditTags.ascx.vb new file mode 100755 index 0000000..5f67871 --- /dev/null +++ b/ucEditTags.ascx.vb @@ -0,0 +1,60 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEditTags + Inherits NewsArticleModuleBase + +#Region " Private Methods " + + Private Sub BindTags() + + Dim objTagController As New TagController + + Localization.LocalizeDataGrid(grdTags, Me.LocalResourceFile) + + grdTags.DataSource = objTagController.List(Me.ModuleId, Null.NullInteger) + grdTags.DataBind() + + If (grdTags.Items.Count > 0) Then + grdTags.Visible = True + lblNoTags.Visible = False + Else + grdTags.Visible = False + lblNoTags.Visible = True + lblNoTags.Text = Localization.GetString("NoTagsMessage.Text", LocalResourceFile) + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + BindTags() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdAddTag_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdAddTag.Click + + Response.Redirect(EditUrl("EditTag"), True) + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucEmailTemplates.ascx b/ucEmailTemplates.ascx new file mode 100755 index 0000000..0b70987 --- /dev/null +++ b/ucEmailTemplates.ascx @@ -0,0 +1,225 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucEmailTemplates.ascx.vb" Inherits="Ventrian.NewsArticles.ucEmailTemplates" %> + +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="TextEditor" Src="~/controls/TextEditor.ascx"%> + +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + + +
      + + + + + + + + + + + + + + + + + + + + + +
      + +
      + + +
      + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      [USERNAME] + +
      [EMAIL] + +
      [DISPLAYNAME] + +
      [FIRSTNAME] + +
      [LASTNAME] + +
      [FULLNAME] + +
      [PORTALNAME] + +
      [CREATEDATE] + +
      [POSTDATE] + +
      [TITLE] + +
      [SUMMARY] + +
      [LINK] + +

      [DISPLAYNAME] + +
      [EMAIL] + +
      [USERNAME] + +
      [FIRSTNAME] + +
      [LASTNAME] + +
      [FULLNAME] + +
      [PORTALNAME] + +
      [POSTDATE] + +
      [TITLE] + +
      [COMMENT] + +
      [LINK] + +
      +
      +
      +

      + +   + +

      + + diff --git a/ucEmailTemplates.ascx.designer.vb b/ucEmailTemplates.ascx.designer.vb new file mode 100755 index 0000000..1dfa4c0 --- /dev/null +++ b/ucEmailTemplates.ascx.designer.vb @@ -0,0 +1,395 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEmailTemplates + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''pnlSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSettings As Global.System.Web.UI.WebControls.Panel + + ''' + '''dshEmailTemplates control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshEmailTemplates As Global.System.Web.UI.UserControl + + ''' + '''tblEmailTemplates control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblEmailTemplates As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblEmailTemplatesHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblEmailTemplatesHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plName As Global.System.Web.UI.UserControl + + ''' + '''drpTemplate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpTemplate As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plSubject control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSubject As Global.System.Web.UI.UserControl + + ''' + '''txtSubject control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtSubject As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valSubject control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valSubject As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''plTemplate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTemplate As Global.System.Web.UI.UserControl + + ''' + '''txtTemplate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTemplate As Global.System.Web.UI.WebControls.TextBox + + ''' + '''dshEmailTemplateHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshEmailTemplateHelp As Global.System.Web.UI.UserControl + + ''' + '''tblEmailTemplateHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblEmailTemplateHelp As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblTemplateArticleHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTemplateArticleHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''lblUserName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblUserName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblEmail As Global.System.Web.UI.WebControls.Label + + ''' + '''lblDisplayName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblDisplayName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblFirstName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblFirstName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblLastName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblLastName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblFullName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblFullName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblPortalName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblPortalName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCreateDate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCreateDate As Global.System.Web.UI.WebControls.Label + + ''' + '''lblPostDate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblPostDate As Global.System.Web.UI.WebControls.Label + + ''' + '''lblTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTitle As Global.System.Web.UI.WebControls.Label + + ''' + '''lblSummary control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSummary As Global.System.Web.UI.WebControls.Label + + ''' + '''lblLink control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblLink As Global.System.Web.UI.WebControls.Label + + ''' + '''lblTemplateCommentHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTemplateCommentHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCommentDisplayName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCommentDisplayName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCommentEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCommentEmail As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCommentUserName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCommentUserName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCommentFirstName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCommentFirstName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCommentLastName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCommentLastName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCommentFullName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCommentFullName As Global.System.Web.UI.WebControls.Label + + ''' + '''lblPortalName2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblPortalName2 As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCommentPostDate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCommentPostDate As Global.System.Web.UI.WebControls.Label + + ''' + '''lblTitle2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTitle2 As Global.System.Web.UI.WebControls.Label + + ''' + '''lblComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblComment As Global.System.Web.UI.WebControls.Label + + ''' + '''lblCommentLink control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCommentLink As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucEmailTemplates.ascx.vb b/ucEmailTemplates.ascx.vb new file mode 100755 index 0000000..e18f5df --- /dev/null +++ b/ucEmailTemplates.ascx.vb @@ -0,0 +1,106 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Services.Exceptions + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucEmailTemplates + Inherits NewsArticleModuleBase + +#Region " Private Methods " + + Private Sub BindTemplateTypes() + + drpTemplate.DataSource = System.Enum.GetValues(GetType(EmailTemplateType)) + drpTemplate.DataBind() + + End Sub + + Private Sub BindTemplate() + + Dim objTemplateController As New EmailTemplateController + + Dim objTemplate As EmailTemplateInfo = objTemplateController.Get(Me.ModuleId, CType(System.Enum.Parse(GetType(EmailTemplateType), drpTemplate.SelectedValue), EmailTemplateType)) + + If Not (objTemplate Is Nothing) Then + + txtSubject.Text = objTemplate.Subject + txtTemplate.Text = objTemplate.Template + + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + If (IsPostBack = False) Then + BindTemplateTypes() + BindTemplate() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub drpTemplate_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles drpTemplate.SelectedIndexChanged + + Try + + BindTemplate() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdUpdate.Click + + Try + + Dim objTemplateController As New EmailTemplateController + + Dim objTemplate As EmailTemplateInfo = objTemplateController.Get(Me.ModuleId, CType(System.Enum.Parse(GetType(EmailTemplateType), drpTemplate.SelectedValue), EmailTemplateType)) + + objTemplate.Subject = txtSubject.Text + objTemplate.Template = txtTemplate.Text + + objTemplateController.Update(objTemplate) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(EditArticleUrl("AdminOptions"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucHeader.ascx b/ucHeader.ascx new file mode 100755 index 0000000..22cc00a --- /dev/null +++ b/ucHeader.ascx @@ -0,0 +1,2 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucHeader.ascx.vb" Inherits="Ventrian.NewsArticles.ucHeader" %> + \ No newline at end of file diff --git a/ucHeader.ascx.designer.vb b/ucHeader.ascx.designer.vb new file mode 100755 index 0000000..eec2bf8 --- /dev/null +++ b/ucHeader.ascx.designer.vb @@ -0,0 +1,26 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucHeader + + ''' + '''plhControls control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plhControls As Global.System.Web.UI.WebControls.PlaceHolder + End Class +End Namespace diff --git a/ucHeader.ascx.vb b/ucHeader.ascx.vb new file mode 100755 index 0000000..24e4238 --- /dev/null +++ b/ucHeader.ascx.vb @@ -0,0 +1,104 @@ +Imports DotNetNuke.Services.Exceptions +Imports Ventrian.NewsArticles.Components.Types + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucHeader + Inherits NewsArticleControlBase + +#Region " Private Members " + + Private _selectedMenu As MenuOptionType = MenuOptionType.CurrentArticles + Private _menuPosition As MenuPositionType = MenuPositionType.Top + Private _processMenu As Boolean = False + +#End Region + +#Region " Public Properties " + + Public WriteOnly Property MenuPosition() As String + Set(ByVal value As String) + Select Case value.ToLower() + + Case "top" + _menuPosition = MenuPositionType.Top + Return + + Case "bottom" + _menuPosition = MenuPositionType.Bottom + Return + + End Select + End Set + End Property + + Public WriteOnly Property SelectedMenu() As String + Set(ByVal value As String) + Select Case Value.ToLower() + + Case "adminoptions" + _selectedMenu = MenuOptionType.AdminOptions + Return + + Case "approvearticles" + _selectedMenu = MenuOptionType.ApproveArticles + Return + + Case "approvecomments" + _selectedMenu = MenuOptionType.ApproveComments + Return + + Case "categories" + _selectedMenu = MenuOptionType.Categories + Return + + Case "currentarticles" + _selectedMenu = MenuOptionType.CurrentArticles + Return + + Case "myarticles" + _selectedMenu = MenuOptionType.MyArticles + Return + + Case "search" + _selectedMenu = MenuOptionType.Search + Return + + Case "syndication" + _selectedMenu = MenuOptionType.Syndication + Return + + Case "submitarticle" + _selectedMenu = MenuOptionType.SubmitArticle + Return + + End Select + End Set + End Property + +#End Region + +#Region " Event Handlers " + + Private Sub Page_PreRender(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.PreRender + + Try + + If (_processMenu = False And _menuPosition = ArticleModuleBase.ArticleSettings.MenuPosition) Then + TokenProcessor.ProcessMenu(plhControls.Controls, ArticleModuleBase, _selectedMenu) + _processMenu = True + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/ucImportFeed.ascx b/ucImportFeed.ascx new file mode 100755 index 0000000..25b0321 --- /dev/null +++ b/ucImportFeed.ascx @@ -0,0 +1,120 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucImportFeed.ascx.vb" Inherits="Ventrian.NewsArticles.ucImportFeed" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + +
      + + + + + + + + + + + + + + + + + + + + + +
      +
      + + +
      + + +
      + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +
      + +
      + + + +
      + +
      + + + + + + + + +
      + + + +
      +
      +
      +

      + +   + +   + +

      diff --git a/ucImportFeed.ascx.designer.vb b/ucImportFeed.ascx.designer.vb new file mode 100755 index 0000000..b728f7b --- /dev/null +++ b/ucImportFeed.ascx.designer.vb @@ -0,0 +1,341 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucImportFeed + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''pnlSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSettings As Global.System.Web.UI.WebControls.Panel + + ''' + '''dshFeed control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshFeed As Global.System.Web.UI.UserControl + + ''' + '''tblFeed control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblFeed As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblFeedSettingsHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblFeedSettingsHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTitle As Global.System.Web.UI.UserControl + + ''' + '''txtTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTitle As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valTitle As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''plUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plUrl As Global.System.Web.UI.UserControl + + ''' + '''txtUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtUrl As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valUrl As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''plIsActive control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plIsActive As Global.System.Web.UI.UserControl + + ''' + '''chkIsActive control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkIsActive As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''dshArticleSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshArticleSettings As Global.System.Web.UI.UserControl + + ''' + '''tblArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblArticle As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plArticleSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plArticleSettings As Global.System.Web.UI.WebControls.Label + + ''' + '''plAutoFeature control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAutoFeature As Global.System.Web.UI.UserControl + + ''' + '''chkAutoFeature control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkAutoFeature As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plAutoExpire control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAutoExpire As Global.System.Web.UI.UserControl + + ''' + '''txtAutoExpire control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtAutoExpire As Global.System.Web.UI.WebControls.TextBox + + ''' + '''drpAutoExpire control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpAutoExpire As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plDateMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plDateMode As Global.System.Web.UI.UserControl + + ''' + '''lstDateMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstDateMode As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''plAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAuthor As Global.System.Web.UI.UserControl + + ''' + '''lblAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblAuthor As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdSelectAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdSelectAuthor As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''pnlAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlAuthor As Global.System.Web.UI.WebControls.Panel + + ''' + '''txtAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtAuthor As Global.System.Web.UI.WebControls.TextBox + + ''' + '''lblAuthorUsername control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblAuthorUsername As Global.System.Web.UI.WebControls.Label + + ''' + '''valAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valAuthor As Global.System.Web.UI.WebControls.CustomValidator + + ''' + '''plCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCategories As Global.System.Web.UI.UserControl + + ''' + '''lstCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstCategories As Global.System.Web.UI.WebControls.ListBox + + ''' + '''lblCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCategories As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdDelete control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdDelete As Global.System.Web.UI.WebControls.LinkButton + End Class +End Namespace diff --git a/ucImportFeed.ascx.vb b/ucImportFeed.ascx.vb new file mode 100755 index 0000000..e4ad273 --- /dev/null +++ b/ucImportFeed.ascx.vb @@ -0,0 +1,286 @@ +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports DotNetNuke.Entities.Users + + +Imports Ventrian.NewsArticles.Base +Imports Ventrian.NewsArticles.Import + +Namespace Ventrian.NewsArticles + + Partial Public Class ucImportFeed + Inherits NewsArticleModuleBase + +#Region " Private Members " + + Private _feedID As Integer = Null.NullInteger + +#End Region + +#Region " Private Methods " + + Private Sub BindAutoExpiry() + + For Each value As Integer In System.Enum.GetValues(GetType(FeedExpiryType)) + Dim li As New ListItem + li.Value = value.ToString() + li.Text = Localization.GetString(System.Enum.GetName(GetType(FeedExpiryType), value), Me.LocalResourceFile) + drpAutoExpire.Items.Add(li) + Next + + End Sub + + Private Sub BindCategories() + + Dim objCategoryController As CategoryController = New CategoryController + + lstCategories.DataSource = objCategoryController.GetCategoriesAll(ModuleId, Null.NullInteger, ArticleSettings.CategorySortType) + lstCategories.DataBind() + + Me.lstCategories.Height = Unit.Parse(ArticleSettings.CategorySelectionHeight.ToString()) + + End Sub + + Private Sub BindDateModes() + + For Each value As Integer In System.Enum.GetValues(GetType(FeedDateMode)) + Dim li As New ListItem + li.Value = value.ToString() + li.Text = Localization.GetString(System.Enum.GetName(GetType(FeedDateMode), value), Me.LocalResourceFile) + lstDateMode.Items.Add(li) + Next + + End Sub + + Private Sub BindFeed() + + If (_feedID = Null.NullInteger) Then + + chkIsActive.Checked = True + lblAuthor.Text = Me.UserInfo.Username + lstDateMode.SelectedValue = Convert.ToInt32(FeedDateMode.ImportDate).ToString() + drpAutoExpire.SelectedValue = Null.NullInteger.ToString() + cmdDelete.Visible = False + + Else + + cmdDelete.Visible = True + cmdDelete.Attributes.Add("onClick", "javascript:return confirm('" & Localization.GetString("Confirmation", LocalResourceFile) & "');") + + Dim objFeedController As New FeedController + Dim objFeed As FeedInfo = objFeedController.Get(_feedID) + + If Not (objFeed Is Nothing) Then + txtTitle.Text = objFeed.Title + txtUrl.Text = objFeed.Url + chkAutoFeature.Checked = objFeed.AutoFeature + chkIsActive.Checked = objFeed.IsActive + lstDateMode.SelectedValue = Convert.ToInt32(objFeed.DateMode).ToString() + If (objFeed.AutoExpire <> Null.NullInteger) Then + txtAutoExpire.Text = objFeed.AutoExpire.ToString() + End If + drpAutoExpire.SelectedValue = Convert.ToInt32(objFeed.AutoExpireUnit).ToString() + + Dim objUser As UserInfo = UserController.GetUser(PortalId, objFeed.UserID, True) + If (objUser IsNot Nothing) Then + lblAuthor.Text = objUser.Username + Else + lblAuthor.Text = Me.UserInfo.Username + End If + + For Each objCategory As CategoryInfo In objFeed.Categories + For Each li As ListItem In lstCategories.Items + If (li.Value = objCategory.CategoryID.ToString()) Then + li.Selected = True + End If + Next + Next + Else + Response.Redirect(EditUrl("ImportFeeds"), True) + End If + + End If + + End Sub + + Private Sub ReadQueryString() + + If Not (Request("FeedID") Is Nothing) Then + _feedID = Convert.ToInt32(Request("FeedID")) + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + ReadQueryString() + + If (IsPostBack = False) Then + + BindAutoExpiry() + BindCategories() + BindDateModes() + BindFeed() + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdUpdate.Click + + + Try + + If (Page.IsValid) Then + + Dim objFeedController As New FeedController + + Dim objFeed As New FeedInfo + + If (_feedID <> Null.NullInteger) Then + objFeed = objFeedController.Get(_feedID) + Else + objFeed = CType(CBO.InitializeObject(objFeed, GetType(FeedInfo)), FeedInfo) + End If + + objFeed.ModuleID = Me.ModuleId + objFeed.Title = txtTitle.Text + objFeed.Url = txtUrl.Text + objFeed.AutoFeature = chkAutoFeature.Checked + objFeed.IsActive = chkIsActive.Checked + objFeed.DateMode = CType(System.Enum.Parse(GetType(FeedDateMode), lstDateMode.SelectedValue), FeedDateMode) + objFeed.AutoExpire = Null.NullInteger + If (txtAutoExpire.Text <> "") Then + If (IsNumeric(txtAutoExpire.Text)) Then + If (Convert.ToInt32(txtAutoExpire.Text) > 0) Then + objFeed.AutoExpire = Convert.ToInt32(txtAutoExpire.Text) + End If + End If + End If + objFeed.AutoExpireUnit = CType(System.Enum.Parse(GetType(FeedExpiryType), drpAutoExpire.SelectedValue), FeedExpiryType) + + If (pnlAuthor.Visible) Then + Dim objUser As UserInfo = UserController.GetUserByName(Me.PortalId, txtAuthor.Text) + + If (objUser IsNot Nothing) Then + objFeed.UserID = objUser.UserID + Else + objFeed.UserID = Me.UserId + End If + Else + Dim objUser As UserInfo = UserController.GetUserByName(Me.PortalId, lblAuthor.Text) + + If (objUser IsNot Nothing) Then + objFeed.UserID = objUser.UserID + Else + objFeed.UserID = Me.UserId + End If + End If + + Dim objCategories As New List(Of CategoryInfo) + For Each li As ListItem In lstCategories.Items + If (li.Selected) Then + Dim objCategory As New CategoryInfo + objCategory.CategoryID = Convert.ToInt32(li.Value) + objCategories.Add(objCategory) + End If + Next + objFeed.Categories = objCategories + + If (_feedID = Null.NullInteger) Then + objFeedController.Add(objFeed) + Else + objFeedController.Update(objFeed) + End If + + Response.Redirect(EditUrl("ImportFeeds"), True) + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdDelete_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdDelete.Click + + Try + + Dim objFeedController As New FeedController + objFeedController.Delete(_feedID) + + Response.Redirect(EditUrl("ImportFeeds"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(EditUrl("ImportFeeds"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdSelectAuthor_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdSelectAuthor.Click + + Try + + cmdSelectAuthor.Visible = False + lblAuthor.Visible = False + + pnlAuthor.Visible = True + txtAuthor.Text = lblAuthor.Text + txtAuthor.Focus() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub valAuthor_ServerValidate(ByVal source As System.Object, ByVal args As System.Web.UI.WebControls.ServerValidateEventArgs) Handles valAuthor.ServerValidate + + Try + + args.IsValid = False + + If (txtAuthor.Text <> "") Then + Dim objUser As UserInfo = UserController.GetUserByName(Me.PortalId, txtAuthor.Text) + + If (objUser IsNot Nothing) Then + args.IsValid = True + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucImportFeeds.ascx b/ucImportFeeds.ascx new file mode 100755 index 0000000..0338cfb --- /dev/null +++ b/ucImportFeeds.ascx @@ -0,0 +1,147 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucImportFeeds.ascx.vb" Inherits="Ventrian.NewsArticles.ucImportFeeds" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> + + + + + + + + + + + + + + + + + +

      + +

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + +
      +
      + +
      + + + + Seconds + Minutes + Hours + Days +
      + + + + Seconds + Minutes + Hours + Days +
      + +
      +

      + +   + +

      +
      +
      + + + + + + + + +
      +
      + + + + + + + + + + + +
      + + <%# DataBinder.Eval(Container.DataItem,"TypeFullName")%> + +
      + + + +
      +
      + + + + + + + + + + + + + S: <%# DataBinder.Eval(Container.DataItem,"StartDate")%> +
      + E: <%# DataBinder.Eval(Container.DataItem,"EndDate")%> +
      + N: <%# DataBinder.Eval(Container.DataItem,"NextStart")%> +
      +
      +
      +
      +
      +
      +
      + \ No newline at end of file diff --git a/ucImportFeeds.ascx.designer.vb b/ucImportFeeds.ascx.designer.vb new file mode 100755 index 0000000..4e37719 --- /dev/null +++ b/ucImportFeeds.ascx.designer.vb @@ -0,0 +1,251 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucImportFeeds + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''grdFeeds control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdFeeds As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''lblNoFeeds control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoFeeds As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdAddFeed control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdAddFeed As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''phScheduler control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phScheduler As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshSchedulerSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshSchedulerSettings As Global.System.Web.UI.UserControl + + ''' + '''tblSchedulerSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSchedulerSettings As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblSchedulerSettingsHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSchedulerSettingsHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plSchedulerEnabled control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSchedulerEnabled As Global.System.Web.UI.UserControl + + ''' + '''chkEnabled control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnabled As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plTimeLapse control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTimeLapse As Global.System.Web.UI.UserControl + + ''' + '''txtTimeLapse control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTimeLapse As Global.System.Web.UI.WebControls.TextBox + + ''' + '''drpTimeLapseMeasurement control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpTimeLapseMeasurement As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plRetryTimeLapse control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plRetryTimeLapse As Global.System.Web.UI.UserControl + + ''' + '''txtRetryTimeLapse control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtRetryTimeLapse As Global.System.Web.UI.WebControls.TextBox + + ''' + '''drpRetryTimeLapseMeasurement control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpRetryTimeLapseMeasurement As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plDeleteArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plDeleteArticles As Global.System.Web.UI.UserControl + + ''' + '''chkDeleteArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkDeleteArticles As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''dshSchedulerHistory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshSchedulerHistory As Global.System.Web.UI.UserControl + + ''' + '''tblSchedulerHistory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSchedulerHistory As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblSchedulerHistoryHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSchedulerHistoryHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''lblNoHistory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoHistory As Global.System.Web.UI.WebControls.Label + + ''' + '''dgScheduleHistory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dgScheduleHistory As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''lblScheduler control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblScheduler As Global.System.Web.UI.WebControls.Label + End Class +End Namespace diff --git a/ucImportFeeds.ascx.vb b/ucImportFeeds.ascx.vb new file mode 100755 index 0000000..16b0595 --- /dev/null +++ b/ucImportFeeds.ascx.vb @@ -0,0 +1,264 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization +Imports DotNetNuke.Services.Scheduling +Imports DotNetNuke.UI.UserControls + +Imports Ventrian.NewsArticles.Import +Imports DotNetNuke.Entities.Modules + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucImportFeeds + Inherits NewsArticleModuleBase + +#Region " Private Methods " + + Private Sub BindFeeds() + + Dim objFeedController As New FeedController + + Localization.LocalizeDataGrid(grdFeeds, Me.LocalResourceFile) + + grdFeeds.DataSource = objFeedController.GetFeedList(ModuleId, False) + grdFeeds.DataBind() + + If (grdFeeds.Items.Count > 0) Then + grdFeeds.Visible = True + lblNoFeeds.Visible = False + Else + grdFeeds.Visible = False + lblNoFeeds.Visible = True + lblNoFeeds.Text = Localization.GetString("NoFeedsMessage.Text", LocalResourceFile) + End If + + End Sub + + Private Sub BindHistory() + + Dim typeName As String = "Ventrian.NewsArticles.Import.RssImportJob, Ventrian.NewsArticles" + Dim objSchedule As ScheduleItem = SchedulingProvider.Instance().GetSchedule(typeName, Null.NullString) + + If (objSchedule IsNot Nothing) Then + + Dim arrSchedule As ArrayList = SchedulingProvider.Instance.GetScheduleHistory(objSchedule.ScheduleID) + + If (arrSchedule.Count > 0) Then + + arrSchedule.Sort(New ScheduleHistorySortStartDate) + + 'Localize Grid + Localization.LocalizeDataGrid(dgScheduleHistory, Me.LocalResourceFile) + + dgScheduleHistory.DataSource = arrSchedule + dgScheduleHistory.DataBind() + + lblNoHistory.Visible = False + dgScheduleHistory.Visible = True + Else + lblNoHistory.Visible = True + dgScheduleHistory.Visible = False + End If + + Else + + lblNoHistory.Visible = True + dgScheduleHistory.Visible = False + + End If + + End Sub + + Private Sub BindSchedulerSettings() + + Dim typeName As String = "Ventrian.NewsArticles.Import.RssImportJob, Ventrian.NewsArticles" + + Dim objSchedule As ScheduleItem = SchedulingProvider.Instance().GetSchedule(typeName, Null.NullString) + + If (objSchedule IsNot Nothing) Then + chkEnabled.Checked = objSchedule.Enabled + + txtTimeLapse.Text = objSchedule.TimeLapse.ToString() + If (drpTimeLapseMeasurement.Items.FindByValue(objSchedule.TimeLapseMeasurement) IsNot Nothing) Then + drpTimeLapseMeasurement.SelectedValue = objSchedule.TimeLapseMeasurement + Else + drpTimeLapseMeasurement.SelectedValue = "m" + End If + + txtRetryTimeLapse.Text = objSchedule.RetryTimeLapse.ToString() + If (drpRetryTimeLapseMeasurement.Items.FindByValue(objSchedule.RetryTimeLapseMeasurement) IsNot Nothing) Then + drpRetryTimeLapseMeasurement.SelectedValue = objSchedule.RetryTimeLapseMeasurement + Else + drpRetryTimeLapseMeasurement.SelectedValue = "m" + End If + Else + txtTimeLapse.Text = "30" + drpTimeLapseMeasurement.SelectedValue = "m" + + txtRetryTimeLapse.Text = "60" + drpRetryTimeLapseMeasurement.SelectedValue = "m" + End If + + Dim objModuleController As New ModuleController + If (Settings.Contains("NewsArticles-Import-Clear-" & Me.ModuleId)) Then + chkDeleteArticles.Checked = Convert.ToBoolean(Settings("NewsArticles-Import-Clear-" & Me.ModuleId).ToString()) + Else + chkDeleteArticles.Checked = False + End If + + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + phScheduler.Visible = Me.UserInfo.IsSuperUser + + + If (IsPostBack = False) Then + + BindFeeds() + + If (phScheduler.Visible) Then + BindSchedulerSettings() + BindHistory() + Else + Dim typeName As String = "Ventrian.NewsArticles.Import.RssImportJob, Ventrian.NewsArticles" + Dim objSchedule As ScheduleItem = SchedulingProvider.Instance().GetSchedule(typeName, Null.NullString) + + If (objSchedule IsNot Nothing) Then + If (objSchedule.Enabled) Then + lblScheduler.Visible = False + Else + lblScheduler.Text = Localization.GetString("SchedulerNotEnabled", Me.LocalResourceFile) + lblScheduler.Visible = True + End If + Else + lblScheduler.Text = Localization.GetString("SchedulerNotEnabled", Me.LocalResourceFile) + lblScheduler.Visible = True + End If + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + + Protected Sub cmdAddFeed_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdAddFeed.Click + + Try + + Response.Redirect(EditUrl("ImportFeed"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub cmdUpdate_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdUpdate.Click + + Try + + Dim typeName As String = "Ventrian.NewsArticles.Import.RssImportJob, Ventrian.NewsArticles" + + Dim objSchedule As ScheduleItem = SchedulingProvider.Instance().GetSchedule(typeName, Null.NullString) + + If (objSchedule IsNot Nothing) Then + + objSchedule.Enabled = chkEnabled.Checked + + If (IsNumeric(txtTimeLapse.Text)) Then + objSchedule.TimeLapse = Convert.ToInt32(txtTimeLapse.Text) + Else + objSchedule.TimeLapse = 30 + End If + objSchedule.TimeLapseMeasurement = drpTimeLapseMeasurement.SelectedValue + + If (IsNumeric(txtTimeLapse.Text)) Then + objSchedule.RetryTimeLapse = Convert.ToInt32(txtRetryTimeLapse.Text) + Else + objSchedule.RetryTimeLapse = 60 + End If + objSchedule.RetryTimeLapseMeasurement = drpRetryTimeLapseMeasurement.SelectedValue + + SchedulingProvider.Instance().UpdateSchedule(objSchedule) + + Else + + objSchedule = New ScheduleItem() + + objSchedule.TypeFullName = typeName + objSchedule.Enabled = chkEnabled.Checked + + If (IsNumeric(txtTimeLapse.Text)) Then + objSchedule.TimeLapse = Convert.ToInt32(txtTimeLapse.Text) + Else + objSchedule.TimeLapse = 30 + End If + objSchedule.TimeLapseMeasurement = drpTimeLapseMeasurement.SelectedValue + + If (IsNumeric(txtTimeLapse.Text)) Then + objSchedule.RetryTimeLapse = Convert.ToInt32(txtRetryTimeLapse.Text) + Else + objSchedule.RetryTimeLapse = 60 + End If + objSchedule.RetryTimeLapseMeasurement = drpRetryTimeLapseMeasurement.SelectedValue + + objSchedule.RetainHistoryNum = 10 + objSchedule.AttachToEvent = "" + objSchedule.CatchUpEnabled = False + objSchedule.Enabled = chkEnabled.Checked + objSchedule.ObjectDependencies = "" + objSchedule.Servers = "" + + objSchedule.ScheduleID = SchedulingProvider.Instance().AddSchedule(objSchedule) + + End If + + Dim objModuleController As New ModuleController + objModuleController.UpdateModuleSetting(Me.ModuleId, "NewsArticles-Import-Clear-" & Me.ModuleId, chkDeleteArticles.Checked.ToString()) + SchedulingProvider.Instance().AddScheduleItemSetting(objSchedule.ScheduleID, "NewsArticles-Import-Clear-" & Me.ModuleId, chkDeleteArticles.Checked.ToString()) + + Response.Redirect(EditUrl("AdminOptions"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + End Sub + + Protected Sub cmdCancel_Click(ByVal sender As Object, ByVal e As EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(EditUrl("AdminOptions"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucMyArticles.ascx b/ucMyArticles.ascx new file mode 100755 index 0000000..739d418 --- /dev/null +++ b/ucMyArticles.ascx @@ -0,0 +1,58 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucMyArticles.ascx.vb" Inherits="Ventrian.NewsArticles.ucMyArticles" %> +<%@ Register TagPrefix="dnn" Namespace="DotNetNuke.UI.WebControls" Assembly="DotNetNuke" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="Ventrian" TagName="Listing" Src="Controls/Listing.ascx"%> + + + +
      +
      + +
      + + + + + + + + + ">" alt="Edit" width="16" height="16"/> + + + + <%= LocalizeString("Title.Header") %> + + <%#Eval("Title")%> + + + + + + <%= LocalizeString("CreatedDate.Header") %> + + <%#GetAdjustedCreateDate(Container.DataItem)%> + + + + + <%= LocalizeString("PublishDate.Header") %> + + <%#GetAdjustedPublishDate(Container.DataItem)%> + + + + + + + +
      <%= LocalizeString("NoArticlesMessage") %>
      +
      +
      +
      + + diff --git a/ucMyArticles.ascx.designer.vb b/ucMyArticles.ascx.designer.vb new file mode 100755 index 0000000..34e3ad2 --- /dev/null +++ b/ucMyArticles.ascx.designer.vb @@ -0,0 +1,71 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucMyArticles + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''chkShowAll control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkShowAll As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''grdMyArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdMyArticles As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''ctlPagingControl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ctlPagingControl As Global.DotNetNuke.UI.WebControls.PagingControl + + ''' + '''phNoArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phNoArticles As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''Header1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Header1 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucMyArticles.ascx.vb b/ucMyArticles.ascx.vb new file mode 100755 index 0000000..2929ada --- /dev/null +++ b/ucMyArticles.ascx.vb @@ -0,0 +1,292 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2005-2012 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucMyArticles + Inherits NewsArticleModuleBase + + Private Enum StatusType + + Draft = 1 + Unapproved = 2 + Approved = 3 + + End Enum + + Private _status As StatusType = StatusType.Draft + +#Region " Private Properties " + + Private ReadOnly Property CurrentPage() As Integer + Get + If (Request("Page") = Null.NullString And Request("CurrentPage") = Null.NullString) Then + Return 1 + Else + Try + If (Request("Page") <> Null.NullString) Then + Return Convert.ToInt32(Request("Page")) + Else + Return Convert.ToInt32(Request("CurrentPage")) + End If + Catch + Return 1 + End Try + End If + End Get + End Property + +#End Region + +#Region " Private Methods " + + Private Sub ReadQueryString() + + If (Request("Status") <> "") Then + Select Case Request("Status").ToLower() + Case "2" + _status = StatusType.Unapproved + Exit Select + Case "3" + _status = StatusType.Approved + Exit Select + End Select + End If + + End Sub + + Private Sub BindSelection() + + If (ArticleSettings.IsApprover Or ArticleSettings.IsAdmin) Then + If (Request("ShowAll") <> "") Then + chkShowAll.Checked = True + End If + Else + chkShowAll.Visible = False + End If + + End Sub + + Private Sub BindArticles() + + Dim objArticleController As ArticleController = New ArticleController + + Localization.LocalizeDataGrid(grdMyArticles, Me.LocalResourceFile) + + Dim count As Integer = 0 + Dim authorID As Integer = Me.UserId + If (chkShowAll.Checked) Then + authorID = Null.NullInteger + End If + + grdMyArticles.DataSource = objArticleController.GetArticleList(Me.ModuleId, Null.NullDate, Null.NullDate, Nothing, Null.NullBoolean, Nothing, Null.NullInteger, CurrentPage, 10, ArticleSettings.SortBy, ArticleSettings.SortDirection, False, True, Null.NullString, authorID, True, True, Null.NullBoolean, Null.NullBoolean, False, False, Null.NullString, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, count) + + Select Case _status + + Case StatusType.Draft + grdMyArticles.DataSource = objArticleController.GetArticleList(Me.ModuleId, Null.NullDate, Null.NullDate, Nothing, Null.NullBoolean, Nothing, Null.NullInteger, CurrentPage, 10, ArticleSettings.SortBy, ArticleSettings.SortDirection, False, True, Null.NullString, authorID, True, True, Null.NullBoolean, Null.NullBoolean, False, False, Null.NullString, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, count) + Exit Select + Case StatusType.Unapproved + grdMyArticles.DataSource = objArticleController.GetArticleList(Me.ModuleId, Null.NullDate, Null.NullDate, Nothing, Null.NullBoolean, Nothing, Null.NullInteger, CurrentPage, 10, ArticleSettings.SortBy, ArticleSettings.SortDirection, False, False, Null.NullString, authorID, True, True, Null.NullBoolean, Null.NullBoolean, False, False, Null.NullString, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, count) + Exit Select + Case StatusType.Approved + grdMyArticles.DataSource = objArticleController.GetArticleList(Me.ModuleId, Null.NullDate, Null.NullDate, Nothing, Null.NullBoolean, Nothing, Null.NullInteger, CurrentPage, 10, ArticleSettings.SortBy, ArticleSettings.SortDirection, True, False, Null.NullString, authorID, True, True, Null.NullBoolean, Null.NullBoolean, False, False, Null.NullString, Nothing, False, Null.NullString, Null.NullInteger, Null.NullString, Null.NullString, count) + Exit Select + + End Select + + grdMyArticles.DataBind() + + If (grdMyArticles.Items.Count = 0) Then + phNoArticles.Visible = True + grdMyArticles.Visible = False + + ctlPagingControl.Visible = False + Else + phNoArticles.Visible = False + grdMyArticles.Visible = True + + If (count > 10) Then + ctlPagingControl.Visible = True + ctlPagingControl.TotalRecords = count + ctlPagingControl.PageSize = 10 + ctlPagingControl.CurrentPage = CurrentPage + ctlPagingControl.QuerystringParams = GetParams() + ctlPagingControl.TabID = TabId + ctlPagingControl.EnableViewState = False + End If + + grdMyArticles.Columns(0).Visible = IsEditable + End If + + End Sub + + Private Sub CheckSecurity() + + If (ArticleSettings.IsSubmitter = False) Then + Response.Redirect(NavigateURL(), True) + End If + + If (Request("ShowAll") <> "") Then + If ((ArticleSettings.IsApprover Or ArticleSettings.IsAdmin) = False) Then + Response.Redirect(NavigateURL(), True) + End If + End If + + End Sub + + Private Function GetParams() As String + + Dim params As String = "" + + If (Request("ctl") <> "") Then + If (Request("ctl").ToLower() = "myarticles") Then + params += "ctl=" & Request("ctl") & "&mid=" & ModuleId.ToString() + End If + End If + + If (Request("articleType") <> "") Then + If (Request("articleType").ToString().ToLower() = "myarticles") Then + params += "articleType=" & Request("articleType") + End If + End If + + If (Request("Status") <> "") Then + params += "&Status=" & Convert.ToInt32(_status).ToString() + End If + + If (Request("ShowAll") <> "") Then + params += "&ShowAll=" & Request("ShowAll") + End If + + Return params + + End Function + +#End Region + +#Region " Protected Methods " + + Protected Function GetAdjustedCreateDate(ByVal objItem As Object) As String + + Dim objArticle As ArticleInfo = CType(objItem, ArticleInfo) + Return objArticle.CreatedDate.ToString("d") & " " & objArticle.CreatedDate.ToString("t") + + End Function + + Protected Function GetAdjustedPublishDate(ByVal objItem As Object) As String + + Dim objArticle As ArticleInfo = CType(objItem, ArticleInfo) + Return objArticle.StartDate.ToString("d") & " " & objArticle.StartDate.ToString("t") + + End Function + + Protected Function GetArticleLink(ByVal objItem As Object) As String + + Dim objArticle As ArticleInfo = CType(objItem, ArticleInfo) + Return Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False) + + End Function + + Protected Function GetEditUrl(ByVal articleID As String) As String + If (ArticleSettings.LaunchLinks) Then + Return Common.GetModuleLink(Me.TabId, Me.ModuleId, "Edit", ArticleSettings, "ArticleID=" & articleID) + Else + Return Common.GetModuleLink(Me.TabId, Me.ModuleId, "SubmitNews", ArticleSettings, "ArticleID=" & articleID) + End If + End Function + + Protected Function GetModuleLink(ByVal key As String, ByVal status As Integer) As String + + If (status = 1) Then + Return Common.GetModuleLink(TabId, ModuleId, "MyArticles", ArticleSettings) + Else + Return Common.GetModuleLink(TabId, ModuleId, "MyArticles", ArticleSettings, "Status=" & status.ToString()) + End If + + End Function + + Public Shadows ReadOnly Property IsEditable() As Boolean + Get + If (_status = StatusType.Draft) Then + Return True + Else + If (ArticleSettings.IsApprover Or ArticleSettings.IsAutoApprover) Then + Return True + End If + End If + + End Get + End Property + + Protected Function IsSelected(ByVal status As Integer) + + If (status = _status) Then + Return "ui-tabs-selected ui-state-active" + Else + Return "" + End If + + End Function + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + CheckSecurity() + ReadQueryString() + + If (IsPostBack = False) Then + BindSelection() + BindArticles() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Protected Sub chkShowAll_CheckedChanged(ByVal sender As Object, ByVal e As EventArgs) Handles chkShowAll.CheckedChanged + + Try + + If (chkShowAll.Checked) Then + If (_status <> StatusType.Draft) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "MyArticles", ArticleSettings, "ShowAll=1", "Status=" & Convert.ToInt32(_status).ToString()), True) + Else + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "MyArticles", ArticleSettings, "ShowAll=1"), True) + End If + Else + If (_status <> StatusType.Draft) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "MyArticles", ArticleSettings, "Status=" & Convert.ToInt32(_status).ToString()), True) + Else + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "MyArticles", ArticleSettings), True) + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucNotAuthenticated.ascx b/ucNotAuthenticated.ascx new file mode 100755 index 0000000..2c69881 --- /dev/null +++ b/ucNotAuthenticated.ascx @@ -0,0 +1,13 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucNotAuthenticated.ascx.vb" Inherits="Ventrian.NewsArticles.ucNotAuthenticated" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + +

      + + diff --git a/ucNotAuthenticated.ascx.designer.vb b/ucNotAuthenticated.ascx.designer.vb new file mode 100755 index 0000000..db2fc36 --- /dev/null +++ b/ucNotAuthenticated.ascx.designer.vb @@ -0,0 +1,62 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucNotAuthenticated + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblAuthenticated control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblAuthenticated As Global.System.Web.UI.WebControls.Label + + ''' + '''lblLogin control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblLogin As Global.System.Web.UI.WebControls.Label + + ''' + '''lblHomePage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblHomePage As Global.System.Web.UI.WebControls.Label + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucNotAuthenticated.ascx.vb b/ucNotAuthenticated.ascx.vb new file mode 100755 index 0000000..6f36072 --- /dev/null +++ b/ucNotAuthenticated.ascx.vb @@ -0,0 +1,58 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Services.Exceptions + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucNotAuthenticated + Inherits NewsArticleModuleBase + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + + End Sub + +#End Region + +#Region " Public Methods " + + Protected Function GetLoginUrl() As String + + Try + + If PortalSettings.LoginTabId <> Null.NullInteger Then + + ' User Defined Tab + ' + Return Page.ResolveUrl("~/Default.aspx?tabid=" & PortalSettings.LoginTabId.ToString) + + Else + + ' Admin Tab + ' + Return Page.ResolveUrl("~/Default.aspx?tabid=" & PortalSettings.ActiveTab.TabID & "&ctl=Login") + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + Return "" + + End Function + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucNotAuthorized.ascx b/ucNotAuthorized.ascx new file mode 100755 index 0000000..04e33b9 --- /dev/null +++ b/ucNotAuthorized.ascx @@ -0,0 +1,10 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucNotAuthorized.ascx.vb" Inherits="Ventrian.NewsArticles.ucNotAuthorized" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + +

      + + diff --git a/ucNotAuthorized.ascx.designer.vb b/ucNotAuthorized.ascx.designer.vb new file mode 100755 index 0000000..6d61249 --- /dev/null +++ b/ucNotAuthorized.ascx.designer.vb @@ -0,0 +1,53 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucNotAuthorized + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblAuthorized control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblAuthorized As Global.System.Web.UI.WebControls.Label + + ''' + '''lblHomePage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblHomePage As Global.System.Web.UI.WebControls.Label + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucNotAuthorized.ascx.vb b/ucNotAuthorized.ascx.vb new file mode 100755 index 0000000..384f2b4 --- /dev/null +++ b/ucNotAuthorized.ascx.vb @@ -0,0 +1,24 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucNotAuthorized + Inherits NewsArticleModuleBase + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucSubmitNews.ascx b/ucSubmitNews.ascx new file mode 100755 index 0000000..b2dff06 --- /dev/null +++ b/ucSubmitNews.ascx @@ -0,0 +1,338 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucSubmitNews.ascx.vb" Inherits="Ventrian.NewsArticles.ucSubmitNews" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="URL" Src="~/controls/URLControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="TextEditor" Src="~/controls/TextEditor.ascx"%> +<%@ Register Assembly="Ventrian.NewsArticles" Namespace="Ventrian.NewsArticles.Components.Validators" TagPrefix="Ventrian" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="article" TagName="UploadFiles" Src="Controls/UploadFiles.ascx" %> +<%@ Register TagPrefix="article" TagName="UploadImages" Src="Controls/UploadImages.ascx" %> + +<%@ Register TagPrefix="dnn" Namespace="DotNetNuke.Web.Client.ClientResourceManagement" Assembly="DotNetNuke.Web.Client" %> + + + + + + + +
      +
      + + + + + + + + + + + +
      In this section, you can specify your content.
      + + + + + + + + + + + + + + + + + +
      + +
      + +
      + + +
      + +
      +
      +
      +
      + + + + + + + + + + + +
      In this section, you can specify your content.
      + + + + + + + + + + + + + + +
      + + +
      + +
      + + +
      + + + + + + + + + + + +
      + +
      +
      + + + +
      + + + + + +
      + + +
      +
      + +
      + + + + + + + + + + + + + + + + + + +
      + +
      + +
      + +
      + +
      +
      + +
      + + + + + + +
      + + + + + + + + + +
      + + + + + + +
      +
      +
      +
      +
      +
      +
      + + + + + + + + + + +
      In this section, you can organize your content.
      + + + + + + + + + +
      + + +
      +
      + +
      +
      +
      +
      + + + + + + + + + + +
      In this section, you can specify how and when your content is published.
      + + + + + + + + + + + + + + + + + + + + + +
      + + + + + + + + +
      + +
      + +
      + + Calendar + + +  :  +
      + + Calendar + +  :  +
      +
      +
      +
      + + + + + + + + + +
      In this section, you can perform actions relating to the content.
      + + + + + + + + +
      + +
      +          +
      +
      + + + diff --git a/ucSubmitNews.ascx.designer.vb b/ucSubmitNews.ascx.designer.vb new file mode 100755 index 0000000..bee8470 --- /dev/null +++ b/ucSubmitNews.ascx.designer.vb @@ -0,0 +1,1124 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucSubmitNews + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''phMirrorText control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phMirrorText As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''lblMirrorText control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblMirrorText As Global.System.Web.UI.WebControls.Label + + ''' + '''phMirror control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phMirror As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshMirror control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshMirror As Global.System.Web.UI.UserControl + + ''' + '''tblMirror control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblMirror As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblMirrorHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblMirrorHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''Image1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Image1 As Global.System.Web.UI.WebControls.Image + + ''' + '''plMirrorArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMirrorArticle As Global.System.Web.UI.UserControl + + ''' + '''chkMirrorArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkMirrorArticle As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''trMirrorModule control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trMirrorModule As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plMirrorModule control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMirrorModule As Global.System.Web.UI.UserControl + + ''' + '''drpMirrorModule control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpMirrorModule As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''trMirrorArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trMirrorArticle As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plMirrorArticleSelect control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMirrorArticleSelect As Global.System.Web.UI.UserControl + + ''' + '''drpMirrorArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpMirrorArticle As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''valMirrorArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valMirrorArticle As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''trMirrorAutoUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trMirrorAutoUpdate As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plMirrorAutoUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMirrorAutoUpdate As Global.System.Web.UI.UserControl + + ''' + '''chkMirrorAutoUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkMirrorAutoUpdate As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''phCreate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phCreate As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshCreate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshCreate As Global.System.Web.UI.UserControl + + ''' + '''tblCreate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblCreate As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblCreateHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblCreateHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''imgSpacer1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents imgSpacer1 As Global.System.Web.UI.WebControls.Image + + ''' + '''plTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTitle As Global.System.Web.UI.UserControl + + ''' + '''txtTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTitle As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valTitle As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''plBody control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plBody As Global.System.Web.UI.UserControl + + ''' + '''txtDetails control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtDetails As Global.System.Web.UI.UserControl + + ''' + '''valBody control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valBody As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''phAttachment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phAttachment As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshAttachment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshAttachment As Global.System.Web.UI.UserControl + + ''' + '''tblAttachment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblAttachment As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''trLink control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trLink As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plLink control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plLink As Global.System.Web.UI.UserControl + + ''' + '''ctlUrlLink control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ctlUrlLink As Global.System.Web.UI.UserControl + + ''' + '''trNewWindow control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trNewWindow As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plNewWindow control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNewWindow As Global.System.Web.UI.UserControl + + ''' + '''chkNewWindow control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkNewWindow As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''ucUploadFiles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucUploadFiles As Global.Ventrian.NewsArticles.Controls.UploadFiles + + ''' + '''ucUploadImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucUploadImages As Global.Ventrian.NewsArticles.Controls.UploadImages + + ''' + '''phExcerpt control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phExcerpt As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshExcerpt control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshExcerpt As Global.System.Web.UI.UserControl + + ''' + '''tblExcerpt control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblExcerpt As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''txtExcerptBasic control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtExcerptBasic As Global.System.Web.UI.WebControls.TextBox + + ''' + '''txtExcerptRich control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtExcerptRich As Global.System.Web.UI.UserControl + + ''' + '''phMeta control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phMeta As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshMeta control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshMeta As Global.System.Web.UI.UserControl + + ''' + '''tblMeta control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblMeta As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plMetaTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMetaTitle As Global.System.Web.UI.UserControl + + ''' + '''txtMetaTitle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtMetaTitle As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plMetaDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMetaDescription As Global.System.Web.UI.UserControl + + ''' + '''txtMetaDescription control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtMetaDescription As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plMetaKeyWords control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMetaKeyWords As Global.System.Web.UI.UserControl + + ''' + '''txtMetaKeyWords control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtMetaKeyWords As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plPageHeadText control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plPageHeadText As Global.System.Web.UI.UserControl + + ''' + '''txtPageHeadText control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtPageHeadText As Global.System.Web.UI.WebControls.TextBox + + ''' + '''phCustomFields control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phCustomFields As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshCustomFields control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshCustomFields As Global.System.Web.UI.UserControl + + ''' + '''tblCustomFields control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblCustomFields As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''rptCustomFields control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rptCustomFields As Global.System.Web.UI.WebControls.Repeater + + ''' + '''phOrganize control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phOrganize As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshOrganize control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshOrganize As Global.System.Web.UI.UserControl + + ''' + '''tblOrganize control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblOrganize As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plOrganizeHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plOrganizeHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''imgSpacer2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents imgSpacer2 As Global.System.Web.UI.WebControls.Image + + ''' + '''trCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trCategories As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCategories As Global.System.Web.UI.UserControl + + ''' + '''lstCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstCategories As Global.System.Web.UI.WebControls.ListBox + + ''' + '''valCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valCategory As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''trTags control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trTags As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plTags control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTags As Global.System.Web.UI.UserControl + + ''' + '''txtTags control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTags As Global.System.Web.UI.WebControls.TextBox + + ''' + '''lblTags control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTags As Global.System.Web.UI.WebControls.Label + + ''' + '''phPublish control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phPublish As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshPublish control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshPublish As Global.System.Web.UI.UserControl + + ''' + '''tblPublish control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblPublish As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plPublishHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plPublishHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''imgSpacer3 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents imgSpacer3 As Global.System.Web.UI.WebControls.Image + + ''' + '''trAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trAuthor As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAuthor As Global.System.Web.UI.UserControl + + ''' + '''lblAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblAuthor As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdSelectAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdSelectAuthor As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ddlAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ddlAuthor As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''pnlAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlAuthor As Global.System.Web.UI.WebControls.Panel + + ''' + '''txtAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtAuthor As Global.System.Web.UI.WebControls.TextBox + + ''' + '''lblAuthorUsername control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblAuthorUsername As Global.System.Web.UI.WebControls.Label + + ''' + '''valAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valAuthor As Global.System.Web.UI.WebControls.CustomValidator + + ''' + '''trFeatured control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trFeatured As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plFeatured control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plFeatured As Global.System.Web.UI.UserControl + + ''' + '''chkFeatured control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkFeatured As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''trSecure control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trSecure As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plSecure control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSecure As Global.System.Web.UI.UserControl + + ''' + '''chkSecure control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkSecure As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''trPublish control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trPublish As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plStartDate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plStartDate As Global.System.Web.UI.UserControl + + ''' + '''txtPublishDate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtPublishDate As Global.System.Web.UI.WebControls.TextBox + + ''' + '''cmdPublishCalendar control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdPublishCalendar As Global.System.Web.UI.WebControls.HyperLink + + ''' + '''valPublishDateRequired control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valPublishDateRequired As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valPublishDate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valPublishDate As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''txtPublishHour control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtPublishHour As Global.System.Web.UI.WebControls.TextBox + + ''' + '''txtPublishMinute control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtPublishMinute As Global.System.Web.UI.WebControls.TextBox + + ''' + '''trExpiry control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trExpiry As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plEndDate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEndDate As Global.System.Web.UI.UserControl + + ''' + '''txtExpiryDate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtExpiryDate As Global.System.Web.UI.WebControls.TextBox + + ''' + '''cmdExpiryCalendar control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdExpiryCalendar As Global.System.Web.UI.WebControls.HyperLink + + ''' + '''valExpiryDate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valExpiryDate As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''txtExpiryHour control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtExpiryHour As Global.System.Web.UI.WebControls.TextBox + + ''' + '''txtExpiryMinute control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtExpiryMinute As Global.System.Web.UI.WebControls.TextBox + + ''' + '''dshAction control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshAction As Global.System.Web.UI.UserControl + + ''' + '''tblAction control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblAction As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plAction control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAction As Global.System.Web.UI.WebControls.Label + + ''' + '''imgSpacer4 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents imgSpacer4 As Global.System.Web.UI.WebControls.Image + + ''' + '''plStatus control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plStatus As Global.System.Web.UI.UserControl + + ''' + '''drpStatus control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpStatus As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''cmdSaveArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdSaveArticle As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdPublishArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdPublishArticle As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdAddEditPages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdAddEditPages As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdDelete control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdDelete As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''valMessageBox control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valMessageBox As Global.System.Web.UI.WebControls.ValidationSummary + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucSubmitNews.ascx.vb b/ucSubmitNews.ascx.vb new file mode 100755 index 0000000..1ce2319 --- /dev/null +++ b/ucSubmitNews.ascx.vb @@ -0,0 +1,2213 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Entities.Users +Imports DotNetNuke.Security +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization +Imports DotNetNuke.UI.UserControls +Imports DotNetNuke.Security.Roles +Imports Ventrian.NewsArticles.Components.Social +Imports Ventrian.NewsArticles.Components.CustomFields +Imports DotNetNuke.Entities.Portals +Imports DotNetNuke.Entities.Tabs +Imports DotNetNuke.Services.FileSystem +Imports DotNetNuke.Security.Permissions +Imports System.IO + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucSubmitNews + Inherits NewsArticleModuleBase + +#Region " Private Members " + + Private _articleID As Integer = Null.NullInteger + Private _returnUrl As String = Null.NullString + Private _richTextValues As New NameValueCollection + +#End Region + +#Region " Private Properties " + + Private Property PublishDate(ByVal defaultHour As Integer, ByVal defaultMinute As Integer) As DateTime + Get + Dim year As Integer = Convert.ToDateTime(txtPublishDate.Text).Year + Dim month As Integer = Convert.ToDateTime(txtPublishDate.Text).Month + Dim day As Integer = Convert.ToDateTime(txtPublishDate.Text).Day + + Dim hour As Integer = defaultHour + If (IsNumeric(txtPublishHour.Text)) Then + If (hour >= 0 And hour <= 23) Then + hour = Convert.ToInt32(txtPublishHour.Text) + End If + End If + + Dim minute As Integer = defaultMinute + If (IsNumeric(txtPublishMinute.Text)) Then + If (minute >= 0 And minute <= 60) Then + minute = Convert.ToInt32(txtPublishMinute.Text) + End If + End If + + Return New DateTime(year, month, day, hour, minute, 0) + End Get + Set(ByVal Value As DateTime) + txtPublishHour.Text = Value.Hour.ToString() + txtPublishMinute.Text = Value.Minute.ToString() + txtPublishDate.Text = New DateTime(Value.Year, Value.Month, Value.Day).ToShortDateString() + End Set + End Property + + Private Property ExpiryDate(ByVal defaultHour As Integer, ByVal defaultMinute As Integer) As DateTime + Get + If (txtExpiryDate.Text.Length = 0) Then + Return Null.NullDate + End If + + Dim year As Integer = Convert.ToDateTime(txtExpiryDate.Text).Year + Dim month As Integer = Convert.ToDateTime(txtExpiryDate.Text).Month + Dim day As Integer = Convert.ToDateTime(txtExpiryDate.Text).Day + + Dim hour As Integer = defaultHour + If (IsNumeric(txtExpiryHour.Text)) Then + If (hour >= 0 And hour <= 23) Then + hour = Convert.ToInt32(txtExpiryHour.Text) + End If + End If + + Dim minute As Integer = defaultMinute + If (IsNumeric(txtExpiryMinute.Text)) Then + If (minute >= 0 And minute <= 60) Then + minute = Convert.ToInt32(txtExpiryMinute.Text) + End If + End If + + Return New DateTime(year, month, day, hour, minute, 0) + End Get + Set(ByVal Value As DateTime) + If (Value = Null.NullDate) Then + txtExpiryDate.Text = "" + Return + End If + txtExpiryHour.Text = Value.Hour.ToString() + txtExpiryMinute.Text = Value.Minute.ToString() + txtExpiryDate.Text = New DateTime(Value.Year, Value.Month, Value.Day).ToShortDateString() + End Set + End Property + + Private ReadOnly Property Details() As TextEditor + Get + Return CType(txtDetails, TextEditor) + End Get + End Property + + Private ReadOnly Property UrlLink() As UrlControl + Get + Return CType(ctlUrlLink, UrlControl) + End Get + End Property + + Private ReadOnly Property ExcerptRich() As DotNetNuke.UI.UserControls.TextEditor + Get + Return CType(txtExcerptRich, TextEditor) + End Get + End Property + +#End Region + +#Region " Private Methods " + + Private Function IsInRole(ByVal roleName As String, ByVal roles As String()) As Boolean + + For Each role As String In roles + If (roleName = role) Then + Return True + End If + Next + + Return False + + End Function + + Private Sub BindArticle() + + If (_articleID <> Null.NullInteger) Then + + Dim objArticleController As ArticleController = New ArticleController + + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + + lblAuthor.Text = objArticle.AuthorDisplayName + txtTitle.Text = objArticle.Title + If (ArticleSettings.TextEditorSummaryMode = Components.Types.TextEditorModeType.Basic) Then + txtExcerptBasic.Text = objArticle.Summary.Replace("<br />", vbCrLf) + Else + ExcerptRich.Text = objArticle.Summary + End If + chkFeatured.Checked = objArticle.IsFeatured + chkSecure.Checked = objArticle.IsSecure + + txtMetaTitle.Text = objArticle.MetaTitle + txtMetaDescription.Text = objArticle.MetaDescription + txtMetaKeyWords.Text = objArticle.MetaKeywords + txtPageHeadText.Text = objArticle.PageHeadText + + If Not (drpStatus.Items.FindByValue(objArticle.Status.ToString()) Is Nothing) Then + drpStatus.SelectedValue = objArticle.Status.ToString() + End If + + PublishDate(objArticle.StartDate.Hour, objArticle.EndDate.Minute) = objArticle.StartDate + + If Not (objArticle.EndDate = Null.NullDate) Then + ExpiryDate(objArticle.EndDate.Hour, objArticle.EndDate.Minute) = objArticle.EndDate + End If + + If (ArticleSettings.IsImagesEnabled) Then + If Not (objArticle.ImageUrl = Null.NullString) Then + If (objArticle.ImageUrl.ToLower().StartsWith("http://") Or objArticle.ImageUrl.ToLower().StartsWith("https://")) Then + If (ArticleSettings.EnableExternalImages) Then + ucUploadImages.ImageExternalUrl = objArticle.ImageUrl + End If + End If + End If + End If + + UrlLink.Url = objArticle.Url + chkNewWindow.Checked = objArticle.IsNewWindow + + Dim categories As ArrayList = objArticleController.GetArticleCategories(_articleID) + For Each category As CategoryInfo In categories + Dim li As ListItem = lstCategories.Items.FindByValue(category.CategoryID.ToString()) + If Not (li Is Nothing) Then + li.Selected = True + End If + Next + txtTags.Text = objArticle.Tags + + Dim objPageController As New PageController + Dim pages As ArrayList = objPageController.GetPageList(_articleID) + If (pages.Count > 0) Then + Details.Text = CType(pages(0), PageInfo).PageText + End If + + cmdDelete.Visible = True + cmdDelete.OnClientClick = "return confirm('" & DotNetNuke.Services.Localization.Localization.GetString("Delete.Text", LocalResourceFile) & "');" + + Dim objMirrorArticleController As New MirrorArticleController + Dim objMirrorArticleInfo As MirrorArticleInfo = objMirrorArticleController.GetMirrorArticle(_articleID) + + If (objMirrorArticleInfo IsNot Nothing) Then + + phMirrorText.Visible = True + If (objMirrorArticleInfo.AutoUpdate) Then + lblMirrorText.Text = Localization.GetString("MirrorTextUpdate", Me.LocalResourceFile) + + If (lblMirrorText.Text.IndexOf("{0}") <> -1) Then + lblMirrorText.Text = lblMirrorText.Text.Replace("{0}", objMirrorArticleInfo.PortalName) + End If + + phCreate.Visible = False + phOrganize.Visible = False + phPublish.Visible = False + + cmdPublishArticle.Visible = False + cmdAddEditPages.Visible = False + Else + lblMirrorText.Text = Localization.GetString("MirrorText", Me.LocalResourceFile) + + If (lblMirrorText.Text.IndexOf("{0}") <> -1) Then + lblMirrorText.Text = lblMirrorText.Text.Replace("{0}", objMirrorArticleInfo.PortalName) + End If + End If + + End If + + Dim objMirrorArticleLinked As ArrayList = objMirrorArticleController.GetMirrorArticleList(_articleID) + + If (objMirrorArticleLinked.Count > 0) Then + + phMirrorText.Visible = True + lblMirrorText.Text = Localization.GetString("MirrorTextLinked", Me.LocalResourceFile) + + If (lblMirrorText.Text.IndexOf("{0}") <> -1) Then + lblMirrorText.Text = lblMirrorText.Text.Replace("{0}", objMirrorArticleLinked.Count.ToString()) + End If + + End If + + Else + + chkFeatured.Checked = ArticleSettings.IsAutoFeatured + chkSecure.Checked = ArticleSettings.IsAutoSecured + If (ArticleSettings.AuthorDefault <> Null.NullInteger) Then + Dim objUser As UserInfo = UserController.GetUser(PortalId, ArticleSettings.AuthorDefault, True) + + If (objUser IsNot Nothing) Then + lblAuthor.Text = objUser.Username + Else + lblAuthor.Text = Me.UserInfo.Username + End If + Else + lblAuthor.Text = Me.UserInfo.Username + End If + PublishDate(DateTime.Now.Hour, DateTime.Now.Minute) = DateTime.Now + cmdDelete.Visible = False + + If (Settings.Contains(ArticleConstants.DEFAULT_CATEGORIES_SETTING)) Then + If Not (Settings(ArticleConstants.DEFAULT_CATEGORIES_SETTING).ToString = Null.NullString) Then + Dim categories As String() = Settings(ArticleConstants.DEFAULT_CATEGORIES_SETTING).ToString().Split(Char.Parse(",")) + + For Each category As String In categories + If Not (lstCategories.Items.FindByValue(category) Is Nothing) Then + lstCategories.Items.FindByValue(category).Selected = True + End If + Next + End If + End If + + End If + + End Sub + + Private Sub BindCategories() + + Dim objCategoryController As CategoryController = New CategoryController + + Dim objCategoriesSelected As New List(Of CategoryInfo) + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(ModuleId, Null.NullInteger, ArticleSettings.CategorySortType) + + If (ArticleSettings.CategoryFilterSubmit) Then + If (ArticleSettings.FilterSingleCategory <> Null.NullInteger) Then + Dim objSelectedCategories As New List(Of CategoryInfo)() + For Each objCategory As CategoryInfo In objCategories + If (objCategory.CategoryID = ArticleSettings.FilterSingleCategory) Then + objSelectedCategories.Add(objCategory) + Exit For + End If + Next + objCategories = objSelectedCategories + End If + + If (ArticleSettings.FilterCategories IsNot Nothing) Then + If (ArticleSettings.FilterCategories.Length > 0) Then + Dim objSelectedCategories As New List(Of CategoryInfo)() + For Each i As Integer In ArticleSettings.FilterCategories + For Each objCategory As CategoryInfo In objCategories + If (objCategory.CategoryID = i) Then + objSelectedCategories.Add(objCategory) + Exit For + End If + Next + Next + objCategories = objSelectedCategories + End If + End If + End If + + For Each objCategory As CategoryInfo In objCategories + If (objCategory.InheritSecurity) Then + objCategoriesSelected.Add(objCategory) + Else + If (Request.IsAuthenticated) Then + If (Settings.Contains(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_SUBMIT_SETTING)) Then + If (PortalSecurity.IsInRoles(Settings(objCategory.CategoryID & "-" & ArticleConstants.PERMISSION_CATEGORY_SUBMIT_SETTING).ToString())) Then + objCategoriesSelected.Add(objCategory) + End If + End If + End If + End If + Next + + lstCategories.DataSource = objCategoriesSelected + lstCategories.DataBind() + + If (Settings.Contains(ArticleConstants.REQUIRE_CATEGORY)) Then + valCategory.Enabled = Convert.ToBoolean(Settings(ArticleConstants.REQUIRE_CATEGORY).ToString()) + End If + + End Sub + + Private Sub BindCustomFields() + + Dim objCustomFieldController As New CustomFieldController() + Dim objCustomFields As ArrayList = objCustomFieldController.List(Me.ModuleId) + + If (objCustomFields.Count = 0) Then + phCustomFields.Visible = False + Else + phCustomFields.Visible = True + rptCustomFields.DataSource = objCustomFields + rptCustomFields.DataBind() + End If + + End Sub + + Private Sub BindStatus() + + For Each value As Integer In System.Enum.GetValues(GetType(StatusType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(StatusType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(StatusType), value), Me.LocalResourceFile) + drpStatus.Items.Add(li) + Next + + End Sub + + Private Sub CheckSecurity() + + If (HasEditRights(_articleID, Me.ModuleId, Me.TabId) = False) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "NotAuthorized", ArticleSettings), True) + End If + + End Sub + + Public Function GetAuthorList(ByVal moduleID As Integer) As ArrayList + + Dim moduleSettings As Hashtable = DotNetNuke.Entities.Portals.PortalSettings.GetModuleSettings(moduleID) + Dim distributionList As String = "" + Dim userList As New ArrayList + + If (moduleSettings.Contains(ArticleConstants.PERMISSION_SUBMISSION_SETTING)) Then + + Dim roles As String = moduleSettings(ArticleConstants.PERMISSION_SUBMISSION_SETTING).ToString() + Dim rolesArray() As String = roles.Split(Convert.ToChar(";")) + Dim userIDs As New Hashtable + + For Each role As String In rolesArray + If (role.Length > 0) Then + + Dim objRoleController As New DotNetNuke.Security.Roles.RoleController + Dim objRole As DotNetNuke.Security.Roles.RoleInfo = objRoleController.GetRoleByName(PortalSettings.PortalId, role) + + If Not (objRole Is Nothing) Then + Dim objUsers As ArrayList = objRoleController.GetUserRolesByRoleName(PortalSettings.PortalId, objRole.RoleName) + For Each objUser As DotNetNuke.Entities.Users.UserRoleInfo In objUsers + If (userIDs.Contains(objUser.UserID) = False) Then + Dim objUserController As DotNetNuke.Entities.Users.UserController = New DotNetNuke.Entities.Users.UserController + Dim objSelectedUser As DotNetNuke.Entities.Users.UserInfo = objUserController.GetUser(PortalSettings.PortalId, objUser.UserID) + If Not (objSelectedUser Is Nothing) Then + If (objSelectedUser.Email.Length > 0) Then + userIDs.Add(objUser.UserID, objUser.UserID) + userList.Add(objSelectedUser) + End If + End If + End If + Next + End If + End If + Next + + End If + + Return userList + + End Function + + Private Sub PopulateAuthorList() + + ddlAuthor.DataSource = GetAuthorList(Me.ModuleId) + ddlAuthor.DataBind() + ddlAuthor.Items.Insert(0, New ListItem(Localization.GetString("SelectAuthor.Text", Me.LocalResourceFile), "-1")) + + End Sub + + Private Sub ReadQueryString() + + If (Request("ArticleID") <> "") Then + If (IsNumeric(Request("ArticleID"))) Then + _articleID = Convert.ToInt32(Request("ArticleID")) + End If + End If + + If (Request("ReturnUrl") <> "") Then + _returnUrl = Request("ReturnUrl") + End If + + End Sub + + Private Function SaveArticle() As Integer + + If (_articleID <> Null.NullInteger) Then + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + + If Not (objArticle Is Nothing) Then + Return SaveArticle(objArticle.Status) + End If + Else + Return SaveArticle(StatusType.Draft) + End If + + End Function + + Private Function SaveArticle(ByVal status As StatusType) As Integer + + Dim objArticleController As ArticleController = New ArticleController + Dim objArticle As ArticleInfo = New ArticleInfo + + Dim statusChanged As Boolean = False + Dim publishArticle As Boolean = False + + If (_articleID = Null.NullInteger) Then + If (pnlAuthor.Visible = False) Then + Dim objUser As UserInfo = UserController.GetUserByName(Me.PortalId, lblAuthor.Text) + + If (objUser IsNot Nothing) Then + objArticle.AuthorID = objUser.UserID + Else + objArticle.AuthorID = Me.UserId + End If + Else + Dim objUser As UserInfo = UserController.GetUserByName(Me.PortalId, txtAuthor.Text) + + If (objUser IsNot Nothing) Then + objArticle.AuthorID = objUser.UserID + Else + objArticle.AuthorID = Me.UserId + End If + End If + + If (ddlAuthor.Visible) Then + objArticle.AuthorID = Convert.ToInt32(ddlAuthor.SelectedValue) + End If + objArticle.CreatedDate = DateTime.Now + objArticle.Status = StatusType.Draft + objArticle.CommentCount = 0 + objArticle.RatingCount = 0 + objArticle.Rating = 0 + objArticle.ShortUrl = "" + Else + objArticle = objArticleController.GetArticle(_articleID) + objArticleController.DeleteArticleCategories(_articleID) + + If (objArticle.Status <> StatusType.Published And status = StatusType.Published) Then + ' Article now approved, notify if not an Approver. + If (objArticle.AuthorID <> Me.UserId) Then + statusChanged = True + End If + End If + + If (pnlAuthor.Visible) Then + Dim objUser As UserInfo = UserController.GetUserByName(Me.PortalId, txtAuthor.Text) + + If (objUser IsNot Nothing) Then + objArticle.AuthorID = objUser.UserID + End If + End If + + If (ddlAuthor.Visible) Then + objArticle.AuthorID = Convert.ToInt32(ddlAuthor.SelectedValue) + End If + End If + + objArticle.MetaTitle = txtMetaTitle.Text.Trim() + objArticle.MetaDescription = txtMetaDescription.Text.Trim() + objArticle.MetaKeywords = txtMetaKeyWords.Text.Trim() + objArticle.PageHeadText = txtPageHeadText.Text.Trim() + + If (chkMirrorArticle.Checked And drpMirrorArticle.Items.Count > 0) Then + Dim objLinkedArticle As ArticleInfo = objArticleController.GetArticle(Convert.ToInt32(drpMirrorArticle.SelectedValue)) + + If (objLinkedArticle IsNot Nothing) Then + objArticle.Title = objLinkedArticle.Title + objArticle.Summary = objLinkedArticle.Summary + objArticle.Url = objLinkedArticle.Url + objArticle.IsNewWindow = objLinkedArticle.IsNewWindow + objArticle.ImageUrl = objLinkedArticle.ImageUrl + + objArticle.MetaTitle = objLinkedArticle.MetaTitle + objArticle.MetaDescription = objLinkedArticle.MetaDescription + objArticle.MetaKeywords = objLinkedArticle.MetaKeywords + objArticle.PageHeadText = objLinkedArticle.PageHeadText + End If + Else + objArticle.Title = txtTitle.Text + If (ArticleSettings.TextEditorSummaryMode = Components.Types.TextEditorModeType.Basic) Then + objArticle.Summary = txtExcerptBasic.Text.Replace(vbCrLf, "<br />") + Else + If (ExcerptRich.Text <> "" AndAlso StripHtml(ExcerptRich.Text).Length > 0 AndAlso ExcerptRich.Text <> "<p>&#160;</p>") Then + objArticle.Summary = ExcerptRich.Text + Else + objArticle.Summary = Null.NullString + End If + End If + objArticle.Url = UrlLink.Url + objArticle.IsNewWindow = chkNewWindow.Checked + If (ArticleSettings.IsImagesEnabled = True) Then + objArticle.ImageUrl = ucUploadImages.ImageExternalUrl + End If + End If + + objArticle.IsFeatured = chkFeatured.Checked + objArticle.IsSecure = chkSecure.Checked + objArticle.LastUpdate = DateTime.Now + objArticle.LastUpdateID = Me.UserId + objArticle.ModuleID = Me.ModuleId + + objArticle.Status = status + + If (objArticle.StartDate <> Null.NullDate) Then + objArticle.StartDate = PublishDate(objArticle.StartDate.Hour, objArticle.StartDate.Minute) + Else + objArticle.StartDate = PublishDate(DateTime.Now.Hour, DateTime.Now.Minute) + End If + + If (ExpiryDate(0, 0) = Null.NullDate) Then + objArticle.EndDate = Null.NullDate + Else + If (objArticle.EndDate <> Null.NullDate) Then + objArticle.EndDate = ExpiryDate(objArticle.EndDate.Hour, objArticle.EndDate.Minute) + Else + objArticle.EndDate = ExpiryDate(0, 0) + End If + End If + + If (_articleID = Null.NullInteger) Then + objArticle.ArticleID = objArticleController.AddArticle(objArticle) + ucUploadImages.UpdateImages(objArticle.ArticleID) + ucUploadFiles.UpdateFiles(objArticle.ArticleID) + objArticleController.UpdateArticle(objArticle) + + If (chkMirrorArticle.Checked And drpMirrorArticle.Items.Count > 0) Then + + ' Mirrored Article + Dim objMirrorArticleInfo As New MirrorArticleInfo + + objMirrorArticleInfo.ArticleID = objArticle.ArticleID + objMirrorArticleInfo.LinkedArticleID = Convert.ToInt32(drpMirrorArticle.SelectedValue) + objMirrorArticleInfo.LinkedPortalID = Convert.ToInt32(drpMirrorModule.SelectedValue.Split("-"c)(0)) + objMirrorArticleInfo.AutoUpdate = chkMirrorAutoUpdate.Checked + + Dim objMirrorArticleController As New MirrorArticleController() + objMirrorArticleController.AddMirrorArticle(objMirrorArticleInfo) + + 'Copy Files + Dim folderLinked As String = "" + + Dim objModuleController As New ModuleController() + Dim objSettingsLinked As Hashtable = objModuleController.GetModuleSettings(drpMirrorModule.SelectedValue.Split("-"c)(1)) + + If (objSettingsLinked.ContainsKey(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) Then + If (IsNumeric(objSettingsLinked(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING))) Then + Dim folderID As Integer = Convert.ToInt32(objSettingsLinked(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(Convert.ToInt32(drpMirrorModule.SelectedValue.Split("-"c)(0)), folderID) + If (objFolder IsNot Nothing) Then + folderLinked = objFolder.FolderPath + End If + End If + End If + + Dim objPortalController As New PortalController + Dim objPortalLinked As PortalInfo = objPortalController.GetPortal(Convert.ToInt32(drpMirrorModule.SelectedValue.Split("-"c)(0))) + + Dim filePathLinked As String = objPortalLinked.HomeDirectoryMapPath & folderLinked.Replace("/", "\") + + Dim folder As String = "" + + Dim objSettings As Hashtable = objModuleController.GetModuleSettings(ModuleId) + + If (objSettings.ContainsKey(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) Then + If (IsNumeric(objSettings(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING))) Then + Dim folderID As Integer = Convert.ToInt32(objSettings(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(PortalId, folderID) + If (objFolder IsNot Nothing) Then + folder = objFolder.FolderPath + End If + End If + End If + + Dim objFileController As New FileController + Dim objFiles As List(Of FileInfo) = objFileController.GetFileList(objMirrorArticleInfo.LinkedArticleID, Null.NullString) + + For Each objFile As FileInfo In objFiles + + If (File.Exists(filePathLinked & objFile.FileName)) Then + + Dim finalCopyPath = filePathLinked & objFile.FileName + + Dim filePath As String = PortalSettings.HomeDirectoryMapPath & folder.Replace("/", "\") + + If Not (Directory.Exists(filePath)) Then + Directory.CreateDirectory(filePath) + End If + + If (File.Exists(filePath & objFile.FileName)) Then + For i As Integer = 1 To 100 + If (File.Exists(filePath & i.ToString() & "_" & objFile.FileName) = False) Then + objFile.FileName = i.ToString() & "_" & objFile.FileName + Exit For + End If + Next + End If + + File.Copy(finalCopyPath, filePath & objFile.FileName) + + objFile.ArticleID = objArticle.ArticleID + objFileController.Add(objFile) + + End If + + Next + + 'Copy Images + + Dim folderImagesLinked As String = "" + + If (objSettingsLinked.ContainsKey(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING)) Then + If (IsNumeric(objSettingsLinked(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING))) Then + Dim folderID As Integer = Convert.ToInt32(objSettingsLinked(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING)) + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(Convert.ToInt32(drpMirrorModule.SelectedValue.Split("-"c)(0)), folderID) + If (objFolder IsNot Nothing) Then + folderImagesLinked = objFolder.FolderPath + End If + End If + End If + + Dim filePathImagesLinked As String = objPortalLinked.HomeDirectoryMapPath & folderImagesLinked.Replace("/", "\") + + Dim folderImages As String = "" + + If (objSettings.ContainsKey(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING)) Then + If (IsNumeric(objSettings(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING))) Then + Dim folderID As Integer = Convert.ToInt32(objSettings(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING)) + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(PortalId, folderID) + If (objFolder IsNot Nothing) Then + folderImages = objFolder.FolderPath + End If + End If + End If + + Dim objImageController As New ImageController + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objMirrorArticleInfo.LinkedArticleID, Null.NullString) + + For Each objImage As ImageInfo In objImages + + Dim objNewImage As ImageInfo = objImage.Clone + + If (File.Exists(filePathImagesLinked & objNewImage.FileName)) Then + + Dim finalCopyPath = filePathImagesLinked & objNewImage.FileName + + Dim filePath As String = PortalSettings.HomeDirectoryMapPath & folderImages.Replace("/", "\") + + If Not (Directory.Exists(filePath)) Then + Directory.CreateDirectory(filePath) + End If + + If (File.Exists(filePath & objNewImage.FileName)) Then + For i As Integer = 1 To 100 + If (File.Exists(filePath & i.ToString() & "_" & objNewImage.FileName) = False) Then + objNewImage.FileName = i.ToString() & "_" & objNewImage.FileName + Exit For + End If + Next + End If + + File.Copy(finalCopyPath, filePath & objNewImage.FileName) + + objNewImage.ImageID = Null.NullInteger + objNewImage.Folder = folderImages + objNewImage.ArticleID = objArticle.ArticleID + objImageController.Add(objNewImage) + + End If + + Next + + End If + + objArticleController.UpdateArticle(objArticle) + If (objArticle.Status = StatusType.Published) Then + publishArticle = True + End If + Else + objArticleController.UpdateArticle(objArticle) + If (statusChanged) Then + publishArticle = True + End If + End If + + SaveCategories(objArticle.ArticleID) + SaveTags(objArticle.ArticleID) + SaveDetails(objArticle.ArticleID, objArticle.Title) + SaveCustomFields(objArticle.ArticleID) + + ' Re-init. + objArticle = objArticleController.GetArticle(objArticle.ArticleID) + + If (publishArticle) Then + If (objArticle.IsApproved) Then + If (ArticleSettings.JournalIntegration) Then + Dim objJournal As New Journal + objJournal.AddArticleToJournal(objArticle, PortalId, TabId, Me.UserId, Null.NullInteger, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False)) + End If + + If (ArticleSettings.JournalIntegrationGroups) Then + + Dim objCategories As ArrayList = objArticleController.GetArticleCategories(objArticle.ArticleID) + + If (objCategories.Count > 0) Then + + Dim objRoleController As New RoleController() + + Dim objRoles As ArrayList = objRoleController.GetRoles() + For Each objRole As RoleInfo In objRoles + Dim roleAccess As Boolean = False + + If (objRole.SecurityMode = SecurityMode.SocialGroup Or objRole.SecurityMode = SecurityMode.Both) Then + + For Each objCategory As CategoryInfo In objCategories + + If (objCategory.InheritSecurity = False) Then + + If (objCategory.CategorySecurityType = CategorySecurityType.Loose) Then + roleAccess = False + Exit For + Else + If (Settings.Contains(objCategory.CategoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING)) Then + If (IsInRole(objRole.RoleName, Settings(objCategory.CategoryID.ToString() & "-" & ArticleConstants.PERMISSION_CATEGORY_VIEW_SETTING).ToString().Split(";"c))) Then + roleAccess = True + End If + End If + End If + + End If + + Next + + End If + + If (roleAccess) Then + Dim objJournal As New Journal + objJournal.AddArticleToJournal(objArticle, PortalId, TabId, Me.UserId, objRole.RoleID, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False)) + End If + + Next + + End If + + End If + + ' Notify Smart Thinker + + If (ArticleSettings.EnableSmartThinkerStoryFeed) Then + Dim objStoryFeed As New wsStoryFeed.StoryFeedWS + objStoryFeed.Url = AddHTTP(Request.ServerVariables("HTTP_HOST") & Me.ResolveUrl("~/DesktopModules/Smart-Thinker%20-%20UserProfile/StoryFeed.asmx")) + + Dim val As String = GetSharedResource("StoryFeed-AddArticle") + + val = val.Replace("[AUTHOR]", objArticle.AuthorDisplayName) + val = val.Replace("[AUTHORID]", objArticle.AuthorID.ToString()) + val = val.Replace("[ARTICLELINK]", Common.GetArticleLink(objArticle, Me.PortalSettings.ActiveTab, ArticleSettings, False)) + val = val.Replace("[ARTICLETITLE]", objArticle.Title) + + Try + objStoryFeed.AddAction(80, _articleID, val, objArticle.AuthorID, "VE6457624576460436531768") + Catch + End Try + End If + + If (ArticleSettings.EnableActiveSocialFeed) Then + If (ArticleSettings.ActiveSocialSubmitKey <> "") Then + If IO.File.Exists(HttpContext.Current.Server.MapPath("~/bin/active.modules.social.dll")) Then + Dim ai As Object = Nothing + Dim asm As System.Reflection.Assembly + Dim ac As Object = Nothing + Try + asm = System.Reflection.Assembly.Load("Active.Modules.Social") + ac = asm.CreateInstance("Active.Modules.Social.API.Journal") + If Not ac Is Nothing Then + ac.AddProfileItem(New Guid(ArticleSettings.ActiveSocialSubmitKey), objArticle.AuthorID, Common.GetArticleLink(objArticle, Me.PortalSettings.ActiveTab, ArticleSettings, False), objArticle.Title, objArticle.Summary, objArticle.Body, 1, "") + End If + Catch ex As Exception + End Try + End If + End If + End If + + End If + End If + + If (_articleID <> Null.NullInteger And statusChanged = False) Then + + If (objArticle.Status = StatusType.Published) Then + ' Check to see if any articles have been linked + + Dim objEmailTemplateController As New EmailTemplateController + + Dim objMirrorArticleController As New MirrorArticleController + Dim objMirrorArticleLinked As ArrayList = objMirrorArticleController.GetMirrorArticleList(_articleID) + + Dim objEventLog As New DotNetNuke.Services.Log.EventLog.EventLogController + objEventLog.AddLog("Article Linked Update", objMirrorArticleLinked.Count.ToString(), PortalSettings, -1, DotNetNuke.Services.Log.EventLog.EventLogController.EventLogType.ADMIN_ALERT) + + If (objMirrorArticleLinked.Count > 0) Then + + For Each objMirrorArticleInfo As MirrorArticleInfo In objMirrorArticleLinked + + Dim objArticleMirrored As ArticleInfo = objArticleController.GetArticle(objMirrorArticleInfo.ArticleID) + + If (objArticleMirrored IsNot Nothing) Then + + If (objArticleMirrored.AuthorEmail <> "") Then + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, EmailTemplateType.ArticleUpdateMirrored, objArticleMirrored.AuthorEmail, ArticleSettings) + End If + + If (objMirrorArticleInfo.AutoUpdate) Then + + objArticleMirrored.Title = objArticle.Title + objArticleMirrored.Summary = objArticle.Summary + + objArticleMirrored.Url = objArticle.Url + objArticleMirrored.IsNewWindow = objArticle.IsNewWindow + objArticleMirrored.ImageUrl = objArticle.ImageUrl + + objArticleMirrored.MetaTitle = objArticle.MetaTitle + objArticleMirrored.MetaDescription = objArticle.MetaDescription + objArticleMirrored.MetaKeywords = objArticle.MetaKeywords + objArticleMirrored.PageHeadText = objArticle.PageHeadText + + ' Save Custom Fields + Dim fieldsToUpdate As New Hashtable + + Dim objCustomValueController As New CustomValueController + Dim objCustomValues As List(Of CustomValueInfo) = objCustomValueController.List(objArticleMirrored.ArticleID) + + For Each objCustomValue As CustomValueInfo In objCustomValues + objCustomValueController.Delete(objArticleMirrored.ArticleID, objCustomValue.CustomFieldID) + Next + + Dim objCustomFieldController As New CustomFieldController + Dim objCustomFields As ArrayList = objCustomFieldController.List(ModuleId) + Dim objCustomFieldsLinked As ArrayList = objCustomFieldController.List(objArticleMirrored.ModuleID) + + For Each objCustomFieldLinked As CustomFieldInfo In objCustomFieldsLinked + For Each objCustomField As CustomFieldInfo In objCustomFields + + If (objCustomFieldLinked.Name.ToLower() = objCustomField.Name.ToLower()) Then + + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID)) Then + fieldsToUpdate.Add(objCustomFieldLinked.CustomFieldID.ToString(), objArticle.CustomList(objCustomField.CustomFieldID).ToString()) + End If + + End If + + Next + Next + + For Each key As String In fieldsToUpdate.Keys + Dim val As String = fieldsToUpdate(key).ToString() + Dim objCustomValue As CustomValueInfo = New CustomValueInfo + objCustomValue.CustomFieldID = Convert.ToInt32(key) + objCustomValue.CustomValue = val + objCustomValue.ArticleID = objArticleMirrored.ArticleID + objCustomValueController.Add(objCustomValue) + Next + + ' Details + + Dim objPageController As PageController = New PageController + Dim currentPages As ArrayList = objPageController.GetPageList(objArticleMirrored.ArticleID) + + For Each objPage As PageInfo In currentPages + objPageController.DeletePage(objPage.PageID) + Next + + Dim pages As ArrayList = objPageController.GetPageList(objArticle.ArticleID) + + For Each objPage As PageInfo In pages + objPage.ArticleID = objArticleMirrored.ArticleID + objPage.PageID = Null.NullInteger + objPageController.AddPage(objPage) + Next + + ' Save Tags + + Dim objTagController As New TagController + objTagController.DeleteArticleTag(objArticleMirrored.ArticleID) + + Dim tagsCurrent As String = objArticle.Tags + + If (tagsCurrent <> "") Then + Dim tags As String() = tagsCurrent.Split(","c) + For Each tag As String In tags + If (tag <> "") Then + Dim objTag As TagInfo = objTagController.Get(objArticleMirrored.ModuleID, tag) + + If (objTag Is Nothing) Then + objTag = New TagInfo + objTag.Name = tag + objTag.NameLowered = tag.ToLower() + objTag.ModuleID = objArticleMirrored.ModuleID + objTag.TagID = objTagController.Add(objTag) + End If + + objTagController.Add(objArticleMirrored.ArticleID, objTag.TagID) + End If + Next + End If + + 'Copy Files + Dim folderLinked As String = "" + + Dim objModuleController As New ModuleController() + Dim objSettingsLinked As Hashtable = objModuleController.GetModuleSettings(objArticleMirrored.ModuleID) + + If (objSettingsLinked.ContainsKey(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) Then + If (IsNumeric(objSettingsLinked(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING))) Then + Dim folderID As Integer = Convert.ToInt32(objSettingsLinked(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(objArticleMirrored.ModuleID, folderID) + If (objFolder IsNot Nothing) Then + folderLinked = objFolder.FolderPath + End If + End If + End If + + Dim objPortalController As New PortalController + Dim objPortalLinked As PortalInfo = objPortalController.GetPortal(objMirrorArticleInfo.PortalID) + + Dim filePathLinked As String = objPortalLinked.HomeDirectoryMapPath & folderLinked.Replace("/", "\") + + Dim folder As String = "" + + Dim objSettings As Hashtable = objModuleController.GetModuleSettings(ModuleId) + + If (objSettings.ContainsKey(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) Then + If (IsNumeric(objSettings(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING))) Then + Dim folderID As Integer = Convert.ToInt32(objSettings(ArticleConstants.DEFAULT_FILES_FOLDER_SETTING)) + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(PortalId, folderID) + If (objFolder IsNot Nothing) Then + folder = objFolder.FolderPath + End If + End If + End If + + Dim objFileController As New FileController + Dim objFilesCurrent As List(Of FileInfo) = objFileController.GetFileList(objArticleMirrored.ArticleID, Null.NullString) + + For Each objFile As FileInfo In objFilesCurrent + objFileController.Delete(objFile.FileID) + Next + + Dim objFiles As List(Of FileInfo) = objFileController.GetFileList(objArticle.ArticleID, Null.NullString) + + For Each objFile As FileInfo In objFiles + + Dim finalCopyPath = PortalSettings.HomeDirectoryMapPath & folder.Replace("/", "\") & objFile.FileName + Dim filePath As String = objPortalLinked.HomeDirectoryMapPath & folderLinked.Replace("/", "\") & objFile.FileName + + If (File.Exists(finalCopyPath)) Then + + If Not (Directory.Exists(objPortalLinked.HomeDirectoryMapPath & folderLinked.Replace("/", "\"))) Then + Directory.CreateDirectory(objPortalLinked.HomeDirectoryMapPath & folderLinked.Replace("/", "\")) + End If + + If (File.Exists(filePath) = False) Then + File.Copy(finalCopyPath, filePath) + End If + + objFile.FileID = Null.NullInteger + objFile.ArticleID = objArticleMirrored.ArticleID + objFileController.Add(objFile) + + End If + + Next + + 'Copy Images + + Dim folderImagesLinked As String = "" + + If (objSettingsLinked.ContainsKey(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING)) Then + If (IsNumeric(objSettingsLinked(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING))) Then + Dim folderID As Integer = Convert.ToInt32(objSettingsLinked(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING)) + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(objArticleMirrored.ModuleID, folderID) + If (objFolder IsNot Nothing) Then + folderImagesLinked = objFolder.FolderPath + End If + End If + End If + + Dim filePathImagesLinked As String = objPortalLinked.HomeDirectoryMapPath & folderImagesLinked.Replace("/", "\") + + Dim folderImages As String = "" + + If (objSettings.ContainsKey(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING)) Then + If (IsNumeric(objSettings(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING))) Then + Dim folderID As Integer = Convert.ToInt32(objSettings(ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING)) + Dim objFolderController As New FolderController + Dim objFolder As FolderInfo = objFolderController.GetFolderInfo(PortalId, folderID) + If (objFolder IsNot Nothing) Then + folderImages = objFolder.FolderPath + End If + End If + End If + + Dim objImageController As New ImageController + Dim objImagesCurrent As List(Of ImageInfo) = objImageController.GetImageList(objArticleMirrored.ArticleID, Null.NullString) + + For Each objImage As ImageInfo In objImagesCurrent + objImageController.Delete(objImage.ImageID, _articleID, objImage.ImageGuid) + Next + + Dim objImages As List(Of ImageInfo) = objImageController.GetImageList(objArticle.ArticleID, Null.NullString) + + For Each objImage As ImageInfo In objImages + + Dim finalCopyPath = PortalSettings.HomeDirectoryMapPath & folderImages.Replace("/", "\") & objImage.FileName + Dim filePath As String = objPortalLinked.HomeDirectoryMapPath & folderImagesLinked.Replace("/", "\") & objImage.FileName + + If (File.Exists(finalCopyPath)) Then + + If Not (Directory.Exists(objPortalLinked.HomeDirectoryMapPath & folderImages.Replace("/", "\"))) Then + Directory.CreateDirectory(objPortalLinked.HomeDirectoryMapPath & folderImages.Replace("/", "\")) + End If + + If (File.Exists(filePath) = False) Then + File.Copy(finalCopyPath, filePath) + End If + + objImage.Folder = folderImages + objImage.ImageID = Null.NullInteger + objImage.ArticleID = objArticleMirrored.ArticleID + objImageController.Add(objImage) + + End If + + Next + + + ' Save + + objArticleController.UpdateArticle(objArticleMirrored) + + End If + + + End If + + Next + + End If + + End If + + End If + + If (statusChanged) Then + Common.NotifyAuthor(objArticle, Me.Settings, Me.ModuleId, PortalSettings.ActiveTab, Me.PortalId, ArticleSettings) + End If + + ArticleController.ClearArticleCache(objArticle.ArticleID) + + Return objArticle.ArticleID + + End Function + + Private Sub SaveCategories(ByVal articleID As Integer) + + Dim objArticleController As ArticleController = New ArticleController + + If (chkMirrorArticle.Checked And drpMirrorArticle.Items.Count > 0) Then + Dim objCategories As ArrayList = objArticleController.GetArticleCategories(Convert.ToInt32(drpMirrorArticle.SelectedValue)) + + For Each objCategory As CategoryInfo In objCategories + For Each item As ListItem In lstCategories.Items + If (objCategory.Name.ToLower() = item.Text.TrimStart("."c).ToLower()) Then + item.Selected = True + End If + Next + Next + End If + + For Each item As ListItem In lstCategories.Items + If (item.Selected) Then + objArticleController.AddArticleCategory(articleID, Int32.Parse(item.Value)) + End If + Next + + DataCache.RemoveCache(ArticleConstants.CACHE_CATEGORY_ARTICLE & articleID.ToString()) + DataCache.RemoveCache(ArticleConstants.CACHE_CATEGORY_ARTICLE_NO_LINK & articleID.ToString()) + + End Sub + + Private Sub SaveTags(ByVal articleID As Integer) + + If (chkMirrorArticle.Checked And drpMirrorArticle.Items.Count > 0) Then + Dim objArticleController As New ArticleController() + Dim objLinkedArticle As ArticleInfo = objArticleController.GetArticle(Convert.ToInt32(drpMirrorArticle.SelectedValue)) + + If (objLinkedArticle IsNot Nothing) Then + txtTags.Text = objLinkedArticle.Tags + End If + End If + + Dim objTagController As New TagController + objTagController.DeleteArticleTag(articleID) + + If (txtTags.Text <> "") Then + Dim tags As String() = txtTags.Text.Split(","c) + For Each tag As String In tags + If (tag <> "") Then + Dim objTag As TagInfo = objTagController.Get(ModuleId, tag) + + If (objTag Is Nothing) Then + objTag = New TagInfo + objTag.Name = tag + objTag.NameLowered = tag.ToLower() + objTag.ModuleID = ModuleId + objTag.TagID = objTagController.Add(objTag) + End If + + objTagController.Add(articleID, objTag.TagID) + End If + Next + End If + + End Sub + + Private Sub SaveDetails(ByVal articleID As Integer, ByVal title As String) + + If (chkMirrorArticle.Checked And drpMirrorArticle.Items.Count > 0) Then + Dim objPageController As PageController = New PageController + Dim pages As ArrayList = objPageController.GetPageList(Convert.ToInt32(drpMirrorArticle.SelectedValue)) + + For Each objPage As PageInfo In pages + objPage.ArticleID = articleID + objPageController.AddPage(objPage) + Next + Else + Dim doUpdate As Boolean = True + If (phMirrorText.Visible = True) Then + Dim objMirrorArticleController As New MirrorArticleController + Dim objMirrorArticleInfo As MirrorArticleInfo = objMirrorArticleController.GetMirrorArticle(_articleID) + + If (objMirrorArticleInfo IsNot Nothing) Then + + If (objMirrorArticleInfo.AutoUpdate) Then + doUpdate = False + End If + End If + End If + + If (doUpdate) Then + If (Details.Text.Trim() <> "") Then + Dim objPageController As PageController = New PageController + Dim pages As ArrayList = objPageController.GetPageList(articleID) + + If (pages.Count > 0) Then + Dim objPage As PageInfo = CType(pages(0), PageInfo) + objPage.PageText = Details.Text + objPageController.UpdatePage(objPage) + Else + Dim objPage As New PageInfo + objPage.PageText = Details.Text + objPage.ArticleID = articleID + objPage.Title = txtTitle.Text + objPageController.AddPage(objPage) + End If + Else + Dim objPageController As PageController = New PageController + Dim pages As ArrayList = objPageController.GetPageList(articleID) + + If (pages.Count = 1) Then + objPageController.DeletePage(CType(pages(0), PageInfo).PageID) + End If + End If + End If + End If + + End Sub + + Private Sub SaveCustomFields(ByVal articleID As Integer) + + Dim fieldsToUpdate As New Hashtable + + Dim objCustomFieldController As New CustomFieldController() + Dim objCustomFields As ArrayList = objCustomFieldController.List(Me.ModuleId) + + If (phCustomFields.Visible) Then + + For Each item As RepeaterItem In rptCustomFields.Items + Dim phValue As PlaceHolder = CType(item.FindControl("phValue"), PlaceHolder) + + If Not (phValue Is Nothing) Then + If (phValue.Controls.Count > 0) Then + + Dim objControl As System.Web.UI.Control = phValue.Controls(0) + Dim customFieldID As Integer = Convert.ToInt32(objControl.ID) + + For Each objCustomField As CustomFieldInfo In objCustomFields + If (objCustomField.CustomFieldID = customFieldID) Then + Select Case objCustomField.FieldType + + Case CustomFieldType.OneLineTextBox + Dim objTextBox As TextBox = CType(objControl, TextBox) + fieldsToUpdate.Add(customFieldID.ToString(), objTextBox.Text) + + Case CustomFieldType.MultiLineTextBox + Dim objTextBox As TextBox = CType(objControl, TextBox) + fieldsToUpdate.Add(customFieldID.ToString(), objTextBox.Text) + + Case CustomFieldType.RichTextBox + Dim objTextBox As TextEditor = CType(objControl, TextEditor) + fieldsToUpdate.Add(customFieldID.ToString(), objTextBox.Text) + + Case CustomFieldType.DropDownList + Dim objDropDownList As DropDownList = CType(objControl, DropDownList) + If (objDropDownList.SelectedValue = "-1") Then + fieldsToUpdate.Add(customFieldID.ToString(), "") + Else + fieldsToUpdate.Add(customFieldID.ToString(), objDropDownList.SelectedValue) + End If + + Case CustomFieldType.CheckBox + Dim objCheckBox As CheckBox = CType(objControl, CheckBox) + fieldsToUpdate.Add(customFieldID.ToString(), objCheckBox.Checked.ToString()) + + Case CustomFieldType.MultiCheckBox + Dim objCheckBoxList As CheckBoxList = CType(objControl, CheckBoxList) + Dim values As String = "" + For Each objCheckBox As ListItem In objCheckBoxList.Items + If (objCheckBox.Selected) Then + If (values = "") Then + values = objCheckBox.Value + Else + values = values & "|" & objCheckBox.Value + End If + End If + Next + fieldsToUpdate.Add(customFieldID.ToString(), values) + + Case CustomFieldType.RadioButton + Dim objRadioButtonList As RadioButtonList = CType(objControl, RadioButtonList) + fieldsToUpdate.Add(customFieldID.ToString(), objRadioButtonList.SelectedValue) + + Case CustomFieldType.ColorPicker + Dim objTextBox As TextBox = CType(objControl, TextBox) + fieldsToUpdate.Add(customFieldID.ToString(), objTextBox.Text) + + End Select + + Exit For + End If + Next + + End If + End If + Next + + End If + + If (chkMirrorArticle.Checked And drpMirrorArticle.Items.Count > 0) Then + + Dim objArticleController As New ArticleController() + Dim objLinkedArticle As ArticleInfo = objArticleController.GetArticle(Convert.ToInt32(drpMirrorArticle.SelectedValue)) + + If (objLinkedArticle IsNot Nothing) Then + + Dim objCustomFieldsLinked As ArrayList = objCustomFieldController.List(Convert.ToInt32(drpMirrorModule.SelectedValue.Split("-"c)(1))) + + For Each objCustomFieldLinked As CustomFieldInfo In objCustomFieldsLinked + For Each objCustomField As CustomFieldInfo In objCustomFields + + If (objCustomFieldLinked.Name.ToLower() = objCustomField.Name.ToLower()) Then + + If (objLinkedArticle.CustomList.Contains(objCustomFieldLinked.CustomFieldID)) Then + fieldsToUpdate.Add(objCustomField.CustomFieldID.ToString(), objLinkedArticle.CustomList(objCustomFieldLinked.CustomFieldID).ToString()) + End If + + End If + + Next + Next + + End If + + End If + + For Each key As String In fieldsToUpdate.Keys + Dim val As String = fieldsToUpdate(key).ToString() + + Dim objCustomValueController As New CustomValueController + Dim objCustomValue As CustomValueInfo = objCustomValueController.GetByCustomField(articleID, Convert.ToInt32(key)) + + If (objCustomValue IsNot Nothing) Then + objCustomValueController.Delete(articleID, Convert.ToInt32(key)) + End If + + objCustomValue = New CustomValueInfo + objCustomValue.CustomFieldID = Convert.ToInt32(key) + objCustomValue.CustomValue = val + objCustomValue.ArticleID = articleID + objCustomValueController.Add(objCustomValue) + Next + + End Sub + + Private Sub SetVisibility() + + trCategories.Visible = ArticleSettings.IsCategoriesEnabled + + If (lstCategories.Items.Count = 0 Or trCategories.Visible = False) Then + Dim objTagController As New TagController() + Dim objTags As ArrayList = objTagController.List(Me.ModuleId, 10) + If (objTags.Count = 0) Then + phOrganize.Visible = False + End If + End If + + If (lstCategories.Items.Count = 0) Then + trCategories.Visible = False + End If + + phExcerpt.Visible = ArticleSettings.IsExcerptEnabled + phMeta.Visible = ArticleSettings.IsMetaEnabled + If (phCustomFields.Visible) Then + phCustomFields.Visible = ArticleSettings.IsCustomEnabled + End If + + trLink.Visible = ArticleSettings.IsLinkEnabled + trNewWindow.Visible = ArticleSettings.IsLinkEnabled + + phAttachment.Visible = (trLink.Visible Or trNewWindow.Visible) + + trFeatured.Visible = ArticleSettings.IsFeaturedEnabled + trSecure.Visible = ArticleSettings.IsSecureEnabled + trPublish.Visible = ArticleSettings.IsPublishEnabled + trExpiry.Visible = ArticleSettings.IsExpiryEnabled + + phPublish.Visible = (trAuthor.Visible Or trFeatured.Visible Or trSecure.Visible Or trPublish.Visible Or trExpiry.Visible) + + drpStatus.Enabled = ArticleSettings.IsApprover + + If (_articleID <> Null.NullInteger) Then + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + + If Not (objArticle Is Nothing) Then + Select Case objArticle.Status + Case StatusType.Draft + cmdSaveArticle.Visible = True + cmdPublishArticle.Visible = True + cmdAddEditPages.Visible = True + cmdDelete.Visible = True + Return + + Case StatusType.AwaitingApproval + cmdSaveArticle.Visible = True + cmdPublishArticle.Visible = False + cmdAddEditPages.Visible = True + cmdDelete.Visible = True + Return + + Case StatusType.Published + cmdSaveArticle.Visible = True + cmdPublishArticle.Visible = False + cmdAddEditPages.Visible = True + cmdDelete.Visible = True + Return + End Select + End If + Else + cmdSaveArticle.Visible = True + cmdPublishArticle.Visible = True + cmdAddEditPages.Visible = True + cmdDelete.Visible = False + End If + + End Sub + + Private Sub SetTextEditor() + + Me.txtExcerptBasic.Visible = (ArticleSettings.TextEditorSummaryMode = Components.Types.TextEditorModeType.Basic) + Me.txtExcerptRich.Visible = (ArticleSettings.TextEditorSummaryMode = Components.Types.TextEditorModeType.Rich) + + 'dshExcerpt.IsExpanded = ArticleSettings.ExpandSummary + 'dshMeta.IsExpanded = ArticleSettings.ExpandMetaInformation + + txtExcerptBasic.Width = Unit.Parse(ArticleSettings.TextEditorSummaryWidth) + Me.txtExcerptBasic.Height = Unit.Parse(ArticleSettings.TextEditorSummaryHeight) + Me.ExcerptRich.Width = Unit.Parse(ArticleSettings.TextEditorSummaryWidth) + Me.ExcerptRich.Height = Unit.Parse(ArticleSettings.TextEditorSummaryHeight) + + Me.Details.Width = Unit.Parse(ArticleSettings.TextEditorWidth) + Me.Details.Height = Unit.Parse(ArticleSettings.TextEditorHeight) + + Me.lstCategories.Height = Unit.Parse(ArticleSettings.CategorySelectionHeight.ToString()) + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init + + Try + + ReadQueryString() + + Dim script As String = "" & vbCrLf _ + & "" & vbCrLf + + Dim CSM As ClientScriptManager = Page.ClientScript + CSM.RegisterClientScriptBlock(Me.GetType, "ColorPicker", script) + + BindCustomFields() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + Try + + Dim objModuleController As ModuleController = New ModuleController + Dim objModule As ModuleInfo = objModuleController.GetModule(Me.ModuleId, Me.TabId) + + If Not (objModule Is Nothing) Then + trAuthor.Visible = (ModulePermissionController.HasModuleAccess(SecurityAccessLevel.Edit, "EDIT", ModuleConfiguration) Or ArticleSettings.IsApprover) + End If + + cmdExpiryCalendar.NavigateUrl = DotNetNuke.Common.Utilities.Calendar.InvokePopupCal(txtExpiryDate) + cmdPublishCalendar.NavigateUrl = DotNetNuke.Common.Utilities.Calendar.InvokePopupCal(txtPublishDate) + + CheckSecurity() + SetTextEditor() + + If (_articleID <> Null.NullInteger) Then + For Each key As String In _richTextValues + For Each item As RepeaterItem In rptCustomFields.Items + If Not (item.FindControl(key) Is Nothing) Then + Dim objTextBox As TextEditor = CType(item.FindControl(key), TextEditor) + objTextBox.Text = _richTextValues(key) + Exit For + End If + Next + Next + End If + + If IsPostBack = False Then + + BindStatus() + BindCategories() + SetVisibility() + BindArticle() + + If (ArticleSettings.ContentSharingPortals = "" Or _articleID <> Null.NullInteger) Then + phMirror.Visible = False + End If + + Page.SetFocus(txtTitle) + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub Page_PreRender(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.PreRender + + Try + + trNewWindow.Visible = (trLink.Visible And (UrlLink.UrlType <> "N")) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub rptCustomFields_OnItemDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.RepeaterItemEventArgs) Handles rptCustomFields.ItemDataBound + + If (e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem) Then + + Dim objArticleController As New ArticleController() + Dim objArticle As ArticleInfo = Nothing + If (_articleID <> Null.NullInteger) Then + objArticle = objArticleController.GetArticle(_articleID) + End If + + Dim objCustomField As CustomFieldInfo = CType(e.Item.DataItem, CustomFieldInfo) + Dim phValue As PlaceHolder = CType(e.Item.FindControl("phValue"), PlaceHolder) + Dim phLabel As PlaceHolder = CType(e.Item.FindControl("phLabel"), PlaceHolder) + + Dim cmdHelp As LinkButton = CType(e.Item.FindControl("cmdHelp"), LinkButton) + Dim pnlHelp As Panel = CType(e.Item.FindControl("pnlHelp"), Panel) + Dim lblLabel As Label = CType(e.Item.FindControl("lblLabel"), Label) + Dim lblHelp As Label = CType(e.Item.FindControl("lblHelp"), Label) + Dim imgHelp As Image = CType(e.Item.FindControl("imgHelp"), Image) + + Dim trItem As HtmlControls.HtmlTableRow = CType(e.Item.FindControl("trItem"), HtmlControls.HtmlTableRow) + + If Not (phValue Is Nothing) Then + + DotNetNuke.UI.Utilities.DNNClientAPI.EnableMinMax(cmdHelp, pnlHelp, True, DotNetNuke.UI.Utilities.DNNClientAPI.MinMaxPersistanceType.None) + + If (objCustomField.IsRequired) Then + lblLabel.Text = objCustomField.Caption & "*:" + Else + lblLabel.Text = objCustomField.Caption & ":" + End If + lblHelp.Text = objCustomField.CaptionHelp + imgHelp.AlternateText = objCustomField.CaptionHelp + + Select Case (objCustomField.FieldType) + + Case CustomFieldType.OneLineTextBox + + Dim objTextBox As New TextBox + objTextBox.CssClass = "NormalTextBox" + objTextBox.ID = objCustomField.CustomFieldID.ToString() + If (objCustomField.Length <> Null.NullInteger AndAlso objCustomField.Length > 0) Then + objTextBox.MaxLength = objCustomField.Length + End If + If (objCustomField.DefaultValue <> "") Then + objTextBox.Text = objCustomField.DefaultValue + End If + If Not (objArticle Is Nothing) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID) And (Page.IsPostBack = False Or objTextBox.Enabled = False)) Then + objTextBox.Text = objArticle.CustomList(objCustomField.CustomFieldID).ToString() + End If + End If + objTextBox.Width = Unit.Pixel(300) + phValue.Controls.Add(objTextBox) + + If (objCustomField.IsRequired) Then + Dim valRequired As New RequiredFieldValidator + valRequired.ControlToValidate = objTextBox.ID + valRequired.ErrorMessage = Localization.GetString("valFieldRequired", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + valRequired.CssClass = "NormalRed" + valRequired.Display = ValidatorDisplay.None + valRequired.SetFocusOnError = True + phValue.Controls.Add(valRequired) + End If + + If (objCustomField.ValidationType <> CustomFieldValidationType.None) Then + Dim valCompare As New CompareValidator + valCompare.ControlToValidate = objTextBox.ID + valCompare.CssClass = "NormalRed" + valCompare.Display = ValidatorDisplay.None + valCompare.SetFocusOnError = True + Select Case objCustomField.ValidationType + + Case CustomFieldValidationType.Currency + valCompare.Type = ValidationDataType.Double + valCompare.Operator = ValidationCompareOperator.DataTypeCheck + valCompare.ErrorMessage = Localization.GetString("valFieldCurrency", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + phValue.Controls.Add(valCompare) + + Case CustomFieldValidationType.Date + valCompare.Type = ValidationDataType.Date + valCompare.Operator = ValidationCompareOperator.DataTypeCheck + valCompare.ErrorMessage = Localization.GetString("valFieldDate", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + phValue.Controls.Add(valCompare) + + Dim objCalendar As New HyperLink + objCalendar.CssClass = "CommandButton" + objCalendar.Text = Localization.GetString("Calendar", Me.LocalResourceFile) + objCalendar.NavigateUrl = DotNetNuke.Common.Utilities.Calendar.InvokePopupCal(objTextBox) + phValue.Controls.Add(objCalendar) + + Case CustomFieldValidationType.Double + valCompare.Type = ValidationDataType.Double + valCompare.Operator = ValidationCompareOperator.DataTypeCheck + valCompare.ErrorMessage = Localization.GetString("valFieldDecimal", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + phValue.Controls.Add(valCompare) + + Case CustomFieldValidationType.Integer + valCompare.Type = ValidationDataType.Integer + valCompare.Operator = ValidationCompareOperator.DataTypeCheck + valCompare.ErrorMessage = Localization.GetString("valFieldNumber", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + phValue.Controls.Add(valCompare) + + Case CustomFieldValidationType.Email + Dim valRegular As New RegularExpressionValidator + valRegular.ControlToValidate = objTextBox.ID + valRegular.ValidationExpression = "\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*" + valRegular.ErrorMessage = Localization.GetString("valFieldEmail", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + valRegular.CssClass = "NormalRed" + valRegular.Display = ValidatorDisplay.None + phValue.Controls.Add(valRegular) + + Case CustomFieldValidationType.Regex + If (objCustomField.RegularExpression <> "") Then + Dim valRegular As New RegularExpressionValidator + valRegular.ControlToValidate = objTextBox.ID + valRegular.ValidationExpression = objCustomField.RegularExpression + valRegular.ErrorMessage = Localization.GetString("valFieldRegex", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + valRegular.CssClass = "NormalRed" + valRegular.Display = ValidatorDisplay.None + phValue.Controls.Add(valRegular) + End If + + End Select + End If + + Case CustomFieldType.MultiLineTextBox + + Dim objTextBox As New TextBox + objTextBox.TextMode = TextBoxMode.MultiLine + objTextBox.CssClass = "NormalTextBox" + objTextBox.ID = objCustomField.CustomFieldID.ToString() + objTextBox.Rows = 4 + If (objCustomField.Length <> Null.NullInteger AndAlso objCustomField.Length > 0) Then + objTextBox.MaxLength = objCustomField.Length + End If + If (objCustomField.DefaultValue <> "") Then + objTextBox.Text = objCustomField.DefaultValue + End If + If Not (objArticle Is Nothing) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID) And (Page.IsPostBack = False Or objTextBox.Enabled = False)) Then + objTextBox.Text = objArticle.CustomList(objCustomField.CustomFieldID).ToString() + End If + End If + objTextBox.Width = Unit.Pixel(300) + phValue.Controls.Add(objTextBox) + + If (objCustomField.IsRequired) Then + Dim valRequired As New RequiredFieldValidator + valRequired.ControlToValidate = objTextBox.ID + valRequired.ErrorMessage = Localization.GetString("valFieldRequired", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + valRequired.CssClass = "NormalRed" + valRequired.Display = ValidatorDisplay.None + valRequired.SetFocusOnError = True + phValue.Controls.Add(valRequired) + End If + + Case CustomFieldType.RichTextBox + + Dim objTextBox As TextEditor = CType(Me.LoadControl("~/controls/TextEditor.ascx"), TextEditor) + objTextBox.ID = objCustomField.CustomFieldID.ToString() + If (objCustomField.DefaultValue <> "") Then + ' objTextBox.Text = objCustomField.DefaultValue + End If + If Not (objArticle Is Nothing) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID) And Page.IsPostBack = False) Then + ' There is a problem assigned values at init with the RTE, using ArrayList to assign later. + _richTextValues.Add(objCustomField.CustomFieldID.ToString(), objArticle.CustomList(objCustomField.CustomFieldID).ToString()) + End If + End If + objTextBox.Width = Unit.Pixel(300) + objTextBox.Height = Unit.Pixel(400) + + phValue.Controls.Add(objTextBox) + + If (objCustomField.IsRequired) Then + Dim valRequired As New RequiredFieldValidator + valRequired.ControlToValidate = objTextBox.ID + valRequired.ErrorMessage = Localization.GetString("valFieldRequired", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + valRequired.CssClass = "NormalRed" + valRequired.SetFocusOnError = True + phValue.Controls.Add(valRequired) + End If + + Case CustomFieldType.DropDownList + + Dim objDropDownList As New DropDownList + objDropDownList.CssClass = "NormalTextBox" + objDropDownList.ID = objCustomField.CustomFieldID.ToString() + + Dim values As String() = objCustomField.FieldElements.Split(Convert.ToChar("|")) + For Each value As String In values + If (value <> "") Then + objDropDownList.Items.Add(value) + End If + Next + + Dim selectText As String = Localization.GetString("SelectValue", Me.LocalResourceFile) + selectText = selectText.Replace("[VALUE]", objCustomField.Caption) + objDropDownList.Items.Insert(0, New ListItem(selectText, "-1")) + + If (objCustomField.DefaultValue <> "") Then + If Not (objDropDownList.Items.FindByValue(objCustomField.DefaultValue) Is Nothing) Then + objDropDownList.SelectedValue = objCustomField.DefaultValue + End If + End If + + objDropDownList.Width = Unit.Pixel(300) + + If Not (objArticle Is Nothing) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID) And (Page.IsPostBack = False Or objDropDownList.Enabled = False)) Then + If Not (objDropDownList.Items.FindByValue(objArticle.CustomList(objCustomField.CustomFieldID).ToString()) Is Nothing) Then + objDropDownList.SelectedValue = objArticle.CustomList(objCustomField.CustomFieldID).ToString() + End If + End If + End If + phValue.Controls.Add(objDropDownList) + + If (objCustomField.IsRequired) Then + Dim valRequired As New RequiredFieldValidator + valRequired.ControlToValidate = objDropDownList.ID + valRequired.ErrorMessage = Localization.GetString("valFieldRequired", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + valRequired.CssClass = "NormalRed" + valRequired.Display = ValidatorDisplay.None + valRequired.SetFocusOnError = True + valRequired.InitialValue = "-1" + phValue.Controls.Add(valRequired) + End If + + Case CustomFieldType.CheckBox + + Dim objCheckBox As New CheckBox + objCheckBox.CssClass = "Normal" + objCheckBox.ID = objCustomField.CustomFieldID.ToString() + If (objCustomField.DefaultValue <> "") Then + Try + objCheckBox.Checked = Convert.ToBoolean(objCustomField.DefaultValue) + Catch + End Try + End If + + If Not (objArticle Is Nothing) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID) And (Page.IsPostBack = False Or objCheckBox.Enabled = False)) Then + If (objArticle.CustomList(objCustomField.CustomFieldID).ToString() <> "") Then + Try + objCheckBox.Checked = Convert.ToBoolean(objArticle.CustomList(objCustomField.CustomFieldID).ToString()) + Catch + End Try + End If + End If + End If + phValue.Controls.Add(objCheckBox) + + Case CustomFieldType.MultiCheckBox + + Dim objCheckBoxList As New CheckBoxList + objCheckBoxList.CssClass = "Normal" + objCheckBoxList.ID = objCustomField.CustomFieldID.ToString() + objCheckBoxList.RepeatColumns = 4 + objCheckBoxList.RepeatDirection = RepeatDirection.Horizontal + objCheckBoxList.RepeatLayout = RepeatLayout.Table + + Dim values As String() = objCustomField.FieldElements.Split(Convert.ToChar("|")) + For Each value As String In values + objCheckBoxList.Items.Add(value) + Next + + If (objCustomField.DefaultValue <> "") Then + Dim vals As String() = objCustomField.DefaultValue.Split(Convert.ToChar("|")) + For Each val As String In vals + For Each item As ListItem In objCheckBoxList.Items + If (item.Value = val) Then + item.Selected = True + End If + Next + Next + End If + + If Not (objArticle Is Nothing) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID) And (Page.IsPostBack = False Or objCheckBoxList.Enabled = False)) Then + Dim vals As String() = objArticle.CustomList(objCustomField.CustomFieldID).ToString().Split(Convert.ToChar("|")) + For Each val As String In vals + For Each item As ListItem In objCheckBoxList.Items + If (item.Value = val) Then + item.Selected = True + End If + Next + Next + End If + End If + + phValue.Controls.Add(objCheckBoxList) + + Case CustomFieldType.RadioButton + + Dim objRadioButtonList As New RadioButtonList + objRadioButtonList.CssClass = "Normal" + objRadioButtonList.ID = objCustomField.CustomFieldID.ToString() + objRadioButtonList.RepeatDirection = RepeatDirection.Horizontal + objRadioButtonList.RepeatLayout = RepeatLayout.Table + objRadioButtonList.RepeatColumns = 4 + + Dim values As String() = objCustomField.FieldElements.Split(Convert.ToChar("|")) + For Each value As String In values + objRadioButtonList.Items.Add(value) + Next + + If (objCustomField.DefaultValue <> "") Then + If Not (objRadioButtonList.Items.FindByValue(objCustomField.DefaultValue) Is Nothing) Then + objRadioButtonList.SelectedValue = objCustomField.DefaultValue + End If + End If + + If Not (objArticle Is Nothing) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID) And (Page.IsPostBack = False Or objRadioButtonList.Enabled = False)) Then + If Not (objRadioButtonList.Items.FindByValue(objArticle.CustomList(objCustomField.CustomFieldID).ToString()) Is Nothing) Then + objRadioButtonList.SelectedValue = objArticle.CustomList(objCustomField.CustomFieldID).ToString() + End If + End If + End If + + phValue.Controls.Add(objRadioButtonList) + + If (objCustomField.IsRequired) Then + Dim valRequired As New RequiredFieldValidator + valRequired.ControlToValidate = objRadioButtonList.ID + valRequired.ErrorMessage = Localization.GetString("valFieldRequired", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + valRequired.CssClass = "NormalRed" + valRequired.Display = ValidatorDisplay.None + valRequired.SetFocusOnError = True + phValue.Controls.Add(valRequired) + End If + + Case CustomFieldType.ColorPicker + + Dim objTextBox As New TextBox + objTextBox.CssClass = "NormalTextBox" + objTextBox.ID = objCustomField.CustomFieldID.ToString() + If (objCustomField.Length <> Null.NullInteger AndAlso objCustomField.Length > 0) Then + objTextBox.MaxLength = objCustomField.Length + End If + If (objCustomField.DefaultValue <> "") Then + objTextBox.Text = objCustomField.DefaultValue + End If + If Not (objArticle Is Nothing) Then + If (objArticle.CustomList.Contains(objCustomField.CustomFieldID) And (Page.IsPostBack = False Or objTextBox.Enabled = False)) Then + objTextBox.Text = objArticle.CustomList(objCustomField.CustomFieldID).ToString() + End If + End If + phValue.Controls.Add(objTextBox) + + If (objCustomField.IsRequired) Then + Dim valRequired As New RequiredFieldValidator + valRequired.ControlToValidate = objTextBox.ID + valRequired.ErrorMessage = Localization.GetString("valFieldRequired", Me.LocalResourceFile).Replace("[CUSTOMFIELD]", objCustomField.Name) + valRequired.CssClass = "NormalRed" + valRequired.Display = ValidatorDisplay.None + valRequired.SetFocusOnError = True + phValue.Controls.Add(valRequired) + End If + + Dim script As String = "" _ + & "" + + Dim CSM As ClientScriptManager = Page.ClientScript + CSM.RegisterClientScriptBlock(Me.GetType, "Picker" + objTextBox.ID, script) + + End Select + + End If + + End If + + End Sub + + Private Sub cmdSaveArticle_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdSaveArticle.Click + + Try + + If (Page.IsValid) Then + Dim objStatusType As StatusType = CType(System.Enum.Parse(GetType(StatusType), drpStatus.SelectedValue), StatusType) + Dim articleID As Integer = SaveArticle(objStatusType) + + If (objStatusType = StatusType.Draft) Then + Response.Redirect(Common.GetModuleLink(Me.TabId, Me.ModuleId, "MyArticles", ArticleSettings), True) + End If + + If (objStatusType = StatusType.AwaitingApproval) Then + + End If + + If (objStatusType = StatusType.Published) Then + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(articleID) + + If Not (objArticle Is Nothing) Then + If (_returnUrl <> "") Then + Response.Redirect(_returnUrl, True) + Else + Response.Redirect(Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), True) + End If + End If + End If + + If (_returnUrl <> "") Then + Response.Redirect(_returnUrl, True) + Else + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "", ArticleSettings), True) + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdPublishArticle_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdPublishArticle.Click + + Try + + If (Page.IsValid) Then + If (ArticleSettings.IsApprover Or ArticleSettings.IsAutoApprover) Then + Dim articleID As Integer = SaveArticle(StatusType.Published) + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(articleID) + + If Not (objArticle Is Nothing) Then + Response.Redirect(Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), True) + Else + Response.Redirect(NavigateURL(), True) + End If + Else + Dim articleID As Integer = SaveArticle(StatusType.AwaitingApproval) + + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(articleID) + + If Not (objArticle Is Nothing) Then + If (Settings.Contains(ArticleConstants.NOTIFY_SUBMISSION_SETTING)) Then + If (Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_SUBMISSION_SETTING)) = True) Then + Dim objEmailTemplateController As New EmailTemplateController + Dim emails As String = objEmailTemplateController.GetApproverDistributionList(ModuleId) + + For Each email As String In emails.Split(Convert.ToChar(";")) + If (email <> "") Then + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, EmailTemplateType.ArticleSubmission, email, ArticleSettings) + End If + Next + End If + End If + + If (Settings.Contains(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL)) Then + If (Settings(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL).ToString() <> "") Then + Dim objEmailTemplateController As New EmailTemplateController + For Each email As String In Settings(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL).ToString().Split(","c) + objEmailTemplateController.SendFormattedEmail(Me.ModuleId, Common.GetArticleLink(objArticle, PortalSettings.ActiveTab, ArticleSettings, False), objArticle, EmailTemplateType.ArticleSubmission, email, ArticleSettings) + Next + End If + End If + End If + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "SubmitNewsComplete", ArticleSettings), True) + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdDelete_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdDelete.Click + + Try + + Dim objArticleController As New ArticleController + objArticleController.DeleteArticle(_articleID, ModuleId) + If (_returnUrl <> "") Then + Response.Redirect(_returnUrl, True) + Else + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "", ArticleSettings), True) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdAddEditPages_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdAddEditPages.Click + + Try + + If (Page.IsValid) Then + Dim articleID As Integer = SaveArticle() + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "EditPages", ArticleSettings, "ArticleID=" & articleID.ToString()), True) + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdSelectAuthor_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdSelectAuthor.Click + + Try + + cmdSelectAuthor.Visible = False + lblAuthor.Visible = False + + If (ArticleSettings.AuthorSelect = Components.Types.AuthorSelectType.ByDropdown) Then + PopulateAuthorList() + ddlAuthor.Visible = True + + If (_articleID <> Null.NullInteger) Then + + Dim objArticleController As New ArticleController + Dim objArticle As ArticleInfo = objArticleController.GetArticle(_articleID) + + If (objArticle IsNot Nothing) Then + If (ddlAuthor.Items.FindByValue(objArticle.AuthorID.ToString()) IsNot Nothing) Then + ddlAuthor.SelectedValue = objArticle.AuthorID.ToString() + End If + End If + Else + If (ArticleSettings.AuthorDefault) Then + If (ddlAuthor.Items.FindByValue(ArticleSettings.AuthorDefault) IsNot Nothing) Then + ddlAuthor.SelectedValue = ArticleSettings.AuthorDefault.ToString() + End If + End If + End If + Else + pnlAuthor.Visible = True + txtAuthor.Text = lblAuthor.Text + txtAuthor.Focus() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + If (_returnUrl <> "") Then + Response.Redirect(_returnUrl, True) + Else + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "", ArticleSettings), True) + End If + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub valAuthor_ServerValidate(ByVal source As System.Object, ByVal args As System.Web.UI.WebControls.ServerValidateEventArgs) Handles valAuthor.ServerValidate + + Try + + args.IsValid = False + + If (txtAuthor.Text <> "") Then + Dim objUser As UserInfo = UserController.GetUserByName(Me.PortalId, txtAuthor.Text) + + If (objUser IsNot Nothing) Then + args.IsValid = True + End If + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub chkMirrorArticle_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles chkMirrorArticle.CheckedChanged + + Try + + phCreate.Visible = Not chkMirrorArticle.Checked + trMirrorModule.Visible = chkMirrorArticle.Checked + trMirrorArticle.Visible = chkMirrorArticle.Checked + trMirrorAutoUpdate.Visible = chkMirrorArticle.Checked + + If (chkMirrorArticle.Checked) Then + + drpMirrorModule.Items.Clear() + drpMirrorModule.DataSource = GetContentSharingPortals(ArticleSettings.ContentSharingPortals) + drpMirrorModule.DataBind() + + If (drpMirrorModule.Items.Count > 0) Then + + Dim objArticleController As New ArticleController() + drpMirrorArticle.DataSource = objArticleController.GetArticleList(Convert.ToInt32(drpMirrorModule.SelectedValue.Split("-"c)(1)), True, "StartDate") + drpMirrorArticle.DataBind() + + End If + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub drpMirrorModule_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles drpMirrorModule.SelectedIndexChanged + + Try + + Dim objArticleController As New ArticleController() + drpMirrorArticle.DataSource = objArticleController.GetArticleList(Convert.ToInt32(drpMirrorModule.SelectedValue.Split("-"c)(1)), True, "StartDate") + drpMirrorArticle.DataBind() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Function GetContentSharingPortals(ByVal linkedPortals As String) As List(Of ContentSharingInfo) + + Dim objPortalController As New PortalController() + Dim objContentSharingPortals As New List(Of ContentSharingInfo) + + For Each element As String In linkedPortals.Split(","c) + + If (element.Split("-"c).Length = 3) Then + + Dim objContentSharing As New ContentSharingInfo + + objContentSharing.LinkedPortalID = Convert.ToInt32(element.Split("-")(0)) + objContentSharing.LinkedTabID = Convert.ToInt32(element.Split("-")(1)) + objContentSharing.LinkedModuleID = Convert.ToInt32(element.Split("-")(2)) + + Dim objTabController As New TabController + Dim objTab As TabInfo = objTabController.GetTab(objContentSharing.LinkedTabID, objContentSharing.LinkedPortalID, False) + + If (objTab IsNot Nothing) Then + objContentSharing.TabTitle = objTab.TabName + End If + + Dim objModuleController As New ModuleController + Dim objModule As ModuleInfo = objModuleController.GetModule(objContentSharing.LinkedModuleID, objContentSharing.LinkedTabID) + + If (objModule IsNot Nothing) Then + objContentSharing.ModuleTitle = objModule.ModuleTitle + objContentSharingPortals.Add(objContentSharing) + End If + + End If + + Next + + Return objContentSharingPortals + + End Function + +#End Region + + End Class + +End Namespace diff --git a/ucSubmitNewsComplete.ascx b/ucSubmitNewsComplete.ascx new file mode 100755 index 0000000..880295e --- /dev/null +++ b/ucSubmitNewsComplete.ascx @@ -0,0 +1,16 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucSubmitNewsComplete.ascx.vb" Inherits="ucSubmitNewsComplete" %> +<%@ Import Namespace="DotNetNuke.Common" %> +<%@ Import Namespace="DotNetNuke.Common.Utilities" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + +

      + +
        +
      • +
      • +
      • +
      + + diff --git a/ucSubmitNewsComplete.ascx.designer.vb b/ucSubmitNewsComplete.ascx.designer.vb new file mode 100755 index 0000000..d6e99cb --- /dev/null +++ b/ucSubmitNewsComplete.ascx.designer.vb @@ -0,0 +1,71 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucSubmitNewsComplete + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblSubmitComplete control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSubmitComplete As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdSubmitArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdSubmitArticle As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdViewMyArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdViewMyArticles As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCurrentArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCurrentArticles As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''Header1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Header1 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucSubmitNewsComplete.ascx.vb b/ucSubmitNewsComplete.ascx.vb new file mode 100755 index 0000000..ec93eec --- /dev/null +++ b/ucSubmitNewsComplete.ascx.vb @@ -0,0 +1,40 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports DotNetNuke.Common + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucSubmitNewsComplete + Inherits NewsArticleModuleBase + +#Region " Event Handlers " + + Private Sub cmdSubmitArticle_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdSubmitArticle.Click + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "SubmitNews", ArticleSettings), True) + + End Sub + + Private Sub cmdViewMyArticles_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdViewMyArticles.Click + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "MyArticles", ArticleSettings), True) + + End Sub + + Private Sub cmdCurrentArticles_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCurrentArticles.Click + + Response.Redirect(Common.GetModuleLink(TabId, ModuleId, "", ArticleSettings), True) + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/ucTemplateEditor.ascx b/ucTemplateEditor.ascx new file mode 100755 index 0000000..0370649 --- /dev/null +++ b/ucTemplateEditor.ascx @@ -0,0 +1,120 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucTemplateEditor.ascx.vb" Inherits="Ventrian.NewsArticles.ucTemplateEditor" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> +<%@ Register TagPrefix="dnn" TagName="TextEditor" Src="~/controls/TextEditor.ascx"%> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> + + + + + + +
      + + + + + + + + + + + + + + + + + + + + +
      +
      + +
      + + + Category.Child.Html + Category.Html + Comment.Item.Html + File.Header.Html + File.Item.Html + File.Footer.Html + Handout.Cover.Html + Handout.Header.Html + Handout.Item.Html + Handout.Footer.Html + Handout.End.Html + Image.Header.Html + Image.Item.Html + Image.Footer.Html + Listing.Header.Html + Listing.Item.Html + Listing.Featured.Html + Listing.Footer.Html + Listing.Empty.Html + Menu.Item.Html + Print.Item.Html + Related.Header.Html + Related.Item.Html + Related.Footer.Html + Rss.Header.Html + Rss.Item.Html + Rss.Footer.Html + Rss.Comment.Header.Html + Rss.Comment.Item.Html + Rss.Comment.Footer.Html + View.Item.Html + View.Title.Html + View.Description.Html + View.Keyword.Html + View.PageHeader.Html + Template.css +
      + +
      +
      + + + + + +
      +
      +
      + + + + + + + +
      + +   + + +
      +
      +

        +

      + + diff --git a/ucTemplateEditor.ascx.designer.vb b/ucTemplateEditor.ascx.designer.vb new file mode 100755 index 0000000..b94d728 --- /dev/null +++ b/ucTemplateEditor.ascx.designer.vb @@ -0,0 +1,233 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucTemplateEditor + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''lblUpdated control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblUpdated As Global.System.Web.UI.WebControls.Label + + ''' + '''pnlSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents pnlSettings As Global.System.Web.UI.WebControls.Panel + + ''' + '''dshSiteTemplates control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshSiteTemplates As Global.System.Web.UI.UserControl + + ''' + '''tblSiteTemplates control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSiteTemplates As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblSiteTemplatesHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSiteTemplatesHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plTemplate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTemplate As Global.System.Web.UI.UserControl + + ''' + '''drpTemplate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpTemplate As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plFile control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plFile As Global.System.Web.UI.UserControl + + ''' + '''drpFile control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpFile As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plTemplateText control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTemplateText As Global.System.Web.UI.UserControl + + ''' + '''txtTemplate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTemplate As Global.System.Web.UI.WebControls.TextBox + + ''' + '''dshTemplateHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshTemplateHelp As Global.System.Web.UI.UserControl + + ''' + '''tblSiteTemplateHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSiteTemplateHelp As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblTemplateHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTemplateHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''dshTemplateNew control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshTemplateNew As Global.System.Web.UI.UserControl + + ''' + '''tblTemplateNew control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblTemplateNew As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plNewTemplateName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNewTemplateName As Global.System.Web.UI.UserControl + + ''' + '''txtNewTemplate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtNewTemplate As Global.System.Web.UI.WebControls.TextBox + + ''' + '''cmdCreate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCreate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''lblTemplateCreated control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblTemplateCreated As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucTemplateEditor.ascx.vb b/ucTemplateEditor.ascx.vb new file mode 100755 index 0000000..2c70876 --- /dev/null +++ b/ucTemplateEditor.ascx.vb @@ -0,0 +1,219 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.IO + +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Security + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucTemplateEditor + Inherits NewsArticleModuleBase + +#Region " Private Methods " + + Private Sub BindTemplates(ByVal selectedValue As String) + + drpTemplate.Items.Clear() + + Dim templateRoot As String = Me.MapPath("Templates") + If Directory.Exists(templateRoot) Then + Dim arrFolders() As String = Directory.GetDirectories(templateRoot) + For Each folder As String In arrFolders + Dim folderName As String = folder.Substring(folder.LastIndexOf("\") + 1) + Dim objListItem As ListItem = New ListItem + objListItem.Text = folderName + objListItem.Value = folderName + drpTemplate.Items.Add(objListItem) + Next + End If + + If Not (drpTemplate.Items.FindByValue(ArticleSettings.Template) Is Nothing) Then + drpTemplate.SelectedValue = ArticleSettings.Template + End If + + If (selectedValue <> "") Then + If Not (drpTemplate.Items.FindByValue(selectedValue) Is Nothing) Then + drpTemplate.SelectedValue = selectedValue + End If + End If + + End Sub + + Private Sub BindFile() + + Dim pathToTemplate As String = Me.MapPath("Templates/" & drpTemplate.SelectedItem.Text & "/") + Dim path As String = pathToTemplate & drpFile.SelectedItem.Text + + If (File.Exists(path) = False) Then + pathToTemplate = Me.MapPath("Templates/Standard/") + path = pathToTemplate & drpFile.SelectedItem.Text + End If + + If (File.Exists(path)) Then + Dim sr As StreamReader = New StreamReader(path) + Try + txtTemplate.Text = sr.ReadToEnd() + Catch ex As Exception + + Finally + If Not sr Is Nothing Then sr.Close() + End Try + Else + txtTemplate.Text = "" + End If + + End Sub + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + If (Me.UserInfo.IsSuperUser = False) Then + If (Settings.Contains(ArticleConstants.PERMISSION_SITE_TEMPLATES_SETTING)) Then + If (Settings(ArticleConstants.PERMISSION_SITE_TEMPLATES_SETTING).ToString() <> "") Then + If (PortalSecurity.IsInRoles(Settings(ArticleConstants.PERMISSION_SITE_TEMPLATES_SETTING).ToString()) = False) Then + Response.Redirect(EditArticleUrl("AdminOptions"), True) + End If + Else + Response.Redirect(EditArticleUrl("AdminOptions"), True) + End If + Else + Response.Redirect(EditArticleUrl("AdminOptions"), True) + End If + End If + + If (Page.IsPostBack = False) Then + BindTemplates("") + BindFile() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub drpTemplate_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles drpTemplate.SelectedIndexChanged + + Try + + BindFile() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub drpFile_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles drpFile.SelectedIndexChanged + + Try + + BindFile() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdUpdate.Click + + Try + + Dim pathToTemplate As String = Me.MapPath("Templates/" & drpTemplate.SelectedItem.Text & "/") + Dim path As String = pathToTemplate & drpFile.SelectedItem.Text + + Dim sw As New StreamWriter(path) + Try + sw.Write(txtTemplate.Text) + Catch + Finally + If Not sw Is Nothing Then sw.Close() + End Try + + lblUpdated.Visible = True + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCreate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCreate.Click + + Try + + If (txtNewTemplate.Text <> "") Then + Dim pathToTemplate As String = Me.MapPath("Templates/" & txtNewTemplate.Text & "/") + System.IO.Directory.CreateDirectory(pathToTemplate) + + If (Directory.Exists(Me.MapPath("Templates/Standard/"))) Then + + Dim copyDirectory As DirectoryInfo = New DirectoryInfo(Me.MapPath("Templates/Standard/")) + Dim DestDir As DirectoryInfo = New DirectoryInfo(pathToTemplate) + + Dim ChildFile As System.IO.FileInfo + + For Each ChildFile In copyDirectory.GetFiles() + ChildFile.CopyTo(Path.Combine(DestDir.FullName, ChildFile.Name), True) + Next + + End If + + pathToTemplate = pathToTemplate & "Images/" + System.IO.Directory.CreateDirectory(pathToTemplate) + + If (Directory.Exists(Me.MapPath("Templates/Standard/Images/"))) Then + + Dim imagesDirectory As DirectoryInfo = New DirectoryInfo(Me.MapPath("Templates/Standard/Images/")) + Dim DestDir As DirectoryInfo = New DirectoryInfo(pathToTemplate) + + Dim ChildFile As System.IO.FileInfo + + For Each ChildFile In imagesDirectory.GetFiles() + ChildFile.CopyTo(Path.Combine(DestDir.FullName, ChildFile.Name), True) + Next + + End If + + + lblTemplateCreated.Visible = True + BindTemplates(txtNewTemplate.Text) + BindFile() + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(EditArticleUrl("AdminOptions"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace \ No newline at end of file diff --git a/ucViewOptions.ascx b/ucViewOptions.ascx new file mode 100755 index 0000000..9b7cd5f --- /dev/null +++ b/ucViewOptions.ascx @@ -0,0 +1,1044 @@ +<%@ Control Language="vb" AutoEventWireup="false" CodeBehind="ucViewOptions.ascx.vb" Inherits="Ventrian.NewsArticles.ucViewOptions" %> +<%@ Register TagPrefix="dnn" TagName="URL" Src="~/controls/URLControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="SectionHead" Src="~/controls/SectionHeadControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="Label" Src="~/controls/LabelControl.ascx" %> +<%@ Register TagPrefix="dnn" TagName="Skin" Src="~/controls/SkinControl.ascx" %> +<%@ Register TagPrefix="dnn" Namespace="DotNetNuke.Security.Permissions.Controls" Assembly="DotNetNuke" %> +<%@ Register TagPrefix="article" TagName="Header" Src="ucHeader.ascx" %> + + + + + +
      + + + + + + + + + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + +
      +
      + + + + + + + + + + + + + + + + + + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +
      + + + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + +
      +
      + + + + + + + + + + + + + + +
      + + + +
      + + + + + + + + + + + + +
      +
      +
      + + + + + + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + + +
      + +   + +
      + +
      + + +
      +
      + + + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + + + +
      +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + +
      + + + + +
      + + + +
      + + + +
      + +
      + + + +
      + + + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + + + +
      + + + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +
      + +
      + +
      +
      + + + + + + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + +
      + + + + + + <%# DataBinder.Eval(Container.DataItem, "Text") %> + + + + +   +   + + + + + + + + +   +   + + + + + + + + +   +   + + + + + + + + +   +   + + + + + + + + +   +   + + + + + + + + +   +
      + +
      + + + +
      + + +   +   + + + + + + + + +   +   + + + + + + +
      +
      +
      + +
      + + + + + + <%# DataBinder.Eval(Container.DataItem, "Text") %> + + + + +   +
      + +
      + + + +
      + + +   +
      + +
      + + + +
      + + +   +
      + +
      + + + +
      + + +   +
      + +
      + + + +
      + + +   +
      + +
      + + + +
      + + +   +
      + +
      + + + +
      + + +   +
      + +
      + + + +
      + + +   +
      + +
      + + + +
      + + +   +
      + +
      + + + +
      +
      +
      + +
      + + + + + + <%# DataBinder.Eval(Container.DataItem, "Text") %> + + + + +   +
      + +
      + + + +
      +
      +
      +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + +
      + + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + + + +
      + + + +
      +
      + + + + + + + + + + + + + + +
      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + +
      + +
      + +
      +
      +
      +

      +    + +

      + + + + \ No newline at end of file diff --git a/ucViewOptions.ascx.designer.vb b/ucViewOptions.ascx.designer.vb new file mode 100755 index 0000000..7553520 --- /dev/null +++ b/ucViewOptions.ascx.designer.vb @@ -0,0 +1,2798 @@ +'------------------------------------------------------------------------------ +' +' This code was generated by a tool. +' +' Changes to this file may cause incorrect behavior and will be lost if +' the code is regenerated. +' +'------------------------------------------------------------------------------ + +Option Strict On +Option Explicit On + +Namespace Ventrian.NewsArticles + + Partial Public Class ucViewOptions + + ''' + '''ucHeader1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader1 As Global.Ventrian.NewsArticles.ucHeader + + ''' + '''dshBasic control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshBasic As Global.System.Web.UI.UserControl + + ''' + '''tblArticle control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblArticle As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblArticleSettingsHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblArticleSettingsHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''dshDetails control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshDetails As Global.System.Web.UI.UserControl + + ''' + '''tblDetails control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblDetails As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plEnableRatings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableRatings As Global.System.Web.UI.UserControl + + ''' + '''chkEnableRatingsAuthenticated control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableRatingsAuthenticated As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableAnonymousRatings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableAnonymousRatings As Global.System.Web.UI.UserControl + + ''' + '''chkEnableRatingsAnonymous control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableRatingsAnonymous As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableCoreSearch control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableCoreSearch As Global.System.Web.UI.UserControl + + ''' + '''chkEnableCoreSearch control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableCoreSearch As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableNotificationPing control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableNotificationPing As Global.System.Web.UI.UserControl + + ''' + '''chkEnableNotificationPing control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableNotificationPing As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableAutoTrackback control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableAutoTrackback As Global.System.Web.UI.UserControl + + ''' + '''chkEnableAutoTrackback control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableAutoTrackback As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableIncomingTrackback control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableIncomingTrackback As Global.System.Web.UI.UserControl + + ''' + '''chkEnableIncomingTrackback control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableIncomingTrackback As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plLaunchLinks control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plLaunchLinks As Global.System.Web.UI.UserControl + + ''' + '''chkLaunchLinks control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkLaunchLinks As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plBubbleFeaturedArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plBubbleFeaturedArticles As Global.System.Web.UI.UserControl + + ''' + '''chkBubbleFeaturedArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkBubbleFeaturedArticles As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plProcessPostTokens control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plProcessPostTokens As Global.System.Web.UI.UserControl + + ''' + '''chkProcessPostTokens control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkProcessPostTokens As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plDisplayType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plDisplayType As Global.System.Web.UI.UserControl + + ''' + '''drpDisplayType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpDisplayType As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plArticlePageSize control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plArticlePageSize As Global.System.Web.UI.UserControl + + ''' + '''drpNumber control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpNumber As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plTemplate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTemplate As Global.System.Web.UI.UserControl + + ''' + '''drpTemplates control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpTemplates As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plTimeZone control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTimeZone As Global.System.Web.UI.UserControl + + ''' + '''drpTimeZone control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpTimeZone As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plSortBy control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSortBy As Global.System.Web.UI.UserControl + + ''' + '''drpSortBy control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpSortBy As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plSortDirection control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSortDirection As Global.System.Web.UI.UserControl + + ''' + '''drpSortDirection control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpSortDirection As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plMenuPosition control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMenuPosition As Global.System.Web.UI.UserControl + + ''' + '''lstMenuPosition control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstMenuPosition As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''dshArchive control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshArchive As Global.System.Web.UI.UserControl + + ''' + '''tblArchive control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblArchive As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''Label1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Label1 As Global.System.Web.UI.UserControl + + ''' + '''chkArchiveCurrentArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkArchiveCurrentArticles As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''Label2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Label2 As Global.System.Web.UI.UserControl + + ''' + '''chkArchiveCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkArchiveCategories As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''Label3 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Label3 As Global.System.Web.UI.UserControl + + ''' + '''chkArchiveAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkArchiveAuthor As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''Label4 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents Label4 As Global.System.Web.UI.UserControl + + ''' + '''chkArchiveMonth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkArchiveMonth As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''dshCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshCategory As Global.System.Web.UI.UserControl + + ''' + '''tblCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblCategory As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plRequireCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plRequireCategory As Global.System.Web.UI.UserControl + + ''' + '''chkRequireCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkRequireCategory As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plDefaultCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plDefaultCategories As Global.System.Web.UI.UserControl + + ''' + '''lstDefaultCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstDefaultCategories As Global.System.Web.UI.WebControls.ListBox + + ''' + '''plCategorySelectionHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCategorySelectionHeight As Global.System.Web.UI.UserControl + + ''' + '''txtCategorySelectionHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtCategorySelectionHeight As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valCategorySelectionHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valCategorySelectionHeight As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valCategorySelectionHeightIsValid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valCategorySelectionHeightIsValid As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''plCategoryBreadcrumb control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCategoryBreadcrumb As Global.System.Web.UI.UserControl + + ''' + '''chkCategoryBreadcrumb control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkCategoryBreadcrumb As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plCategoryName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCategoryName As Global.System.Web.UI.UserControl + + ''' + '''chkCategoryName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkCategoryName As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plCategorySortOrder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCategorySortOrder As Global.System.Web.UI.UserControl + + ''' + '''lstCategorySortOrder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstCategorySortOrder As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''plCategoryFilterSubmit control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCategoryFilterSubmit As Global.System.Web.UI.UserControl + + ''' + '''chkCategoryFilterSubmit control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkCategoryFilterSubmit As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''dshComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshComments As Global.System.Web.UI.UserControl + + ''' + '''tblComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblComments As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plEnableComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableComments As Global.System.Web.UI.UserControl + + ''' + '''chkEnableComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableComments As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableAnonymousComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableAnonymousComments As Global.System.Web.UI.UserControl + + ''' + '''chkEnableAnonymousComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableAnonymousComments As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableCommentModeration control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableCommentModeration As Global.System.Web.UI.UserControl + + ''' + '''chkEnableCommentModeration control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableCommentModeration As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plUseCaptcha control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plUseCaptcha As Global.System.Web.UI.UserControl + + ''' + '''chkUseCaptcha control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkUseCaptcha As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plHideWebsite control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plHideWebsite As Global.System.Web.UI.UserControl + + ''' + '''chkHideWebsite control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkHideWebsite As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plRequireName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plRequireName As Global.System.Web.UI.UserControl + + ''' + '''chkRequireName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkRequireName As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plRequireEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plRequireEmail As Global.System.Web.UI.UserControl + + ''' + '''chkRequireEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkRequireEmail As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plNotifyDefault control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNotifyDefault As Global.System.Web.UI.UserControl + + ''' + '''chkNotifyDefault control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkNotifyDefault As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plSortDirectionComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSortDirectionComments As Global.System.Web.UI.UserControl + + ''' + '''drpSortDirectionComments control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpSortDirectionComments As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plAkismetKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAkismetKey As Global.System.Web.UI.UserControl + + ''' + '''txtAkismetKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtAkismetKey As Global.System.Web.UI.WebControls.TextBox + + ''' + '''phContentSharing control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents phContentSharing As Global.System.Web.UI.WebControls.PlaceHolder + + ''' + '''dshContentSharing control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshContentSharing As Global.System.Web.UI.UserControl + + ''' + '''tblContentSharing control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblContentSharing As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''lblContentSharing control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblContentSharing As Global.System.Web.UI.WebControls.Label + + ''' + '''plAddArticleInstances control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAddArticleInstances As Global.System.Web.UI.UserControl + + ''' + '''drpContentSharingPortals control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpContentSharingPortals As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''cmdContentSharingAdd control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdContentSharingAdd As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''lblContentSharingNoneAvailable control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblContentSharingNoneAvailable As Global.System.Web.UI.WebControls.Label + + ''' + '''plAvailableArticleInstances control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAvailableArticleInstances As Global.System.Web.UI.UserControl + + ''' + '''grdContentSharing control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdContentSharing As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''lblNoContentSharing control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblNoContentSharing As Global.System.Web.UI.WebControls.Label + + ''' + '''dshFileSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshFileSettings As Global.System.Web.UI.UserControl + + ''' + '''tblFile control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblFile As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plDefaultFileFolder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plDefaultFileFolder As Global.System.Web.UI.UserControl + + ''' + '''drpDefaultFileFolder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpDefaultFileFolder As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''dshFilter control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshFilter As Global.System.Web.UI.UserControl + + ''' + '''tblFilter control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblFilter As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plMaxArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMaxArticles As Global.System.Web.UI.UserControl + + ''' + '''txtMaxArticles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtMaxArticles As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valMaxArticlesIsValid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valMaxArticlesIsValid As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''plMaxAge control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plMaxAge As Global.System.Web.UI.UserControl + + ''' + '''txtMaxAge control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtMaxAge As Global.System.Web.UI.WebControls.TextBox + + ''' + '''lblMaxAge control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblMaxAge As Global.System.Web.UI.WebControls.Label + + ''' + '''valMaxAgeType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valMaxAgeType As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''plCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plCategories As Global.System.Web.UI.UserControl + + ''' + '''rdoAllCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rdoAllCategories As Global.System.Web.UI.WebControls.RadioButton + + ''' + '''rdoSingleCategory control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rdoSingleCategory As Global.System.Web.UI.WebControls.RadioButton + + ''' + '''drpCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpCategories As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''rdoMatchAny control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rdoMatchAny As Global.System.Web.UI.WebControls.RadioButton + + ''' + '''rdoMatchAll control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rdoMatchAll As Global.System.Web.UI.WebControls.RadioButton + + ''' + '''lstCategories control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstCategories As Global.System.Web.UI.WebControls.ListBox + + ''' + '''lblHoldCtrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblHoldCtrl As Global.System.Web.UI.WebControls.Label + + ''' + '''plShowPending control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plShowPending As Global.System.Web.UI.UserControl + + ''' + '''chkShowPending control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkShowPending As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plShowFeaturedOnly control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plShowFeaturedOnly As Global.System.Web.UI.UserControl + + ''' + '''chkShowFeaturedOnly control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkShowFeaturedOnly As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plShowNotFeaturedOnly control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plShowNotFeaturedOnly As Global.System.Web.UI.UserControl + + ''' + '''chkShowNotFeaturedOnly control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkShowNotFeaturedOnly As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plShowSecuredOnly control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plShowSecuredOnly As Global.System.Web.UI.UserControl + + ''' + '''chkShowSecuredOnly control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkShowSecuredOnly As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plShowNotSecuredOnly control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plShowNotSecuredOnly As Global.System.Web.UI.UserControl + + ''' + '''chkShowNotSecuredOnly control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkShowNotSecuredOnly As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''dshAuthorFilterSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshAuthorFilterSettings As Global.System.Web.UI.UserControl + + ''' + '''tblAuthorFilterSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblAuthorFilterSettings As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAuthor As Global.System.Web.UI.UserControl + + ''' + '''lblAuthorFilter control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblAuthorFilter As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdSelectAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdSelectAuthor As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ddlAuthor control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ddlAuthor As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plQueryStringFilter control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plQueryStringFilter As Global.System.Web.UI.UserControl + + ''' + '''chkQueryStringFilter control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkQueryStringFilter As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plQueryStringParam control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plQueryStringParam As Global.System.Web.UI.UserControl + + ''' + '''txtQueryStringParam control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtQueryStringParam As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plUsernameFilter control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plUsernameFilter As Global.System.Web.UI.UserControl + + ''' + '''chkUsernameFilter control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkUsernameFilter As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plUsernameParam control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plUsernameParam As Global.System.Web.UI.UserControl + + ''' + '''txtUsernameParam control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtUsernameParam As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plLoggedInUser control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plLoggedInUser As Global.System.Web.UI.UserControl + + ''' + '''chkLoggedInUser control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkLoggedInUser As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''dshForm control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshForm As Global.System.Web.UI.UserControl + + ''' + '''tblForm control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblForm As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plAuthorSelection control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAuthorSelection As Global.System.Web.UI.UserControl + + ''' + '''lstAuthorSelection control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstAuthorSelection As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''plAuthorDefault control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAuthorDefault As Global.System.Web.UI.UserControl + + ''' + '''lblAuthorDefault control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblAuthorDefault As Global.System.Web.UI.WebControls.Label + + ''' + '''cmdSelectAuthorDefault control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdSelectAuthorDefault As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''drpAuthorDefault control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpAuthorDefault As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plExpandSummary control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plExpandSummary As Global.System.Web.UI.UserControl + + ''' + '''chkExpandSummary control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkExpandSummary As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plTextEditorWidth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTextEditorWidth As Global.System.Web.UI.UserControl + + ''' + '''txtTextEditorWidth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTextEditorWidth As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valEditorWidth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valEditorWidth As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valEditorWidthIsValid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valEditorWidthIsValid As Global.System.Web.UI.WebControls.CustomValidator + + ''' + '''plTextEditorHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTextEditorHeight As Global.System.Web.UI.UserControl + + ''' + '''txtTextEditorHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTextEditorHeight As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valEditorHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valEditorHeight As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valEditorHeightIsvalid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valEditorHeightIsvalid As Global.System.Web.UI.WebControls.CustomValidator + + ''' + '''plTextEditorSummaryMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTextEditorSummaryMode As Global.System.Web.UI.UserControl + + ''' + '''lstTextEditorSummaryMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstTextEditorSummaryMode As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''plTextEditorSummaryWidth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTextEditorSummaryWidth As Global.System.Web.UI.UserControl + + ''' + '''txtTextEditorSummaryWidth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTextEditorSummaryWidth As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valTextEditorSummaryWidth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valTextEditorSummaryWidth As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valTextEditorSummaryWidthIsValid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valTextEditorSummaryWidthIsValid As Global.System.Web.UI.WebControls.CustomValidator + + ''' + '''plTextEditorSummaryHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTextEditorSummaryHeight As Global.System.Web.UI.UserControl + + ''' + '''txtTextEditorSummaryHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTextEditorSummaryHeight As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valTextEditorSummaryHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valTextEditorSummaryHeight As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valTextEditorSummaryHeightIsValid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valTextEditorSummaryHeightIsValid As Global.System.Web.UI.WebControls.CustomValidator + + ''' + '''dshImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshImage As Global.System.Web.UI.UserControl + + ''' + '''tblImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblImage As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plIncludeJQuery control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plIncludeJQuery As Global.System.Web.UI.UserControl + + ''' + '''chkIncludeJQuery control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkIncludeJQuery As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plJQueryPath control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plJQueryPath As Global.System.Web.UI.UserControl + + ''' + '''txtJQueryPath control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtJQueryPath As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plEnableImagesUpload control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableImagesUpload As Global.System.Web.UI.UserControl + + ''' + '''chkEnableImagesUpload control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableImagesUpload As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableImages As Global.System.Web.UI.UserControl + + ''' + '''chkEnablePortalImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnablePortalImages As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableImagesExternal control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableImagesExternal As Global.System.Web.UI.UserControl + + ''' + '''chkEnableExternalImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableExternalImages As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plDefaultImageFolder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plDefaultImageFolder As Global.System.Web.UI.UserControl + + ''' + '''drpDefaultImageFolder control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpDefaultImageFolder As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plResizeImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plResizeImages As Global.System.Web.UI.UserControl + + ''' + '''chkResizeImages control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkResizeImages As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plImageMaxWidth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plImageMaxWidth As Global.System.Web.UI.UserControl + + ''' + '''txtImageMaxWidth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtImageMaxWidth As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valImageMaxWidth control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valImageMaxWidth As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valImageMaxWidthIsNumber control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valImageMaxWidthIsNumber As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''plImageMaxHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plImageMaxHeight As Global.System.Web.UI.UserControl + + ''' + '''txtImageMaxHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtImageMaxHeight As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valImageMaxHeight control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valImageMaxHeight As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valImageMaxHeightIsNumber control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valImageMaxHeightIsNumber As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''plThumbnailType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plThumbnailType As Global.System.Web.UI.UserControl + + ''' + '''rdoThumbnailType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents rdoThumbnailType As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''plUseWatermark control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plUseWatermark As Global.System.Web.UI.UserControl + + ''' + '''chkUseWatermark control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkUseWatermark As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plWatermarkText control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plWatermarkText As Global.System.Web.UI.UserControl + + ''' + '''txtWatermarkText control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtWatermarkText As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plWatermarkImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plWatermarkImage As Global.System.Web.UI.UserControl + + ''' + '''ctlWatermarkImage control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ctlWatermarkImage As DotNetNuke.UI.UserControls.UrlControl + + ''' + '''plWatermarkPosition control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plWatermarkPosition As Global.System.Web.UI.UserControl + + ''' + '''drpWatermarkPosition control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpWatermarkPosition As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''dshNotification control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshNotification As Global.System.Web.UI.UserControl + + ''' + '''tblNotification control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblNotification As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plNotifySubmission control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNotifySubmission As Global.System.Web.UI.UserControl + + ''' + '''chkNotifySubmission control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkNotifySubmission As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plNotifySubmissionEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNotifySubmissionEmail As Global.System.Web.UI.UserControl + + ''' + '''txtSubmissionEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtSubmissionEmail As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plNotifyApproval control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNotifyApproval As Global.System.Web.UI.UserControl + + ''' + '''chkNotifyApproval control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkNotifyApproval As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plNotifyComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNotifyComment As Global.System.Web.UI.UserControl + + ''' + '''chkNotifyComment control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkNotifyComment As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plNotifyCommentEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNotifyCommentEmail As Global.System.Web.UI.UserControl + + ''' + '''txtNotifyCommentEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtNotifyCommentEmail As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plNotifyCommentApproval control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNotifyCommentApproval As Global.System.Web.UI.UserControl + + ''' + '''chkNotifyCommentApproval control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkNotifyCommentApproval As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plNotifyCommentApprovalEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plNotifyCommentApprovalEmail As Global.System.Web.UI.UserControl + + ''' + '''txtNotifyCommentApprovalEmail control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtNotifyCommentApprovalEmail As Global.System.Web.UI.WebControls.TextBox + + ''' + '''dshRelated control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshRelated As Global.System.Web.UI.UserControl + + ''' + '''tblRelated control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblRelated As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plRelatedMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plRelatedMode As Global.System.Web.UI.UserControl + + ''' + '''lstRelatedMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstRelatedMode As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''dshSecurity control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshSecurity As Global.System.Web.UI.UserControl + + ''' + '''tblSecurity control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSecurity As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plRoleGroup control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plRoleGroup As Global.System.Web.UI.UserControl + + ''' + '''drpSecurityRoleGroups control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents drpSecurityRoleGroups As Global.System.Web.UI.WebControls.DropDownList + + ''' + '''plBasicSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plBasicSettings As Global.System.Web.UI.UserControl + + ''' + '''grdBasicPermissions control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdBasicPermissions As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''plSecureUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSecureUrl As Global.System.Web.UI.UserControl + + ''' + '''txtSecureUrl control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtSecureUrl As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plFormSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plFormSettings As Global.System.Web.UI.UserControl + + ''' + '''grdFormPermissions control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdFormPermissions As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''lblFormSettingsHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblFormSettingsHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''trAdminSettings1 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trAdminSettings1 As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''plAdminSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAdminSettings As Global.System.Web.UI.UserControl + + ''' + '''trAdminSettings2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents trAdminSettings2 As Global.System.Web.UI.HtmlControls.HtmlTableRow + + ''' + '''grdAdminPermissions control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents grdAdminPermissions As Global.System.Web.UI.WebControls.DataGrid + + ''' + '''dshSEOSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshSEOSettings As Global.System.Web.UI.UserControl + + ''' + '''tblSEO control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSEO As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plTitleReplacement control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTitleReplacement As Global.System.Web.UI.UserControl + + ''' + '''lstTitleReplacement control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstTitleReplacement As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''plAlwaysShowPageID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plAlwaysShowPageID As Global.System.Web.UI.UserControl + + ''' + '''chkAlwaysShowPageID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkAlwaysShowPageID As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plUrlMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plUrlMode As Global.System.Web.UI.UserControl + + ''' + '''lstUrlMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstUrlMode As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''plShorternID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plShorternID As Global.System.Web.UI.UserControl + + ''' + '''txtShorternID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtShorternID As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valShorternID control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valShorternID As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''plUseCanonicalLink control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plUseCanonicalLink As Global.System.Web.UI.UserControl + + ''' + '''chkUseCanonicalLink control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkUseCanonicalLink As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plExpandMetaInformation control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plExpandMetaInformation As Global.System.Web.UI.UserControl + + ''' + '''chkExpandMetaInformation control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkExpandMetaInformation As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plUniquePageTitles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plUniquePageTitles As Global.System.Web.UI.UserControl + + ''' + '''chkUniquePageTitles control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkUniquePageTitles As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''dshSyndicationSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshSyndicationSettings As Global.System.Web.UI.UserControl + + ''' + '''tblSyndication control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblSyndication As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plEnableSyndication control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableSyndication As Global.System.Web.UI.UserControl + + ''' + '''chkEnableSyndication control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableSyndication As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plEnableSyndicationEnclosures control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableSyndicationEnclosures As Global.System.Web.UI.UserControl + + ''' + '''chkEnableSyndicationEnclosures control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableSyndicationEnclosures As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plSyndicationEnclosureType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSyndicationEnclosureType As Global.System.Web.UI.UserControl + + ''' + '''lstSyndicationEnclosureType control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstSyndicationEnclosureType As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''plEnableSyndicationHtml control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plEnableSyndicationHtml As Global.System.Web.UI.UserControl + + ''' + '''chkEnableSyndicationHtml control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkEnableSyndicationHtml As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plSyndicationLinkMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSyndicationLinkMode As Global.System.Web.UI.UserControl + + ''' + '''lstSyndicationLinkMode control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lstSyndicationLinkMode As Global.System.Web.UI.WebControls.RadioButtonList + + ''' + '''plSyndicationSummaryLength control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSyndicationSummaryLength As Global.System.Web.UI.UserControl + + ''' + '''txtSyndicationSummaryLength control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtSyndicationSummaryLength As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valSyndicationSummaryLength control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valSyndicationSummaryLength As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''lblSyndicationSummaryLengthHelp control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents lblSyndicationSummaryLengthHelp As Global.System.Web.UI.WebControls.Label + + ''' + '''plSyndicationMaxCount control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSyndicationMaxCount As Global.System.Web.UI.UserControl + + ''' + '''txtSyndicationMaxCount control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtSyndicationMaxCount As Global.System.Web.UI.WebControls.TextBox + + ''' + '''valSyndicationMaxCount control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valSyndicationMaxCount As Global.System.Web.UI.WebControls.RequiredFieldValidator + + ''' + '''valSyndicationMaxCountIsValid control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents valSyndicationMaxCountIsValid As Global.System.Web.UI.WebControls.CompareValidator + + ''' + '''plSyndicationImagePath control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSyndicationImagePath As Global.System.Web.UI.UserControl + + ''' + '''txtSyndicationImagePath control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtSyndicationImagePath As Global.System.Web.UI.WebControls.TextBox + + ''' + '''dshTwitterSettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dshTwitterSettings As Global.System.Web.UI.UserControl + + ''' + '''tblTwitter control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tblTwitter As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plTwitterName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plTwitterName As Global.System.Web.UI.UserControl + + ''' + '''txtTwitterName control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtTwitterName As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plBitLyLogin control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plBitLyLogin As Global.System.Web.UI.UserControl + + ''' + '''txtBitLyLogin control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtBitLyLogin As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plBitLyAPIKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plBitLyAPIKey As Global.System.Web.UI.UserControl + + ''' + '''txtBitLyAPIKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtBitLyAPIKey As Global.System.Web.UI.WebControls.TextBox + + ''' + '''dsh3rdPartySettings control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents dsh3rdPartySettings As Global.System.Web.UI.UserControl + + ''' + '''tbl3rdParty control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents tbl3rdParty As Global.System.Web.UI.HtmlControls.HtmlTable + + ''' + '''plJournalIntegration control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plJournalIntegration As Global.System.Web.UI.UserControl + + ''' + '''chkJournalIntegration control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkJournalIntegration As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plJournalIntegrationGroups control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plJournalIntegrationGroups As Global.System.Web.UI.UserControl + + ''' + '''chkJournalIntegrationGroups control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkJournalIntegrationGroups As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plActiveSocial control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plActiveSocial As Global.System.Web.UI.UserControl + + ''' + '''chkActiveSocial control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkActiveSocial As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''plActiveSocialSubmissionKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plActiveSocialSubmissionKey As Global.System.Web.UI.UserControl + + ''' + '''txtActiveSocialSubmissionKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtActiveSocialSubmissionKey As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plActiveSocialRateKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plActiveSocialRateKey As Global.System.Web.UI.UserControl + + ''' + '''txtActiveSocialRateKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtActiveSocialRateKey As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plActiveSocialCommentKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plActiveSocialCommentKey As Global.System.Web.UI.UserControl + + ''' + '''txtActiveSocialCommentKey control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents txtActiveSocialCommentKey As Global.System.Web.UI.WebControls.TextBox + + ''' + '''plSmartThinkerStoryFeed control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents plSmartThinkerStoryFeed As Global.System.Web.UI.UserControl + + ''' + '''chkSmartThinkerStoryFeed control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents chkSmartThinkerStoryFeed As Global.System.Web.UI.WebControls.CheckBox + + ''' + '''cmdUpdate control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdUpdate As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''cmdCancel control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents cmdCancel As Global.System.Web.UI.WebControls.LinkButton + + ''' + '''ucHeader2 control. + ''' + ''' + '''Auto-generated field. + '''To modify move field declaration from designer file to code-behind file. + ''' + Protected WithEvents ucHeader2 As Global.Ventrian.NewsArticles.ucHeader + End Class +End Namespace diff --git a/ucViewOptions.ascx.vb b/ucViewOptions.ascx.vb new file mode 100755 index 0000000..d42ae33 --- /dev/null +++ b/ucViewOptions.ascx.vb @@ -0,0 +1,1944 @@ +' +' News Articles for DotNetNuke - http://www.dotnetnuke.com +' Copyright (c) 2002-2007 +' by Ventrian ( sales@ventrian.com ) ( http://www.ventrian.com ) +' + +Imports System.IO + +Imports DotNetNuke.Common.Utilities +Imports DotNetNuke.Entities.Modules +Imports DotNetNuke.Security.Roles +Imports DotNetNuke.Services.Exceptions +Imports DotNetNuke.Services.Localization + +Imports Ventrian.NewsArticles.Components.Types +Imports DotNetNuke.Services.FileSystem +Imports DotNetNuke.Entities.Portals + +Imports Ventrian.NewsArticles.Base + +Namespace Ventrian.NewsArticles + + Partial Public Class ucViewOptions + Inherits NewsArticleModuleBase + +#Region " Private Methods " + + Public Class ListItemComparer + Implements IComparer(Of ListItem) + + Public Function Compare(ByVal x As ListItem, ByVal y As ListItem) As Integer _ + Implements IComparer(Of ListItem).Compare + + Dim c As New CaseInsensitiveComparer + Return c.Compare(x.Text, y.Text) + End Function + End Class + + Public Shared Sub SortDropDown(ByVal cbo As DropDownList) + Dim lstListItems As New List(Of ListItem) + For Each li As ListItem In cbo.Items + lstListItems.Add(li) + Next + lstListItems.Sort(New ListItemComparer) + cbo.Items.Clear() + cbo.Items.AddRange(lstListItems.ToArray) + End Sub + +#Region " Private Methods - Load Types/Dropdowns " + + Private Sub BindRoleGroups() + + Dim objRole As New RoleController + + drpSecurityRoleGroups.DataSource = RoleController.GetRoleGroups(PortalId) + drpSecurityRoleGroups.DataBind() + drpSecurityRoleGroups.Items.Insert(0, New ListItem(Localization.GetString("AllGroups", Me.LocalResourceFile), "-1")) + + End Sub + + Private Sub BindRoles() + + Dim objRole As New RoleController + + Dim availableRoles As ArrayList = New ArrayList + Dim roles As ArrayList + If (drpSecurityRoleGroups.SelectedValue = "-1") Then + roles = objRole.GetPortalRoles(PortalId) + Else + roles = objRole.GetRolesByGroup(PortalId, Convert.ToInt32(drpSecurityRoleGroups.SelectedValue)) + End If + + If Not roles Is Nothing Then + For Each Role As RoleInfo In roles + availableRoles.Add(New ListItem(Role.RoleName, Role.RoleName)) + Next + End If + + grdBasicPermissions.DataSource = availableRoles + grdBasicPermissions.DataBind() + + grdFormPermissions.DataSource = availableRoles + grdFormPermissions.DataBind() + + grdAdminPermissions.DataSource = availableRoles + grdAdminPermissions.DataBind() + + End Sub + + Private Sub BindAuthorSelection() + + For Each value As Integer In System.Enum.GetValues(GetType(AuthorSelectType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(AuthorSelectType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(AuthorSelectType), value), Me.LocalResourceFile) + lstAuthorSelection.Items.Add(li) + Next + + End Sub + + Private Sub BindCategorySortOrder() + + For Each value As Integer In System.Enum.GetValues(GetType(CategorySortType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(CategorySortType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(CategorySortType), value), Me.LocalResourceFile) + lstCategorySortOrder.Items.Add(li) + Next + + End Sub + + Private Sub BindDisplayTypes() + + For Each value As Integer In System.Enum.GetValues(GetType(DisplayType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(DisplayType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(DisplayType), value), Me.LocalResourceFile) + drpDisplayType.Items.Add(li) + Next + + End Sub + + Private Sub BindRelatedTypes() + + For Each value As Integer In System.Enum.GetValues(GetType(RelatedType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(RelatedType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(RelatedType), value), Me.LocalResourceFile) + lstRelatedMode.Items.Add(li) + Next + + End Sub + + Private Sub BindFolders() + + Dim folders As List(Of IFolderInfo) = FolderManager.Instance.GetFolders(PortalId) + For Each folder As FolderInfo In folders + Dim FolderItem As New ListItem + If folder.FolderPath = Null.NullString Then + FolderItem.Text = Localization.GetString("Root", Me.LocalResourceFile) + Else + FolderItem.Text = folder.FolderPath + End If + FolderItem.Value = folder.FolderID.ToString() + drpDefaultImageFolder.Items.Add(FolderItem) + drpDefaultFileFolder.Items.Add(New ListItem(FolderItem.Text, FolderItem.Value)) + Next + + End Sub + + Private Sub BindTextEditorMode() + + For Each value As Integer In System.Enum.GetValues(GetType(TextEditorModeType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(TextEditorModeType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(TextEditorModeType), value), Me.LocalResourceFile) + lstTextEditorSummaryMode.Items.Add(li) + Next + + End Sub + + Private Sub BindTitleReplacement() + + For Each value As Integer In System.Enum.GetValues(GetType(TitleReplacementType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(TitleReplacementType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(TitleReplacementType), value), Me.LocalResourceFile) + lstTitleReplacement.Items.Add(li) + Next + + End Sub + + Private Sub BindUrlMode() + + For Each value As Integer In System.Enum.GetValues(GetType(UrlModeType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(UrlModeType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(UrlModeType), value), Me.LocalResourceFile) + lstUrlMode.Items.Add(li) + Next + + End Sub + + Private Sub BindPageSize() + + drpNumber.Items.Add(New ListItem(Localization.GetString("NoRestriction", Me.LocalResourceFile), "-1")) + drpNumber.Items.Add(New ListItem(Localization.GetString("1", Me.LocalResourceFile), "1")) + drpNumber.Items.Add(New ListItem(Localization.GetString("2", Me.LocalResourceFile), "2")) + drpNumber.Items.Add(New ListItem(Localization.GetString("3", Me.LocalResourceFile), "3")) + drpNumber.Items.Add(New ListItem(Localization.GetString("4", Me.LocalResourceFile), "4")) + drpNumber.Items.Add(New ListItem(Localization.GetString("5", Me.LocalResourceFile), "5")) + drpNumber.Items.Add(New ListItem(Localization.GetString("6", Me.LocalResourceFile), "6")) + drpNumber.Items.Add(New ListItem(Localization.GetString("7", Me.LocalResourceFile), "7")) + drpNumber.Items.Add(New ListItem(Localization.GetString("8", Me.LocalResourceFile), "8")) + drpNumber.Items.Add(New ListItem(Localization.GetString("9", Me.LocalResourceFile), "9")) + drpNumber.Items.Add(New ListItem(Localization.GetString("10", Me.LocalResourceFile), "10")) + drpNumber.Items.Add(New ListItem(Localization.GetString("15", Me.LocalResourceFile), "15")) + drpNumber.Items.Add(New ListItem(Localization.GetString("20", Me.LocalResourceFile), "20")) + drpNumber.Items.Add(New ListItem(Localization.GetString("50", Me.LocalResourceFile), "50")) + + End Sub + + Private Sub BindSortBy() + + drpSortBy.Items.Add(New ListItem(Localization.GetString("PublishDate.Text", Me.LocalResourceFile), "StartDate")) + drpSortBy.Items.Add(New ListItem(Localization.GetString("ExpiryDate.Text", Me.LocalResourceFile), "EndDate")) + drpSortBy.Items.Add(New ListItem(Localization.GetString("LastUpdate.Text", Me.LocalResourceFile), "LastUpdate")) + drpSortBy.Items.Add(New ListItem(Localization.GetString("HighestRated.Text", Me.LocalResourceFile), "Rating")) + drpSortBy.Items.Add(New ListItem(Localization.GetString("MostCommented.Text", Me.LocalResourceFile), "CommentCount")) + drpSortBy.Items.Add(New ListItem(Localization.GetString("MostViewed.Text", Me.LocalResourceFile), "NumberOfViews")) + drpSortBy.Items.Add(New ListItem(Localization.GetString("Random.Text", Me.LocalResourceFile), "NewID()")) + drpSortBy.Items.Add(New ListItem(Localization.GetString("SortTitle.Text", Me.LocalResourceFile), "Title")) + + End Sub + + Private Sub BindSortDirection() + + drpSortDirection.Items.Add(New ListItem(Localization.GetString("Ascending.Text", Me.LocalResourceFile), "ASC")) + drpSortDirection.Items.Add(New ListItem(Localization.GetString("Descending.Text", Me.LocalResourceFile), "DESC")) + + drpSortDirectionComments.Items.Add(New ListItem(Localization.GetString("Ascending.Text", Me.LocalResourceFile), "0")) + drpSortDirectionComments.Items.Add(New ListItem(Localization.GetString("Descending.Text", Me.LocalResourceFile), "1")) + + End Sub + + Private Sub BindSyndicationLinkMode() + + For Each value As Integer In System.Enum.GetValues(GetType(SyndicationLinkType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(SyndicationLinkType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(SyndicationLinkType), value), Me.LocalResourceFile) + lstSyndicationLinkMode.Items.Add(li) + Next + + End Sub + + Private Sub BindSyndicationEnclosureType() + + For Each value As Integer In System.Enum.GetValues(GetType(SyndicationEnclosureType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(SyndicationEnclosureType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(SyndicationEnclosureType), value) & "-Enclosure", Me.LocalResourceFile) + lstSyndicationEnclosureType.Items.Add(li) + Next + + End Sub + + Private Sub BindMenuPositionType() + + For Each value As Integer In System.Enum.GetValues(GetType(MenuPositionType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(MenuPositionType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(MenuPositionType), value), Me.LocalResourceFile) + lstMenuPosition.Items.Add(li) + Next + + End Sub + + Private Sub BindTemplates() + + Dim templateRoot As String = Me.MapPath("Templates") + If Directory.Exists(templateRoot) Then + Dim arrFolders() As String = Directory.GetDirectories(templateRoot) + For Each folder As String In arrFolders + Dim folderName As String = folder.Substring(folder.LastIndexOf("\") + 1) + Dim objListItem As ListItem = New ListItem + objListItem.Text = folderName + objListItem.Value = folderName + drpTemplates.Items.Add(objListItem) + Next + End If + + End Sub + + Private Sub BindCategories() + + Dim objCategoryController As CategoryController = New CategoryController + Dim objCategories As List(Of CategoryInfo) = objCategoryController.GetCategoriesAll(Me.ModuleId, Null.NullInteger, ArticleSettings.CategorySortType) + + lstCategories.DataSource = objCategories + lstCategories.DataBind() + + lstDefaultCategories.DataSource = objCategories + lstDefaultCategories.DataBind() + + drpCategories.DataSource = objCategories + drpCategories.DataBind() + + End Sub + + Private Sub BindTimeZone() + + DotNetNuke.Services.Localization.Localization.LoadTimeZoneDropDownList(drpTimeZone, BasePage.PageCulture.Name, Convert.ToString(PortalSettings.TimeZoneOffset)) + + End Sub + + Private Sub BindThumbnailType() + + For Each value As Integer In System.Enum.GetValues(GetType(ThumbnailType)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(ThumbnailType), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(ThumbnailType), value), Me.LocalResourceFile) + rdoThumbnailType.Items.Add(li) + Next + + End Sub + + Private Sub BindWatermarkPosition() + + For Each value As Integer In System.Enum.GetValues(GetType(WatermarkPosition)) + Dim li As New ListItem + li.Value = System.Enum.GetName(GetType(WatermarkPosition), value) + li.Text = Localization.GetString(System.Enum.GetName(GetType(WatermarkPosition), value), Me.LocalResourceFile) + drpWatermarkPosition.Items.Add(li) + Next + + End Sub + +#End Region + + Private Sub BindSettings() + + BindBasicSettings() + BindArchiveSettings() + BindCategorySettings() + BindCommentSettings() + BindContentSharingSettings() + BindFilterSettings() + BindFormSettings() + BindImageSettings() + BindFileSettings() + BindNotificationSettings() + BindRelatedSettings() + BindSecuritySettings() + BindSEOSettings() + BindSyndicationSettings() + BindTwitterSettings() + BindThirdPartySettings() + + End Sub + +#Region " Private Methods - Bind/Save Basic Settings " + + Private Sub BindBasicSettings() + + chkEnableRatingsAuthenticated.Checked = ArticleSettings.EnableRatingsAuthenticated + chkEnableRatingsAnonymous.Checked = ArticleSettings.EnableRatingsAnonymous + chkEnableCoreSearch.Checked = ArticleSettings.EnableCoreSearch + + chkEnableNotificationPing.Checked = ArticleSettings.EnableNotificationPing + chkEnableAutoTrackback.Checked = ArticleSettings.EnableAutoTrackback + + chkProcessPostTokens.Checked = ArticleSettings.ProcessPostTokens + + If (Settings.Contains(ArticleConstants.ENABLE_INCOMING_TRACKBACK_SETTING)) Then + chkEnableIncomingTrackback.Checked = Convert.ToBoolean(Settings(ArticleConstants.ENABLE_INCOMING_TRACKBACK_SETTING).ToString()) + Else + chkEnableIncomingTrackback.Checked = True + End If + + If (Settings.Contains(ArticleConstants.LAUNCH_LINKS)) Then + chkLaunchLinks.Checked = Convert.ToBoolean(Settings(ArticleConstants.LAUNCH_LINKS).ToString()) + Else + chkLaunchLinks.Checked = ArticleSettings.LaunchLinks + End If + + If (Settings.Contains(ArticleConstants.BUBBLE_FEATURED_ARTICLES)) Then + chkBubbleFeaturedArticles.Checked = Convert.ToBoolean(Settings(ArticleConstants.BUBBLE_FEATURED_ARTICLES).ToString()) + Else + chkBubbleFeaturedArticles.Checked = False + End If + + If (Settings.Contains(ArticleConstants.REQUIRE_CATEGORY)) Then + chkRequireCategory.Checked = Convert.ToBoolean(Settings(ArticleConstants.REQUIRE_CATEGORY).ToString()) + Else + chkRequireCategory.Checked = False + End If + + If Not (drpDisplayType.Items.FindByValue(ArticleSettings.DisplayMode.ToString()) Is Nothing) Then + drpDisplayType.SelectedValue = ArticleSettings.DisplayMode.ToString() + End If + + If Not (drpTemplates.Items.FindByValue(ArticleSettings.Template) Is Nothing) Then + drpTemplates.SelectedValue = ArticleSettings.Template + End If + + If (drpNumber.Items.FindByValue(ArticleSettings.PageSize.ToString()) IsNot Nothing) Then + drpNumber.SelectedValue = ArticleSettings.PageSize.ToString() + End If + + If Not (drpTimeZone.Items.FindByValue(ArticleSettings.ServerTimeZone.ToString()) Is Nothing) Then + drpTimeZone.SelectedValue = ArticleSettings.ServerTimeZone.ToString() + End If + + If Not (drpSortBy.Items.FindByValue(ArticleSettings.SortBy.ToString()) Is Nothing) Then + drpSortBy.SelectedValue = ArticleSettings.SortBy.ToString() + End If + + If Not (drpSortDirection.Items.FindByValue(ArticleSettings.SortDirection.ToString()) Is Nothing) Then + drpSortDirection.SelectedValue = ArticleSettings.SortDirection.ToString() + End If + + If (lstMenuPosition.Items.FindByValue(ArticleSettings.MenuPosition.ToString()) IsNot Nothing) Then + lstMenuPosition.SelectedValue = ArticleSettings.MenuPosition.ToString() + End If + + End Sub + + Private Sub SaveBasicSettings() + + Dim objModules As New ModuleController + + ' General Configuration + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_RATINGS_AUTHENTICATED_SETTING, chkEnableRatingsAuthenticated.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_RATINGS_ANONYMOUS_SETTING, chkEnableRatingsAnonymous.Checked.ToString()) + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.ENABLE_CORE_SEARCH_SETTING, chkEnableCoreSearch.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PROCESS_POST_TOKENS, chkProcessPostTokens.Checked.ToString()) + + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_NOTIFICATION_PING_SETTING, chkEnableNotificationPing.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_AUTO_TRACKBACK_SETTING, chkEnableAutoTrackback.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_INCOMING_TRACKBACK_SETTING, chkEnableIncomingTrackback.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.LAUNCH_LINKS, chkLaunchLinks.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.BUBBLE_FEATURED_ARTICLES, chkBubbleFeaturedArticles.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.REQUIRE_CATEGORY, chkRequireCategory.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.DISPLAY_MODE, CType(System.Enum.Parse(GetType(DisplayType), drpDisplayType.SelectedValue), DisplayType).ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.PAGE_SIZE_SETTING, drpNumber.SelectedValue) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.TEMPLATE_SETTING, drpTemplates.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SERVER_TIMEZONE, drpTimeZone.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SORT_BY, drpSortBy.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SORT_DIRECTION, drpSortDirection.SelectedValue) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.MENU_POSITION_TYPE, lstMenuPosition.SelectedValue) + + ' Clear Cache + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.LISTING_ITEM) + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.LISTING_FEATURED) + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.LISTING_HEADER) + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.LISTING_FOOTER) + + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.VIEW_ITEM) + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.VIEW_HEADER) + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.VIEW_FOOTER) + + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.COMMENT_ITEM) + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.COMMENT_HEADER) + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.COMMENT_FOOTER) + + DataCache.RemoveCache(TabModuleId.ToString() & TemplateConstants.MENU_ITEM) + + End Sub + +#End Region + +#Region " Private Methods - Bind/Save Archive Settings " + + Private Sub BindArchiveSettings() + + chkArchiveCurrentArticles.Checked = ArticleSettings.ArchiveCurrentArticles + chkArchiveCategories.Checked = ArticleSettings.ArchiveCategories + chkArchiveAuthor.Checked = ArticleSettings.ArchiveAuthor + chkArchiveMonth.Checked = ArticleSettings.ArchiveMonth + + End Sub + + Private Sub SaveArchiveSettings() + + Dim objModules As New ModuleController + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.ARCHIVE_CURRENT_ARTICLES_SETTING, chkArchiveCurrentArticles.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.ARCHIVE_CATEGORIES_SETTING, chkArchiveCategories.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.ARCHIVE_AUTHOR_SETTING, chkArchiveAuthor.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.ARCHIVE_MONTH_SETTING, chkArchiveMonth.Checked.ToString()) + + End Sub + + +#End Region + +#Region " Private Methods - Bind/Save Category Settings " + + Private Sub BindCategorySettings() + + If (Settings.Contains(ArticleConstants.DEFAULT_CATEGORIES_SETTING)) Then + If Not (Settings(ArticleConstants.DEFAULT_CATEGORIES_SETTING).ToString = Null.NullString) Then + Dim categories As String() = Settings(ArticleConstants.DEFAULT_CATEGORIES_SETTING).ToString().Split(Char.Parse(",")) + + For Each category As String In categories + If Not (lstDefaultCategories.Items.FindByValue(category) Is Nothing) Then + lstDefaultCategories.Items.FindByValue(category).Selected = True + End If + Next + End If + End If + + txtCategorySelectionHeight.Text = ArticleSettings.CategorySelectionHeight.ToString() + chkCategoryBreadcrumb.Checked = ArticleSettings.CategoryBreadcrumb + chkCategoryName.Checked = ArticleSettings.IncludeInPageName + chkCategoryFilterSubmit.Checked = ArticleSettings.CategoryFilterSubmit + + If (lstCategorySortOrder.Items.FindByValue(ArticleSettings.CategorySortType.ToString()) IsNot Nothing) Then + lstCategorySortOrder.SelectedValue = ArticleSettings.CategorySortType.ToString() + End If + + End Sub + + Private Sub SaveCategorySettings() + + Dim objModules As New ModuleController + + Dim categories As String = "" + For Each item As ListItem In lstDefaultCategories.Items + If item.Selected Then + If (categories.Length > 0) Then + categories = categories & "," + End If + categories = categories & item.Value + End If + Next item + + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.DEFAULT_CATEGORIES_SETTING, categories) + + If (IsNumeric(txtCategorySelectionHeight.Text)) Then + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.CATEGORY_SELECTION_HEIGHT_SETTING, txtCategorySelectionHeight.Text) + End If + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.CATEGORY_BREADCRUMB_SETTING, chkCategoryBreadcrumb.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.CATEGORY_NAME_SETTING, chkCategoryName.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.CATEGORY_FILTER_SUBMIT_SETTING, chkCategoryFilterSubmit.Checked.ToString()) + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.CATEGORY_SORT_SETTING, lstCategorySortOrder.SelectedValue) + + End Sub + +#End Region + + Private Sub BindCommentSettings() + + If (Settings.Contains(ArticleConstants.ENABLE_COMMENTS_SETTING)) Then + chkEnableComments.Checked = Convert.ToBoolean(Settings(ArticleConstants.ENABLE_COMMENTS_SETTING).ToString()) + Else + chkEnableComments.Checked = True + End If + + If (Settings.Contains(ArticleConstants.ENABLE_ANONYMOUS_COMMENTS_SETTING)) Then + chkEnableAnonymousComments.Checked = Convert.ToBoolean(Settings(ArticleConstants.ENABLE_ANONYMOUS_COMMENTS_SETTING).ToString()) + Else + chkEnableAnonymousComments.Checked = True + End If + + If (Settings.Contains(ArticleConstants.ENABLE_COMMENT_MODERATION_SETTING)) Then + chkEnableCommentModeration.Checked = Convert.ToBoolean(Settings(ArticleConstants.ENABLE_COMMENT_MODERATION_SETTING).ToString()) + Else + chkEnableCommentModeration.Checked = False + End If + + If (Settings.Contains(ArticleConstants.COMMENT_HIDE_WEBSITE_SETTING)) Then + chkHideWebsite.Checked = Convert.ToBoolean(Settings(ArticleConstants.COMMENT_HIDE_WEBSITE_SETTING).ToString()) + Else + chkHideWebsite.Checked = False + End If + + If (Settings.Contains(ArticleConstants.COMMENT_REQUIRE_NAME_SETTING)) Then + chkRequireName.Checked = Convert.ToBoolean(Settings(ArticleConstants.COMMENT_REQUIRE_NAME_SETTING).ToString()) + Else + chkRequireName.Checked = True + End If + + If (Settings.Contains(ArticleConstants.COMMENT_REQUIRE_EMAIL_SETTING)) Then + chkRequireEmail.Checked = Convert.ToBoolean(Settings(ArticleConstants.COMMENT_REQUIRE_EMAIL_SETTING).ToString()) + Else + chkRequireEmail.Checked = True + End If + + If (Settings.Contains(ArticleConstants.USE_CAPTCHA_SETTING)) Then + chkUseCaptcha.Checked = Convert.ToBoolean(Settings(ArticleConstants.USE_CAPTCHA_SETTING).ToString()) + Else + chkUseCaptcha.Checked = False + End If + + If (Settings.Contains(ArticleConstants.NOTIFY_DEFAULT_SETTING)) Then + chkNotifyDefault.Checked = Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_DEFAULT_SETTING).ToString()) + Else + chkNotifyDefault.Checked = False + End If + + If Not (drpSortDirectionComments.Items.FindByValue(ArticleSettings.SortDirectionComments.ToString()) Is Nothing) Then + drpSortDirectionComments.SelectedValue = ArticleSettings.SortDirectionComments.ToString() + End If + + If (Settings.Contains(ArticleConstants.COMMENT_AKISMET_SETTING)) Then + txtAkismetKey.Text = Settings(ArticleConstants.COMMENT_AKISMET_SETTING).ToString() + End If + + End Sub + + Private Sub SaveCommentSettings() + + Dim objModules As New ModuleController + + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_COMMENTS_SETTING, chkEnableComments.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_ANONYMOUS_COMMENTS_SETTING, chkEnableAnonymousComments.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_COMMENT_MODERATION_SETTING, chkEnableCommentModeration.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.COMMENT_HIDE_WEBSITE_SETTING, chkHideWebsite.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.COMMENT_REQUIRE_NAME_SETTING, chkRequireName.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.COMMENT_REQUIRE_EMAIL_SETTING, chkRequireEmail.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.USE_CAPTCHA_SETTING, chkUseCaptcha.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.NOTIFY_DEFAULT_SETTING, chkNotifyDefault.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.COMMENT_SORT_DIRECTION_SETTING, drpSortDirectionComments.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.COMMENT_AKISMET_SETTING, txtAkismetKey.Text) + + End Sub + + Private Sub BindContentSharingSettings() + + If (Me.UserInfo.IsSuperUser = False) Then + phContentSharing.Visible = False + Else + BindAvailableContentSharingPortals() + BindSelectedContentSharingPortals() + End If + + End Sub + + Private Sub SaveContentSharingSettings() + + End Sub + + Private Sub BindFilterSettings() + + If (ArticleSettings.MaxArticles <> Null.NullInteger) Then + txtMaxArticles.Text = ArticleSettings.MaxArticles.ToString() + End If + + If (ArticleSettings.MaxAge <> Null.NullInteger) Then + txtMaxAge.Text = ArticleSettings.MaxAge.ToString() + End If + + If (ArticleSettings.FilterSingleCategory = Null.NullInteger) Then + If (ArticleSettings.FilterCategories IsNot Nothing) Then + For Each category As String In ArticleSettings.FilterCategories + If Not (lstCategories.Items.FindByValue(category) Is Nothing) Then + lstCategories.Items.FindByValue(category).Selected = True + End If + Next + + If (ArticleSettings.MatchCategories = MatchOperatorType.MatchAny) Then + rdoMatchAny.Checked = True + End If + + If (ArticleSettings.MatchCategories = MatchOperatorType.MatchAll) Then + rdoMatchAll.Checked = True + End If + Else + rdoAllCategories.Checked = True + End If + Else + rdoSingleCategory.Checked = True + + If (drpCategories.Items.FindByValue(ArticleSettings.FilterSingleCategory.ToString()) IsNot Nothing) Then + drpCategories.SelectedValue = ArticleSettings.FilterSingleCategory.ToString() + End If + End If + + chkShowPending.Checked = ArticleSettings.ShowPending + + chkShowFeaturedOnly.Checked = ArticleSettings.FeaturedOnly + chkShowNotFeaturedOnly.Checked = ArticleSettings.NotFeaturedOnly + + chkShowSecuredOnly.Checked = ArticleSettings.SecuredOnly + chkShowNotSecuredOnly.Checked = ArticleSettings.NotSecuredOnly + + If (ArticleSettings.Author <> Null.NullInteger) Then + Dim objUserController As New DotNetNuke.Entities.Users.UserController + Dim objUser As DotNetNuke.Entities.Users.UserInfo = objUserController.GetUser(Me.PortalId, ArticleSettings.Author) + + If Not (objUser Is Nothing) Then + lblAuthorFilter.Text = objUser.Username + End If + Else + lblAuthorFilter.Text = Localization.GetString("SelectAuthor.Text", Me.LocalResourceFile) + End If + + chkQueryStringFilter.Checked = ArticleSettings.AuthorUserIDFilter + txtQueryStringParam.Text = ArticleSettings.AuthorUserIDParam + chkUsernameFilter.Checked = ArticleSettings.AuthorUsernameFilter + txtUsernameParam.Text = ArticleSettings.AuthorUsernameParam + chkLoggedInUser.Checked = ArticleSettings.AuthorLoggedInUserFilter + + End Sub + + Private Sub SaveFilterSettings() + + Dim objModules As New ModuleController + + If (txtMaxArticles.Text <> "") Then + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.MAX_ARTICLES_SETTING, txtMaxArticles.Text) + Else + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.MAX_ARTICLES_SETTING, Null.NullInteger.ToString()) + End If + + If (txtMaxAge.Text <> "") Then + If (IsNumeric(txtMaxAge.Text)) Then + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.MAX_AGE_SETTING, txtMaxAge.Text) + Else + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.MAX_AGE_SETTING, Null.NullInteger.ToString()) + End If + Else + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.MAX_AGE_SETTING, Null.NullInteger.ToString()) + End If + + If (rdoAllCategories.Checked) Then + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.CATEGORIES_SETTING & Me.TabId.ToString(), Null.NullInteger.ToString()) + End If + + If (rdoSingleCategory.Checked) Then + If (drpCategories.SelectedValue <> "") Then + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.CATEGORIES_FILTER_SINGLE_SETTING, drpCategories.SelectedValue) + Else + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.CATEGORIES_FILTER_SINGLE_SETTING, Null.NullInteger.ToString()) + End If + Else + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.CATEGORIES_FILTER_SINGLE_SETTING, Null.NullInteger.ToString()) + End If + + If (rdoMatchAny.Checked Or rdoMatchAll.Checked) Then + Dim categories As String = "" + For Each item As ListItem In lstCategories.Items + If item.Selected Then + If (categories.Length > 0) Then + categories = categories & "," + End If + categories = categories & item.Value + End If + Next item + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.CATEGORIES_SETTING & Me.TabId.ToString(), categories) + + If (rdoMatchAny.Checked) Then + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.MATCH_OPERATOR_SETTING, MatchOperatorType.MatchAny.ToString()) + End If + + If (rdoMatchAll.Checked) Then + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.MATCH_OPERATOR_SETTING, MatchOperatorType.MatchAll.ToString()) + End If + End If + + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.SHOW_PENDING_SETTING, chkShowPending.Checked.ToString()) + + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.SHOW_FEATURED_ONLY_SETTING, chkShowFeaturedOnly.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.SHOW_NOT_FEATURED_ONLY_SETTING, chkShowNotFeaturedOnly.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.SHOW_SECURED_ONLY_SETTING, chkShowSecuredOnly.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.SHOW_NOT_SECURED_ONLY_SETTING, chkShowNotSecuredOnly.Checked.ToString()) + + If (ddlAuthor.Visible) Then + If (ddlAuthor.Items.Count > 0) Then + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.AUTHOR_SETTING, ddlAuthor.SelectedValue) + End If + End If + + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.AUTHOR_USERID_FILTER_SETTING, chkQueryStringFilter.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.AUTHOR_USERID_PARAM_SETTING, txtQueryStringParam.Text) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.AUTHOR_USERNAME_FILTER_SETTING, chkUsernameFilter.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.AUTHOR_USERNAME_PARAM_SETTING, txtUsernameParam.Text) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.AUTHOR_LOGGED_IN_USER_FILTER_SETTING, chkLoggedInUser.Checked.ToString()) + + End Sub + + Private Sub BindFormSettings() + + If (lstAuthorSelection.Items.FindByValue(ArticleSettings.AuthorSelect.ToString()) IsNot Nothing) Then + lstAuthorSelection.SelectedValue = ArticleSettings.AuthorSelect.ToString() + End If + + If (ArticleSettings.AuthorDefault <> Null.NullInteger) Then + Dim objUserController As New DotNetNuke.Entities.Users.UserController + Dim objUser As DotNetNuke.Entities.Users.UserInfo = objUserController.GetUser(Me.PortalId, ArticleSettings.AuthorDefault) + + If Not (objUser Is Nothing) Then + lblAuthorDefault.Text = objUser.Username + End If + End If + + chkExpandSummary.Checked = ArticleSettings.ExpandSummary + txtTextEditorWidth.Text = ArticleSettings.TextEditorWidth + txtTextEditorHeight.Text = ArticleSettings.TextEditorHeight + If (lstTextEditorSummaryMode.Items.FindByValue(ArticleSettings.TextEditorSummaryMode.ToString()) IsNot Nothing) Then + lstTextEditorSummaryMode.SelectedValue = ArticleSettings.TextEditorSummaryMode.ToString() + End If + txtTextEditorSummaryWidth.Text = ArticleSettings.TextEditorSummaryWidth + txtTextEditorSummaryHeight.Text = ArticleSettings.TextEditorSummaryHeight + + End Sub + + Private Sub SaveFormSettings() + + Dim objModules As New ModuleController + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.AUTHOR_SELECT_TYPE, lstAuthorSelection.SelectedValue) + If (drpAuthorDefault.Visible) Then + If (drpAuthorDefault.Items.Count > 0) Then + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.AUTHOR_DEFAULT_SETTING, drpAuthorDefault.SelectedValue) + End If + End If + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.EXPAND_SUMMARY_SETTING, chkExpandSummary.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.TEXT_EDITOR_WIDTH, txtTextEditorWidth.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.TEXT_EDITOR_HEIGHT, txtTextEditorHeight.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.TEXT_EDITOR_SUMMARY_MODE, lstTextEditorSummaryMode.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.TEXT_EDITOR_SUMMARY_WIDTH, txtTextEditorSummaryWidth.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.TEXT_EDITOR_SUMMARY_HEIGHT, txtTextEditorSummaryHeight.Text) + + End Sub + + Private Sub BindImageSettings() + + chkIncludeJQuery.Checked = ArticleSettings.IncludeJQuery + txtJQueryPath.Text = Me.ArticleSettings.ImageJQueryPath + chkEnableImagesUpload.Checked = ArticleSettings.EnableImagesUpload + chkEnablePortalImages.Checked = ArticleSettings.EnablePortalImages + chkEnableExternalImages.Checked = ArticleSettings.EnableExternalImages + If (drpDefaultImageFolder.Items.FindByValue(ArticleSettings.DefaultImagesFolder.ToString) IsNot Nothing) Then + drpDefaultImageFolder.SelectedValue = ArticleSettings.DefaultImagesFolder.ToString + End If + chkResizeImages.Checked = ArticleSettings.ResizeImages + If (rdoThumbnailType.Items.FindByValue(ArticleSettings.ImageThumbnailType.ToString) IsNot Nothing) Then + rdoThumbnailType.SelectedValue = ArticleSettings.ImageThumbnailType.ToString + Else + rdoThumbnailType.SelectedIndex = 0 + End If + txtImageMaxWidth.Text = ArticleSettings.MaxImageWidth.ToString() + txtImageMaxHeight.Text = ArticleSettings.MaxImageHeight.ToString() + + chkUseWatermark.Checked = Me.ArticleSettings.WatermarkEnabled + txtWatermarkText.Text = Me.ArticleSettings.WatermarkText + ctlWatermarkImage.Url = Me.ArticleSettings.WatermarkImage + If Not (drpWatermarkPosition.Items.FindByValue(ArticleSettings.WatermarkPosition.ToString()) Is Nothing) Then + drpWatermarkPosition.SelectedValue = ArticleSettings.WatermarkPosition.ToString() + End If + + End Sub + + Private Sub SaveImageSettings() + + Dim objModules As New ModuleController + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.INCLUDE_JQUERY_SETTING, chkIncludeJQuery.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.IMAGE_JQUERY_PATH, txtJQueryPath.Text) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_UPLOAD_IMAGES_SETTING, chkEnableImagesUpload.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_PORTAL_IMAGES_SETTING, chkEnablePortalImages.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_EXTERNAL_IMAGES_SETTING, chkEnableExternalImages.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.DEFAULT_IMAGES_FOLDER_SETTING, drpDefaultImageFolder.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.IMAGE_RESIZE_SETTING, chkResizeImages.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.IMAGE_THUMBNAIL_SETTING, rdoThumbnailType.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.IMAGE_MAX_WIDTH_SETTING, txtImageMaxWidth.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.IMAGE_MAX_HEIGHT_SETTING, txtImageMaxHeight.Text) + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.IMAGE_WATERMARK_ENABLED_SETTING, chkUseWatermark.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.IMAGE_WATERMARK_TEXT_SETTING, txtWatermarkText.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.IMAGE_WATERMARK_IMAGE_SETTING, ctlWatermarkImage.Url) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.IMAGE_WATERMARK_IMAGE_POSITION_SETTING, drpWatermarkPosition.SelectedValue) + + End Sub + + Private Sub BindFileSettings() + + If (drpDefaultFileFolder.Items.FindByValue(ArticleSettings.DefaultFilesFolder.ToString) IsNot Nothing) Then + drpDefaultFileFolder.SelectedValue = ArticleSettings.DefaultFilesFolder.ToString + End If + + End Sub + + Private Sub SaveFileSettings() + + Dim objModules As New ModuleController + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.DEFAULT_FILES_FOLDER_SETTING, drpDefaultFileFolder.SelectedValue) + + End Sub + + Private Sub BindSecuritySettings() + + txtSecureUrl.Text = ArticleSettings.SecureUrl.ToString() + If (ArticleSettings.RoleGroupID <> Null.NullInteger) Then + If (drpSecurityRoleGroups.Items.FindByValue(ArticleSettings.RoleGroupID.ToString()) IsNot Nothing) Then + drpSecurityRoleGroups.SelectedValue = ArticleSettings.RoleGroupID.ToString() + End If + End If + + BindRoles() + + End Sub + + Private Sub SaveSecuritySettings() + + Dim objModules As New ModuleController + + Dim submitRoles As String = "" + Dim secureRoles As String = "" + Dim autoSecureRoles As String = "" + Dim approveRoles As String = "" + Dim autoApproveRoles As String = "" + Dim autoApproveCommentRoles As String = "" + Dim featureRoles As String = "" + Dim autoFeatureRoles As String = "" + For Each item As DataGridItem In grdBasicPermissions.Items + Dim role As String = grdBasicPermissions.DataKeys(item.ItemIndex).ToString() + + Dim chkSubmit As CheckBox = CType(item.FindControl("chkSubmit"), CheckBox) + If (chkSubmit.Checked) Then + If (submitRoles = "") Then + submitRoles = role + Else + submitRoles = submitRoles & ";" & role + End If + End If + + Dim chkSecure As CheckBox = CType(item.FindControl("chkSecure"), CheckBox) + If (chkSecure.Checked) Then + If (secureRoles = "") Then + secureRoles = role + Else + secureRoles = secureRoles & ";" & role + End If + End If + + Dim chkAutoSecure As CheckBox = CType(item.FindControl("chkAutoSecure"), CheckBox) + If (chkAutoSecure.Checked) Then + If (autoSecureRoles = "") Then + autoSecureRoles = role + Else + autoSecureRoles = autoSecureRoles & ";" & role + End If + End If + + Dim chkApprove As CheckBox = CType(item.FindControl("chkApprove"), CheckBox) + If (chkApprove.Checked) Then + If (approveRoles = "") Then + approveRoles = role + Else + approveRoles = approveRoles & ";" & role + End If + End If + + Dim chkAutoApproveArticle As CheckBox = CType(item.FindControl("chkAutoApproveArticle"), CheckBox) + If (chkAutoApproveArticle.Checked) Then + If (autoApproveRoles = "") Then + autoApproveRoles = role + Else + autoApproveRoles = autoApproveRoles & ";" & role + End If + End If + + Dim chkAutoApproveComment As CheckBox = CType(item.FindControl("chkAutoApproveComment"), CheckBox) + If (chkAutoApproveComment.Checked) Then + If (autoApproveCommentRoles = "") Then + autoApproveCommentRoles = role + Else + autoApproveCommentRoles = autoApproveCommentRoles & ";" & role + End If + End If + + Dim chkFeature As CheckBox = CType(item.FindControl("chkFeature"), CheckBox) + If (chkFeature.Checked) Then + If (featureRoles = "") Then + featureRoles = role + Else + featureRoles = featureRoles & ";" & role + End If + End If + + Dim chkAutoFeature As CheckBox = CType(item.FindControl("chkAutoFeature"), CheckBox) + If (chkAutoFeature.Checked) Then + If (autoFeatureRoles = "") Then + autoFeatureRoles = role + Else + autoFeatureRoles = autoFeatureRoles & ";" & role + End If + End If + Next + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_SUBMISSION_SETTING, submitRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_SECURE_SETTING, secureRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_AUTO_SECURE_SETTING, autoSecureRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_APPROVAL_SETTING, approveRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_AUTO_APPROVAL_SETTING, autoApproveRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_AUTO_APPROVAL_COMMENT_SETTING, autoApproveCommentRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_FEATURE_SETTING, featureRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_AUTO_FEATURE_SETTING, autoFeatureRoles) + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_ROLE_GROUP_ID, drpSecurityRoleGroups.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_SECURE_URL_SETTING, txtSecureUrl.Text) + + Dim categoriesRoles As String = "" + Dim excerptRoles As String = "" + Dim imageRoles As String = "" + Dim fileRoles As String = "" + Dim linkRoles As String = "" + Dim publishRoles As String = "" + Dim expiryRoles As String = "" + Dim metaRoles As String = "" + Dim customRoles As String = "" + + For Each item As DataGridItem In grdFormPermissions.Items + Dim role As String = grdFormPermissions.DataKeys(item.ItemIndex).ToString() + + Dim chkCategories As CheckBox = CType(item.FindControl("chkCategories"), CheckBox) + If (chkCategories.Checked) Then + If (categoriesRoles = "") Then + categoriesRoles = role + Else + categoriesRoles = categoriesRoles & ";" & role + End If + End If + + Dim chkExcerpt As CheckBox = CType(item.FindControl("chkExcerpt"), CheckBox) + If (chkExcerpt.Checked) Then + If (excerptRoles = "") Then + excerptRoles = role + Else + excerptRoles = excerptRoles & ";" & role + End If + End If + + Dim chkImage As CheckBox = CType(item.FindControl("chkImage"), CheckBox) + If (chkImage.Checked) Then + If (imageRoles = "") Then + imageRoles = role + Else + imageRoles = imageRoles & ";" & role + End If + End If + + Dim chkFile As CheckBox = CType(item.FindControl("chkFile"), CheckBox) + If (chkFile.Checked) Then + If (fileRoles = "") Then + fileRoles = role + Else + fileRoles = fileRoles & ";" & role + End If + End If + + Dim chkLink As CheckBox = CType(item.FindControl("chkLink"), CheckBox) + If (chkLink.Checked) Then + If (linkRoles = "") Then + linkRoles = role + Else + linkRoles = linkRoles & ";" & role + End If + End If + + Dim chkPublishDate As CheckBox = CType(item.FindControl("chkPublishDate"), CheckBox) + If (chkPublishDate.Checked) Then + If (publishRoles = "") Then + publishRoles = role + Else + publishRoles = publishRoles & ";" & role + End If + End If + + Dim chkExpiryDate As CheckBox = CType(item.FindControl("chkExpiryDate"), CheckBox) + If (chkExpiryDate.Checked) Then + If (expiryRoles = "") Then + expiryRoles = role + Else + expiryRoles = expiryRoles & ";" & role + End If + End If + + Dim chkMeta As CheckBox = CType(item.FindControl("chkMeta"), CheckBox) + If (chkMeta.Checked) Then + If (metaRoles = "") Then + metaRoles = role + Else + metaRoles = metaRoles & ";" & role + End If + End If + + Dim chkCustom As CheckBox = CType(item.FindControl("chkCustom"), CheckBox) + If (chkCustom.Checked) Then + If (customRoles = "") Then + customRoles = role + Else + customRoles = customRoles & ";" & role + End If + End If + Next + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_CATEGORIES_SETTING, categoriesRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_EXCERPT_SETTING, excerptRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_IMAGE_SETTING, imageRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_FILE_SETTING, fileRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_LINK_SETTING, linkRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_PUBLISH_SETTING, publishRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_EXPIRY_SETTING, expiryRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_META_SETTING, metaRoles) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_CUSTOM_SETTING, customRoles) + + Dim siteTemplatesRoles As String = "" + For Each item As DataGridItem In grdAdminPermissions.Items + Dim role As String = grdAdminPermissions.DataKeys(item.ItemIndex).ToString() + + Dim chkSiteTemplates As CheckBox = CType(item.FindControl("chkSiteTemplates"), CheckBox) + If (chkSiteTemplates.Checked) Then + If (siteTemplatesRoles = "") Then + siteTemplatesRoles = role + Else + siteTemplatesRoles = siteTemplatesRoles & ";" & role + End If + End If + Next + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.PERMISSION_SITE_TEMPLATES_SETTING, siteTemplatesRoles) + + End Sub + + Private Sub BindNotificationSettings() + + If (Settings.Contains(ArticleConstants.NOTIFY_SUBMISSION_SETTING)) Then + chkNotifySubmission.Checked = Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_SUBMISSION_SETTING).ToString()) + Else + chkNotifySubmission.Checked = True + End If + + If (Settings.Contains(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL)) Then + txtSubmissionEmail.Text = Settings(ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL).ToString() + End If + + If (Settings.Contains(ArticleConstants.NOTIFY_APPROVAL_SETTING)) Then + chkNotifyApproval.Checked = Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_APPROVAL_SETTING).ToString()) + Else + chkNotifyApproval.Checked = True + End If + + If (Settings.Contains(ArticleConstants.NOTIFY_COMMENT_SETTING)) Then + chkNotifyComment.Checked = Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_COMMENT_SETTING).ToString()) + Else + chkNotifyComment.Checked = True + End If + + If (Settings.Contains(ArticleConstants.NOTIFY_COMMENT_SETTING_EMAIL)) Then + txtNotifyCommentEmail.Text = Settings(ArticleConstants.NOTIFY_COMMENT_SETTING_EMAIL).ToString() + End If + + If (Settings.Contains(ArticleConstants.NOTIFY_COMMENT_APPROVAL_SETTING)) Then + chkNotifyCommentApproval.Checked = Convert.ToBoolean(Settings(ArticleConstants.NOTIFY_COMMENT_APPROVAL_SETTING).ToString()) + Else + chkNotifyCommentApproval.Checked = True + End If + + If (Settings.Contains(ArticleConstants.NOTIFY_COMMENT_APPROVAL_EMAIL_SETTING)) Then + txtNotifyCommentApprovalEmail.Text = Settings(ArticleConstants.NOTIFY_COMMENT_APPROVAL_EMAIL_SETTING).ToString() + End If + + End Sub + + Private Sub SaveNotificationSettings() + + Dim objModules As New ModuleController + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.NOTIFY_SUBMISSION_SETTING, chkNotifySubmission.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.NOTIFY_SUBMISSION_SETTING_EMAIL, txtSubmissionEmail.Text.Trim().ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.NOTIFY_APPROVAL_SETTING, chkNotifyApproval.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.NOTIFY_COMMENT_SETTING, chkNotifyComment.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.NOTIFY_COMMENT_SETTING_EMAIL, txtNotifyCommentEmail.Text.Trim().ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.NOTIFY_COMMENT_APPROVAL_SETTING, chkNotifyCommentApproval.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.NOTIFY_COMMENT_APPROVAL_EMAIL_SETTING, txtNotifyCommentApprovalEmail.Text.Trim().ToString()) + + End Sub + + Private Sub BindRelatedSettings() + + If (lstRelatedMode.Items.FindByValue(RelatedType.MatchCategoriesAnyTagsAny.ToString()) IsNot Nothing) Then + lstRelatedMode.SelectedValue = RelatedType.MatchCategoriesAnyTagsAny.ToString() + End If + + If (Settings.Contains(ArticleConstants.RELATED_MODE)) Then + If (lstRelatedMode.Items.FindByValue(Settings(ArticleConstants.RELATED_MODE).ToString()) IsNot Nothing) Then + lstRelatedMode.SelectedValue = Settings(ArticleConstants.RELATED_MODE).ToString() + End If + End If + + End Sub + + Private Sub SaveRelatedSettings() + + Dim objModules As New ModuleController + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.RELATED_MODE, lstRelatedMode.SelectedValue.ToString()) + + End Sub + + Private Sub BindSEOSettings() + + If lstTitleReplacement.Items.FindByValue(ArticleSettings.TitleReplacement.ToString()) IsNot Nothing Then + lstTitleReplacement.SelectedValue = ArticleSettings.TitleReplacement.ToString() + End If + + chkAlwaysShowPageID.Checked = ArticleSettings.AlwaysShowPageID + + If lstUrlMode.Items.FindByValue(ArticleSettings.UrlModeType.ToString()) IsNot Nothing Then + lstUrlMode.SelectedValue = ArticleSettings.UrlModeType.ToString() + End If + + txtShorternID.Text = ArticleSettings.ShortenedID + + chkUseCanonicalLink.Checked = ArticleSettings.UseCanonicalLink + chkExpandMetaInformation.Checked = ArticleSettings.ExpandMetaInformation + chkUniquePageTitles.Checked = ArticleSettings.UniquePageTitles + + End Sub + + Private Sub SaveSEOSettings() + + Dim objModules As New ModuleController + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.TITLE_REPLACEMENT_TYPE, lstTitleReplacement.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SEO_ALWAYS_SHOW_PAGEID_SETTING, chkAlwaysShowPageID.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SEO_URL_MODE_SETTING, lstUrlMode.SelectedValue) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SEO_SHORTEN_ID_SETTING, txtShorternID.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SEO_USE_CANONICAL_LINK_SETTING, chkUseCanonicalLink.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SEO_EXPAND_META_INFORMATION_SETTING, chkExpandMetaInformation.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SEO_UNIQUE_PAGE_TITLES_SETTING, chkUniquePageTitles.Checked.ToString()) + + End Sub + + Private Sub BindSyndicationSettings() + + chkEnableSyndication.Checked = ArticleSettings.EnableSyndication + chkEnableSyndicationEnclosures.Checked = ArticleSettings.EnableSyndicationEnclosures + chkEnableSyndicationHtml.Checked = ArticleSettings.EnableSyndicationHtml + + If (lstSyndicationLinkMode.Items.FindByValue(ArticleSettings.SyndicationLinkType.ToString()) IsNot Nothing) Then + lstSyndicationLinkMode.SelectedValue = ArticleSettings.SyndicationLinkType.ToString() + End If + + If (lstSyndicationEnclosureType.Items.FindByValue(ArticleSettings.SyndicationEnclosureType.ToString()) IsNot Nothing) Then + lstSyndicationEnclosureType.SelectedValue = ArticleSettings.SyndicationEnclosureType.ToString() + End If + + If (ArticleSettings.SyndicationSummaryLength <> Null.NullInteger) Then + txtSyndicationSummaryLength.Text = ArticleSettings.SyndicationSummaryLength.ToString() + End If + + txtSyndicationMaxCount.Text = ArticleSettings.SyndicationMaxCount.ToString() + txtSyndicationImagePath.Text = ArticleSettings.SyndicationImagePath + + End Sub + + Private Sub SaveSyndicationSettings() + + Dim objModules As New ModuleController + + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_SYNDICATION_SETTING, chkEnableSyndication.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_SYNDICATION_ENCLOSURES_SETTING, chkEnableSyndicationEnclosures.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.ENABLE_SYNDICATION_HTML_SETTING, chkEnableSyndicationHtml.Checked.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.SYNDICATION_LINK_TYPE, lstSyndicationLinkMode.SelectedValue.ToString()) + objModules.UpdateTabModuleSetting(TabModuleId, ArticleConstants.SYNDICATION_ENCLOSURE_TYPE, lstSyndicationEnclosureType.SelectedValue.ToString()) + + objModules.DeleteModuleSetting(ModuleId, ArticleConstants.SYNDICATION_SUMMARY_LENGTH) + If (txtSyndicationSummaryLength.Text <> "") Then + If (Convert.ToInt32(txtSyndicationSummaryLength.Text) > 0) Then + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SYNDICATION_SUMMARY_LENGTH, txtSyndicationSummaryLength.Text) + End If + End If + + Try + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SYNDICATION_MAX_COUNT, txtSyndicationMaxCount.Text) + Catch + End Try + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SYNDICATION_IMAGE_PATH, txtSyndicationImagePath.Text) + + End Sub + + Private Sub BindTwitterSettings() + + If (Settings.Contains(ArticleConstants.TWITTER_USERNAME)) Then + txtTwitterName.Text = Settings(ArticleConstants.TWITTER_USERNAME).ToString() + End If + + If (Settings.Contains(ArticleConstants.TWITTER_BITLY_LOGIN)) Then + txtBitLyLogin.Text = Settings(ArticleConstants.TWITTER_BITLY_LOGIN).ToString() + End If + + If (Settings.Contains(ArticleConstants.TWITTER_BITLY_API_KEY)) Then + txtBitLyAPIKey.Text = Settings(ArticleConstants.TWITTER_BITLY_API_KEY).ToString() + End If + + End Sub + + Private Sub SaveTwitterSettings() + + Dim objModules As New ModuleController + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.TWITTER_USERNAME, txtTwitterName.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.TWITTER_BITLY_LOGIN, txtBitLyLogin.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.TWITTER_BITLY_API_KEY, txtBitLyAPIKey.Text) + + End Sub + + Private Sub BindThirdPartySettings() + + chkJournalIntegration.Checked = ArticleSettings.JournalIntegration + chkJournalIntegrationGroups.Checked = ArticleSettings.JournalIntegrationGroups + + If (Settings.Contains(ArticleConstants.ACTIVE_SOCIAL_SETTING)) Then + chkActiveSocial.Checked = Convert.ToBoolean(Settings(ArticleConstants.ACTIVE_SOCIAL_SETTING).ToString()) + Else + chkActiveSocial.Checked = False + End If + + txtActiveSocialSubmissionKey.Text = ArticleSettings.ActiveSocialSubmitKey + txtActiveSocialCommentKey.Text = ArticleSettings.ActiveSocialCommentKey + txtActiveSocialRateKey.Text = ArticleSettings.ActiveSocialRateKey + + If (Settings.Contains(ArticleConstants.SMART_THINKER_STORY_FEED_SETTING)) Then + chkSmartThinkerStoryFeed.Checked = Convert.ToBoolean(Settings(ArticleConstants.SMART_THINKER_STORY_FEED_SETTING).ToString()) + Else + chkSmartThinkerStoryFeed.Checked = False + End If + + End Sub + + Private Sub SaveThirdPartySettings() + + Dim objModules As New ModuleController + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.JOURNAL_INTEGRATION_SETTING, chkJournalIntegration.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.JOURNAL_INTEGRATION_GROUPS_SETTING, chkJournalIntegrationGroups.Checked.ToString()) + + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.ACTIVE_SOCIAL_SETTING, chkActiveSocial.Checked.ToString()) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.ACTIVE_SOCIAL_SUBMIT_SETTING, txtActiveSocialSubmissionKey.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.ACTIVE_SOCIAL_COMMENT_SETTING, txtActiveSocialCommentKey.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.ACTIVE_SOCIAL_RATE_SETTING, txtActiveSocialRateKey.Text) + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.SMART_THINKER_STORY_FEED_SETTING, chkSmartThinkerStoryFeed.Checked.ToString()) + + End Sub + + Private Function IsInRole(ByVal roleName As String, ByVal roles As String()) As Boolean + + For Each role As String In roles + If (roleName = role) Then + Return True + End If + Next + + Return False + + End Function + + Private Sub PopulateAuthorList() + + ddlAuthor.DataSource = GetAuthorList(Me.ModuleId) + ddlAuthor.DataBind() + SortDropDown(ddlAuthor) + ddlAuthor.Items.Insert(0, New ListItem(Localization.GetString("SelectAuthor.Text", Me.LocalResourceFile), "-1")) + + If Not (ddlAuthor.Items.FindByValue(Me.ArticleSettings.Author.ToString()) Is Nothing) Then + ddlAuthor.SelectedValue = Me.ArticleSettings.Author.ToString() + End If + + End Sub + + Private Sub PopulateAuthorListDefault() + + drpAuthorDefault.DataSource = GetAuthorList(Me.ModuleId) + drpAuthorDefault.DataBind() + SortDropDown(drpAuthorDefault) + drpAuthorDefault.Items.Insert(0, New ListItem(Localization.GetString("NoDefault.Text", Me.LocalResourceFile), "-1")) + + If Not (drpAuthorDefault.Items.FindByValue(Me.ArticleSettings.AuthorDefault.ToString()) Is Nothing) Then + drpAuthorDefault.SelectedValue = Me.ArticleSettings.AuthorDefault.ToString() + End If + + End Sub + + Public Function GetAuthorList(ByVal moduleID As Integer) As ArrayList + + Dim moduleSettings As Hashtable = DotNetNuke.Entities.Portals.PortalSettings.GetModuleSettings(moduleID) + Dim distributionList As String = "" + Dim userList As New ArrayList + + If (moduleSettings.Contains(ArticleConstants.PERMISSION_SUBMISSION_SETTING)) Then + + Dim roles As String = moduleSettings(ArticleConstants.PERMISSION_SUBMISSION_SETTING).ToString() + Dim rolesArray() As String = roles.Split(Convert.ToChar(";")) + Dim userIDs As New Hashtable + + For Each role As String In rolesArray + If (role.Length > 0) Then + + Dim objRoleController As New DotNetNuke.Security.Roles.RoleController + Dim objRole As DotNetNuke.Security.Roles.RoleInfo = objRoleController.GetRoleByName(PortalSettings.PortalId, role) + + If Not (objRole Is Nothing) Then + Dim objUsers As ArrayList = objRoleController.GetUserRolesByRoleName(PortalSettings.PortalId, objRole.RoleName) + For Each objUser As DotNetNuke.Entities.Users.UserRoleInfo In objUsers + If (userIDs.Contains(objUser.UserID) = False) Then + Dim objUserController As DotNetNuke.Entities.Users.UserController = New DotNetNuke.Entities.Users.UserController + Dim objSelectedUser As DotNetNuke.Entities.Users.UserInfo = objUserController.GetUser(PortalSettings.PortalId, objUser.UserID) + If Not (objSelectedUser Is Nothing) Then + If (objSelectedUser.Email.Length > 0) Then + userIDs.Add(objUser.UserID, objUser.UserID) + userList.Add(objSelectedUser) + End If + End If + End If + Next + End If + End If + Next + + End If + + Return userList + + End Function + + Private Sub BindAvailableContentSharingPortals() + + drpContentSharingPortals.Items.Clear() + + Dim objContentSharingPortals As List(Of ContentSharingInfo) = GetContentSharingPortals(ArticleSettings.ContentSharingPortals) + + Dim objPortalController As New PortalController() + Dim objPortals As ArrayList = objPortalController.GetPortals() + + For Each objPortal As PortalInfo In objPortals + + If (objPortal.PortalID <> Me.PortalId) Then + + Dim objDesktopModuleController As New DesktopModuleController + Dim objDesktopModuleInfo As DesktopModuleInfo = objDesktopModuleController.GetDesktopModuleByModuleName("DnnForge - NewsArticles") + + If Not (objDesktopModuleInfo Is Nothing) Then + + Dim objTabController As New DotNetNuke.Entities.Tabs.TabController() + Dim objTabs As ArrayList = objTabController.GetTabs(objPortal.PortalID) + For Each objTab As DotNetNuke.Entities.Tabs.TabInfo In objTabs + If Not (objTab Is Nothing) Then + If (objTab.IsDeleted = False) Then + Dim objModules As New ModuleController + For Each pair As KeyValuePair(Of Integer, ModuleInfo) In objModules.GetTabModules(objTab.TabID) + Dim objModule As ModuleInfo = pair.Value + If (objModule.IsDeleted = False) Then + If (objModule.DesktopModuleID = objDesktopModuleInfo.DesktopModuleID) Then + If objModule.IsDeleted = False Then + Dim strPath As String = objTab.TabName + Dim objTabSelected As DotNetNuke.Entities.Tabs.TabInfo = objTab + While objTabSelected.ParentId <> Null.NullInteger + objTabSelected = objTabController.GetTab(objTabSelected.ParentId, objTab.PortalID, False) + If (objTabSelected Is Nothing) Then + Exit While + End If + strPath = objTabSelected.TabName & " -> " & strPath + End While + + Dim add As Boolean = True + + For Each objContentSharingPortal As ContentSharingInfo In objContentSharingPortals + If (objContentSharingPortal.LinkedModuleID = objModule.ModuleID And objContentSharingPortal.LinkedPortalID = objPortal.PortalID) Then + add = False + Exit For + End If + Next + + If (add) Then + Dim objListItem As New ListItem + objListItem.Value = objPortal.PortalID.ToString() & "-" & objTab.TabID.ToString() & "-" & objModule.ModuleID.ToString() + Dim o As New PortalAliasController + Dim aliases As ArrayList = o.GetPortalAliasArrayByPortalID(objPortal.PortalID) + If (aliases.Count > 0) Then + objListItem.Text = DotNetNuke.Common.AddHTTP(CType(aliases(0), PortalAliasInfo).HTTPAlias) & " -> " & strPath & " -> " & objModule.ModuleTitle + Else + objListItem.Text = objPortal.PortalName & " -> " & strPath & " -> " & objModule.ModuleTitle + End If + drpContentSharingPortals.Items.Add(objListItem) + End If + End If + End If + End If + Next + End If + End If + Next + + End If + + End If + + Next + + If (drpContentSharingPortals.Items.Count = 0) Then + lblContentSharingNoneAvailable.Visible = True + drpContentSharingPortals.Visible = False + cmdContentSharingAdd.Visible = False + Else + lblContentSharingNoneAvailable.Visible = False + drpContentSharingPortals.Visible = True + cmdContentSharingAdd.Visible = True + End If + + End Sub + + Private Sub BindSelectedContentSharingPortals() + + If (Page.IsPostBack = False) Then + Localization.LocalizeDataGrid(grdContentSharing, Me.LocalResourceFile) + End If + + Dim objContentSharingPortals As List(Of ContentSharingInfo) = GetContentSharingPortals(ArticleSettings.ContentSharingPortals) + + If (objContentSharingPortals.Count > 0) Then + grdContentSharing.DataSource = objContentSharingPortals + grdContentSharing.DataBind() + lblNoContentSharing.Visible = False + grdContentSharing.Visible = True + Else + lblNoContentSharing.Visible = True + grdContentSharing.Visible = False + End If + + End Sub + + Private Function GetContentSharingPortals(ByVal linkedPortals As String) As List(Of ContentSharingInfo) + + Dim objPortalController As New PortalController() + Dim objContentSharingPortals As New List(Of ContentSharingInfo) + + For Each element As String In linkedPortals.Split(","c) + + If (element.Split("-"c).Length = 3) Then + + Dim objContentSharing As New ContentSharingInfo + + objContentSharing.LinkedPortalID = Convert.ToInt32(element.Split("-")(0)) + objContentSharing.LinkedTabID = Convert.ToInt32(element.Split("-")(1)) + objContentSharing.LinkedModuleID = Convert.ToInt32(element.Split("-")(2)) + + Dim objModuleController As New ModuleController + Dim objModule As ModuleInfo = objModuleController.GetModule(objContentSharing.LinkedModuleID, objContentSharing.LinkedTabID) + + If (objModule IsNot Nothing) Then + objContentSharing.ModuleTitle = objModule.ModuleTitle + objContentSharingPortals.Add(objContentSharing) + End If + + End If + + Next + + Return objContentSharingPortals + + End Function + +#End Region + +#Region " Event Handlers " + + Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load + + Try + + If (Page.IsPostBack = False) Then + + BindCategorySortOrder() + BindDisplayTypes() + BindAuthorSelection() + BindTextEditorMode() + BindPageSize() + BindTemplates() + BindTitleReplacement() + BindTimeZone() + BindRoleGroups() + BindFolders() + BindCategories() + BindSortBy() + BindSortDirection() + BindSyndicationLinkMode() + BindSyndicationEnclosureType() + BindUrlMode() + BindMenuPositionType() + BindRelatedTypes() + BindThumbnailType() + BindWatermarkPosition() + BindSettings() + + lstDefaultCategories.Height = Unit.Parse(ArticleSettings.CategorySelectionHeight.ToString()) + lstCategories.Height = Unit.Parse(ArticleSettings.CategorySelectionHeight.ToString()) + + trAdminSettings1.Visible = Me.UserInfo.IsSuperUser + trAdminSettings2.Visible = Me.UserInfo.IsSuperUser + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdUpdate_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdUpdate.Click + + Try + + If (Page.IsValid) Then + + SaveBasicSettings() + SaveArchiveSettings() + SaveCategorySettings() + SaveCommentSettings() + SaveFilterSettings() + SaveFormSettings() + SaveImageSettings() + SaveFileSettings() + SaveNotificationSettings() + SaveRelatedSettings() + SaveSecuritySettings() + SaveSEOSettings() + SaveSyndicationSettings() + SaveTwitterSettings() + SaveThirdPartySettings() + + CategoryController.ClearCache(ModuleId) + LayoutController.ClearCache(Me) + + Response.Redirect(EditArticleUrl("AdminOptions"), True) + + End If + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdCancel_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdCancel.Click + + Try + + Response.Redirect(EditArticleUrl("AdminOptions"), True) + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub valEditorWidthIsValid_ServerValidate(ByVal source As System.Object, ByVal args As System.Web.UI.WebControls.ServerValidateEventArgs) Handles valEditorWidthIsValid.ServerValidate + + Try + + Try + Unit.Parse(txtTextEditorWidth.Text) + args.IsValid = True + Catch ex As Exception + args.IsValid = False + End Try + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub valEditorHeightIsvalid_ServerValidate(ByVal source As System.Object, ByVal args As System.Web.UI.WebControls.ServerValidateEventArgs) Handles valEditorHeightIsvalid.ServerValidate + + Try + + Try + Unit.Parse(txtTextEditorHeight.Text) + args.IsValid = True + Catch ex As Exception + args.IsValid = False + End Try + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdSelectAuthor_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdSelectAuthor.Click + + Try + + PopulateAuthorList() + ddlAuthor.Visible = True + cmdSelectAuthor.Visible = False + lblAuthorFilter.Visible = False + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub cmdSelectAuthorDefault_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdSelectAuthorDefault.Click + + Try + + PopulateAuthorListDefault() + drpAuthorDefault.Visible = True + cmdSelectAuthorDefault.Visible = False + lblAuthorDefault.Visible = False + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + + Private Sub grdBasicPermissions_ItemDataBound(ByVal sender As System.Object, ByVal e As System.Web.UI.WebControls.DataGridItemEventArgs) Handles grdBasicPermissions.ItemDataBound + + If (e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem) Then + Dim objListItem As ListItem = CType(e.Item.DataItem, ListItem) + + If Not (objListItem Is Nothing) Then + + Dim role As String = CType(e.Item.DataItem, ListItem).Value + + Dim chkSubmit As CheckBox = CType(e.Item.FindControl("chkSubmit"), CheckBox) + Dim chkSecure As CheckBox = CType(e.Item.FindControl("chkSecure"), CheckBox) + Dim chkAutoSecure As CheckBox = CType(e.Item.FindControl("chkAutoSecure"), CheckBox) + Dim chkApprove As CheckBox = CType(e.Item.FindControl("chkApprove"), CheckBox) + Dim chkAutoApproveArticle As CheckBox = CType(e.Item.FindControl("chkAutoApproveArticle"), CheckBox) + Dim chkAutoApproveComment As CheckBox = CType(e.Item.FindControl("chkAutoApproveComment"), CheckBox) + Dim chkFeature As CheckBox = CType(e.Item.FindControl("chkFeature"), CheckBox) + Dim chkAutoFeature As CheckBox = CType(e.Item.FindControl("chkAutoFeature"), CheckBox) + + If (objListItem.Value = PortalSettings.AdministratorRoleName.ToString()) Then + chkSubmit.Enabled = False + chkSubmit.Checked = True + chkSecure.Enabled = True + If (Settings.Contains(ArticleConstants.PERMISSION_SECURE_SETTING)) Then + chkSecure.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_SECURE_SETTING).ToString().Split(";"c)) + End If + chkAutoSecure.Enabled = True + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_SECURE_SETTING)) Then + chkAutoSecure.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_AUTO_SECURE_SETTING).ToString().Split(";"c)) + End If + chkApprove.Enabled = False + chkApprove.Checked = True + chkAutoApproveArticle.Enabled = True + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_APPROVAL_SETTING)) Then + chkAutoApproveArticle.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_AUTO_APPROVAL_SETTING).ToString().Split(";"c)) + End If + chkAutoApproveComment.Enabled = True + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_APPROVAL_COMMENT_SETTING)) Then + chkAutoApproveComment.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_AUTO_APPROVAL_COMMENT_SETTING).ToString().Split(";"c)) + End If + chkFeature.Enabled = False + chkFeature.Checked = True + chkAutoFeature.Enabled = True + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_FEATURE_SETTING)) Then + chkAutoFeature.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_AUTO_FEATURE_SETTING).ToString().Split(";"c)) + End If + Else + If (Settings.Contains(ArticleConstants.PERMISSION_SUBMISSION_SETTING)) Then + chkSubmit.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_SUBMISSION_SETTING).ToString().Split(";"c)) + End If + If (Settings.Contains(ArticleConstants.PERMISSION_SECURE_SETTING)) Then + chkSecure.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_SECURE_SETTING).ToString().Split(";"c)) + End If + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_SECURE_SETTING)) Then + chkAutoSecure.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_AUTO_SECURE_SETTING).ToString().Split(";"c)) + End If + If (Settings.Contains(ArticleConstants.PERMISSION_APPROVAL_SETTING)) Then + chkApprove.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_APPROVAL_SETTING).ToString().Split(";"c)) + End If + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_APPROVAL_SETTING)) Then + chkAutoApproveArticle.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_AUTO_APPROVAL_SETTING).ToString().Split(";"c)) + End If + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_APPROVAL_COMMENT_SETTING)) Then + chkAutoApproveComment.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_AUTO_APPROVAL_COMMENT_SETTING).ToString().Split(";"c)) + End If + If (Settings.Contains(ArticleConstants.PERMISSION_FEATURE_SETTING)) Then + chkFeature.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_FEATURE_SETTING).ToString().Split(";"c)) + End If + If (Settings.Contains(ArticleConstants.PERMISSION_AUTO_FEATURE_SETTING)) Then + chkAutoFeature.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_AUTO_FEATURE_SETTING).ToString().Split(";"c)) + End If + End If + + End If + + End If + + End Sub + + Private Sub grdFormPermissions_ItemDataBound(ByVal sender As System.Object, ByVal e As System.Web.UI.WebControls.DataGridItemEventArgs) Handles grdFormPermissions.ItemDataBound + + If (e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem) Then + Dim objListItem As ListItem = CType(e.Item.DataItem, ListItem) + + If Not (objListItem Is Nothing) Then + + Dim role As String = CType(e.Item.DataItem, ListItem).Value + + Dim chkCategories As CheckBox = CType(e.Item.FindControl("chkCategories"), CheckBox) + Dim chkExcerpt As CheckBox = CType(e.Item.FindControl("chkExcerpt"), CheckBox) + Dim chkImage As CheckBox = CType(e.Item.FindControl("chkImage"), CheckBox) + Dim chkFile As CheckBox = CType(e.Item.FindControl("chkFile"), CheckBox) + Dim chkLink As CheckBox = CType(e.Item.FindControl("chkLink"), CheckBox) + Dim chkPublishDate As CheckBox = CType(e.Item.FindControl("chkPublishDate"), CheckBox) + Dim chkExpiryDate As CheckBox = CType(e.Item.FindControl("chkExpiryDate"), CheckBox) + Dim chkMeta As CheckBox = CType(e.Item.FindControl("chkMeta"), CheckBox) + Dim chkCustom As CheckBox = CType(e.Item.FindControl("chkCustom"), CheckBox) + + If (Settings.Contains(ArticleConstants.PERMISSION_CATEGORIES_SETTING)) Then + chkCategories.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_CATEGORIES_SETTING).ToString().Split(";"c)) + Else + chkCategories.Checked = True + End If + If (Settings.Contains(ArticleConstants.PERMISSION_EXCERPT_SETTING)) Then + chkExcerpt.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_EXCERPT_SETTING).ToString().Split(";"c)) + Else + chkExcerpt.Checked = True + End If + If (Settings.Contains(ArticleConstants.PERMISSION_IMAGE_SETTING)) Then + chkImage.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_IMAGE_SETTING).ToString().Split(";"c)) + Else + chkImage.Checked = True + End If + If (Settings.Contains(ArticleConstants.PERMISSION_FILE_SETTING)) Then + chkFile.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_FILE_SETTING).ToString().Split(";"c)) + Else + chkFile.Checked = True + End If + If (Settings.Contains(ArticleConstants.PERMISSION_LINK_SETTING)) Then + chkLink.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_LINK_SETTING).ToString().Split(";"c)) + Else + chkLink.Checked = True + End If + If (Settings.Contains(ArticleConstants.PERMISSION_PUBLISH_SETTING)) Then + chkPublishDate.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_PUBLISH_SETTING).ToString().Split(";"c)) + Else + chkPublishDate.Checked = True + End If + If (Settings.Contains(ArticleConstants.PERMISSION_EXPIRY_SETTING)) Then + chkExpiryDate.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_EXPIRY_SETTING).ToString().Split(";"c)) + Else + chkExpiryDate.Checked = True + End If + If (Settings.Contains(ArticleConstants.PERMISSION_META_SETTING)) Then + chkMeta.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_META_SETTING).ToString().Split(";"c)) + Else + chkMeta.Checked = True + End If + If (Settings.Contains(ArticleConstants.PERMISSION_CUSTOM_SETTING)) Then + chkCustom.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_CUSTOM_SETTING).ToString().Split(";"c)) + Else + chkCustom.Checked = True + End If + + End If + + End If + + End Sub + + Private Sub grdAdminPermissions_ItemDataBound(ByVal sender As System.Object, ByVal e As System.Web.UI.WebControls.DataGridItemEventArgs) Handles grdAdminPermissions.ItemDataBound + + If (e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem) Then + Dim objListItem As ListItem = CType(e.Item.DataItem, ListItem) + + If Not (objListItem Is Nothing) Then + + Dim role As String = CType(e.Item.DataItem, ListItem).Value + + Dim chkSiteTemplates As CheckBox = CType(e.Item.FindControl("chkSiteTemplates"), CheckBox) + + If (Settings.Contains(ArticleConstants.PERMISSION_SITE_TEMPLATES_SETTING)) Then + chkSiteTemplates.Checked = IsInRole(role, Settings(ArticleConstants.PERMISSION_SITE_TEMPLATES_SETTING).ToString().Split(";"c)) + Else + chkSiteTemplates.Checked = False + End If + + End If + + End If + + End Sub + + Private Sub cmdContentSharingAdd_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdContentSharingAdd.Click + + Dim currentPortals As String = Null.NullString() + If (ArticleSettings.ContentSharingPortals = Null.NullString) Then + currentPortals = drpContentSharingPortals.SelectedValue + Else + currentPortals = ArticleSettings.ContentSharingPortals & "," & drpContentSharingPortals.SelectedValue + End If + + Dim objModules As New ModuleController + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.CONTENT_SHARING_SETTING, currentPortals) + + Settings(ArticleConstants.CONTENT_SHARING_SETTING) = currentPortals + + BindSelectedContentSharingPortals() + BindAvailableContentSharingPortals() + + End Sub + + Private Sub grdContentSharing_ItemCommand(ByVal sender As System.Object, ByVal e As System.Web.UI.WebControls.DataGridCommandEventArgs) Handles grdContentSharing.ItemCommand + + If (e.CommandName = "Delete") Then + + Dim linkedModuleID As Integer = Convert.ToInt32(e.CommandArgument) + + Dim updateSetting As String = Null.NullString() + Dim objContentSharingPortals As List(Of ContentSharingInfo) = GetContentSharingPortals(ArticleSettings.ContentSharingPortals) + + For Each objContentSharingPortal As ContentSharingInfo In objContentSharingPortals + If (objContentSharingPortal.LinkedModuleID <> linkedModuleID) Then + + If (updateSetting = "") Then + updateSetting = objContentSharingPortal.LinkedPortalID.ToString() & "-" & objContentSharingPortal.LinkedTabID.ToString() & "-" & objContentSharingPortal.LinkedModuleID.ToString() + Else + updateSetting = updateSetting & "," & objContentSharingPortal.LinkedPortalID.ToString() & "-" & objContentSharingPortal.LinkedTabID.ToString() & "-" & objContentSharingPortal.LinkedModuleID.ToString() + End If + + End If + Next + + Dim objModules As New ModuleController + objModules.UpdateModuleSetting(ModuleId, ArticleConstants.CONTENT_SHARING_SETTING, updateSetting) + + Settings(ArticleConstants.CONTENT_SHARING_SETTING) = updateSetting + + BindSelectedContentSharingPortals() + BindAvailableContentSharingPortals() + + End If + + End Sub + + Private Sub drpSecurityRoleGroups_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles drpSecurityRoleGroups.SelectedIndexChanged + + Try + + BindRoles() + + Catch exc As Exception 'Module failed to load + ProcessModuleLoadException(Me, exc) + End Try + + End Sub + +#End Region + + End Class + +End Namespace diff --git a/web.config b/web.config new file mode 100755 index 0000000..1c703c7 --- /dev/null +++ b/web.config @@ -0,0 +1,13 @@ + + + + + + + + + + + + +