/*
* Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved
*
* Licensed under the Apache License, Version 2.0 (the License);
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
using System;
namespace ElmSharp
{
///
/// The ToolbarItem is a item of Toolbar.
///
public class ToolbarItem : ItemObject
{
string _icon;
string _text;
internal ToolbarItem(string text, string icon) : base(IntPtr.Zero)
{
_text = text;
_icon = icon;
}
///
/// Sets or gets the icon path of the item.
///
public string Icon
{
get
{
return _icon;
}
set
{
_icon = value;
Interop.Elementary.elm_toolbar_item_icon_set(Handle, value);
}
}
///
/// Sets or gets the text string of the item.
///
public string Text
{
get
{
return _text;
}
set
{
_text = value;
SetPartText(null, value);
}
}
///
/// Sets or gets the enable of the item.
///
[Obsolete("Enabled is obsolete as of version v1.1.0-beta-023. Please use IsEnabled instead.")]
public bool Enabled
{
get
{
return IsEnabled;
}
set
{
IsEnabled = value;
}
}
///
/// Sets or gets whether displaying the item as a separator.
///
/// Items aren't set as a separator by default. If set as a separator it displays a separator theme, so it won't display icons or labels.
public bool IsSeparator
{
get
{
return Interop.Elementary.elm_toolbar_item_separator_get(Handle);
}
set
{
Interop.Elementary.elm_toolbar_item_separator_set(Handle, value);
}
}
///
/// Sets or gets whether the item is selected.
///
public bool IsSelected
{
get
{
return Interop.Elementary.elm_toolbar_item_selected_get(Handle);
}
set
{
Interop.Elementary.elm_toolbar_item_selected_set(Handle, value);
}
}
///
/// Selected will be triggered when the item is selected.
///
public event EventHandler Selected;
///
/// LongPressed will be triggered when the item is pressed long time.
///
public event EventHandler LongPressed;
///
/// Clicked will be triggered when the item is clicked.
///
public event EventHandler Clicked;
internal void SendSelected()
{
Selected?.Invoke(this, EventArgs.Empty);
}
internal void SendLongPressed()
{
LongPressed?.Invoke(this, EventArgs.Empty);
}
internal void SendClicked()
{
Clicked?.Invoke(this, EventArgs.Empty);
}
}
}