added metadata types to Advanced Search
This commit is contained in:
parent
12657e5aa7
commit
70c3d52357
20 changed files with 1048 additions and 259 deletions
|
@ -21,7 +21,7 @@
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
# Author : $Author: fgerlits $
|
# Author : $Author: fgerlits $
|
||||||
# Version : $Revision: 1.16 $
|
# Version : $Revision: 1.17 $
|
||||||
# Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/etc/Makefile.in,v $
|
# Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/etc/Makefile.in,v $
|
||||||
#
|
#
|
||||||
# @configure_input@
|
# @configure_input@
|
||||||
|
@ -115,6 +115,8 @@ WIDGETS_LIB_OBJS = ${TMP_DIR}/ImageButton.o \
|
||||||
${TMP_DIR}/CornerImages.o \
|
${TMP_DIR}/CornerImages.o \
|
||||||
${TMP_DIR}/ButtonImages.o \
|
${TMP_DIR}/ButtonImages.o \
|
||||||
${TMP_DIR}/ComboBoxText.o \
|
${TMP_DIR}/ComboBoxText.o \
|
||||||
|
${TMP_DIR}/MetadataComboBoxText.o \
|
||||||
|
${TMP_DIR}/OperatorComboBoxText.o \
|
||||||
${TMP_DIR}/Notebook.o \
|
${TMP_DIR}/Notebook.o \
|
||||||
${TMP_DIR}/WidgetFactory.o \
|
${TMP_DIR}/WidgetFactory.o \
|
||||||
${TMP_DIR}/ZebraTreeView.o \
|
${TMP_DIR}/ZebraTreeView.o \
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.3 $
|
Version : $Revision: 1.4 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/include/LiveSupport/Widgets/ComboBoxText.h,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/include/LiveSupport/Widgets/ComboBoxText.h,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -40,6 +40,9 @@
|
||||||
#include "configure.h"
|
#include "configure.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
#include <exception>
|
||||||
|
|
||||||
#include <gtkmm/label.h>
|
#include <gtkmm/label.h>
|
||||||
#include <gtkmm/menu.h>
|
#include <gtkmm/menu.h>
|
||||||
#include <gtkmm/comboboxtext.h>
|
#include <gtkmm/comboboxtext.h>
|
||||||
|
@ -64,7 +67,7 @@ using namespace LiveSupport::Core;
|
||||||
* A combo box holding text entries.
|
* A combo box holding text entries.
|
||||||
*
|
*
|
||||||
* @author $Author: fgerlits $
|
* @author $Author: fgerlits $
|
||||||
* @version $Revision: 1.3 $
|
* @version $Revision: 1.4 $
|
||||||
*/
|
*/
|
||||||
class ComboBoxText : public Gtk::ComboBoxText
|
class ComboBoxText : public Gtk::ComboBoxText
|
||||||
{
|
{
|
||||||
|
@ -114,10 +117,21 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
*/
|
*/
|
||||||
Glib::RefPtr<Gdk::Pixbuf> rightImage;
|
Glib::RefPtr<Gdk::Pixbuf> rightImage;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A map type for storing { text, key } pairs.
|
||||||
|
*/
|
||||||
|
typedef std::map<const Glib::ustring, Ptr<const Glib::ustring>::Ref>
|
||||||
|
KeyMapType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A map containing { text, key } pairs.
|
||||||
|
*/
|
||||||
|
KeyMapType keyMap;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default constructor.
|
* Default constructor.
|
||||||
*/
|
*/
|
||||||
ComboBoxText(void) throw ()
|
ComboBoxText(void) throw ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -131,7 +145,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
void
|
void
|
||||||
onMenuPosition(int & x,
|
onMenuPosition(int & x,
|
||||||
int & y,
|
int & y,
|
||||||
bool & pushIn) throw ();
|
bool & pushIn) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Event handler for the combo box being clicked.
|
* Event handler for the combo box being clicked.
|
||||||
|
@ -140,13 +154,13 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* @return true if the the event was handled, false otherwise.
|
* @return true if the the event was handled, false otherwise.
|
||||||
*/
|
*/
|
||||||
bool
|
bool
|
||||||
onBoxClicked(GdkEventButton * event) throw ();
|
onBoxClicked(GdkEventButton * event) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Event handler for the menu item selected.
|
* Event handler for the menu item selected.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
onMenuItemSelected(void) throw ();
|
onMenuItemSelected(void) throw ();
|
||||||
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -158,7 +172,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
*/
|
*/
|
||||||
virtual void
|
virtual void
|
||||||
on_size_request(Gtk::Requisition* requisition)
|
on_size_request(Gtk::Requisition* requisition)
|
||||||
throw ();
|
throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the size allocate event.
|
* Handle the size allocate event.
|
||||||
|
@ -167,31 +181,31 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
*/
|
*/
|
||||||
virtual void
|
virtual void
|
||||||
on_size_allocate(Gtk::Allocation& allocation)
|
on_size_allocate(Gtk::Allocation& allocation)
|
||||||
throw ();
|
throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the map event.
|
* Handle the map event.
|
||||||
*/
|
*/
|
||||||
virtual void
|
virtual void
|
||||||
on_map() throw ();
|
on_map() throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the unmap event.
|
* Handle the unmap event.
|
||||||
*/
|
*/
|
||||||
virtual void
|
virtual void
|
||||||
on_unmap() throw ();
|
on_unmap() throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the realize event.
|
* Handle the realize event.
|
||||||
*/
|
*/
|
||||||
virtual void
|
virtual void
|
||||||
on_realize() throw ();
|
on_realize() throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the unrealize event.
|
* Handle the unrealize event.
|
||||||
*/
|
*/
|
||||||
virtual void
|
virtual void
|
||||||
on_unrealize() throw ();
|
on_unrealize() throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the expose event.
|
* Handle the expose event.
|
||||||
|
@ -200,7 +214,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* @return true if something was drawn (?)
|
* @return true if something was drawn (?)
|
||||||
*/
|
*/
|
||||||
virtual bool
|
virtual bool
|
||||||
on_expose_event(GdkEventExpose* event) throw ();
|
on_expose_event(GdkEventExpose* event) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Execute a function on all children of this container.
|
* Execute a function on all children of this container.
|
||||||
|
@ -214,7 +228,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
forall_vfunc(gboolean includeInternals,
|
forall_vfunc(gboolean includeInternals,
|
||||||
GtkCallback callback,
|
GtkCallback callback,
|
||||||
gpointer callbackData)
|
gpointer callbackData)
|
||||||
throw ();
|
throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the add event.
|
* Handle the add event.
|
||||||
|
@ -222,7 +236,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* @param child the child being added to the widget.
|
* @param child the child being added to the widget.
|
||||||
*/
|
*/
|
||||||
virtual void
|
virtual void
|
||||||
on_add(Gtk::Widget* child) throw ();
|
on_add(Gtk::Widget* child) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the remove event.
|
* Handle the remove event.
|
||||||
|
@ -230,7 +244,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* @param child the child to remove from the widget.
|
* @param child the child to remove from the widget.
|
||||||
*/
|
*/
|
||||||
virtual void
|
virtual void
|
||||||
on_remove(Gtk::Widget* child) throw ();
|
on_remove(Gtk::Widget* child) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tell what kind of children this container accepts.
|
* Tell what kind of children this container accepts.
|
||||||
|
@ -238,7 +252,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* @return the type of children this container accepts.
|
* @return the type of children this container accepts.
|
||||||
*/
|
*/
|
||||||
virtual GtkType
|
virtual GtkType
|
||||||
child_type_vfunc() const throw ();
|
child_type_vfunc() const throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A signal object to notify people that the selection has changed.
|
* A signal object to notify people that the selection has changed.
|
||||||
|
@ -262,7 +276,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* A virtual destructor.
|
* A virtual destructor.
|
||||||
*/
|
*/
|
||||||
virtual
|
virtual
|
||||||
~ComboBoxText(void) throw ();
|
~ComboBoxText(void) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Append a new text entry to the combo box menu.
|
* Append a new text entry to the combo box menu.
|
||||||
|
@ -270,7 +284,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* @param text the text entry to append.
|
* @param text the text entry to append.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
append_text(const Glib::ustring &text) throw ();
|
append_text(const Glib::ustring &text) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the active text.
|
* Return the active text.
|
||||||
|
@ -278,7 +292,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* @return the active text of the combo box.
|
* @return the active text of the combo box.
|
||||||
*/
|
*/
|
||||||
Glib::ustring
|
Glib::ustring
|
||||||
get_active_text(void) const throw ();
|
get_active_text(void) const throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Insert a new text entry at a given position.
|
* Insert a new text entry at a given position.
|
||||||
|
@ -288,7 +302,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
insert_text(int position,
|
insert_text(int position,
|
||||||
const Glib::ustring & text) throw ();
|
const Glib::ustring & text) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the active text.
|
* Set the active text.
|
||||||
|
@ -296,7 +310,37 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* @param text the text to select as active.
|
* @param text the text to select as active.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
set_active_text(const Glib::ustring & text) throw ();
|
set_active_text(const Glib::ustring & text) throw ();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the active text.
|
||||||
|
*
|
||||||
|
* @param index the number of the menu item to select as active.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
set_active(int index) throw ();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a new entry, together with an (invisible) key.
|
||||||
|
*
|
||||||
|
* @param text the text to be displayed
|
||||||
|
* @param key the key corresponding to this text
|
||||||
|
* @see getActiveKey()
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
appendPair(Ptr<const Glib::ustring>::Ref text,
|
||||||
|
Ptr<const Glib::ustring>::Ref key)
|
||||||
|
throw ();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the key corresponding to the selected item.
|
||||||
|
*
|
||||||
|
* @return the key corresponding to the currently active (selected)
|
||||||
|
* text
|
||||||
|
*/
|
||||||
|
Ptr<const Glib::ustring>::Ref
|
||||||
|
getActiveKey(void) throw (std::logic_error);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Accessor for the selectionChanged signal.
|
* Accessor for the selectionChanged signal.
|
||||||
|
@ -310,8 +354,7 @@ class ComboBoxText : public Gtk::ComboBoxText
|
||||||
* @return the signal object (a protected member of this class)
|
* @return the signal object (a protected member of this class)
|
||||||
*/
|
*/
|
||||||
sigc::signal<void>
|
sigc::signal<void>
|
||||||
signalSelectionChanged(void) throw ();
|
signalSelectionChanged(void) throw ();
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,97 @@
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Copyright (c) 2004 Media Development Loan Fund
|
||||||
|
|
||||||
|
This file is part of the LiveSupport project.
|
||||||
|
http://livesupport.campware.org/
|
||||||
|
To report bugs, send an e-mail to bugs@campware.org
|
||||||
|
|
||||||
|
LiveSupport 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.
|
||||||
|
|
||||||
|
LiveSupport 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 LiveSupport; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
|
||||||
|
Author : $Author: fgerlits $
|
||||||
|
Version : $Revision: 1.1 $
|
||||||
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/include/LiveSupport/Widgets/MetadataComboBoxText.h,v $
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------*/
|
||||||
|
#ifndef LiveSupport_Widgets_MetadataComboBoxText_h
|
||||||
|
#define LiveSupport_Widgets_MetadataComboBoxText_h
|
||||||
|
|
||||||
|
#ifndef __cplusplus
|
||||||
|
#error This is a C++ include file
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* ============================================================ include files */
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "configure.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "LiveSupport/Core/MetadataTypeContainer.h"
|
||||||
|
#include "LiveSupport/Widgets/ComboBoxText.h"
|
||||||
|
|
||||||
|
|
||||||
|
namespace LiveSupport {
|
||||||
|
namespace Widgets {
|
||||||
|
|
||||||
|
using namespace LiveSupport::Core;
|
||||||
|
|
||||||
|
/* ================================================================ constants */
|
||||||
|
|
||||||
|
|
||||||
|
/* =================================================================== macros */
|
||||||
|
|
||||||
|
|
||||||
|
/* =============================================================== data types */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A combo box holding all possible metadata type entries.
|
||||||
|
*
|
||||||
|
* @author $Author: fgerlits $
|
||||||
|
* @version $Revision: 1.1 $
|
||||||
|
*/
|
||||||
|
class MetadataComboBoxText : public ComboBoxText
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
MetadataComboBoxText(Glib::RefPtr<Gdk::Pixbuf> leftImage,
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> centerImage,
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> rightImage,
|
||||||
|
Ptr<MetadataTypeContainer>::Ref metadataTypes)
|
||||||
|
throw ();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A virtual destructor.
|
||||||
|
*/
|
||||||
|
virtual
|
||||||
|
~MetadataComboBoxText(void) throw ();
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* ================================================= external data structures */
|
||||||
|
|
||||||
|
|
||||||
|
/* ====================================================== function prototypes */
|
||||||
|
|
||||||
|
|
||||||
|
} // namespace Widgets
|
||||||
|
} // namespace LiveSupport
|
||||||
|
|
||||||
|
#endif // LiveSupport_Widgets_MetadataComboBoxText_h
|
||||||
|
|
|
@ -0,0 +1,98 @@
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Copyright (c) 2004 Media Development Loan Fund
|
||||||
|
|
||||||
|
This file is part of the LiveSupport project.
|
||||||
|
http://livesupport.campware.org/
|
||||||
|
To report bugs, send an e-mail to bugs@campware.org
|
||||||
|
|
||||||
|
LiveSupport 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.
|
||||||
|
|
||||||
|
LiveSupport 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 LiveSupport; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
|
||||||
|
Author : $Author: fgerlits $
|
||||||
|
Version : $Revision: 1.1 $
|
||||||
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/include/LiveSupport/Widgets/OperatorComboBoxText.h,v $
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------*/
|
||||||
|
#ifndef LiveSupport_Widgets_OperatorComboBoxText_h
|
||||||
|
#define LiveSupport_Widgets_OperatorComboBoxText_h
|
||||||
|
|
||||||
|
#ifndef __cplusplus
|
||||||
|
#error This is a C++ include file
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* ============================================================ include files */
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "configure.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "LiveSupport/Core/LocalizedObject.h"
|
||||||
|
#include "LiveSupport/Widgets/ComboBoxText.h"
|
||||||
|
|
||||||
|
|
||||||
|
namespace LiveSupport {
|
||||||
|
namespace Widgets {
|
||||||
|
|
||||||
|
using namespace LiveSupport::Core;
|
||||||
|
|
||||||
|
/* ================================================================ constants */
|
||||||
|
|
||||||
|
|
||||||
|
/* =================================================================== macros */
|
||||||
|
|
||||||
|
|
||||||
|
/* =============================================================== data types */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A combo box holding all possible search operator entries.
|
||||||
|
*
|
||||||
|
* @author $Author: fgerlits $
|
||||||
|
* @version $Revision: 1.1 $
|
||||||
|
*/
|
||||||
|
class OperatorComboBoxText : public ComboBoxText,
|
||||||
|
public LocalizedObject
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
OperatorComboBoxText(Glib::RefPtr<Gdk::Pixbuf> leftImage,
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> centerImage,
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> rightImage,
|
||||||
|
Ptr<ResourceBundle>::Ref bundle)
|
||||||
|
throw ();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A virtual destructor.
|
||||||
|
*/
|
||||||
|
virtual
|
||||||
|
~OperatorComboBoxText(void) throw ();
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* ================================================= external data structures */
|
||||||
|
|
||||||
|
|
||||||
|
/* ====================================================== function prototypes */
|
||||||
|
|
||||||
|
|
||||||
|
} // namespace Widgets
|
||||||
|
} // namespace LiveSupport
|
||||||
|
|
||||||
|
#endif // LiveSupport_Widgets_OperatorComboBoxText_h
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.21 $
|
Version : $Revision: 1.22 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/include/LiveSupport/Widgets/WidgetFactory.h,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/include/LiveSupport/Widgets/WidgetFactory.h,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -44,12 +44,15 @@
|
||||||
#include <gtkmm/image.h>
|
#include <gtkmm/image.h>
|
||||||
|
|
||||||
#include "LiveSupport/Core/Configurable.h"
|
#include "LiveSupport/Core/Configurable.h"
|
||||||
|
#include "LiveSupport/Core/MetadataTypeContainer.h"
|
||||||
|
|
||||||
#include "LiveSupport/Widgets/CornerImages.h"
|
#include "LiveSupport/Widgets/CornerImages.h"
|
||||||
#include "LiveSupport/Widgets/ButtonImages.h"
|
#include "LiveSupport/Widgets/ButtonImages.h"
|
||||||
#include "LiveSupport/Widgets/Button.h"
|
#include "LiveSupport/Widgets/Button.h"
|
||||||
#include "LiveSupport/Widgets/ImageButton.h"
|
#include "LiveSupport/Widgets/ImageButton.h"
|
||||||
#include "LiveSupport/Widgets/ComboBoxText.h"
|
#include "LiveSupport/Widgets/ComboBoxText.h"
|
||||||
|
#include "LiveSupport/Widgets/MetadataComboBoxText.h"
|
||||||
|
#include "LiveSupport/Widgets/OperatorComboBoxText.h"
|
||||||
#include "LiveSupport/Widgets/BlueBin.h"
|
#include "LiveSupport/Widgets/BlueBin.h"
|
||||||
#include "LiveSupport/Widgets/EntryBin.h"
|
#include "LiveSupport/Widgets/EntryBin.h"
|
||||||
|
|
||||||
|
@ -89,7 +92,7 @@ class ZebraTreeView;
|
||||||
* </code></pre>
|
* </code></pre>
|
||||||
*
|
*
|
||||||
* @author $Author: fgerlits $
|
* @author $Author: fgerlits $
|
||||||
* @version $Revision: 1.21 $
|
* @version $Revision: 1.22 $
|
||||||
*/
|
*/
|
||||||
class WidgetFactory :
|
class WidgetFactory :
|
||||||
virtual public Configurable
|
virtual public Configurable
|
||||||
|
@ -186,7 +189,7 @@ class WidgetFactory :
|
||||||
/**
|
/**
|
||||||
* The default constructor.
|
* The default constructor.
|
||||||
*/
|
*/
|
||||||
WidgetFactory(void) throw ()
|
WidgetFactory(void) throw ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -207,7 +210,7 @@ class WidgetFactory :
|
||||||
* A virtual destructor, as this class has virtual functions.
|
* A virtual destructor, as this class has virtual functions.
|
||||||
*/
|
*/
|
||||||
virtual
|
virtual
|
||||||
~WidgetFactory(void) throw ()
|
~WidgetFactory(void) throw ()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -218,7 +221,7 @@ class WidgetFactory :
|
||||||
* @return the name of the expected XML configuration element.
|
* @return the name of the expected XML configuration element.
|
||||||
*/
|
*/
|
||||||
static const std::string
|
static const std::string
|
||||||
getConfigElementName(void) throw ()
|
getConfigElementName(void) throw ()
|
||||||
{
|
{
|
||||||
return configElementNameStr;
|
return configElementNameStr;
|
||||||
}
|
}
|
||||||
|
@ -229,7 +232,7 @@ class WidgetFactory :
|
||||||
* @return the singleton instance of this object.
|
* @return the singleton instance of this object.
|
||||||
*/
|
*/
|
||||||
static Ptr<WidgetFactory>::Ref
|
static Ptr<WidgetFactory>::Ref
|
||||||
getInstance() throw ();
|
getInstance() throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Configure the object based on the XML element supplied.
|
* Configure the object based on the XML element supplied.
|
||||||
|
@ -268,17 +271,43 @@ class WidgetFactory :
|
||||||
* @return a button of the requested type, or 0
|
* @return a button of the requested type, or 0
|
||||||
*/
|
*/
|
||||||
ImageButton *
|
ImageButton *
|
||||||
createButton(ImageButtonType type) throw ();
|
createButton(ImageButtonType type) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a combo box, that holds text entries.
|
* Create a combo box that holds text entries.
|
||||||
* It is the reponsibility of the caller to dispose of the created
|
* It is the reponsibility of the caller to dispose of the created
|
||||||
* object properly.
|
* object properly.
|
||||||
*
|
*
|
||||||
* @return a combo box, that holds text entries.
|
* @return a combo box, that holds text entries.
|
||||||
*/
|
*/
|
||||||
ComboBoxText *
|
ComboBoxText *
|
||||||
createComboBoxText(void) throw ();
|
createComboBoxText(void) throw ();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a metadata combo box that holds metadata types.
|
||||||
|
* It is the reponsibility of the caller to dispose of the created
|
||||||
|
* object properly.
|
||||||
|
*
|
||||||
|
* @param metadataTypes a container of metadata types to display.
|
||||||
|
* @return a combo box, that holds metadata types.
|
||||||
|
*/
|
||||||
|
MetadataComboBoxText *
|
||||||
|
createMetadataComboBoxText(
|
||||||
|
Ptr<MetadataTypeContainer>::Ref metadataTypes)
|
||||||
|
throw ();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a combo box that holds comparison operators.
|
||||||
|
* It is the reponsibility of the caller to dispose of the created
|
||||||
|
* object properly.
|
||||||
|
*
|
||||||
|
* @param bundle a localization bundle.
|
||||||
|
* @return a combo box, that holds comparison operators.
|
||||||
|
*/
|
||||||
|
OperatorComboBoxText *
|
||||||
|
createOperatorComboBoxText(
|
||||||
|
Ptr<ResourceBundle>::Ref bundle)
|
||||||
|
throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create and return a blue singular container.
|
* Create and return a blue singular container.
|
||||||
|
@ -288,7 +317,7 @@ class WidgetFactory :
|
||||||
* @return a blue singular container.
|
* @return a blue singular container.
|
||||||
*/
|
*/
|
||||||
BlueBin *
|
BlueBin *
|
||||||
createBlueBin(void) throw ();
|
createBlueBin(void) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create and return a dark blue singular container.
|
* Create and return a dark blue singular container.
|
||||||
|
@ -298,7 +327,7 @@ class WidgetFactory :
|
||||||
* @return a dark blue singular container.
|
* @return a dark blue singular container.
|
||||||
*/
|
*/
|
||||||
BlueBin *
|
BlueBin *
|
||||||
createDarkBlueBin(void) throw ();
|
createDarkBlueBin(void) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create and return a singular container holding a text entry.
|
* Create and return a singular container holding a text entry.
|
||||||
|
@ -308,7 +337,7 @@ class WidgetFactory :
|
||||||
* @return a singular container holding a text entry.
|
* @return a singular container holding a text entry.
|
||||||
*/
|
*/
|
||||||
EntryBin *
|
EntryBin *
|
||||||
createEntryBin(void) throw ();
|
createEntryBin(void) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the images for the white window.
|
* Return the images for the white window.
|
||||||
|
@ -316,7 +345,7 @@ class WidgetFactory :
|
||||||
* @return the corner images for the white window.
|
* @return the corner images for the white window.
|
||||||
*/
|
*/
|
||||||
Ptr<CornerImages>::Ref
|
Ptr<CornerImages>::Ref
|
||||||
getWhiteWindowCorners(void) throw ()
|
getWhiteWindowCorners(void) throw ()
|
||||||
{
|
{
|
||||||
return whiteWindowImages;
|
return whiteWindowImages;
|
||||||
}
|
}
|
||||||
|
@ -329,7 +358,7 @@ class WidgetFactory :
|
||||||
* @return the container holding the requested image.
|
* @return the container holding the requested image.
|
||||||
*/
|
*/
|
||||||
Gtk::Image *
|
Gtk::Image *
|
||||||
createImage(ImageType imageName) throw ();
|
createImage(ImageType imageName) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create and return a ZebraTreeView instance.
|
* Create and return a ZebraTreeView instance.
|
||||||
|
@ -340,7 +369,7 @@ class WidgetFactory :
|
||||||
*/
|
*/
|
||||||
ZebraTreeView *
|
ZebraTreeView *
|
||||||
createTreeView(Glib::RefPtr<Gtk::TreeModel> treeModel)
|
createTreeView(Glib::RefPtr<Gtk::TreeModel> treeModel)
|
||||||
throw ();
|
throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a window with a single line of text, and an OK button.
|
* Create a window with a single line of text, and an OK button.
|
||||||
|
@ -351,7 +380,7 @@ class WidgetFactory :
|
||||||
* @param message the message to include in the window.
|
* @param message the message to include in the window.
|
||||||
*/
|
*/
|
||||||
WhiteWindow *
|
WhiteWindow *
|
||||||
createMessageWindow(Ptr<Glib::ustring>::Ref message) throw ();
|
createMessageWindow(Ptr<Glib::ustring>::Ref message) throw ();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.5 $
|
Version : $Revision: 1.6 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/src/ComboBoxText.cxx,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/src/ComboBoxText.cxx,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -450,6 +450,44 @@ ComboBoxText :: set_active_text(const Glib::ustring & text) throw ()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
* Set the first item in the combo box to be the active text.
|
||||||
|
*----------------------------------------------------------------------------*/
|
||||||
|
void
|
||||||
|
ComboBoxText :: set_active(int index) throw ()
|
||||||
|
{
|
||||||
|
menu->set_active(index);
|
||||||
|
onMenuItemSelected();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
* Add a new entry, together with an (invisible) key.
|
||||||
|
*----------------------------------------------------------------------------*/
|
||||||
|
void
|
||||||
|
ComboBoxText :: appendPair(Ptr<const Glib::ustring>::Ref text,
|
||||||
|
Ptr<const Glib::ustring>::Ref key) throw ()
|
||||||
|
{
|
||||||
|
append_text(*text);
|
||||||
|
keyMap[*text] = key;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
* Get the key corresponding to the selected item.
|
||||||
|
*----------------------------------------------------------------------------*/
|
||||||
|
Ptr<const Glib::ustring>::Ref
|
||||||
|
ComboBoxText :: getActiveKey(void) throw (std::logic_error)
|
||||||
|
{
|
||||||
|
KeyMapType::const_iterator it = keyMap.find(get_active_text());
|
||||||
|
if (it != keyMap.end()) {
|
||||||
|
return it->second;
|
||||||
|
} else {
|
||||||
|
throw std::logic_error("no active key found in OperatorComboBoxText");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*------------------------------------------------------------------------------
|
/*------------------------------------------------------------------------------
|
||||||
* Accessor for the selectionChanged signal.
|
* Accessor for the selectionChanged signal.
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
|
|
79
livesupport/modules/widgets/src/MetadataComboBoxText.cxx
Normal file
79
livesupport/modules/widgets/src/MetadataComboBoxText.cxx
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Copyright (c) 2004 Media Development Loan Fund
|
||||||
|
|
||||||
|
This file is part of the LiveSupport project.
|
||||||
|
http://livesupport.campware.org/
|
||||||
|
To report bugs, send an e-mail to bugs@campware.org
|
||||||
|
|
||||||
|
LiveSupport 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.
|
||||||
|
|
||||||
|
LiveSupport 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 LiveSupport; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
|
||||||
|
Author : $Author: fgerlits $
|
||||||
|
Version : $Revision: 1.1 $
|
||||||
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/src/MetadataComboBoxText.cxx,v $
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* ============================================================ include files */
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "configure.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "LiveSupport/Widgets/MetadataComboBoxText.h"
|
||||||
|
|
||||||
|
|
||||||
|
using namespace LiveSupport::Core;
|
||||||
|
using namespace LiveSupport::Widgets;
|
||||||
|
|
||||||
|
/* =================================================== local data structures */
|
||||||
|
|
||||||
|
|
||||||
|
/* ================================================ local constants & macros */
|
||||||
|
|
||||||
|
|
||||||
|
/* =============================================== local function prototypes */
|
||||||
|
|
||||||
|
|
||||||
|
/* ============================================================= module code */
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
* Constructor.
|
||||||
|
*----------------------------------------------------------------------------*/
|
||||||
|
MetadataComboBoxText :: MetadataComboBoxText(
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> leftImage,
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> centerImage,
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> rightImage,
|
||||||
|
Ptr<MetadataTypeContainer>::Ref metadataTypes)
|
||||||
|
throw ()
|
||||||
|
: ComboBoxText(leftImage, centerImage, rightImage)
|
||||||
|
{
|
||||||
|
MetadataTypeContainer::Vector::const_iterator it;
|
||||||
|
for (it = metadataTypes->begin(); it != metadataTypes->end(); ++it) {
|
||||||
|
Ptr<const MetadataType>::Ref metadata = *it;
|
||||||
|
appendPair(metadata->getLocalizedName(), metadata->getDcName());
|
||||||
|
}
|
||||||
|
set_active(0); // select the first item
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
* Destructor.
|
||||||
|
*----------------------------------------------------------------------------*/
|
||||||
|
MetadataComboBoxText :: ~MetadataComboBoxText(void) throw ()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
85
livesupport/modules/widgets/src/OperatorComboBoxText.cxx
Normal file
85
livesupport/modules/widgets/src/OperatorComboBoxText.cxx
Normal file
|
@ -0,0 +1,85 @@
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Copyright (c) 2004 Media Development Loan Fund
|
||||||
|
|
||||||
|
This file is part of the LiveSupport project.
|
||||||
|
http://livesupport.campware.org/
|
||||||
|
To report bugs, send an e-mail to bugs@campware.org
|
||||||
|
|
||||||
|
LiveSupport 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.
|
||||||
|
|
||||||
|
LiveSupport 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 LiveSupport; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
|
||||||
|
Author : $Author: fgerlits $
|
||||||
|
Version : $Revision: 1.1 $
|
||||||
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/src/OperatorComboBoxText.cxx,v $
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* ============================================================ include files */
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "configure.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "LiveSupport/Widgets/OperatorComboBoxText.h"
|
||||||
|
|
||||||
|
|
||||||
|
using namespace LiveSupport::Core;
|
||||||
|
using namespace LiveSupport::Widgets;
|
||||||
|
|
||||||
|
/* =================================================== local data structures */
|
||||||
|
|
||||||
|
|
||||||
|
/* ================================================ local constants & macros */
|
||||||
|
|
||||||
|
|
||||||
|
/* =============================================== local function prototypes */
|
||||||
|
|
||||||
|
|
||||||
|
/* ============================================================= module code */
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
* Constructor.
|
||||||
|
*----------------------------------------------------------------------------*/
|
||||||
|
OperatorComboBoxText :: OperatorComboBoxText(
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> leftImage,
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> centerImage,
|
||||||
|
Glib::RefPtr<Gdk::Pixbuf> rightImage,
|
||||||
|
Ptr<ResourceBundle>::Ref bundle)
|
||||||
|
throw ()
|
||||||
|
: ComboBoxText(leftImage, centerImage, rightImage),
|
||||||
|
LocalizedObject(bundle)
|
||||||
|
{
|
||||||
|
appendPair(getResourceUstring("partialOperatorDisplay"),
|
||||||
|
getResourceUstring("partialOperatorSearchKey"));
|
||||||
|
appendPair(getResourceUstring("prefixOperatorDisplay"),
|
||||||
|
getResourceUstring("prefixOperatorSearchKey"));
|
||||||
|
appendPair(getResourceUstring("=OperatorDisplay"),
|
||||||
|
getResourceUstring("=OperatorSearchKey"));
|
||||||
|
appendPair(getResourceUstring("<=OperatorDisplay"),
|
||||||
|
getResourceUstring("<=OperatorSearchKey"));
|
||||||
|
appendPair(getResourceUstring(">=OperatorDisplay"),
|
||||||
|
getResourceUstring(">=OperatorSearchKey"));
|
||||||
|
set_active(0); // select the first item
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
* Destructor.
|
||||||
|
*----------------------------------------------------------------------------*/
|
||||||
|
OperatorComboBoxText :: ~OperatorComboBoxText(void) throw ()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.23 $
|
Version : $Revision: 1.24 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/src/WidgetFactory.cxx,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/widgets/src/WidgetFactory.cxx,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -33,6 +33,7 @@
|
||||||
#include "configure.h"
|
#include "configure.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <unicode/resbund.h>
|
||||||
#include <gtkmm/entry.h>
|
#include <gtkmm/entry.h>
|
||||||
|
|
||||||
#include "LiveSupport/Widgets/Colors.h"
|
#include "LiveSupport/Widgets/Colors.h"
|
||||||
|
@ -283,7 +284,7 @@ static const std::string schedulerWindowTitleImageName
|
||||||
* Return the singleton instance to WidgetFactory
|
* Return the singleton instance to WidgetFactory
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
Ptr<WidgetFactory>::Ref
|
Ptr<WidgetFactory>::Ref
|
||||||
WidgetFactory :: getInstance(void) throw ()
|
WidgetFactory :: getInstance(void) throw ()
|
||||||
{
|
{
|
||||||
if (!singleton.get()) {
|
if (!singleton.get()) {
|
||||||
singleton.reset(new WidgetFactory());
|
singleton.reset(new WidgetFactory());
|
||||||
|
@ -355,7 +356,7 @@ WidgetFactory :: loadImage(const std::string imageName)
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
Button *
|
Button *
|
||||||
WidgetFactory :: createButton(const Glib::ustring & label,
|
WidgetFactory :: createButton(const Glib::ustring & label,
|
||||||
ButtonType type) throw ()
|
ButtonType type) throw ()
|
||||||
{
|
{
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case pushButton:
|
case pushButton:
|
||||||
|
@ -374,7 +375,7 @@ WidgetFactory :: createButton(const Glib::ustring & label,
|
||||||
* Create a combo box
|
* Create a combo box
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
ComboBoxText *
|
ComboBoxText *
|
||||||
WidgetFactory :: createComboBoxText(void) throw ()
|
WidgetFactory :: createComboBoxText(void) throw ()
|
||||||
{
|
{
|
||||||
return new ComboBoxText(comboBoxLeftImage,
|
return new ComboBoxText(comboBoxLeftImage,
|
||||||
comboBoxCenterImage,
|
comboBoxCenterImage,
|
||||||
|
@ -382,11 +383,41 @@ WidgetFactory :: createComboBoxText(void) throw ()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
* Create a metadata combo box
|
||||||
|
*----------------------------------------------------------------------------*/
|
||||||
|
MetadataComboBoxText *
|
||||||
|
WidgetFactory :: createMetadataComboBoxText(
|
||||||
|
Ptr<MetadataTypeContainer>::Ref metadataTypes)
|
||||||
|
throw ()
|
||||||
|
{
|
||||||
|
return new MetadataComboBoxText(comboBoxLeftImage,
|
||||||
|
comboBoxCenterImage,
|
||||||
|
comboBoxRightImage,
|
||||||
|
metadataTypes);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------------
|
||||||
|
* Create a comparison operator combo box
|
||||||
|
*----------------------------------------------------------------------------*/
|
||||||
|
OperatorComboBoxText *
|
||||||
|
WidgetFactory :: createOperatorComboBoxText(
|
||||||
|
Ptr<ResourceBundle>::Ref bundle)
|
||||||
|
throw ()
|
||||||
|
{
|
||||||
|
return new OperatorComboBoxText(comboBoxLeftImage,
|
||||||
|
comboBoxCenterImage,
|
||||||
|
comboBoxRightImage,
|
||||||
|
bundle);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*------------------------------------------------------------------------------
|
/*------------------------------------------------------------------------------
|
||||||
* Create a blue bin
|
* Create a blue bin
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
BlueBin *
|
BlueBin *
|
||||||
WidgetFactory :: createBlueBin(void) throw ()
|
WidgetFactory :: createBlueBin(void) throw ()
|
||||||
{
|
{
|
||||||
return new BlueBin(Colors::LightBlue, blueBinImages);
|
return new BlueBin(Colors::LightBlue, blueBinImages);
|
||||||
}
|
}
|
||||||
|
@ -396,7 +427,7 @@ WidgetFactory :: createBlueBin(void) throw ()
|
||||||
* Create a dark blue bin
|
* Create a dark blue bin
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
BlueBin *
|
BlueBin *
|
||||||
WidgetFactory :: createDarkBlueBin(void) throw ()
|
WidgetFactory :: createDarkBlueBin(void) throw ()
|
||||||
{
|
{
|
||||||
return new BlueBin(Colors::MasterPanelCenterBlue, darkBlueBinImages);
|
return new BlueBin(Colors::MasterPanelCenterBlue, darkBlueBinImages);
|
||||||
}
|
}
|
||||||
|
@ -406,7 +437,7 @@ WidgetFactory :: createDarkBlueBin(void) throw ()
|
||||||
* Create an entry bin
|
* Create an entry bin
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
EntryBin *
|
EntryBin *
|
||||||
WidgetFactory :: createEntryBin(void) throw ()
|
WidgetFactory :: createEntryBin(void) throw ()
|
||||||
{
|
{
|
||||||
return new EntryBin(Colors::LightBlue, entryBinImages);
|
return new EntryBin(Colors::LightBlue, entryBinImages);
|
||||||
}
|
}
|
||||||
|
@ -416,7 +447,7 @@ WidgetFactory :: createEntryBin(void) throw ()
|
||||||
* Create a stock button
|
* Create a stock button
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
ImageButton *
|
ImageButton *
|
||||||
WidgetFactory :: createButton(ImageButtonType type) throw ()
|
WidgetFactory :: createButton(ImageButtonType type) throw ()
|
||||||
{
|
{
|
||||||
Glib::RefPtr<Gdk::Pixbuf> passiveImage;
|
Glib::RefPtr<Gdk::Pixbuf> passiveImage;
|
||||||
Glib::RefPtr<Gdk::Pixbuf> rollImage;
|
Glib::RefPtr<Gdk::Pixbuf> rollImage;
|
||||||
|
@ -489,7 +520,7 @@ WidgetFactory :: createButton(ImageButtonType type) throw ()
|
||||||
* Create a resize image
|
* Create a resize image
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
Gtk::Image *
|
Gtk::Image *
|
||||||
WidgetFactory :: createImage(ImageType imageName) throw ()
|
WidgetFactory :: createImage(ImageType imageName) throw ()
|
||||||
{
|
{
|
||||||
Glib::RefPtr<Gdk::Pixbuf> rawImage;
|
Glib::RefPtr<Gdk::Pixbuf> rawImage;
|
||||||
|
|
||||||
|
@ -533,7 +564,7 @@ WidgetFactory :: createImage(ImageType imageName) throw ()
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
ZebraTreeView *
|
ZebraTreeView *
|
||||||
WidgetFactory :: createTreeView(Glib::RefPtr<Gtk::TreeModel> treeModel)
|
WidgetFactory :: createTreeView(Glib::RefPtr<Gtk::TreeModel> treeModel)
|
||||||
throw ()
|
throw ()
|
||||||
{
|
{
|
||||||
return new ZebraTreeView(treeModel);
|
return new ZebraTreeView(treeModel);
|
||||||
}
|
}
|
||||||
|
@ -544,7 +575,7 @@ WidgetFactory :: createTreeView(Glib::RefPtr<Gtk::TreeModel> treeModel)
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
WhiteWindow *
|
WhiteWindow *
|
||||||
WidgetFactory :: createMessageWindow(Ptr<Glib::ustring>::Ref message)
|
WidgetFactory :: createMessageWindow(Ptr<Glib::ustring>::Ref message)
|
||||||
throw ()
|
throw ()
|
||||||
{
|
{
|
||||||
return new MessageWindow(message);
|
return new MessageWindow(message);
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,8 @@
|
||||||
storageClientFactory,
|
storageClientFactory,
|
||||||
schedulerClientFactory,
|
schedulerClientFactory,
|
||||||
outputPlayer,
|
outputPlayer,
|
||||||
cuePlayer) >
|
cuePlayer,
|
||||||
|
metadataTypeContainer) >
|
||||||
|
|
||||||
<!ELEMENT resourceBundle EMPTY >
|
<!ELEMENT resourceBundle EMPTY >
|
||||||
<!ATTLIST resourceBundle path CDATA #REQUIRED >
|
<!ATTLIST resourceBundle path CDATA #REQUIRED >
|
||||||
|
@ -84,7 +85,14 @@
|
||||||
<!ATTLIST helixPlayer audioStreamTimeout NMTOKEN #IMPLIED >
|
<!ATTLIST helixPlayer audioStreamTimeout NMTOKEN #IMPLIED >
|
||||||
<!ATTLIST helixPlayer fadeLookAheatTime NMTOKEN #IMPLIED >
|
<!ATTLIST helixPlayer fadeLookAheatTime NMTOKEN #IMPLIED >
|
||||||
|
|
||||||
|
<!ELEMENT metadataTypeContainer (metadataType+) >
|
||||||
|
|
||||||
|
<!ELEMENT metadataType EMPTY >
|
||||||
|
<!ATTLIST metadataType dcName NMTOKEN #REQUIRED >
|
||||||
|
<!ATTLIST metadataType id3Tag CDATA #IMPLIED >
|
||||||
|
<!ATTLIST metadataType localizationKey NMTOKEN #REQUIRED >
|
||||||
]>
|
]>
|
||||||
|
|
||||||
<gLiveSupport>
|
<gLiveSupport>
|
||||||
<resourceBundle path = "./tmp/gLiveSupport"
|
<resourceBundle path = "./tmp/gLiveSupport"
|
||||||
locale = "en"
|
locale = "en"
|
||||||
|
@ -134,5 +142,146 @@
|
||||||
</audioPlayer>
|
</audioPlayer>
|
||||||
</cuePlayer>
|
</cuePlayer>
|
||||||
|
|
||||||
|
<metadataTypeContainer>
|
||||||
|
<metadataType dcName = "dc:title"
|
||||||
|
id3Tag = "Title"
|
||||||
|
localizationKey = "title"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:creator"
|
||||||
|
id3Tag = "Artist"
|
||||||
|
localizationKey = "creator"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:source"
|
||||||
|
id3Tag = "Album"
|
||||||
|
localizationKey = "album"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:year"
|
||||||
|
id3Tag = "Year"
|
||||||
|
localizationKey = "year"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:type"
|
||||||
|
id3Tag = "Genre"
|
||||||
|
localizationKey = "genre"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:description"
|
||||||
|
id3Tag = "Comment"
|
||||||
|
localizationKey = "description"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:format"
|
||||||
|
localizationKey = "format"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:bpm"
|
||||||
|
id3Tag = "BPM"
|
||||||
|
localizationKey = "bpm"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:rating"
|
||||||
|
id3Tag = "Rating"
|
||||||
|
localizationKey = "rating"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dcterms:extent"
|
||||||
|
localizationKey = "length"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:encoded_by"
|
||||||
|
id3Tag = "Encoded by"
|
||||||
|
localizationKey = "encoded_by"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:track_num"
|
||||||
|
id3Tag = "Track"
|
||||||
|
localizationKey = "track_number"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:disc_num"
|
||||||
|
id3Tag = "Disk"
|
||||||
|
localizationKey = "disc_number"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:mood"
|
||||||
|
id3Tag = "Mood"
|
||||||
|
localizationKey = "mood"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:publisher"
|
||||||
|
id3Tag = "Label"
|
||||||
|
localizationKey = "publishing_label"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:composer"
|
||||||
|
id3Tag = "Composer"
|
||||||
|
localizationKey = "composer"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:bitrate"
|
||||||
|
id3Tag = "Bitrate"
|
||||||
|
localizationKey = "bitrate"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:channels"
|
||||||
|
id3Tag = "Channels"
|
||||||
|
localizationKey = "channels"
|
||||||
|
/> <!-- one of "", "Mono", "Stereo" or "5.1" -->
|
||||||
|
<metadataType dcName = "ls:samplerate"
|
||||||
|
id3Tag = "Samplerate"
|
||||||
|
localizationKey = "sample_rate"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:encoder"
|
||||||
|
id3Tag = "Encoder"
|
||||||
|
localizationKey = "encoding_software"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:crc"
|
||||||
|
id3Tag = "CRC"
|
||||||
|
localizationKey = "checksum"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:lyrics"
|
||||||
|
id3Tag = "Lyrics"
|
||||||
|
localizationKey = "lyrics"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:orchestra"
|
||||||
|
id3Tag = "Orchestra or band"
|
||||||
|
localizationKey = "orchestra_or_band"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:conductor"
|
||||||
|
id3Tag = "Conductor"
|
||||||
|
localizationKey = "conductor"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:lyricist"
|
||||||
|
id3Tag = "Lyricist"
|
||||||
|
localizationKey = "lyricist"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:originallyricist"
|
||||||
|
id3Tag = "Original lyricist"
|
||||||
|
localizationKey = "original_lyricist"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:radiostationname"
|
||||||
|
id3Tag = "Radio station name"
|
||||||
|
localizationKey = "radio_station_name"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:audiofileinfourl"
|
||||||
|
id3Tag = "Audio file information web page"
|
||||||
|
localizationKey = "audio_file_info_url"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:artisturl"
|
||||||
|
id3Tag = "Artist web page"
|
||||||
|
localizationKey = "artist_url"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:audiosourceurl"
|
||||||
|
id3Tag = "Audio source web page"
|
||||||
|
localizationKey = "audio_source_url"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:buycdurl"
|
||||||
|
id3Tag = "Buy CD web page"
|
||||||
|
localizationKey = "buy_cd_url"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:isrcnumber"
|
||||||
|
id3Tag = "ISRC number"
|
||||||
|
localizationKey = "isrc_number"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:catalognumber"
|
||||||
|
id3Tag = "Catalog"
|
||||||
|
localizationKey = "catalog_number"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:originalartist"
|
||||||
|
id3Tag = "Original Artist"
|
||||||
|
localizationKey = "original_artist"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:rights"
|
||||||
|
id3Tag = "Copyright"
|
||||||
|
localizationKey = "copyright"
|
||||||
|
/>
|
||||||
|
<!-- TODO: finish; the above are only the Main and Music tabs -->
|
||||||
|
</metadataTypeContainer>
|
||||||
</gLiveSupport>
|
</gLiveSupport>
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,8 @@
|
||||||
storageClientFactory,
|
storageClientFactory,
|
||||||
schedulerClientFactory,
|
schedulerClientFactory,
|
||||||
outputPlayer,
|
outputPlayer,
|
||||||
cuePlayer) >
|
cuePlayer,
|
||||||
|
metadataTypeContainer) >
|
||||||
|
|
||||||
<!ELEMENT resourceBundle EMPTY >
|
<!ELEMENT resourceBundle EMPTY >
|
||||||
<!ATTLIST resourceBundle path CDATA #REQUIRED >
|
<!ATTLIST resourceBundle path CDATA #REQUIRED >
|
||||||
|
@ -84,7 +85,14 @@
|
||||||
<!ATTLIST helixPlayer audioStreamTimeout NMTOKEN #IMPLIED >
|
<!ATTLIST helixPlayer audioStreamTimeout NMTOKEN #IMPLIED >
|
||||||
<!ATTLIST helixPlayer fadeLookAheatTime NMTOKEN #IMPLIED >
|
<!ATTLIST helixPlayer fadeLookAheatTime NMTOKEN #IMPLIED >
|
||||||
|
|
||||||
|
<!ELEMENT metadataTypeContainer (metadataType+) >
|
||||||
|
|
||||||
|
<!ELEMENT metadataType EMPTY >
|
||||||
|
<!ATTLIST metadataType dcName NMTOKEN #REQUIRED >
|
||||||
|
<!ATTLIST metadataType id3Tag CDATA #IMPLIED >
|
||||||
|
<!ATTLIST metadataType localizationKey NMTOKEN #REQUIRED >
|
||||||
]>
|
]>
|
||||||
|
|
||||||
<gLiveSupport>
|
<gLiveSupport>
|
||||||
<resourceBundle path = "ls_install_dir/var/gLiveSupport"
|
<resourceBundle path = "ls_install_dir/var/gLiveSupport"
|
||||||
locale = "en"
|
locale = "en"
|
||||||
|
@ -134,5 +142,142 @@
|
||||||
</audioPlayer>
|
</audioPlayer>
|
||||||
</cuePlayer>
|
</cuePlayer>
|
||||||
|
|
||||||
|
<metadataTypeContainer>
|
||||||
|
<metadataType dcName = "dc:title"
|
||||||
|
id3Tag = "Title"
|
||||||
|
localizationKey = "title"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:creator"
|
||||||
|
id3Tag = "Artist"
|
||||||
|
localizationKey = "creator"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:type"
|
||||||
|
id3Tag = "Genre"
|
||||||
|
localizationKey = "genre"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:format"
|
||||||
|
localizationKey = "file_format"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dcterms:extent"
|
||||||
|
localizationKey = "length"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:source"
|
||||||
|
id3Tag = "Album"
|
||||||
|
localizationKey = "album"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:year"
|
||||||
|
id3Tag = "Year"
|
||||||
|
localizationKey = "year"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:bpm"
|
||||||
|
id3Tag = "BPM"
|
||||||
|
localizationKey = "bpm"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:rating"
|
||||||
|
id3Tag = "Rating"
|
||||||
|
localizationKey = "rating"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:encoded_by"
|
||||||
|
id3Tag = "Encoded by"
|
||||||
|
localizationKey = "encoded_by"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:track_num"
|
||||||
|
id3Tag = "Track"
|
||||||
|
localizationKey = "track_number"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:disc_num"
|
||||||
|
id3Tag = "Disk"
|
||||||
|
localizationKey = "disc_number"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:mood"
|
||||||
|
id3Tag = "Mood"
|
||||||
|
localizationKey = "mood"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:publisher"
|
||||||
|
id3Tag = "Label"
|
||||||
|
localizationKey = "publishing_label"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:composer"
|
||||||
|
id3Tag = "Composer"
|
||||||
|
localizationKey = "composer"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:bitrate"
|
||||||
|
id3Tag = "Bitrate"
|
||||||
|
localizationKey = "bitrate"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:channels"
|
||||||
|
id3Tag = "Channels"
|
||||||
|
localizationKey = "channels"
|
||||||
|
/> <!-- one of "", "Mono", "Stereo" or "5.1" -->
|
||||||
|
<metadataType dcName = "ls:samplerate"
|
||||||
|
id3Tag = "Samplerate"
|
||||||
|
localizationKey = "sample_rate"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:encoder"
|
||||||
|
id3Tag = "Encoder"
|
||||||
|
localizationKey = "encoding_software"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:crc"
|
||||||
|
id3Tag = "CRC"
|
||||||
|
localizationKey = "checksum"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:lyrics"
|
||||||
|
id3Tag = "Lyrics"
|
||||||
|
localizationKey = "lyrics"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:orchestra"
|
||||||
|
id3Tag = "Orchestra or band" <!-- ??? -->
|
||||||
|
localizationKey = "orchestra_or_band"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:conductor"
|
||||||
|
id3Tag = "Conductor"
|
||||||
|
localizationKey = "conductor"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:lyricist"
|
||||||
|
id3Tag = "Lyricist"
|
||||||
|
localizationKey = "lyricist"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:originallyricist"
|
||||||
|
id3Tag = "Original lyricist"
|
||||||
|
localizationKey = "original_lyricist"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:radiostationname"
|
||||||
|
id3Tag = "Radio station name"
|
||||||
|
localizationKey = "radio_station_name"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:audiofileinfourl"
|
||||||
|
id3Tag = "Audio file information web page"
|
||||||
|
localizationKey = "audio_file_info_url"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:artisturl"
|
||||||
|
id3Tag = "Artist web page"
|
||||||
|
localizationKey = "artist_url"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:audiosourceurl"
|
||||||
|
id3Tag = "Audio source web page"
|
||||||
|
localizationKey = "audio_source_url"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:buycdurl"
|
||||||
|
id3Tag = "Buy CD web page"
|
||||||
|
localizationKey = "buy_cd_url"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:isrcnumber"
|
||||||
|
id3Tag = "ISRC number"
|
||||||
|
localizationKey = "isrc_number"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:catalognumber"
|
||||||
|
id3Tag = "Catalog"
|
||||||
|
localizationKey = "catalog_number"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "ls:originalartist"
|
||||||
|
id3Tag = "Original Artist"
|
||||||
|
localizationKey = "original_artist"
|
||||||
|
/>
|
||||||
|
<metadataType dcName = "dc:rights"
|
||||||
|
id3Tag = "Copyright"
|
||||||
|
localizationKey = "copyright"
|
||||||
|
/>
|
||||||
|
<!-- TODO: finish; the above are only the Main and Music tabs -->
|
||||||
|
</metadataTypeContainer>
|
||||||
</gLiveSupport>
|
</gLiveSupport>
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.1 $
|
Version : $Revision: 1.2 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/AdvancedSearchEntry.cxx,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/AdvancedSearchEntry.cxx,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -57,12 +57,17 @@ using namespace LiveSupport::GLiveSupport;
|
||||||
/*------------------------------------------------------------------------------
|
/*------------------------------------------------------------------------------
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
AdvancedSearchEntry :: AdvancedSearchEntry(Ptr<ResourceBundle>::Ref bundle)
|
AdvancedSearchEntry :: AdvancedSearchEntry(
|
||||||
throw ()
|
Ptr<MetadataTypeContainer>::Ref metadataTypes,
|
||||||
: LocalizedObject(bundle)
|
Ptr<ResourceBundle>::Ref bundle)
|
||||||
|
throw ()
|
||||||
|
: LocalizedObject(bundle),
|
||||||
|
metadataTypes(metadataTypes)
|
||||||
{
|
{
|
||||||
AdvancedSearchItem * searchOptionsBox = Gtk::manage(new
|
AdvancedSearchItem * searchOptionsBox = Gtk::manage(new
|
||||||
AdvancedSearchItem(true, getBundle()) );
|
AdvancedSearchItem(true,
|
||||||
|
metadataTypes,
|
||||||
|
getBundle() ));
|
||||||
pack_start(*searchOptionsBox, Gtk::PACK_SHRINK, 5);
|
pack_start(*searchOptionsBox, Gtk::PACK_SHRINK, 5);
|
||||||
|
|
||||||
searchOptionsBox->signal_add_new().connect(sigc::mem_fun(*this,
|
searchOptionsBox->signal_add_new().connect(sigc::mem_fun(*this,
|
||||||
|
@ -74,10 +79,12 @@ AdvancedSearchEntry :: AdvancedSearchEntry(Ptr<ResourceBundle>::Ref bundle)
|
||||||
* Add a new search condition entrys item.
|
* Add a new search condition entrys item.
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
void
|
void
|
||||||
AdvancedSearchEntry :: onAddNewCondition(void) throw ()
|
AdvancedSearchEntry :: onAddNewCondition(void) throw ()
|
||||||
{
|
{
|
||||||
AdvancedSearchItem * searchOptionsBox = Gtk::manage(new
|
AdvancedSearchItem * searchOptionsBox = Gtk::manage(new
|
||||||
AdvancedSearchItem(false, getBundle()) );
|
AdvancedSearchItem(false,
|
||||||
|
metadataTypes,
|
||||||
|
getBundle() ));
|
||||||
pack_start(*searchOptionsBox, Gtk::PACK_SHRINK, 5);
|
pack_start(*searchOptionsBox, Gtk::PACK_SHRINK, 5);
|
||||||
|
|
||||||
searchOptionsBox->signal_add_new().connect(sigc::mem_fun(*this,
|
searchOptionsBox->signal_add_new().connect(sigc::mem_fun(*this,
|
||||||
|
@ -91,7 +98,7 @@ AdvancedSearchEntry :: onAddNewCondition(void) throw ()
|
||||||
* Return the current state of the search fields.
|
* Return the current state of the search fields.
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
Ptr<SearchCriteria>::Ref
|
Ptr<SearchCriteria>::Ref
|
||||||
AdvancedSearchEntry :: getSearchCriteria(void) throw ()
|
AdvancedSearchEntry :: getSearchCriteria(void) throw ()
|
||||||
{
|
{
|
||||||
Ptr<SearchCriteria>::Ref criteria(new SearchCriteria("all", "and"));
|
Ptr<SearchCriteria>::Ref criteria(new SearchCriteria("all", "and"));
|
||||||
|
|
||||||
|
@ -112,8 +119,8 @@ AdvancedSearchEntry :: getSearchCriteria(void) throw ()
|
||||||
* Connect a callback to the "enter key pressed" event.
|
* Connect a callback to the "enter key pressed" event.
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
void
|
void
|
||||||
AdvancedSearchEntry :: connectCallback(const sigc::slot<void> & callback)
|
AdvancedSearchEntry :: connectCallback(const sigc::slot<void> & callback)
|
||||||
throw ()
|
throw ()
|
||||||
{
|
{
|
||||||
Gtk::Box_Helpers::BoxList children = this->children();
|
Gtk::Box_Helpers::BoxList children = this->children();
|
||||||
Gtk::Box_Helpers::BoxList::type_base::iterator it;
|
Gtk::Box_Helpers::BoxList::type_base::iterator it;
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.1 $
|
Version : $Revision: 1.2 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/AdvancedSearchEntry.h,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/AdvancedSearchEntry.h,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -44,6 +44,7 @@
|
||||||
|
|
||||||
#include "LiveSupport/Core/Ptr.h"
|
#include "LiveSupport/Core/Ptr.h"
|
||||||
#include "LiveSupport/Core/LocalizedObject.h"
|
#include "LiveSupport/Core/LocalizedObject.h"
|
||||||
|
#include "LiveSupport/Core/MetadataTypeContainer.h"
|
||||||
#include "LiveSupport/Core/SearchCriteria.h"
|
#include "LiveSupport/Core/SearchCriteria.h"
|
||||||
|
|
||||||
|
|
||||||
|
@ -64,7 +65,7 @@ using namespace LiveSupport::Core;
|
||||||
* A Gtk::VBox with one or more search input fields in it.
|
* A Gtk::VBox with one or more search input fields in it.
|
||||||
*
|
*
|
||||||
* @author $Author: fgerlits $
|
* @author $Author: fgerlits $
|
||||||
* @version $Revision: 1.1 $
|
* @version $Revision: 1.2 $
|
||||||
*/
|
*/
|
||||||
class AdvancedSearchEntry : public Gtk::VBox,
|
class AdvancedSearchEntry : public Gtk::VBox,
|
||||||
public LocalizedObject
|
public LocalizedObject
|
||||||
|
@ -72,16 +73,20 @@ class AdvancedSearchEntry : public Gtk::VBox,
|
||||||
private:
|
private:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default constructor.
|
* A container holding all known metadata types.
|
||||||
*/
|
*/
|
||||||
AdvancedSearchEntry(void) throw ();
|
Ptr<MetadataTypeContainer>::Ref metadataTypes;
|
||||||
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor with localization parameter.
|
* Constructor.
|
||||||
|
*
|
||||||
|
* @param metadataTypes container holding all known metadata types
|
||||||
*/
|
*/
|
||||||
AdvancedSearchEntry(Ptr<ResourceBundle>::Ref bundle)
|
AdvancedSearchEntry(Ptr<MetadataTypeContainer>::Ref metadataTypes,
|
||||||
|
Ptr<ResourceBundle>::Ref bundle)
|
||||||
throw ();
|
throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.1 $
|
Version : $Revision: 1.2 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/AdvancedSearchItem.cxx,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/AdvancedSearchItem.cxx,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -58,23 +58,13 @@ using namespace LiveSupport::GLiveSupport;
|
||||||
/*------------------------------------------------------------------------------
|
/*------------------------------------------------------------------------------
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*----------------------------------------------------------------------------*/
|
*----------------------------------------------------------------------------*/
|
||||||
AdvancedSearchItem :: AdvancedSearchItem(bool isFirst,
|
AdvancedSearchItem :: AdvancedSearchItem(
|
||||||
Ptr<ResourceBundle>::Ref bundle)
|
bool isFirst,
|
||||||
throw ()
|
Ptr<MetadataTypeContainer>::Ref metadataTypes,
|
||||||
|
Ptr<ResourceBundle>::Ref bundle)
|
||||||
|
throw ()
|
||||||
: LocalizedObject(bundle)
|
: LocalizedObject(bundle)
|
||||||
{
|
{
|
||||||
try {
|
|
||||||
if (!metadataTypes) {
|
|
||||||
readMetadataTypes();
|
|
||||||
}
|
|
||||||
if (!operatorTypes) {
|
|
||||||
readOperatorTypes();
|
|
||||||
}
|
|
||||||
} catch (std::invalid_argument &e) {
|
|
||||||
std::cerr << e.what() << std::endl;
|
|
||||||
std::exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
Ptr<WidgetFactory>::Ref wf = WidgetFactory::getInstance();
|
Ptr<WidgetFactory>::Ref wf = WidgetFactory::getInstance();
|
||||||
|
|
||||||
Gtk::Label * searchByLabel;
|
Gtk::Label * searchByLabel;
|
||||||
|
@ -89,19 +79,10 @@ AdvancedSearchItem :: AdvancedSearchItem(bool isFirst,
|
||||||
|
|
||||||
pack_start(*searchByLabel, Gtk::PACK_SHRINK, 5);
|
pack_start(*searchByLabel, Gtk::PACK_SHRINK, 5);
|
||||||
|
|
||||||
metadataEntry = Gtk::manage(wf->createComboBoxText());
|
metadataEntry = Gtk::manage(wf->createMetadataComboBoxText(metadataTypes));
|
||||||
MapVector::const_iterator it;
|
|
||||||
for (it = metadataTypes->begin(); it != metadataTypes->end(); ++it) {
|
|
||||||
metadataEntry->append_text(it->first);
|
|
||||||
}
|
|
||||||
metadataEntry->set_active_text(metadataTypes->front().first);
|
|
||||||
pack_start(*metadataEntry, Gtk::PACK_EXPAND_WIDGET, 5);
|
pack_start(*metadataEntry, Gtk::PACK_EXPAND_WIDGET, 5);
|
||||||
|
|
||||||
operatorEntry = Gtk::manage(wf->createComboBoxText());
|
operatorEntry = Gtk::manage(wf->createOperatorComboBoxText(bundle));
|
||||||
for (it = operatorTypes->begin(); it != operatorTypes->end(); ++it) {
|
|
||||||
operatorEntry->append_text(it->first);
|
|
||||||
}
|
|
||||||
operatorEntry->set_active_text(operatorTypes->front().first);
|
|
||||||
pack_start(*operatorEntry, Gtk::PACK_EXPAND_WIDGET, 5);
|
pack_start(*operatorEntry, Gtk::PACK_EXPAND_WIDGET, 5);
|
||||||
|
|
||||||
valueEntry = Gtk::manage(wf->createEntryBin());
|
valueEntry = Gtk::manage(wf->createEntryBin());
|
||||||
|
@ -125,100 +106,15 @@ AdvancedSearchItem :: AdvancedSearchItem(bool isFirst,
|
||||||
Ptr<SearchCriteria::SearchConditionType>::Ref
|
Ptr<SearchCriteria::SearchConditionType>::Ref
|
||||||
AdvancedSearchItem :: getSearchCondition(void) throw ()
|
AdvancedSearchItem :: getSearchCondition(void) throw ()
|
||||||
{
|
{
|
||||||
std::string metadataName = metadataEntry->get_active_text();
|
Ptr<const Glib::ustring>::Ref metadataKey = metadataEntry->getActiveKey();
|
||||||
std::string metadataKey;
|
Ptr<const Glib::ustring>::Ref operatorKey = operatorEntry->getActiveKey();
|
||||||
bool found = false;
|
std::string value = valueEntry->get_text();
|
||||||
MapVector::const_iterator it;
|
|
||||||
for (it = metadataTypes->begin(); it != metadataTypes->end(); ++it) {
|
|
||||||
if (it->first == metadataName) {
|
|
||||||
found = true;
|
|
||||||
metadataKey = it->second;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!found) {
|
|
||||||
std::cerr << "unknown metadata type: " << metadataName
|
|
||||||
<< std::endl << "(this should never happen)" << std::endl;
|
|
||||||
std::exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string operatorName = operatorEntry->get_active_text();
|
|
||||||
std::string operatorKey;
|
|
||||||
found = false;
|
|
||||||
for (it = operatorTypes->begin(); it != operatorTypes->end(); ++it) {
|
|
||||||
if (it->first == operatorName) {
|
|
||||||
found = true;
|
|
||||||
operatorKey = it->second;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!found) {
|
|
||||||
std::cerr << "unknown comparison operator: " << operatorName
|
|
||||||
<< std::endl << "(this should never happen)" << std::endl;
|
|
||||||
std::exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string value = valueEntry->get_text();
|
|
||||||
|
|
||||||
Ptr<SearchCriteria::SearchConditionType>::Ref
|
Ptr<SearchCriteria::SearchConditionType>::Ref
|
||||||
condition(new SearchCriteria::SearchConditionType(metadataKey,
|
condition(new SearchCriteria::SearchConditionType(*metadataKey,
|
||||||
operatorKey,
|
*operatorKey,
|
||||||
value) );
|
value));
|
||||||
|
|
||||||
return condition;
|
return condition;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*------------------------------------------------------------------------------
|
|
||||||
* Read the localized metadata field names.
|
|
||||||
*----------------------------------------------------------------------------*/
|
|
||||||
void
|
|
||||||
AdvancedSearchItem :: readMetadataTypes(void)
|
|
||||||
throw (std::invalid_argument)
|
|
||||||
{
|
|
||||||
metadataTypes.reset(new MapVector);
|
|
||||||
|
|
||||||
metadataTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring("genreMetadataDisplay"),
|
|
||||||
*getResourceUstring("genreMetadataSearchKey") ));
|
|
||||||
metadataTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring("creatorMetadataDisplay"),
|
|
||||||
*getResourceUstring("creatorMetadataSearchKey") ));
|
|
||||||
metadataTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring("albumMetadataDisplay"),
|
|
||||||
*getResourceUstring("albumMetadataSearchKey") ));
|
|
||||||
metadataTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring("titleMetadataDisplay"),
|
|
||||||
*getResourceUstring("titleMetadataSearchKey") ));
|
|
||||||
metadataTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring("lengthMetadataDisplay"),
|
|
||||||
*getResourceUstring("lengthMetadataSearchKey") ));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*------------------------------------------------------------------------------
|
|
||||||
* Read the localized comparison operator names.
|
|
||||||
*----------------------------------------------------------------------------*/
|
|
||||||
void
|
|
||||||
AdvancedSearchItem :: readOperatorTypes(void)
|
|
||||||
throw (std::invalid_argument)
|
|
||||||
{
|
|
||||||
operatorTypes.reset(new MapVector);
|
|
||||||
|
|
||||||
operatorTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring("partialOperatorDisplay"),
|
|
||||||
*getResourceUstring("partialOperatorSearchKey") ));
|
|
||||||
operatorTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring("prefixOperatorDisplay"),
|
|
||||||
*getResourceUstring("prefixOperatorSearchKey") ));
|
|
||||||
operatorTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring("=OperatorDisplay"),
|
|
||||||
*getResourceUstring("=OperatorSearchKey") ));
|
|
||||||
operatorTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring("<=OperatorDisplay"),
|
|
||||||
*getResourceUstring("<=OperatorSearchKey") ));
|
|
||||||
operatorTypes->push_back(std::make_pair(
|
|
||||||
*getResourceUstring(">=OperatorDisplay"),
|
|
||||||
*getResourceUstring(">=OperatorSearchKey") ));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.1 $
|
Version : $Revision: 1.2 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/AdvancedSearchItem.h,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/AdvancedSearchItem.h,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -47,8 +47,10 @@
|
||||||
|
|
||||||
#include "LiveSupport/Core/Ptr.h"
|
#include "LiveSupport/Core/Ptr.h"
|
||||||
#include "LiveSupport/Core/LocalizedObject.h"
|
#include "LiveSupport/Core/LocalizedObject.h"
|
||||||
|
#include "LiveSupport/Core/MetadataTypeContainer.h"
|
||||||
#include "LiveSupport/Core/SearchCriteria.h"
|
#include "LiveSupport/Core/SearchCriteria.h"
|
||||||
#include "LiveSupport/Widgets/ComboBoxText.h"
|
#include "LiveSupport/Widgets/MetadataComboBoxText.h"
|
||||||
|
#include "LiveSupport/Widgets/OperatorComboBoxText.h"
|
||||||
#include "LiveSupport/Widgets/EntryBin.h"
|
#include "LiveSupport/Widgets/EntryBin.h"
|
||||||
#include "LiveSupport/Widgets/ImageButton.h"
|
#include "LiveSupport/Widgets/ImageButton.h"
|
||||||
|
|
||||||
|
@ -71,7 +73,7 @@ using namespace LiveSupport::Widgets;
|
||||||
* A single search input field.
|
* A single search input field.
|
||||||
*
|
*
|
||||||
* @author $Author: fgerlits $
|
* @author $Author: fgerlits $
|
||||||
* @version $Revision: 1.1 $
|
* @version $Revision: 1.2 $
|
||||||
*/
|
*/
|
||||||
class AdvancedSearchItem : public Gtk::HBox,
|
class AdvancedSearchItem : public Gtk::HBox,
|
||||||
public LocalizedObject
|
public LocalizedObject
|
||||||
|
@ -85,25 +87,15 @@ class AdvancedSearchItem : public Gtk::HBox,
|
||||||
typedef std::vector<std::pair<Glib::ustring, Glib::ustring> >
|
typedef std::vector<std::pair<Glib::ustring, Glib::ustring> >
|
||||||
MapVector;
|
MapVector;
|
||||||
|
|
||||||
/**
|
|
||||||
* The list of possible metadata field names.
|
|
||||||
*/
|
|
||||||
Ptr<MapVector>::Ref metadataTypes;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The list of possible comparison operators.
|
|
||||||
*/
|
|
||||||
Ptr<MapVector>::Ref operatorTypes;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The metadata field.
|
* The metadata field.
|
||||||
*/
|
*/
|
||||||
ComboBoxText * metadataEntry;
|
MetadataComboBoxText * metadataEntry;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The operator field.
|
* The operator field.
|
||||||
*/
|
*/
|
||||||
ComboBoxText * operatorEntry;
|
OperatorComboBoxText * operatorEntry;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The "search for this value" field.
|
* The "search for this value" field.
|
||||||
|
@ -120,41 +112,19 @@ class AdvancedSearchItem : public Gtk::HBox,
|
||||||
*/
|
*/
|
||||||
ImageButton * closeButton;
|
ImageButton * closeButton;
|
||||||
|
|
||||||
/**
|
|
||||||
* Default constructor.
|
|
||||||
*/
|
|
||||||
AdvancedSearchItem(void) throw ();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Read the localized metadata field names.
|
|
||||||
*
|
|
||||||
* @exception std::invalid_argument if some keys are not found in
|
|
||||||
* the resource bundle
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
readMetadataTypes(void) throw (std::invalid_argument);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Read the localized comparison operator names.
|
|
||||||
*
|
|
||||||
* @exception std::invalid_argument if some keys are not found in
|
|
||||||
* the resource bundle
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
readOperatorTypes(void) throw (std::invalid_argument);
|
|
||||||
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor with localization parameter.
|
* Constructor.
|
||||||
*
|
*
|
||||||
* @param isFirst true if this is the first search condition
|
* @param isFirst true if this is the first search condition
|
||||||
* (so it does not need a Close button)
|
* (so it does not need a Close button)
|
||||||
* @param bundle the resource bundle for localization
|
* @param metadataTypes container holding all known metadata types
|
||||||
*/
|
*/
|
||||||
AdvancedSearchItem(bool isFirst,
|
AdvancedSearchItem(bool isFirst,
|
||||||
Ptr<ResourceBundle>::Ref bundle)
|
Ptr<MetadataTypeContainer>::Ref metadataTypes,
|
||||||
|
Ptr<ResourceBundle>::Ref bundle)
|
||||||
throw ();
|
throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.44 $
|
Version : $Revision: 1.45 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/GLiveSupport.cxx,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/GLiveSupport.cxx,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -239,6 +239,21 @@ GLiveSupport :: configure(const xmlpp::Element & element)
|
||||||
|
|
||||||
cuePlayer = apf->getAudioPlayer();
|
cuePlayer = apf->getAudioPlayer();
|
||||||
cuePlayer->initialize();
|
cuePlayer->initialize();
|
||||||
|
|
||||||
|
// configure the MetadataTypeContainer
|
||||||
|
nodes = element.get_children(MetadataTypeContainer::getConfigElementName());
|
||||||
|
if (nodes.size() < 1) {
|
||||||
|
throw std::invalid_argument("no metadataTypeContainer element");
|
||||||
|
}
|
||||||
|
Ptr<ResourceBundle>::Ref metadataBundle;
|
||||||
|
try {
|
||||||
|
metadataBundle = getBundle("metadataTypes");
|
||||||
|
} catch (std::invalid_argument &e) {
|
||||||
|
throw std::invalid_argument(e.what());
|
||||||
|
}
|
||||||
|
metadataTypeContainer.reset(new MetadataTypeContainer(metadataBundle));
|
||||||
|
metadataTypeContainer->configure(
|
||||||
|
*((const xmlpp::Element*) *(nodes.begin())) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -376,6 +391,8 @@ GLiveSupport :: changeLanguage(Ptr<const std::string>::Ref locale)
|
||||||
{
|
{
|
||||||
changeLocale(*locale);
|
changeLocale(*locale);
|
||||||
|
|
||||||
|
metadataTypeContainer->setBundle(getBundle());
|
||||||
|
|
||||||
if (masterPanel.get()) {
|
if (masterPanel.get()) {
|
||||||
masterPanel->changeLanguage(getBundle());
|
masterPanel->changeLanguage(getBundle());
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.35 $
|
Version : $Revision: 1.36 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/GLiveSupport.h,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/GLiveSupport.h,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -48,6 +48,7 @@
|
||||||
|
|
||||||
#include "LiveSupport/Core/Ptr.h"
|
#include "LiveSupport/Core/Ptr.h"
|
||||||
#include "LiveSupport/Core/LocalizedConfigurable.h"
|
#include "LiveSupport/Core/LocalizedConfigurable.h"
|
||||||
|
#include "LiveSupport/Core/MetadataTypeContainer.h"
|
||||||
#include "LiveSupport/Authentication/AuthenticationClientInterface.h"
|
#include "LiveSupport/Authentication/AuthenticationClientInterface.h"
|
||||||
#include "LiveSupport/Storage/StorageClientInterface.h"
|
#include "LiveSupport/Storage/StorageClientInterface.h"
|
||||||
#include "LiveSupport/SchedulerClient/SchedulerClientInterface.h"
|
#include "LiveSupport/SchedulerClient/SchedulerClientInterface.h"
|
||||||
|
@ -101,7 +102,7 @@ class MasterPanelWindow;
|
||||||
* respective documentation.
|
* respective documentation.
|
||||||
*
|
*
|
||||||
* @author $Author: fgerlits $
|
* @author $Author: fgerlits $
|
||||||
* @version $Revision: 1.35 $
|
* @version $Revision: 1.36 $
|
||||||
* @see LocalizedObject#getBundle(const xmlpp::Element &)
|
* @see LocalizedObject#getBundle(const xmlpp::Element &)
|
||||||
* @see AuthenticationClientFactory
|
* @see AuthenticationClientFactory
|
||||||
* @see StorageClientFactory
|
* @see StorageClientFactory
|
||||||
|
@ -174,6 +175,11 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
*/
|
*/
|
||||||
Ptr<LanguageMap>::Ref supportedLanguages;
|
Ptr<LanguageMap>::Ref supportedLanguages;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The container for all the possible metadata types.
|
||||||
|
*/
|
||||||
|
Ptr<MetadataTypeContainer>::Ref metadataTypeContainer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The master panel window.
|
* The master panel window.
|
||||||
*/
|
*/
|
||||||
|
@ -227,13 +233,13 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* Store the contents of the Scratchpad as a user preference.
|
* Store the contents of the Scratchpad as a user preference.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
storeScratchpadContents(void) throw ();
|
storeScratchpadContents(void) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Load the contents of the Scratchpad as a user preference.
|
* Load the contents of the Scratchpad as a user preference.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
loadScratchpadContents(void) throw ();
|
loadScratchpadContents(void) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Release the resources used by the output audio player.
|
* Release the resources used by the output audio player.
|
||||||
|
@ -256,7 +262,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*/
|
*/
|
||||||
GLiveSupport(void) throw ()
|
GLiveSupport(void) throw ()
|
||||||
: outputPlayerIsPaused(false),
|
: outputPlayerIsPaused(false),
|
||||||
cuePlayerIsPaused(false)
|
cuePlayerIsPaused(false)
|
||||||
{
|
{
|
||||||
|
@ -267,7 +273,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* Virtual destructor.
|
* Virtual destructor.
|
||||||
*/
|
*/
|
||||||
virtual
|
virtual
|
||||||
~GLiveSupport(void) throw ()
|
~GLiveSupport(void) throw ()
|
||||||
{
|
{
|
||||||
if (outputPlayer.get()) {
|
if (outputPlayer.get()) {
|
||||||
outputPlayer->deInitialize();
|
outputPlayer->deInitialize();
|
||||||
|
@ -284,7 +290,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* @return the name of the expected XML configuration element.
|
* @return the name of the expected XML configuration element.
|
||||||
*/
|
*/
|
||||||
static const std::string
|
static const std::string
|
||||||
getConfigElementName(void) throw ()
|
getConfigElementName(void) throw ()
|
||||||
{
|
{
|
||||||
return configElementNameStr;
|
return configElementNameStr;
|
||||||
}
|
}
|
||||||
|
@ -313,7 +319,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* false otherwise
|
* false otherwise
|
||||||
*/
|
*/
|
||||||
bool
|
bool
|
||||||
checkConfiguration(void) throw ();
|
checkConfiguration(void) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Display a message window.
|
* Display a message window.
|
||||||
|
@ -322,14 +328,15 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* @param message the message to display
|
* @param message the message to display
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
displayMessageWindow(Ptr<Glib::ustring>::Ref message) throw ();
|
displayMessageWindow(Ptr<Glib::ustring>::Ref message)
|
||||||
|
throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show the main window, and run the application.
|
* Show the main window, and run the application.
|
||||||
* This call will only return after the main window has been closed.
|
* This call will only return after the main window has been closed.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
show(void) throw ();
|
show(void) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Change the language of the application.
|
* Change the language of the application.
|
||||||
|
@ -356,7 +363,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
*/
|
*/
|
||||||
bool
|
bool
|
||||||
login(const std::string & login,
|
login(const std::string & login,
|
||||||
const std::string & password) throw ();
|
const std::string & password) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the session id for the user.
|
* Return the session id for the user.
|
||||||
|
@ -368,7 +375,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* @see #login
|
* @see #login
|
||||||
*/
|
*/
|
||||||
Ptr<SessionId>::Ref
|
Ptr<SessionId>::Ref
|
||||||
getSessionId(void) const throw ()
|
getSessionId(void) const throw ()
|
||||||
{
|
{
|
||||||
return sessionId;
|
return sessionId;
|
||||||
}
|
}
|
||||||
|
@ -380,7 +387,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* @see #logout
|
* @see #logout
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
logout(void) throw ();
|
logout(void) throw ();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Accessor function to the scheduler client held by this object.
|
* Accessor function to the scheduler client held by this object.
|
||||||
|
@ -388,7 +395,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* @return the scheduler client held by this object.
|
* @return the scheduler client held by this object.
|
||||||
*/
|
*/
|
||||||
Ptr<SchedulerClientInterface>::Ref
|
Ptr<SchedulerClientInterface>::Ref
|
||||||
getScheduler(void) throw ()
|
getScheduler(void) throw ()
|
||||||
{
|
{
|
||||||
return scheduler;
|
return scheduler;
|
||||||
}
|
}
|
||||||
|
@ -399,7 +406,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* @return the storage client held by this object.
|
* @return the storage client held by this object.
|
||||||
*/
|
*/
|
||||||
Ptr<StorageClientInterface>::Ref
|
Ptr<StorageClientInterface>::Ref
|
||||||
getStorage(void) throw ()
|
getStorage(void) throw ()
|
||||||
{
|
{
|
||||||
return storage;
|
return storage;
|
||||||
}
|
}
|
||||||
|
@ -410,11 +417,22 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
* @return the map of supported languages.
|
* @return the map of supported languages.
|
||||||
*/
|
*/
|
||||||
Ptr<const LanguageMap>::Ref
|
Ptr<const LanguageMap>::Ref
|
||||||
getSupportedLanguages(void) const throw ()
|
getSupportedLanguages(void) const throw ()
|
||||||
{
|
{
|
||||||
return supportedLanguages;
|
return supportedLanguages;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return a container with all supported metadata types.
|
||||||
|
*
|
||||||
|
* @return the metadata type container
|
||||||
|
*/
|
||||||
|
Ptr<MetadataTypeContainer>::Ref
|
||||||
|
getMetadataTypeContainer(void) const throw ()
|
||||||
|
{
|
||||||
|
return metadataTypeContainer;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show the UI components that are visible when no one is logged in.
|
* Show the UI components that are visible when no one is logged in.
|
||||||
*/
|
*/
|
||||||
|
@ -593,7 +611,7 @@ class GLiveSupport : public LocalizedConfigurable,
|
||||||
*/
|
*/
|
||||||
virtual void
|
virtual void
|
||||||
deletePlayable(Ptr<Playable>::Ref playable)
|
deletePlayable(Ptr<Playable>::Ref playable)
|
||||||
throw (XmlRpcException);
|
throw (XmlRpcException);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Play a Playable object using the output audio player.
|
* Play a Playable object using the output audio player.
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
|
|
||||||
Author : $Author: fgerlits $
|
Author : $Author: fgerlits $
|
||||||
Version : $Revision: 1.15 $
|
Version : $Revision: 1.16 $
|
||||||
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/SearchWindow.cxx,v $
|
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/products/gLiveSupport/src/SearchWindow.cxx,v $
|
||||||
|
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -166,9 +166,11 @@ SearchWindow :: constructAdvancedSearchView(void) throw ()
|
||||||
Ptr<WidgetFactory>::Ref wf = WidgetFactory::getInstance();
|
Ptr<WidgetFactory>::Ref wf = WidgetFactory::getInstance();
|
||||||
|
|
||||||
// the three main components of the window
|
// the three main components of the window
|
||||||
advancedSearchEntry = Gtk::manage(new AdvancedSearchEntry(getBundle()));
|
advancedSearchEntry = Gtk::manage(new AdvancedSearchEntry(
|
||||||
Gtk::Box * searchButtonBox = Gtk::manage(new Gtk::HButtonBox(
|
gLiveSupport->getMetadataTypeContainer(),
|
||||||
Gtk::BUTTONBOX_END ));
|
getBundle() ));
|
||||||
|
Gtk::Box * searchButtonBox = Gtk::manage(new Gtk::HButtonBox(
|
||||||
|
Gtk::BUTTONBOX_END ));
|
||||||
|
|
||||||
// set up the callback function for the entry field
|
// set up the callback function for the entry field
|
||||||
advancedSearchEntry->connectCallback(sigc::mem_fun(
|
advancedSearchEntry->connectCallback(sigc::mem_fun(
|
||||||
|
|
|
@ -189,5 +189,44 @@ hu:table
|
||||||
|
|
||||||
cuePlayerLabel:string { "Belehallgatni" }
|
cuePlayerLabel:string { "Belehallgatni" }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
metadataTypes:table
|
||||||
|
{
|
||||||
|
title:string { "Title" }
|
||||||
|
creator:string { "Creator" }
|
||||||
|
album:string { "Album" }
|
||||||
|
year:string { "Year" }
|
||||||
|
genre:string { "Genre" }
|
||||||
|
description:string { "Description" }
|
||||||
|
format:string { "Format" }
|
||||||
|
length:string { "Length" }
|
||||||
|
bpm:string { "BPM" }
|
||||||
|
rating:string { "Rating" }
|
||||||
|
encoded_by:string { "Encoded by" }
|
||||||
|
track_number:string { "Track number" }
|
||||||
|
disc_number:string { "Disc number" }
|
||||||
|
mood:string { "Mood" }
|
||||||
|
publishing_label:string { "Publishing label" }
|
||||||
|
composer:string { "Composer" }
|
||||||
|
bitrate:string { "Bitrate" }
|
||||||
|
channels:string { "Channels" }
|
||||||
|
sample_rate:string { "Sample rate" }
|
||||||
|
encoding_software:string { "Encoding software" }
|
||||||
|
checksum:string { "Checksum" }
|
||||||
|
lyrics:string { "Lyrics" }
|
||||||
|
orchestra_or_band:string { "Orchestra or band" }
|
||||||
|
conductor:string { "Conductor" }
|
||||||
|
lyricist:string { "Lyricist" }
|
||||||
|
original_lyricist:string { "Original lyricist" }
|
||||||
|
radio_station_name:string { "Radio station name" }
|
||||||
|
audio_file_info_url:string { "File info web page" }
|
||||||
|
artist_url:string { "Artist web page" }
|
||||||
|
audio_source_url:string { "Source web page" }
|
||||||
|
buy_cd_url:string { "Buy CD web page" }
|
||||||
|
isrc_number:string { "ISRC number" }
|
||||||
|
catalog_number:string { "Catalog number" }
|
||||||
|
original_artist:string { "Original artist" }
|
||||||
|
copyright:string { "Copyright" }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -191,5 +191,44 @@ root:table
|
||||||
|
|
||||||
cuePlayerLabel:string { "Preview" }
|
cuePlayerLabel:string { "Preview" }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
metadataTypes:table
|
||||||
|
{
|
||||||
|
title:string { "Title" }
|
||||||
|
creator:string { "Creator" }
|
||||||
|
album:string { "Album" }
|
||||||
|
year:string { "Year" }
|
||||||
|
genre:string { "Genre" }
|
||||||
|
description:string { "Description" }
|
||||||
|
format:string { "Format" }
|
||||||
|
length:string { "Length" }
|
||||||
|
bpm:string { "BPM" }
|
||||||
|
rating:string { "Rating" }
|
||||||
|
encoded_by:string { "Encoded by" }
|
||||||
|
track_number:string { "Track number" }
|
||||||
|
disc_number:string { "Disc number" }
|
||||||
|
mood:string { "Mood" }
|
||||||
|
publishing_label:string { "Publishing label" }
|
||||||
|
composer:string { "Composer" }
|
||||||
|
bitrate:string { "Bitrate" }
|
||||||
|
channels:string { "Channels" }
|
||||||
|
sample_rate:string { "Sample rate" }
|
||||||
|
encoding_software:string { "Encoding software" }
|
||||||
|
checksum:string { "Checksum" }
|
||||||
|
lyrics:string { "Lyrics" }
|
||||||
|
orchestra_or_band:string { "Orchestra or band" }
|
||||||
|
conductor:string { "Conductor" }
|
||||||
|
lyricist:string { "Lyricist" }
|
||||||
|
original_lyricist:string { "Original lyricist" }
|
||||||
|
radio_station_name:string { "Radio station name" }
|
||||||
|
audio_file_info_url:string { "File info web page" }
|
||||||
|
artist_url:string { "Artist web page" }
|
||||||
|
audio_source_url:string { "Source web page" }
|
||||||
|
buy_cd_url:string { "Buy CD web page" }
|
||||||
|
isrc_number:string { "ISRC number" }
|
||||||
|
catalog_number:string { "Catalog number" }
|
||||||
|
original_artist:string { "Original artist" }
|
||||||
|
copyright:string { "Copyright" }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue