aboutsummaryrefslogtreecommitdiffstats
path: root/themes
diff options
context:
space:
mode:
authormistic100 <mistic@piwigo.org>2014-05-17 22:04:36 +0000
committermistic100 <mistic@piwigo.org>2014-05-17 22:04:36 +0000
commit914b6d96d2cae67507ef848a7a229fd5319d7968 (patch)
tree97d0c9f0741ddb6ddee8cfbb20717b6b0fd9b75e /themes
parentce8a29810abe6f7fdf82043b32ca87ba0f14220c (diff)
feature 3080 : simpler date inputs (one input + fontello + picker selects)
git-svn-id: http://piwigo.org/svn/trunk@28497 68402e56-0260-453c-a942-63ccdbb3a9ee
Diffstat (limited to 'themes')
-rw-r--r--themes/default/js/datepicker.js188
-rw-r--r--themes/default/template/include/datepicker.inc.tpl18
-rw-r--r--themes/default/template/search.tpl11
3 files changed, 0 insertions, 217 deletions
diff --git a/themes/default/js/datepicker.js b/themes/default/js/datepicker.js
deleted file mode 100644
index ff2c2d4d2..000000000
--- a/themes/default/js/datepicker.js
+++ /dev/null
@@ -1,188 +0,0 @@
-// initialize controls
-// buttonImageName: Directory and name of calendar picture
-// day, month, year: selectors of visible date controls
-// linked_date: selector of hidden linked dates control
-// checked_on_change: selector of control to change "checked" attribut
-// min_linked_date: selector of hidden linked date control witch give min value
-// max_linked_date: selector of hidden linked date control witch give max value
-function pwg_common_initialization_datepicker(buttonImageName, day, month, year, linked_date, checked_on_change, min_linked_date, max_linked_date)
-{
- // return formated date with control values
- function pwg_get_fmt_from_ctrls()
- {
- return $(year).val() + "-" + $(month).val() + "-" + $(day).val();
- }
-
- // return if linked_date is valid date
- function is_valid_linked_value(linked_date_name)
- {
- var array_date = $(linked_date_name).val().split('-');
- return (
- (array_date.length == 3) &&
- (array_date[0].length) &&
- (array_date[1].length) && (array_date[1] != "0") &&
- (array_date[2].length) && (array_date[2] != "0")
- )
- }
-
- // Action on change date value
- function pwg_on_date_change()
- {
- pwg_check_date();
- if (checked_on_change != null)
- {
- $(checked_on_change).prop("checked", true);
- }
- }
-
- // In order to desable element of list
- function pwg_disabled_selection()
- {
- var array_date = $(linked_date).val().split('-')
- , y = array_date[0]
- , m = array_date[1];
-
- // Init list
- $(day + " option").removeAttr("disabled");
- $(month + " option").removeAttr("disabled");
-
- var daysInMonth = 32 - new Date(y, m - 1, 32).getDate();
- $(day + " option:gt(" + (daysInMonth) +")").attr("disabled", "disabled");
-
- if ((min_linked_date != null) && (is_valid_linked_value(min_linked_date) == true))
- {
- date_cmp = min_linked_date;
- op_cmp = "lt";
- }
- else if ((max_linked_date != null) && (is_valid_linked_value(max_linked_date) == true))
- {
- date_cmp = max_linked_date;
- op_cmp = "gt";
- }
- else
- {
- date_cmp = null;
- op_cmp = null;
- }
-
- if (op_cmp != null)
- {
- array_date = $(date_cmp).val().split('-');
- y_cmp = array_date[0];
- m_cmp = array_date[1];
- d_cmp = array_date[2];
-
- if (y == y_cmp)
- {
- $(month + " option:" + op_cmp + "(" + (m_cmp) +")").attr("disabled", "disabled");
- if (op_cmp == "lt")
- {
- $(month + " option:eq(" + (0) +")").removeAttr("disabled");
- }
-
- if (m == m_cmp)
- {
- $(day + " option:" + op_cmp + "(" + (d_cmp) +")").attr("disabled", "disabled");
- if (op_cmp == "lt")
- {
- $(day + " option:eq(" + (0) +")").removeAttr("disabled");
- }
- }
- }
- }
- }
-
- // Prevent selection of invalid dates through the select controls
- function pwg_check_date()
- {
- var last_date = $(linked_date).val()
- , cancel=false;
-
- $(linked_date).val(pwg_get_fmt_from_ctrls());
-
- if ((min_linked_date != null) && (is_valid_linked_value(min_linked_date)))
- {
- cancel = ($(min_linked_date).datepicker("getDate") > $(linked_date).datepicker("getDate"));
- }
- else if ((max_linked_date != null) && (is_valid_linked_value(max_linked_date)))
- {
- cancel = ($(max_linked_date).datepicker("getDate") < $(linked_date).datepicker("getDate"));
- }
-
- if (cancel)
- {
- var array_date = last_date.split('-');
- $(year).val(array_date[0]);
- $(month).val(array_date[1]);
- $(day).val(array_date[2]);
- // check again
- pwg_check_date();
- }
- }
-
- jQuery().ready(function(){
- // Init hidden value
- $(linked_date).val(pwg_get_fmt_from_ctrls());
-
- // Init Datepicker
- jQuery(linked_date).datepicker({
- dateFormat:'yy-m-d',
- beforeShow:
- // Prepare to show a date picker linked to three select controls
- function readLinked(input) {
- if (min_linked_date != null)
- {
- return {minDate: $(min_linked_date).datepicker("getDate")};
- }
- else if (max_linked_date != null)
- {
- return {maxDate: $(max_linked_date).datepicker("getDate")};
- }
- else
- {
- return {};
- }
- },
- onSelect:
- // Update three select controls to match a date picker selection
- function updateLinked(date) {
- if (date.length == 0)
- {
- $(year).val("");
- $(month).val("0");
- $(day).val("0");
- }
- else
- {
- var array_date = date.split('-');
- $(year).val(array_date[0]);
- $(month).val(array_date[1]);
- $(day).val(array_date[2]);
- }
- pwg_on_date_change();
- },
- showOn: "both",
- buttonImage: buttonImageName,
- buttonImageOnly: true,
- buttonText: ""
- });
-
- // Check showed controls
- jQuery(day + ", " + month + ", " + year).change(
- function ()
- {
- pwg_on_date_change();
- });
-
- // Check showed controls
- jQuery(day + ", " + month + ", " + year).focus(
- function ()
- {
- pwg_disabled_selection();
- });
-
- // In order to init linked input
- pwg_check_date();
- });
-
-}
diff --git a/themes/default/template/include/datepicker.inc.tpl b/themes/default/template/include/datepicker.inc.tpl
deleted file mode 100644
index 9b58b0d2d..000000000
--- a/themes/default/template/include/datepicker.inc.tpl
+++ /dev/null
@@ -1,18 +0,0 @@
-{combine_script id='datepicker.js' load='footer' require='jquery.ui.datepicker' path='themes/default/js/datepicker.js'}
-
-{assign var="datepicker_language" value="themes/default/js/ui/i18n/jquery.ui.datepicker-`$lang_info.code`.js"}
-
-{if "PHPWG_ROOT_PATH"|@constant|@cat:$datepicker_language|@file_exists}
-{combine_script id="jquery.ui.datepicker-$lang_info.code" load='footer' path=$datepicker_language}
-{/if}
-
-{combine_css path="themes/default/js/ui/theme/jquery.ui.datepicker.css"}
-
-{footer_script require='jquery.ui.datepicker,datepicker.js'}
-function pwg_initialization_datepicker(day, month, year, linked_date, checked_on_change, min_linked_date, max_linked_date)
-{ldelim}
- return pwg_common_initialization_datepicker(
- "{$ROOT_URL}{$themeconf.icon_dir}/datepicker.png",
- day, month, year, linked_date, checked_on_change, min_linked_date, max_linked_date);
-}
-{/footer_script}
diff --git a/themes/default/template/search.tpl b/themes/default/template/search.tpl
index 4db60eb96..56c142182 100644
--- a/themes/default/template/search.tpl
+++ b/themes/default/template/search.tpl
@@ -3,17 +3,6 @@
{include file='include/resize.inc.tpl'}
*}
-{* Example of datepicker *}
-{*
-{include file='include/datepicker.inc.tpl'}
-
-{footer_script}{literal}
- pwg_initialization_datepicker("#start_day", "#start_month", "#start_year", "#start_linked_date", null, null, "#end_linked_date");
- pwg_initialization_datepicker("#end_day", "#end_month", "#end_year", "#end_linked_date", null, "#start_linked_date", null);
- jQuery().ready(function(){ $(".date_today").hide(); });
-{/literal}{/footer_script}
-*}
-
{if isset($MENUBAR)}{$MENUBAR}{/if}
<div id="content" class="content{if isset($MENUBAR)} contentWithMenu{/if}">