/**
-<<<<<<< HEAD
-=======
* @defgroup Calendar Calendar
+ * @ingroup Elementary
*
* This is a Calendar widget. Calender widget helps applications to flexibly
* display a calender with day of the week, day, year and month. Applications will be
* able to choose a specific date that will be reported in the smart_callbacks for
- * the calendar widget. The APIs of calendar widget let the applications perform
+ * the calendar widget. The APIs of calendar widget let the applications perform
* other functions like,
* placing marks on specific dates
* Setting the bounds for the calendar (minimum and maximum years)
* - @c "changed" - emitted when the date in the calendar is changed.
*
* Supported elm_object common APIs.
- * @li elm_object_signal_emit
- * @li elm_object_signal_callback_add
- * @li elm_object_signal_callback_del
- *
+ * @li @ref elm_object_signal_emit
+ * @li @ref elm_object_signal_callback_add
+ * @li @ref elm_object_signal_callback_del
+ *
+ * Here is some sample code using it:
+ * @li @ref calendar_example_01
+ * @li @ref calendar_example_02
+ * @li @ref calendar_example_03
+ * @li @ref calendar_example_04
+ * @li @ref calendar_example_05
+ * @li @ref calendar_example_06
*/
/**
->>>>>>> remotes/origin/upstream
* @addtogroup Calendar
* @{
*/
-<<<<<<< HEAD
-/**
- * @enum _Elm_Calendar_Mark_Repeat
- * @typedef Elm_Calendar_Mark_Repeat
-=======
typedef enum
{
ELM_CALENDAR_UNIQUE, /**< Default value. Marks will be displayed only on event day. */
/**
* @enum _Elm_Calendar_Mark_Repeat_Type
* @typedef Elm_Calendar_Mark_Repeat_Type
->>>>>>> remotes/origin/upstream
*
* Event periodicity, used to define if a mark should be repeated
* @b beyond event's day. It's set when a mark is added.
* there will be marks every week after this date. Marks will be displayed
* at 13th, 20th, 27th, 3rd June ...
*
-<<<<<<< HEAD
- * Values don't work as bitmask, only one can be choosen.
- *
- * Supported elm_object common APIs.
- * @li elm_object_signal_emit
- * @li elm_object_signal_callback_add
- * @li elm_object_signal_callback_del
-=======
* Values don't work as bitmask, only one can be chosen.
->>>>>>> remotes/origin/upstream
*
* @see elm_calendar_mark_add()
*
* @ingroup Calendar
*/
-<<<<<<< HEAD
+typedef _Elm_Calendar_Mark_Repeat_Type Elm_Calendar_Mark_Repeat_Type;
+
typedef enum
{
- ELM_CALENDAR_UNIQUE, /**< Default value. Marks will be displayed only on event day. */
- ELM_CALENDAR_DAILY, /**< Marks will be displayed everyday after event day (inclusive). */
- ELM_CALENDAR_WEEKLY, /**< Marks will be displayed every week after event day (inclusive) - i.e. each seven days. */
- ELM_CALENDAR_MONTHLY, /**< Marks will be displayed every month day that coincides to event day. E.g.: if an event is set to 30th Jan, no marks will be displayed on Feb, but will be displayed on 30th Mar*/
- ELM_CALENDAR_ANNUALLY /**< Marks will be displayed every year that coincides to event day (and month). E.g. an event added to 30th Jan 2012 will be repeated on 30th Jan 2013. */
-} Elm_Calendar_Mark_Repeat;
-=======
-typedef _Elm_Calendar_Mark_Repeat_Type Elm_Calendar_Mark_Repeat_Type;
->>>>>>> remotes/origin/upstream
+ ELM_DAY_SUNDAY,
+ ELM_DAY_MONDAY,
+ ELM_DAY_TUESDAY,
+ ELM_DAY_WEDNESDAY,
+ ELM_DAY_THURSDAY,
+ ELM_DAY_FRIDAY,
+ ELM_DAY_SATURDAY,
+ ELM_DAY_LAST
+} _Elm_Calendar_Weekday;
+
+/**
+ * @enum _Elm_Calendar_Weekday
+ * @typedef Elm_Calendar_Weekday
+ *
+ * a weekday
+ *
+ * @see elm_calendar_first_day_of_week_set()
+ *
+ * @ingroup Calendar
+ */
+typedef _Elm_Calendar_Weekday Elm_Calendar_Weekday;
+
+
+typedef enum
+{
+ ELM_CALENDAR_SELECT_MODE_DEFAULT = 0, /**< Default value. a day is always selected. */
+ ELM_CALENDAR_SELECT_MODE_ALWAYS, /**< a day is always selected. */
+ ELM_CALENDAR_SELECT_MODE_NONE, /**< None of the days can be selected. */
+ ELM_CALENDAR_SELECT_MODE_ONDEMAND /**< User may have selected a day or not. */
+} _Elm_Calendar_Select_Mode;
+
+/**
+ * @enum _Elm_Calendar_Select_Mode
+ * @typedef Elm_Calendar_Select_Mode
+ *
+ * the mode, who determine how user could select a day
+ *
+ * @see elm_calendar_select_mode_set()
+ *
+ * @ingroup Calendar
+ */
+typedef _Elm_Calendar_Select_Mode Elm_Calendar_Select_Mode;
typedef struct _Elm_Calendar_Mark Elm_Calendar_Mark; /**< Item handle for a calendar mark. Created with elm_calendar_mark_add() and deleted with elm_calendar_mark_del(). */
/**
-<<<<<<< HEAD
-=======
* @typedef Elm_Calendar_Format_Cb
*
* This callback type is used to format the string that will be used
* @return String representing time that will be set to calendar's text.
*
* @see elm_calendar_format_function_set()
+ *
+ * @ingroup Calendar
*/
typedef char * (*Elm_Calendar_Format_Cb)(struct tm *stime);
/**
->>>>>>> remotes/origin/upstream
* Add a new calendar widget to the given parent Elementary
* (container) object.
*
* @param min The minimum year, greater than 1901;
* @param max The maximum year;
*
-<<<<<<< HEAD
- * Maximum must be greater than minimum, except if you don't wan't to set
-=======
* Maximum must be greater than minimum, except if you don't want to set
->>>>>>> remotes/origin/upstream
* maximum year.
* Default values are 1902 and -1.
*
EAPI void elm_calendar_min_max_year_get(const Evas_Object *obj, int *min, int *max);
/**
- * Enable or disable day selection
+ * Set select day mode to use.
*
* @param obj The calendar object.
-<<<<<<< HEAD
- * @param enabled @c EINA_TRUE to enable selection or @c EINA_FALSE to
- * disable it.
-=======
- * @param disabled @c EINA_TRUE to disable selection or @c EINA_FALSE to
- * enable it.
->>>>>>> remotes/origin/upstream
- *
- * Enabled by default. If disabled, the user still can select months,
- * but not days. Selected days are highlighted on calendar.
- * It should be used if you won't need such selection for the widget usage.
- *
- * When a day is selected, or month is changed, smart callbacks for
- * signal "changed" will be called.
- *
-<<<<<<< HEAD
- * @see elm_calendar_day_selection_enable_get()
-=======
- * @see elm_calendar_day_selection_disabled_get()
->>>>>>> remotes/origin/upstream
+ * @param select_mdoe The select mode to use.
*
- * @ref calendar_example_04
+ * Set the day selection mode used.
*
* @ingroup Calendar
*/
-<<<<<<< HEAD
-EAPI void elm_calendar_day_selection_enabled_set(Evas_Object *obj, Eina_Bool enabled);
+EAPI void elm_calendar_select_mode_set(Evas_Object *obj, Elm_Calendar_Select_Mode mode);
/**
- * Get a value whether day selection is enabled or not.
- *
- * @see elm_calendar_day_selection_enable_set() for details.
+ * Get the select day mode used.
*
* @param obj The calendar object.
- * @return EINA_TRUE means day selection is enabled. EINA_FALSE indicates
- * it's disabled. If @p obj is NULL, EINA_FALSE is returned.
-=======
-EAPI void elm_calendar_day_selection_disabled_set(Evas_Object *obj, Eina_Bool disabled);
-
-/**
- * Get a value whether day selection is disabled or not.
*
- * @param obj The calendar object.
- * @return EINA_TRUE means day selection is disabled. EINA_FALSE indicates
- * it's enabled. If @p obj is NULL, EINA_FALSE is returned.
+ * @return the selected mode
*
- * @see elm_calendar_day_selection_disabled_set() for details.
->>>>>>> remotes/origin/upstream
+ * Get the day selection mode used.
*
- * @ref calendar_example_05
+ * @see elm_calendar_select_mode_set() for more details
*
* @ingroup Calendar
*/
-<<<<<<< HEAD
-EAPI Eina_Bool elm_calendar_day_selection_enabled_get(const Evas_Object *obj);
-=======
-EAPI Eina_Bool elm_calendar_day_selection_disabled_get(const Evas_Object *obj);
->>>>>>> remotes/origin/upstream
+EAPI Elm_Calendar_Select_Mode elm_calendar_select_mode_get(const Evas_Object *obj);
/**
* Set selected date to be highlighted on calendar.
*
* @param obj The calendar object
* @param selected_time A @b tm struct to point to selected date
-<<<<<<< HEAD
- * @return EINA_FALSE means an error ocurred and returned time shouldn't
-=======
* @return EINA_FALSE means an error occurred and returned time shouldn't
->>>>>>> remotes/origin/upstream
* be considered.
*
* Get date selected by the user or set by function
* month and year;
*
* @param obj The calendar object
- * @param format_function Function to set the month-year string given
+ * @param format_func Function to set the month-year string given
* the selected date
*
* By default it uses strftime with "%B %Y" format string.
*
* @ingroup Calendar
*/
-<<<<<<< HEAD
-EAPI void elm_calendar_format_function_set(Evas_Object *obj, char *(*format_function)(struct tm *stime));
-=======
EAPI void elm_calendar_format_function_set(Evas_Object *obj, Elm_Calendar_Format_Cb format_func);
->>>>>>> remotes/origin/upstream
/**
* Add a new mark to the calendar
*
* @ingroup Calendar
*/
-<<<<<<< HEAD
-EAPI Elm_Calendar_Mark *elm_calendar_mark_add(Evas_Object *obj, const char *mark_type, struct tm *mark_time, Elm_Calendar_Mark_Repeat repeat);
-=======
EAPI Elm_Calendar_Mark *elm_calendar_mark_add(Evas_Object *obj, const char *mark_type, struct tm *mark_time, Elm_Calendar_Mark_Repeat_Type repeat);
->>>>>>> remotes/origin/upstream
/**
* Delete mark from the calendar.
* this function.
*
* When the month is changed, i.e. user selects next or previous month,
-<<<<<<< HEAD
- * marks will be drawed.
-=======
* marks will be drawn.
->>>>>>> remotes/origin/upstream
*
* @see elm_calendar_mark_add()
* @see elm_calendar_mark_del()
EAPI double elm_calendar_interval_get(const Evas_Object *obj);
/**
+ * Set the first day of week to use on calendar widgets'.
+ *
+ * @param obj The calendar object
+ * @param day An int which correspond to the first day of the week (Sunday = 0, monday = 1,
+ * ..., saturday = 6)
+ *
+ * @ingroup Calendar
+ */
+EAPI void elm_calendar_first_day_of_week_set(Evas_Object *obj, Elm_Calendar_Weekday day);
+
+/**
+ * Get the first day of week, who are used on calendar widgets'.
+ *
+ * @param obj The calendar object
+ * @return An int which correspond to the first day of the week (Sunday = 0, monday = 1,
+ * ..., saturday = 6)
+ *
+ * @see elm_calendar_first_day_of_week_set() for more details
+ *
+ * @ingroup Calendar
+ */
+EAPI Elm_Calendar_Weekday elm_calendar_first_day_of_week_get(const Evas_Object *obj);
+
+/**
* @}
*/