From 17b259df9cb6b28779d4881b2b6c805ee2e48eea Mon Sep 17 00:00:00 2001 From: Michele Calgaro Date: Fri, 7 Jun 2024 23:30:05 +0900 Subject: Rename to tde-ebook-reader Signed-off-by: Michele Calgaro --- .../optionsDialog/network/NetworkOptionsDialog.cpp | 104 +++++++++++++++++++++ 1 file changed, 104 insertions(+) create mode 100644 reader/src/optionsDialog/network/NetworkOptionsDialog.cpp (limited to 'reader/src/optionsDialog/network/NetworkOptionsDialog.cpp') diff --git a/reader/src/optionsDialog/network/NetworkOptionsDialog.cpp b/reader/src/optionsDialog/network/NetworkOptionsDialog.cpp new file mode 100644 index 0000000..5c39131 --- /dev/null +++ b/reader/src/optionsDialog/network/NetworkOptionsDialog.cpp @@ -0,0 +1,104 @@ +/* + * Copyright (C) 2010-2012 Geometer Plus + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + * 02110-1301, USA. + */ + +#include "NetworkOptionsDialog.h" + +#include +#include +#include + +#include +#include +#include +#include +#include + +#include "../../reader/Reader.h" + +//#include "../../network/NetworkLinkCollection.h" +//#include "../../network/NetworkLink.h" +#include "../../network/UserList.h" + + +class NetworkLinkBooleanOptionEntry : public ZLBooleanOptionEntry { + +public: + NetworkLinkBooleanOptionEntry(ZLBooleanOption &option); + bool initialState() const; + void onAccept(bool state); + +private: + ZLBooleanOption &myOption; +}; + +NetworkLinkBooleanOptionEntry::NetworkLinkBooleanOptionEntry(ZLBooleanOption &option) : myOption(option) { +} + +bool NetworkLinkBooleanOptionEntry::initialState() const { + return myOption.value(); +} + +void NetworkLinkBooleanOptionEntry::onAccept(bool state) { + bool oldState = myOption.value(); + myOption.setValue(state); + if (state != oldState) { +// Reader::Instance().invalidateNetworkView(); + } +} + + + +NetworkOptionsDialog::NetworkOptionsDialog() : AbstractOptionsDialog(ZLResourceKey("NetworkOptionsDialog"), true) { + Reader &reader = Reader::Instance(); + + ZLDialogContent &connectionTab = dialog().createTab(ZLResourceKey("Connection")); + + ZLNetworkManager &networkManager = ZLNetworkManager::Instance(); + connectionTab.addOption(ZLResourceKey("timeout"), new ZLSimpleSpinOptionEntry(networkManager.TimeoutOption(), 5)); + if (!networkManager.providesProxyInfo()) { + ZLToggleBooleanOptionEntry *useProxyEntry = new ZLToggleBooleanOptionEntry(networkManager.UseProxyOption()); + connectionTab.addOption(ZLResourceKey("useProxy"), useProxyEntry); + ZLSimpleStringOptionEntry *proxyHostEntry = new ZLSimpleStringOptionEntry(networkManager.ProxyHostOption()); + connectionTab.addOption(ZLResourceKey("proxyHost"), proxyHostEntry); + ZLSimpleStringOptionEntry *proxyPortEntry = new ZLSimpleStringOptionEntry(networkManager.ProxyPortOption()); + connectionTab.addOption(ZLResourceKey("proxyPort"), proxyPortEntry); + useProxyEntry->addDependentEntry(proxyHostEntry); + useProxyEntry->addDependentEntry(proxyPortEntry); + useProxyEntry->onStateChanged(useProxyEntry->initialState()); + } + +// ZLDialogContent &libraryTab = dialog().createTab(ZLResourceKey("NetworkLibrary")); + +// NetworkLinkCollection &linkCollection = NetworkLinkCollection::Instance(); +// const std::size_t linkCollectionSize = linkCollection.size(); +// const std::size_t linkCollectionSizeMinusOne = linkCollectionSize - 1; +// for (std::size_t i = 0; i < linkCollectionSize; ++i) { +// NetworkLink &link = linkCollection.link(i); +// if (i < linkCollectionSizeMinusOne) { +// NetworkLink &link2 = linkCollection.link(++i); +// libraryTab.addOptions(link.SiteName, "", new NetworkLinkBooleanOptionEntry(link.OnOption), +// link2.SiteName, "", new NetworkLinkBooleanOptionEntry(link2.OnOption)); +// } else { +// libraryTab.addOption(link.SiteName, "", new NetworkLinkBooleanOptionEntry(link.OnOption)); +// } +// } + + std::vector > additional; + createIntegrationTab(reader.webBrowserCollection(), ZLResourceKey("Web"), additional); +} -- cgit v1.2.3