public
Description: Yet Another Javascript framework
Homepage: http://jplus.nowazhu.com
Clone URL: git://github.com/nowa/jplus.git
Click here to lend your support to: jplus and make a donation at www.pledgie.com !
dcalendar 0.1 done
nowa (author)
Sun Jul 20 19:36:34 -0700 2008
commit  04cb39140ec9d945ffef67c2164cd61c5053d587
tree    e06533fd3c803b2550b475784162578dedbf4a4b
parent  cdaaea05145d12411f4199788d1f88907dd973a2
...
41
42
43
44
 
45
46
47
...
49
50
51
 
 
 
 
 
 
 
 
 
 
 
 
 
52
53
54
...
57
58
59
 
 
60
61
62
...
41
42
43
 
44
45
46
47
...
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
...
70
71
72
73
74
75
76
77
0
@@ -41,7 +41,7 @@
0
     }
0
     
0
     .dcalendar td{
0
- background: #fff;
0
+ background-color: #fff;
0
     }
0
     
0
     .dcalendar .dcal-days td{
0
@@ -49,6 +49,19 @@
0
       height: 30px;
0
       line-height: 30px;
0
     }
0
+
0
+ .dcal-days td.selected{
0
+ background-color: #0099CB;
0
+ color: #fff;
0
+ }
0
+
0
+ .dcal-selected{
0
+ margin: 10px 20px;
0
+ }
0
+
0
+ .dcal-selected li{
0
+ line-height: 20px;
0
+ }
0
   </style>
0
 </head>
0
 <body>
0
@@ -57,6 +70,8 @@
0
     <h3>DCalendar <span class="author">by <a href="http://nowazhu.com/blog/">nowa</a></span></h3>
0
     
0
     <div jpc="dcalendar"></div>
0
+ <br><br><br>
0
+ <div jpc="dcalendar"></div>
0
   </div>
0
 
0
 </body>
...
3
4
5
6
 
7
8
9
...
21
22
23
24
 
25
26
27
28
29
 
30
31
 
32
33
34
35
36
 
37
38
 
39
40
41
42
43
 
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
 
65
66
 
67
68
69
70
71
 
72
73
 
74
75
76
77
78
 
79
80
 
81
82
83
84
85
 
86
87
 
88
89
90
91
92
 
93
94
 
95
96
97
98
99
 
100
101
 
102
103
104
105
106
 
107
108
 
109
110
111
112
113
 
114
115
 
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
 
137
138
 
139
140
141
142
143
 
144
145
 
146
147
148
149
150
 
151
152
 
153
154
155
156
157
 
158
159
 
160
161
162
163
164
 
165
166
167
168
169
170
171
172
 
 
173
174
175
176
177
 
 
 
 
178
179
180
...
3
4
5
 
6
7
8
9
...
21
22
23
 
24
25
26
27
28
 
29
30
 
31
32
33
34
35
 
36
37
 
38
39
40
41
42
 
43
44
 
 
 
 
 
 
 
 
 
 
 
 
45
 
 
46
47
48
49
 
50
51
 
52
53
54
55
56
 
57
58
 
59
60
61
62
63
 
64
65
 
66
67
68
69
70
 
71
72
 
73
74
75
76
77
 
78
79
 
80
81
82
83
84
 
85
86
 
87
88
89
90
91
 
92
93
 
94
95
96
97
98
 
99
100
 
101
102
 
 
103
104
105
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
106
107
 
108
109
110
111
112
 
113
114
 
115
116
117
118
119
 
120
121
 
122
123
124
125
126
 
127
128
 
129
130
131
132
133
 
134
135
136
137
138
 
 
 
 
139
140
141
 
 
142
 
143
144
145
146
147
148
149
0
@@ -3,7 +3,7 @@
0
 <plist version="1.0">
0
 <dict>
0
   <key>currentDocument</key>
0
- <string>src/request/request.js</string>
0
+ <string>src/utilities/dcalendar.js</string>
0
   <key>documents</key>
0
   <array>
0
     <dict>
0
@@ -21,160 +21,129 @@
0
   <integer>255</integer>
0
   <key>metaData</key>
0
   <dict>
0
- <key>examples/dev.html</key>
0
+ <key>examples/dcalendar.html</key>
0
     <dict>
0
       <key>caret</key>
0
       <dict>
0
         <key>column</key>
0
- <integer>22</integer>
0
+ <integer>29</integer>
0
         <key>line</key>
0
- <integer>46</integer>
0
+ <integer>65</integer>
0
       </dict>
0
       <key>firstVisibleColumn</key>
0
       <integer>0</integer>
0
       <key>firstVisibleLine</key>
0
- <integer>25</integer>
0
+ <integer>24</integer>
0
     </dict>
0
- <key>src/core/function.js</key>
0
+ <key>src/dom/element.event.js</key>
0
     <dict>
0
       <key>caret</key>
0
       <dict>
0
         <key>column</key>
0
- <integer>70</integer>
0
+ <integer>32</integer>
0
         <key>line</key>
0
- <integer>45</integer>
0
- </dict>
0
- <key>firstVisibleColumn</key>
0
- <integer>0</integer>
0
- <key>firstVisibleLine</key>
0
- <integer>41</integer>
0
- </dict>
0
- <key>src/core/jplus.js</key>
0
- <dict>
0
- <key>caret</key>
0
- <dict>
0
- <key>column</key>
0
         <integer>13</integer>
0
- <key>line</key>
0
- <integer>43</integer>
0
       </dict>
0
       <key>firstVisibleColumn</key>
0
       <integer>0</integer>
0
       <key>firstVisibleLine</key>
0
- <integer>2</integer>
0
+ <integer>143</integer>
0
     </dict>
0
- <key>src/core/object.js</key>
0
+ <key>src/dom/element.js</key>
0
     <dict>
0
       <key>caret</key>
0
       <dict>
0
         <key>column</key>
0
- <integer>33</integer>
0
+ <integer>17</integer>
0
         <key>line</key>
0
- <integer>140</integer>
0
+ <integer>111</integer>
0
       </dict>
0
       <key>firstVisibleColumn</key>
0
       <integer>0</integer>
0
       <key>firstVisibleLine</key>
0
- <integer>0</integer>
0
+ <integer>268</integer>
0
     </dict>
0
- <key>src/dom/element.js</key>
0
+ <key>src/native/array.js</key>
0
     <dict>
0
       <key>caret</key>
0
       <dict>
0
         <key>column</key>
0
- <integer>37</integer>
0
+ <integer>19</integer>
0
         <key>line</key>
0
- <integer>135</integer>
0
+ <integer>156</integer>
0
       </dict>
0
       <key>firstVisibleColumn</key>
0
       <integer>0</integer>
0
       <key>firstVisibleLine</key>
0
- <integer>120</integer>
0
+ <integer>52</integer>
0
     </dict>
0
- <key>src/event/event.js</key>
0
+ <key>src/native/date.js</key>
0
     <dict>
0
       <key>caret</key>
0
       <dict>
0
         <key>column</key>
0
- <integer>1</integer>
0
+ <integer>3</integer>
0
         <key>line</key>
0
- <integer>14</integer>
0
+ <integer>94</integer>
0
       </dict>
0
       <key>firstVisibleColumn</key>
0
       <integer>0</integer>
0
       <key>firstVisibleLine</key>
0
- <integer>8</integer>
0
+ <integer>66</integer>
0
     </dict>
0
- <key>src/native/array.js</key>
0
+ <key>src/native/enumerable.js</key>
0
     <dict>
0
       <key>caret</key>
0
       <dict>
0
         <key>column</key>
0
- <integer>5</integer>
0
+ <integer>30</integer>
0
         <key>line</key>
0
- <integer>63</integer>
0
+ <integer>29</integer>
0
       </dict>
0
- <key>columnSelection</key>
0
- <false/>
0
       <key>firstVisibleColumn</key>
0
       <integer>0</integer>
0
       <key>firstVisibleLine</key>
0
- <integer>45</integer>
0
- <key>selectFrom</key>
0
- <dict>
0
- <key>column</key>
0
- <integer>1</integer>
0
- <key>line</key>
0
- <integer>63</integer>
0
- </dict>
0
- <key>selectTo</key>
0
- <dict>
0
- <key>column</key>
0
- <integer>10</integer>
0
- <key>line</key>
0
- <integer>63</integer>
0
- </dict>
0
+ <integer>79</integer>
0
     </dict>
0
- <key>src/native/hash.js</key>
0
+ <key>src/native/number.js</key>
0
     <dict>
0
       <key>caret</key>
0
       <dict>
0
         <key>column</key>
0
- <integer>21</integer>
0
+ <integer>68</integer>
0
         <key>line</key>
0
- <integer>66</integer>
0
+ <integer>57</integer>
0
       </dict>
0
       <key>firstVisibleColumn</key>
0
       <integer>0</integer>
0
       <key>firstVisibleLine</key>
0
- <integer>114</integer>
0
+ <integer>40</integer>
0
     </dict>
0
- <key>src/request/request.js</key>
0
+ <key>src/utilities/dcalendar.js</key>
0
     <dict>
0
       <key>caret</key>
0
       <dict>
0
         <key>column</key>
0
- <integer>23</integer>
0
+ <integer>62</integer>
0
         <key>line</key>
0
- <integer>54</integer>
0
+ <integer>157</integer>
0
       </dict>
0
       <key>firstVisibleColumn</key>
0
       <integer>0</integer>
0
       <key>firstVisibleLine</key>
0
- <integer>40</integer>
0
+ <integer>122</integer>
0
     </dict>
0
   </dict>
0
   <key>openDocuments</key>
0
   <array>
0
- <string>src/request/request.js</string>
0
- <string>src/core/object.js</string>
0
- <string>src/core/function.js</string>
0
- <string>src/event/event.js</string>
0
+ <string>examples/dcalendar.html</string>
0
+ <string>src/utilities/dcalendar.js</string>
0
     <string>src/dom/element.js</string>
0
- <string>src/core/jplus.js</string>
0
- <string>src/native/hash.js</string>
0
     <string>src/native/array.js</string>
0
- <string>examples/dev.html</string>
0
+ <string>src/dom/element.event.js</string>
0
+ <string>src/native/number.js</string>
0
+ <string>src/native/enumerable.js</string>
0
+ <string>src/native/date.js</string>
0
   </array>
0
   <key>showFileHierarchyDrawer</key>
0
   <true/>
...
22
23
24
 
 
 
 
25
26
27
...
85
86
87
88
 
89
90
91
...
93
94
95
96
 
97
98
99
100
101
102
 
103
104
105
...
22
23
24
25
26
27
28
29
30
31
...
89
90
91
 
92
93
94
95
...
97
98
99
 
100
101
102
103
104
105
 
106
107
108
109
0
@@ -22,6 +22,10 @@ function $(element, notrash) {
0
   return (!notrash) ? Element.extend(element) : element;
0
 }
0
 
0
+function $i(id) {
0
+ return document.getElementById(id);
0
+}
0
+
0
 // element constructor
0
 (function() {
0
   var element = this.Element;
0
@@ -85,7 +89,7 @@ Element.Methods = {
0
         break;
0
       case 'string':
0
         var property = Element.Properties.get(prop);
0
- (property && property.set) ? property.set.apply(element, Array.slice(arguments, 1)) : element.setProperty(prop, value);
0
+ (property && property.set) ? property.set.apply(element, $A(arguments).slice(1)) : element.setProperty(prop, value);
0
     }
0
     return element;
0
   },
0
@@ -93,13 +97,13 @@ Element.Methods = {
0
   get: function(element, prop) {
0
     element = $(element);
0
     var property = Element.Properties.get(prop);
0
- return (property && property.get) ? property.get.apply(element, Array.slice(arguments, 1)) : element.getProperty(prop);
0
+ return (property && property.get) ? property.get.apply(element, $A(arguments).slice(1)) : element.getProperty(prop);
0
   },
0
   
0
   erase: function(element, prop){
0
     element = $(element);
0
     var property = Element.Properties.get(prop);
0
- (property && property.erase) ? property.erase.apply(element, Array.slice(arguments, 1)) : element.removeProperty(prop);
0
+ (property && property.erase) ? property.erase.apply(element, $A(arguments).slice(1)) : element.removeProperty(prop);
0
     return element;
0
   },
0
   
...
32
33
34
 
 
35
36
37
38
39
40
 
 
 
 
41
42
43
44
45
46
47
 
48
 
49
50
51
...
59
60
61
 
 
 
 
 
 
 
 
 
 
 
 
 
 
62
63
64
...
66
67
68
69
 
70
71
72
73
 
 
 
74
75
76
77
78
79
80
 
81
82
83
84
85
 
 
 
 
 
 
 
 
 
 
 
 
 
86
87
 
 
 
88
89
 
 
90
91
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
92
93
94
 
 
 
 
 
 
 
 
 
 
95
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
96
97
98
99
100
 
101
102
103
104
105
 
 
106
107
108
...
32
33
34
35
36
37
38
 
 
 
 
39
40
41
42
43
44
45
46
47
48
 
49
50
51
52
53
54
...
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
...
83
84
85
 
86
87
 
 
 
88
89
90
91
92
93
94
95
96
 
97
98
99
100
101
 
102
103
104
105
106
107
108
109
110
111
112
113
114
115
 
116
117
118
119
 
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
 
205
206
207
208
209
210
211
212
213
214
215
0
@@ -32,20 +32,23 @@ DCalendar.core = Class.create({
0
   
0
   onmouse_end: 0,
0
   
0
+ selected_cache: {},
0
+
0
   initialize: function(options) {
0
     this.options = Object.extend(this.options, options || {});
0
- this.today = Date.now();
0
- this.year = this.today.year();
0
- this.month = this.today.month();
0
- this.day = this.today.day();
0
+ this.curr_day = Date.now();
0
+ this.year = this.curr_day.year();
0
+ this.month = this.curr_day.month();
0
+ this.day = this.curr_day.day();
0
     
0
     var _wrapper = this.options.wrapper ? this.options.wrapper : document;
0
     var divs = _wrapper.getElementsByTagName('div');
0
     $A(divs).each(function(div) {
0
       if (div.getAttribute('jpc') == 'dcalendar') {
0
         div = $(div);
0
- div.set('DCID', div.get('DCID') || DCalendar.DCID++);
0
+ div.setAttribute('DCID', div.get('DCID') || DCalendar.DCID++);
0
         div.id = 'dcid_' + div.get('DCID');
0
+ this.selected_cache[div.id] = {};
0
         this.containers.push(div);
0
       }
0
     }, this);
0
@@ -59,6 +62,20 @@ DCalendar.core = Class.create({
0
     }, this);
0
   },
0
   
0
+ change_to_date: function(date) {
0
+ this.fireEvent('onMonthChange');
0
+ this.curr_day = date;
0
+ this.year = this.curr_day.year();
0
+ this.month = this.curr_day.month();
0
+ this.day = this.curr_day.day();
0
+ this.create();
0
+ this.refresh_selected();
0
+ },
0
+
0
+ set_default: function(d) {
0
+ this.defaultc = d;
0
+ },
0
+
0
   before_create: function() {
0
     this.fireEvent('beforeCreate');
0
   },
0
@@ -66,43 +83,133 @@ DCalendar.core = Class.create({
0
   create: function() {
0
     this.before_create();
0
     var _days = this.get_month_days(this.month-1);
0
- var _html = '<table class="dcalendar" border="0" cellspacing="1" cellpadding="4"><tbody><tr class="dcal-title"><td colspan="' + _days + '">' + this.today.strftime('%Y年%m月') + '</td></tr><tr class="dcal-days" id="' + this.defaultc.id + '_days">';
0
+ var _html = '<table class="dcalendar" border="0" cellspacing="1" cellpadding="4"><tbody><tr class="dcal-title"><td colspan="3"><a href="#" id="' + this.defaultc.id + '_prev">上一月</a></td><td colspan="' + (_days-6) + '">' + this.curr_day.strftime('%Y年%m月') + '</td><td colspan="3"><a href="#" id="' + this.defaultc.id + '_next">下一月</a></td></tr><tr class="dcal-days" id="' + this.defaultc.id + '_days">';
0
     _days.times(function(i) {
0
- _html += '<td>' + (i + 1) + '</td>';
0
- });
0
- _html += '</tr></tbody></table>';
0
+ _html += '<td id="' + this.defaultc.id + '_days_' + (i + 1) + '">' + (i + 1) + '</td>';
0
+ }, this);
0
+ _html += '</tr></tbody></table><div id="' + this.defaultc.id + '_selected" class="dcal-selected"></div>';
0
     this.defaultc.innerHTML = _html;
0
     
0
     this.enabled();
0
   },
0
   
0
   enabled: function() {
0
- var days_line = $(this.defaultc.id + '_days');
0
+ var _dcal = this, days_line = $(this.defaultc.id + '_days'), prev = $(this.defaultc.id + '_prev'), next = $(this.defaultc.id + '_next');
0
     this.on_days_line = false;
0
     this.onmouse_start = 0;
0
     this.onmouse_end = 0;
0
     
0
- var _dcal = this, _tds = days_line.getElementsByTagName('td');
0
+ prev.observe('click', function(e) {
0
+ _dcal.set_default($(this.id.split('_').slice(0, 2).join('_')));
0
+ _dcal.change_to_date(_dcal.curr_day.after('Month', -1));
0
+ return false;
0
+ });
0
+
0
+ next.observe('click', function(e) {
0
+ _dcal.set_default($(this.id.split('_').slice(0, 2).join('_')));
0
+ _dcal.change_to_date(_dcal.curr_day.after('Month', 1));
0
+ return false;
0
+ });
0
+
0
+ var _tds = days_line.getElementsByTagName('td');
0
     $A(_tds).each(function(td) {
0
- td.observe('click', function(e) {
0
+ $(td).observe('click', function(e) {
0
+ var defaultc = $(this.id.split('_').slice(0, 2).join('_'));
0
+ _dcal.defaultc = defaultc;
0
         this.className = this.className == 'selected' ? '' : 'selected';
0
- _dcal.refresh_selected(this.parentNode.parentNode.parentNode.parentNode);
0
+ _dcal.set_cache();
0
+ _dcal.refresh_selected();
0
       })
0
     });
0
+
0
+ days_line.observe('mousedown', function(e) {
0
+ var target = e.target;
0
+ _dcal.on_days_line = true;
0
+ if (target.get('tag') == 'td') {
0
+ _dcal.defaultc = $(target.id.split('_').slice(0, 2).join('_'));
0
+ target.className = target.className == 'selected' ? '' : 'selected';
0
+ _dcal.onmouse_start = parseInt(target.innerHTML);
0
+ }
0
+ });
0
+
0
+ days_line.observe('mouseup', function(e) {
0
+ var target = e.target;
0
+ _dcal.on_days_line = false;
0
+ if (target.get('tag') == 'td') {
0
+ target.className = target.className == 'selected' ? '' : 'selected';
0
+ var _end = parseInt(target.innerHTML);
0
+ if (_end < _dcal.onmouse_start) {
0
+ _dcal.onmouse_end = _dcal.onmouse_start;
0
+ _dcal.onmouse_start = _end;
0
+ } else {
0
+ _dcal.onmouse_end = _end;
0
+ }
0
+ }
0
+
0
+ for (var i = _dcal.onmouse_start+1; i <= _dcal.onmouse_end-1; i++) {
0
+ var _td = $(_dcal.defaultc.id + '_days_' + i);
0
+ _td.className = _td.className == 'selected' ? '' : 'selected';
0
+ }
0
+ _dcal.set_cache();
0
+ _dcal.refresh_selected();
0
+ });
0
   },
0
   
0
   refresh_selected: function(container) {
0
+ container = container || this.defaultc;
0
+ this.format_cache(this.selected_cache[container.id][this.year + '-' + this.month]);
0
+ },
0
+
0
+ set_cache: function(container) {
0
+ container = container || this.defaultc;
0
+ var days_line = $(this.defaultc.id + '_days'), _tds = days_line.getElementsByTagName('td'), _selected = '';
0
+ $A(_tds).each(function(td) {
0
+ _selected += td.className == 'selected' ? '1' : '0';
0
+ });
0
     
0
+ this.selected_cache[container.id][this.year + '-' + this.month] = _selected;
0
+ },
0
+
0
+ format_cache: function(cache) {
0
+ if (!$defined(cache)) return;
0
+ var _start = '', _end = '', _days = cache.length, _sel_wrapper = $i(this.defaultc.id + '_selected');
0
+ _sel_wrapper.innerHTML = '';
0
+ (_days).times(function(i) {
0
+ if (cache.charAt(i) == '1') {
0
+ $i(this.defaultc.id + '_days_' + (i + 1)).className = 'selected';
0
+ if (_start == '') {
0
+ _start = this.year + '-' + this.month.toPaddedString(2) + '-' + (i + 1).toPaddedString(2);
0
+ } else {
0
+ _end = this.year + '-' + this.month.toPaddedString(2) + '-' + (i + 1).toPaddedString(2);
0
+ }
0
+ if (i == (_days - 1)) {
0
+ if (_start != '') _sel_wrapper.appendChild(this.selected_item(_start, _end));
0
+ }
0
+ } else {
0
+ _end = this.year + '-' + this.month.toPaddedString(2) + '-' + (i).toPaddedString(2)
0
+ if (_start != '') _sel_wrapper.appendChild(this.selected_item(_start, _end));
0
+ _start = '';
0
+ _end = '';
0
+ }
0
+ }, this);
0
+ },
0
+
0
+ selected_item: function(start, end) {
0
+ var _child = document.createElement('li');
0
+ _child.innerHTML = start + (end == '' || end == start ? '' : ' ~ ' + end);
0
+ return _child;
0
   },
0
   
0
   get_month_days: function(month) {
0
     var _days = this.days_of_month[month];
0
- if (month==1 && (year%4==0 && year%100!=0 || year%400==0)) _days++;
0
+ if (month==1 && (this.year%4==0 && this.year%100!=0 || this.year%400==0)) _days++;
0
     return _days;
0
   }
0
   
0
 });
0
 
0
+document.onselectstart= function(event) {return false};
0
+
0
 document.observe('dom:ready', function() {
0
   var dcal = new DCalendar.core({wrapper: $('main')});
0
   dcal.show();

Comments

    No one has commented yet.