tdesktop/Telegram/SourceFiles/boxes/edit_privacy_box.h

138 lines
3.3 KiB
C
Raw Normal View History

/*
This file is part of Telegram Desktop,
the official desktop application for the Telegram messaging service.
For license and copyright information please follow this link:
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
*/
#pragma once
2017-04-06 14:38:10 +00:00
#include "boxes/abstract_box.h"
#include "mtproto/sender.h"
#include "apiwrap.h"
namespace Calls {
enum class PeerToPeer;
} // namespace Calls
namespace Ui {
class FlatLabel;
class LinkButton;
template <typename Enum>
class RadioenumGroup;
template <typename Enum>
class Radioenum;
template <typename Widget>
2017-09-13 16:57:44 +00:00
class SlideWrap;
} // namespace Ui
class EditPrivacyBox : public BoxContent, private MTP::Sender {
public:
using Value = ApiWrap::Privacy;
using Option = Value::Option;
enum class Exception {
Always,
Never,
};
class Controller {
public:
using Key = ApiWrap::Privacy::Key;
virtual Key key() = 0;
virtual MTPInputPrivacyKey apiKey() = 0;
virtual QString title() = 0;
virtual bool hasOption(Option option) {
return true;
}
virtual QString description() = 0;
virtual QString warning() {
return QString();
}
virtual QString exceptionLinkText(Exception exception, int count) = 0;
virtual QString exceptionBoxTitle(Exception exception) = 0;
virtual QString exceptionsDescription() = 0;
virtual void confirmSave(bool someAreDisallowed, FnMut<void()> saveCallback) {
saveCallback();
}
virtual ~Controller() = default;
protected:
EditPrivacyBox *view() const {
return _view;
}
private:
void setView(EditPrivacyBox *box) {
_view = box;
}
EditPrivacyBox *_view = nullptr;
friend class EditPrivacyBox;
};
EditPrivacyBox(
QWidget*,
std::unique_ptr<Controller> controller,
rpl::producer<Value> preloaded);
protected:
void prepare() override;
int resizeGetHeight(int newWidth) override;
void resizeEvent(QResizeEvent *e) override;
private:
style::margins exceptionLinkMargins() const;
bool showExceptionLink(Exception exception) const;
void createWidgets();
QVector<MTPInputPrivacyRule> collectResult();
void dataReady(Value &&value);
int countDefaultHeight(int newWidth);
void editExceptionUsers(Exception exception);
QString exceptionLinkText(Exception exception);
std::vector<not_null<UserData*>> &exceptionUsers(Exception exception);
object_ptr<Ui::SlideWrap<Ui::LinkButton>> &exceptionLink(
Exception exception);
std::unique_ptr<Controller> _controller;
Value _value;
bool _prepared = false;
std::shared_ptr<Ui::RadioenumGroup<Option>> _optionGroup;
object_ptr<Ui::FlatLabel> _loading;
object_ptr<Ui::FlatLabel> _description = { nullptr };
object_ptr<Ui::Radioenum<Option>> _everyone = { nullptr };
object_ptr<Ui::Radioenum<Option>> _contacts = { nullptr };
object_ptr<Ui::Radioenum<Option>> _nobody = { nullptr };
object_ptr<Ui::FlatLabel> _warning = { nullptr };
object_ptr<Ui::FlatLabel> _exceptionsTitle = { nullptr };
2017-09-13 16:57:44 +00:00
object_ptr<Ui::SlideWrap<Ui::LinkButton>> _alwaysLink = { nullptr };
object_ptr<Ui::SlideWrap<Ui::LinkButton>> _neverLink = { nullptr };
object_ptr<Ui::FlatLabel> _exceptionsDescription = { nullptr };
};
class EditCallsPeerToPeer : public BoxContent {
public:
EditCallsPeerToPeer(QWidget*) {
}
protected:
void prepare() override;
private:
using PeerToPeer = Calls::PeerToPeer;
void chosen(PeerToPeer value);
std::vector<object_ptr<Ui::Radioenum<PeerToPeer>>> _options;
};