// -*- Mode: C++; indent-tabs-mode: nil; tab-width: 2 -*-
/*
* Copyright (C) 2011 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* 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, see .
*
* Authored by: Neil Jagdish Patel
*/
#ifndef UNITY_MULTI_RANGE_FILTER_H
#define UNITY_MULTI_RANGE_FILTER_H
#include "Filter.h"
namespace unity
{
namespace dash
{
class MultiRangeFilter : public Filter
{
public:
typedef std::shared_ptr Ptr;
typedef std::vector Options;
MultiRangeFilter(DeeModel* model, DeeModelIter* iter);
void Clear();
nux::ROProperty options;
sigc::signal option_added;
sigc::signal option_removed;
protected:
void Update(Filter::Hints& hints);
private:
void UpdateState();
Options const& get_options() const;
int PositionOfId(std::string const& id);
void OptionChanged(bool is_active, std::string const& id);
private:
Options options_;
int left_pos_;
int right_pos_;
bool ignore_changes_;
};
}
}
#endif