-
Notifications
You must be signed in to change notification settings - Fork 1
/
Settings.ascx.cs
102 lines (91 loc) · 4.22 KB
/
Settings.ascx.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*
' Copyright (c) 2017 Risdall Marketing Group
' All rights reserved.
'
' 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.
'
*/
using System;
using DotNetNuke.Entities.Modules;
using DotNetNuke.Services.Exceptions;
namespace Risdall.Modules.DNN_AMP
{
/// -----------------------------------------------------------------------------
/// <summary>
/// The Settings class manages Module Settings
///
/// Typically your settings control would be used to manage settings for your module.
/// There are two types of settings, ModuleSettings, and TabModuleSettings.
///
/// ModuleSettings apply to all "copies" of a module on a site, no matter which page the module is on.
///
/// TabModuleSettings apply only to the current module on the current page, if you copy that module to
/// another page the settings are not transferred.
///
/// If you happen to save both TabModuleSettings and ModuleSettings, TabModuleSettings overrides ModuleSettings.
///
/// Below we have some examples of how to access these settings but you will need to uncomment to use.
///
/// Because the control inherits from DNN_AMPSettingsBase you have access to any custom properties
/// defined there, as well as properties from DNN such as PortalId, ModuleId, TabId, UserId and many more.
/// </summary>
/// -----------------------------------------------------------------------------
public partial class Settings : DNN_AMPModuleSettingsBase
{
#region Base Method Implementations
/// -----------------------------------------------------------------------------
/// <summary>
/// LoadSettings loads the settings from the Database and displays them
/// </summary>
/// -----------------------------------------------------------------------------
public override void LoadSettings()
{
try
{
if (Page.IsPostBack == false)
{
//Check for existing settings and use those on this page
//Settings["SettingName"]
/* uncomment to load saved settings in the text boxes
if(Settings.Contains("Setting1"))
txtSetting1.Text = Settings["Setting1"].ToString();
if (Settings.Contains("Setting2"))
txtSetting2.Text = Settings["Setting2"].ToString();
*/
}
}
catch (Exception exc) //Module failed to load
{
Exceptions.ProcessModuleLoadException(this, exc);
}
}
/// -----------------------------------------------------------------------------
/// <summary>
/// UpdateSettings saves the modified settings to the Database
/// </summary>
/// -----------------------------------------------------------------------------
public override void UpdateSettings()
{
try
{
var modules = new ModuleController();
//the following are two sample Module Settings, using the text boxes that are commented out in the ASCX file.
//module settings
//modules.UpdateModuleSetting(ModuleId, "Setting1", txtSetting1.Text);
//modules.UpdateModuleSetting(ModuleId, "Setting2", txtSetting2.Text);
//tab module settings
//modules.UpdateTabModuleSetting(TabModuleId, "Setting1", txtSetting1.Text);
//modules.UpdateTabModuleSetting(TabModuleId, "Setting2", txtSetting2.Text);
}
catch (Exception exc) //Module failed to load
{
Exceptions.ProcessModuleLoadException(this, exc);
}
}
#endregion
}
}