31.03.2015, 18:07
|
Интересующийся
|
|
Регистрация: 31.03.2015
Сообщений: 27
|
|
Календарь. Стрелочка. Помогите!
Доброе время суток! Возникла беда со скриптом, нужна помощь, не знаю что делать. Есть скрипт календаря:
function getObj(objID)
{
if (document.getElementById) {return document.getElementById(objID);}
else if (document.all) {return document.all[objID];}
else if (document.layers) {return document.layers[objID];}
}
function checkClick(e) {
e?evt=e:evt=event;
CSE=evt.target?evt.target:evt.srcElement;
if (CSE.tagName!='SPAN')
if (getObj('fc'))
if (!isChild(CSE,getObj('fc')))
getObj('fc').style.display='none';
}
function isChild(s,d) {
while(s) {
if (s==d)
return true;
s=s.parentNode;
}
return false;
}
function Left(obj)
{
var curleft = 0;
if (obj.offsetParent)
{
while (obj.offsetParent)
{
curleft += obj.offsetLeft
obj = obj.offsetParent;
}
}
else if (obj.x)
curleft += obj.x;
return curleft;
}
function Top(obj)
{
var curtop = 0;
if (obj.offsetParent)
{
while (obj.offsetParent)
{
curtop += obj.offsetTop
obj = obj.offsetParent;
}
}
else if (obj.y)
curtop += obj.y;
return curtop;
}
// Calendar script
var now = new Date;
var sccd=now.getDate();
var sccm=now.getMonth();
var sccy=now.getFullYear();
var ccm=now.getMonth();
var ccy=now.getFullYear();
// For current selected date
var selectedd, selectedm, selectedy;
document.write('<table id="fc" style="z-index: 100; position: fixed; margin-top: -100px; margin-left: 17.25%; width: 350px; border: 1px solid rgb(242, 140, 38); background: none repeat scroll 0% 0% rgb(251, 251, 251);border-collapse:collapse;display:none;-moz-user-select:none;-khtml-user-select:none;user-select:none;" cellpadding="2">');
document.write('<tbody style="display: block; padding: 15px"><tr onselectstart="return false"><td style="cursor:pointer;font-size:48px;font-family: PTSans,sans-serif;padding-left:30px;" onclick="upmonth(-1)">‹</td><td style="color: rgb(242, 140, 38); font-family: PTSans,sans-serif; font-size: 24pt; padding: 25px;" colspan="5" id="mns" align="center" ></td><td align="right" style="cursor:pointer;font-size:48px;font-family: PTSans,sans-serif;padding-right:30px;" onclick="upmonth(1)">›</td></tr>');
document.write('<tr style="font-family: PTSans,sans-serif; line-height: 1; font-size: 18px;"><td align=center>ПН</td><td align=center>ВТ</td><td align=center>СР</td><td align=center>ЧТ</td><td align=center>ПТ</td><td align=center>СБ</td><td align=center>ВС</td></tr>');
for(var kk=1;kk<=6;kk++) {
document.write('<tr>');
for(var tt=1;tt<=7;tt++) {
num=7 * (kk-1) - (-tt);
document.write('<td id="cv' + num + '" style="width:10px;height:10px"> </td>');
}
document.write('</tr>');
}
document.write('<tr><td colspan="7" align="center" style="cursor:pointer;font:18px PTSans,sans-serif;background:#F28C26;padding:5px;color:#fff;" onclick="today()">Сегодня: '+addnull(sccd,sccm+1,sccy)+'</td></tr>');
document.write('</table>');
document.all?document.attachEvent('onclick',checkClick):document.addEventListener('click',checkClick,false);
var updobj;
function lcs(ielem) {
updobj=ielem;
getObj('fc').style.left=Left(ielem)+'px';
getObj('fc').style.top=Top(ielem)+ielem.offsetHeight+'px';
getObj('fc').style.display='';
// First check date is valid
curdt=ielem.value;
curdtarr=curdt.split('-');
isdt=true;
for(var k=0;k<curdtarr.length;k++) {
if (isNaN(curdtarr[k]))
isdt=false;
}
if (isdt&(curdtarr.length==3)) {
ccm=curdtarr[1]-1;
ccy=curdtarr[2];
selectedd=parseInt ( curdtarr[0], 10 );
selectedm=parseInt ( curdtarr[1]-1, 10 );
selectedy=parseInt ( curdtarr[2], 10 );
prepcalendar(curdtarr[0],curdtarr[1]-1,curdtarr[2]);
}
}
function evtTgt(e){
var el;
if(e.target)el=e.target;
else if(e.srcElement)el=e.srcElement;
if(el.nodeType==3)el=el.parentNode; // defeat Safari bug
return el;
}
function EvtObj(e){if(!e)e=window.event;return e;}
function cs_over(e) {
evtTgt(EvtObj(e)).style.background='#FFEBCC';
}
function cs_out(e) {
evtTgt(EvtObj(e)).style.background='#FFFFFF';
}
function cs_click(e) {
updobj.value=calvalarr[evtTgt(EvtObj(e)).id.substring(2,evtTgt(EvtObj(e)).id.length)];
getObj('fc').style.display='none';
}
var mn=new Array('Январь','Февраль','Март','Апрель','Май','Июнь','Июль','Август','Сентрябрь','Октябрь','Ноябрь','Декабрь');
var mnn=new Array('31','28','31','30','31','30','31','31','30','31','30','31');
var mnl=new Array('31','29','31','30','31','30','31','31','30','31','30','31');
var calvalarr=new Array(42);
function f_cps(obj) {
obj.style.background='';
obj.style.font='18px PTSans, sans-serif;';
obj.style.color='#535558';
obj.style.textAlign='center';
obj.style.textDecoration='none';
obj.style.border='';
obj.style.cursor='pointer';
}
function f_cpps(obj) {
obj.style.background='#C4D3EA';
obj.style.font='18px PTSans, sans-serif;';
obj.style.color='#FF9900';
obj.style.textAlign='center';
obj.style.textDecoration='line-through';
obj.style.border='1px solid #6487AE';
obj.style.cursor='default';
}
function f_hds(obj) {
obj.style.background='#FFF799';
obj.style.font='bold 18px PTSans, sans-serif;';
obj.style.color='#333333';
obj.style.textAlign='center';
obj.style.border='1px solid #6487AE';
obj.style.cursor='pointer';
}
// day selected
function prepcalendar(hd,cm,cy) {
now=new Date();
sd=now.getDate();
td=new Date();
td.setDate(1);
td.setFullYear(cy);
td.setMonth(cm);
cd=td.getDay();
if (cd==0)cd=6; else cd--;
getObj('mns').innerHTML=mn[cm]+' <span style="cursor:pointer" onclick="upmonth(-12)">‹</span>'+cy+'<span style="cursor:pointer" onclick="upmonth(12)">›</span>';
marr=((cy%4)==0)?mnl:mnn;
for(var d=1;d<=42;d++) {
cv=getObj('cv'+parseInt(d));
f_cps(cv);
if ((d >= (cd -(-1)))&&(d<=cd-(-marr[cm]))) {
dip=((d-cd < sd)&&(cm==sccm)&&(cy==sccy));
htd=((hd!='')&&(d-cd==hd));
cv.onmouseover=cs_over;
cv.onmouseout=cs_out;
cv.onclick=cs_click;
// if today
if (sccm == cm && sccd == (d-cd) && sccy == cy)
cv.style.color='#FF9900';
// if selected date
if (cm == selectedm && cy == selectedy && selectedd == (d-cd) )
{
cv.style.background='#FFEBCC';
//cv.style.color='#e0d0c0';
//cv.style.fontSize='1.1em';
//cv.style.fontStyle='italic';
//cv.style.fontWeight='bold';
// when use style.background
cv.onmouseout=null;
}
cv.innerHTML=d-cd;
calvalarr[d]=addnull(d-cd,cm-(-1),cy);
}
else {
cv.innerHTML=' ';
cv.onmouseover=null;
cv.onmouseout=null;
cv.onclick=null;
cv.style.cursor='default';
}
}
}
prepcalendar('',ccm,ccy);
function upmonth(s)
{
marr=((ccy%4)==0)?mnl:mnn;
ccm+=s;
if (ccm>=12)
{
ccm-=12;
ccy++;
}
else if(ccm<0)
{
ccm+=12;
ccy--;
}
prepcalendar('',ccm,ccy);
}
function today() {
updobj.value=addnull(now.getDate(),now.getMonth()+1,now.getFullYear());
getObj('fc').style.display='none';
prepcalendar('',sccm,sccy);
}
function addnull(d,m,y)
{
var d0='',m0='';
if (d<10)d0='0';
if (m<10)m0='0';
return ''+d0+d+'-'+m0+m+'-'+y;
}
Выглядит он вот так, нужно добавить стрелочку, но средствами js без понятия как решить...(
|
|
31.03.2015, 18:16
|
Интересующийся
|
|
Регистрация: 31.03.2015
Сообщений: 27
|
|
В гугле смотрел, стили не подключаются, если есть знающие, помогите пожалуйста.
|
|
31.03.2015, 18:59
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,124
|
|
Sylar V,
напечатайте стили если нормально никак
<!DOCTYPE HTML>
<html>
<head>
<title>Untitled</title><meta charset="utf-8">
</head>
<body>
<script>
function getObj(objID)
{
if (document.getElementById) {return document.getElementById(objID);}
else if (document.all) {return document.all[objID];}
else if (document.layers) {return document.layers[objID];}
}
function checkClick(e) {
e?evt=e:evt=event;
CSE=evt.target?evt.target:evt.srcElement;
if (CSE.tagName!='SPAN')
if (getObj('fc'))
if (!isChild(CSE,getObj('fc')))
getObj('fc').style.display='none';
}
function isChild(s,d) {
while(s) {
if (s==d)
return true;
s=s.parentNode;
}
return false;
}
function Left(obj)
{
var curleft = 0;
if (obj.offsetParent)
{
while (obj.offsetParent)
{
curleft += obj.offsetLeft
obj = obj.offsetParent;
}
}
else if (obj.x)
curleft += obj.x;
return curleft;
}
function Top(obj)
{
var curtop = 0;
if (obj.offsetParent)
{
while (obj.offsetParent)
{
curtop += obj.offsetTop
obj = obj.offsetParent;
}
}
else if (obj.y)
curtop += obj.y;
return curtop;
}
// Calendar script
var now = new Date;
var sccd=now.getDate();
var sccm=now.getMonth();
var sccy=now.getFullYear();
var ccm=now.getMonth();
var ccy=now.getFullYear();
// For current selected date
var selectedd, selectedm, selectedy;
document.write('<table id="fc" style="z-index: 100; position: fixed; margin-top: 10px; margin-left: 17.25%; width: 350px; border: 1px solid rgb(242, 140, 38); background: none repeat scroll 0% 0% rgb(251, 251, 251);border-collapse:collapse;-moz-user-select:none;-khtml-user-select:none;user-select:none;" cellpadding="2">');
document.write('<tbody style="display: block; padding: 15px"><tr onselectstart="return false"><td style="cursor:pointer;font-size:48px;font-family: PTSans,sans-serif;padding-left:30px;" onclick="upmonth(-1)">‹</td><td style="color: rgb(242, 140, 38); font-family: PTSans,sans-serif; font-size: 24pt; padding: 25px;" colspan="5" id="mns" align="center" ></td><td align="right" style="cursor:pointer;font-size:48px;font-family: PTSans,sans-serif;padding-right:30px;" onclick="upmonth(1)">›</td></tr>');
document.write('<tr style="font-family: PTSans,sans-serif; line-height: 1; font-size: 18px;"><td align=center>ПН</td><td align=center>ВТ</td><td align=center>СР</td><td align=center>ЧТ</td><td align=center>ПТ</td><td align=center>СБ</td><td align=center>ВС</td></tr>');
for(var kk=1;kk<=6;kk++) {
document.write('<tr>');
for(var tt=1;tt<=7;tt++) {
num=7 * (kk-1) - (-tt);
document.write('<td id="cv' + num + '" style="width:10px;height:10px"> </td>');
}
document.write('</tr>');
}
document.write('<tr><td colspan="7" align="center" style="cursor:pointer;font:18px PTSans,sans-serif;background:#F28C26;padding:5px;color:#fff;" onclick="today()">Сегодня: '+addnull(sccd,sccm+1,sccy)+'</td></tr>');
document.write('</table>');
document.all?document.attachEvent('onclick',checkClick):document.addEventListener('click',checkClick,false);
var updobj;
function lcs(ielem) {
updobj=ielem;
getObj('fc').style.left=Left(ielem)+'px';
getObj('fc').style.top=Top(ielem)+ielem.offsetHeight+'px';
getObj('fc').style.display='';
// First check date is valid
curdt=ielem.value;
curdtarr=curdt.split('-');
isdt=true;
for(var k=0;k<curdtarr.length;k++) {
if (isNaN(curdtarr[k]))
isdt=false;
}
if (isdt&(curdtarr.length==3)) {
ccm=curdtarr[1]-1;
ccy=curdtarr[2];
selectedd=parseInt ( curdtarr[0], 10 );
selectedm=parseInt ( curdtarr[1]-1, 10 );
selectedy=parseInt ( curdtarr[2], 10 );
prepcalendar(curdtarr[0],curdtarr[1]-1,curdtarr[2]);
}
}
function evtTgt(e){
var el;
if(e.target)el=e.target;
else if(e.srcElement)el=e.srcElement;
if(el.nodeType==3)el=el.parentNode; // defeat Safari bug
return el;
}
function EvtObj(e){if(!e)e=window.event;return e;}
function cs_over(e) {
evtTgt(EvtObj(e)).style.background='#FFEBCC';
}
function cs_out(e) {
evtTgt(EvtObj(e)).style.background='#FFFFFF';
}
function cs_click(e) {
updobj.value=calvalarr[evtTgt(EvtObj(e)).id.substring(2,evtTgt(EvtObj(e)).id.length)];
getObj('fc').style.display='none';
}
var mn=new Array('Январь','Февраль','Март','Апрель','Май','Июнь','Июль','Август','Сентрябрь','Октябрь','Ноябрь','Декабрь');
var mnn=new Array('31','28','31','30','31','30','31','31','30','31','30','31');
var mnl=new Array('31','29','31','30','31','30','31','31','30','31','30','31');
var calvalarr=new Array(42);
function f_cps(obj) {
obj.style.background='';
obj.style.font='18px PTSans, sans-serif;';
obj.style.color='#535558';
obj.style.textAlign='center';
obj.style.textDecoration='none';
obj.style.border='';
obj.style.cursor='pointer';
}
function f_cpps(obj) {
obj.style.background='#C4D3EA';
obj.style.font='18px PTSans, sans-serif;';
obj.style.color='#FF9900';
obj.style.textAlign='center';
obj.style.textDecoration='line-through';
obj.style.border='1px solid #6487AE';
obj.style.cursor='default';
}
function f_hds(obj) {
obj.style.background='#FFF799';
obj.style.font='bold 18px PTSans, sans-serif;';
obj.style.color='#333333';
obj.style.textAlign='center';
obj.style.border='1px solid #6487AE';
obj.style.cursor='pointer';
}
// day selected
function prepcalendar(hd,cm,cy) {
now=new Date();
sd=now.getDate();
td=new Date();
td.setDate(1);
td.setFullYear(cy);
td.setMonth(cm);
cd=td.getDay();
if (cd==0)cd=6; else cd--;
getObj('mns').innerHTML=mn[cm]+' <span style="cursor:pointer" onclick="upmonth(-12)">‹</span>'+cy+'<span style="cursor:pointer" onclick="upmonth(12)">›</span>';
marr=((cy%4)==0)?mnl:mnn;
for(var d=1;d<=42;d++) {
cv=getObj('cv'+parseInt(d));
f_cps(cv);
if ((d >= (cd -(-1)))&&(d<=cd-(-marr[cm]))) {
dip=((d-cd < sd)&&(cm==sccm)&&(cy==sccy));
htd=((hd!='')&&(d-cd==hd));
cv.onmouseover=cs_over;
cv.onmouseout=cs_out;
cv.onclick=cs_click;
// if today
if (sccm == cm && sccd == (d-cd) && sccy == cy)
cv.style.color='#FF9900';
// if selected date
if (cm == selectedm && cy == selectedy && selectedd == (d-cd) )
{
cv.style.background='#FFEBCC';
//cv.style.color='#e0d0c0';
//cv.style.fontSize='1.1em';
//cv.style.fontStyle='italic';
//cv.style.fontWeight='bold';
// when use style.background
cv.onmouseout=null;
}
cv.innerHTML=d-cd;
calvalarr[d]=addnull(d-cd,cm-(-1),cy);
}
else {
cv.innerHTML=' ';
cv.onmouseover=null;
cv.onmouseout=null;
cv.onclick=null;
cv.style.cursor='default';
}
}
}
prepcalendar('',ccm,ccy);
function upmonth(s)
{
marr=((ccy%4)==0)?mnl:mnn;
ccm+=s;
if (ccm>=12)
{
ccm-=12;
ccy++;
}
else if(ccm<0)
{
ccm+=12;
ccy--;
}
prepcalendar('',ccm,ccy);
}
function today() {
updobj.value=addnull(now.getDate(),now.getMonth()+1,now.getFullYear());
getObj('fc').style.display='none';
prepcalendar('',sccm,sccy);
}
function addnull(d,m,y)
{
var d0='',m0='';
if (d<10)d0='0';
if (m<10)m0='0';
return ''+d0+d+'-'+m0+m+'-'+y;
}
document.write("<style type='text\/css'>#fc::after,#fc::before{display:block;content:'';border:30px solid transparent;border-right:30px solid rgb(242,140,38);position:absolute;width:0px;height:0px;top:30px;left:-60px;border:}#fc::after{border-right:30px solid #FBFBFB;left:-59px}<\/style>")
</script>
</body>
</html>
|
|
31.03.2015, 19:06
|
Интересующийся
|
|
Регистрация: 31.03.2015
Сообщений: 27
|
|
рони,
Спасибо большое, стрелочка появилась, но теперь календарь сразу же включается при загрузке сайта, а не всплывает при нажатии на инпут, это можно исправить как-то, оставив стрелочку?
|
|
31.03.2015, 19:12
|
Интересующийся
|
|
Регистрация: 31.03.2015
Сообщений: 27
|
|
рони,
Можно ли осуществить подключение внешних стилей?
|
|
31.03.2015, 19:14
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,124
|
|
Sylar V,
вам нужна строка 268 куда вы её воткнёте дело ваше -- ненадо копировать макет
|
|
31.03.2015, 19:14
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,124
|
|
Sylar V,
можно и без строки стилями но вроде бы просили скриптом
|
|
31.03.2015, 19:16
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,124
|
|
Sylar V,
<style type="text/css">#fc::after,#fc::before{display:block;content:'';border:30px solid transparent;border-right:30px solid rgb(242,140,38);position:absolute;width:0px;height:0px;top:30px;left:-60px;border:}#fc::after{border-right:30px solid #FBFBFB;left:-59px}</style>
|
|
31.03.2015, 19:43
|
Интересующийся
|
|
Регистрация: 31.03.2015
Сообщений: 27
|
|
рони,
БОЛЬШОЕ СПАСИБО!!! )) ВСЕ ПОЛУЧИЛОСЬ)
|
|
|
|