summaryrefslogtreecommitdiffstats
path: root/kcontrol/konqhtml/policydlg.cpp
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commit4aed2c8219774f5d797760606b8489a92ddc5163 (patch)
tree3f8c130f7d269626bf6a9447407ef6c35954426a /kcontrol/konqhtml/policydlg.cpp
downloadtdebase-4aed2c8219774f5d797760606b8489a92ddc5163.tar.gz
tdebase-4aed2c8219774f5d797760606b8489a92ddc5163.zip
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdebase@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kcontrol/konqhtml/policydlg.cpp')
-rw-r--r--kcontrol/konqhtml/policydlg.cpp128
1 files changed, 128 insertions, 0 deletions
diff --git a/kcontrol/konqhtml/policydlg.cpp b/kcontrol/konqhtml/policydlg.cpp
new file mode 100644
index 000000000..801068d3a
--- /dev/null
+++ b/kcontrol/konqhtml/policydlg.cpp
@@ -0,0 +1,128 @@
+// (C) < 2002 to whoever created and edited this file before
+// (C) 2002 Leo Savernik <l.savernik@aon.at>
+// Generalizing the policy dialog
+
+#include <qlayout.h>
+#include <qlabel.h>
+#include <qwhatsthis.h>
+#include <qcombobox.h>
+
+#include <klocale.h>
+#include <kbuttonbox.h>
+#include <kmessagebox.h>
+
+#include <qpushbutton.h>
+
+#include "policydlg.h"
+#include "policies.h"
+
+PolicyDialog::PolicyDialog( Policies *policies, QWidget *parent, const char *name )
+ : KDialogBase(parent, name, true, QString::null, Ok|Cancel, Ok, true),
+ policies(policies)
+{
+ QFrame *main = makeMainWidget();
+
+ insertIdx = 1; // index where to insert additional panels
+ topl = new QVBoxLayout(main, 0, spacingHint());
+
+ QGridLayout *grid = new QGridLayout(topl, 2, 2);
+ grid->setColStretch(1, 1);
+
+ QLabel *l = new QLabel(i18n("&Host or domain name:"), main);
+ grid->addWidget(l, 0, 0);
+
+ le_domain = new QLineEdit(main);
+ l->setBuddy( le_domain );
+ grid->addWidget(le_domain, 0, 1);
+ connect( le_domain,SIGNAL(textChanged( const QString & )),
+ SLOT(slotTextChanged( const QString &)));
+
+ QWhatsThis::add(le_domain, i18n("Enter the name of a host (like www.kde.org) "
+ "or a domain, starting with a dot (like .kde.org or .org)") );
+
+ l_feature_policy = new QLabel(main);
+ grid->addWidget(l_feature_policy, 1, 0);
+
+ cb_feature_policy = new QComboBox(main);
+ l_feature_policy->setBuddy( cb_feature_policy );
+ policy_values << i18n("Use Global") << i18n("Accept") << i18n("Reject");
+ cb_feature_policy->insertStringList(policy_values);
+ grid->addWidget(cb_feature_policy, 1, 1);
+
+ le_domain->setFocus();
+
+ enableButtonOK(!le_domain->text().isEmpty());
+}
+
+PolicyDialog::FeatureEnabledPolicy PolicyDialog::featureEnabledPolicy() const {
+ return (FeatureEnabledPolicy)cb_feature_policy->currentItem();
+}
+
+void PolicyDialog::slotTextChanged( const QString &text)
+{
+ enableButtonOK(!text.isEmpty());
+}
+
+void PolicyDialog::setDisableEdit( bool state, const QString& text )
+{
+ le_domain->setText( text );
+
+ le_domain->setEnabled( state );
+
+ if( state )
+ cb_feature_policy->setFocus();
+}
+
+void PolicyDialog::refresh() {
+ FeatureEnabledPolicy pol;
+
+ if (policies->isFeatureEnabledPolicyInherited())
+ pol = InheritGlobal;
+ else if (policies->isFeatureEnabled())
+ pol = Accept;
+ else
+ pol = Reject;
+ cb_feature_policy->setCurrentItem(pol);
+}
+
+void PolicyDialog::setFeatureEnabledLabel(const QString &text) {
+ l_feature_policy->setText(text);
+}
+
+void PolicyDialog::setFeatureEnabledWhatsThis(const QString &text) {
+ QWhatsThis::add(cb_feature_policy, text);
+}
+
+void PolicyDialog::addPolicyPanel(QWidget *panel) {
+ topl->insertWidget(insertIdx++,panel);
+}
+
+QString PolicyDialog::featureEnabledPolicyText() const {
+ int pol = cb_feature_policy->currentItem();
+ if (pol >= 0 && pol < 3) // Keep in sync with FeatureEnabledPolicy
+ return policy_values[pol];
+ else
+ return QString::null;
+}
+
+void PolicyDialog::accept()
+{
+ if( le_domain->text().isEmpty() )
+ {
+ KMessageBox::information( 0, i18n("You must first enter a domain name.") );
+ return;
+ }
+
+ FeatureEnabledPolicy pol = (FeatureEnabledPolicy)
+ cb_feature_policy->currentItem();
+ if (pol == InheritGlobal) {
+ policies->inheritFeatureEnabledPolicy();
+ } else if (pol == Reject) {
+ policies->setFeatureEnabled(false);
+ } else {
+ policies->setFeatureEnabled(true);
+ }
+ QDialog::accept();
+}
+
+#include "policydlg.moc"