Showing
4 changed files
with
94 additions
and
29 deletions
1 | +// Daten zu einem einzelnen Teaser | ||
1 | function c_GalleryThumb (thu, cat, tit, tex, u) | 2 | function c_GalleryThumb (thu, cat, tit, tex, u) |
2 | { | 3 | { |
3 | var thumb = thu; | 4 | var thumb = thu; |
@@ -13,30 +14,19 @@ function c_GalleryThumb (thu, cat, tit, tex, u) | @@ -13,30 +14,19 @@ function c_GalleryThumb (thu, cat, tit, tex, u) | ||
13 | this.getUrl = function () { return url; } | 14 | this.getUrl = function () { return url; } |
14 | } | 15 | } |
15 | 16 | ||
16 | -function c_GalleryThumbs (_id, data, pos, _count) | 17 | +// Container fuer alle Teaser wird via ajax ueber den picToolService |
18 | +// gefuellt. | ||
19 | +function c_GalleryThumbs (_id, pos, _count) | ||
17 | { | 20 | { |
18 | var thumbs = new Array (); | 21 | var thumbs = new Array (); |
19 | var startIdx = pos; | 22 | var startIdx = pos; |
20 | var id = _id; | 23 | var id = _id; |
21 | var count = _count; | 24 | var count = _count; |
22 | 25 | ||
23 | - for (var d in data) | ||
24 | - { | ||
25 | - var expr = /(.*) [^ ]*$/; | ||
26 | - thumbs.push ( | ||
27 | - new c_GalleryThumb ( | ||
28 | - d.getThumbUrl (), | ||
29 | - d.getOrdnerName (0).toUpperCase (), | ||
30 | - d.titel, | ||
31 | - d.ffBildzeile+' '.substr (0, 100).replace (expr, '$1...'), | ||
32 | - d.getShowUrl ())); | ||
33 | - } | ||
34 | - | ||
35 | // Dies kann warscheinlich auch raus aus c_GalleryThumbs | 26 | // Dies kann warscheinlich auch raus aus c_GalleryThumbs |
36 | this.popup = function (i) | 27 | this.popup = function (i) |
37 | { | 28 | { |
38 | url = document.getElementById (id+'_BG_URL1_'+i).href; | 29 | url = document.getElementById (id+'_BG_URL1_'+i).href; |
39 | - thumbs = eval (); | ||
40 | 30 | ||
41 | if (url.match (/javascript:ftvlaunch\(/)) | 31 | if (url.match (/javascript:ftvlaunch\(/)) |
42 | { | 32 | { |
@@ -89,6 +79,16 @@ function c_GalleryThumbs (_id, data, pos, _count) | @@ -89,6 +79,16 @@ function c_GalleryThumbs (_id, data, pos, _count) | ||
89 | 79 | ||
90 | changeDisplay (client); | 80 | changeDisplay (client); |
91 | 81 | ||
82 | + if (thumbs.length - (startIdx + count) === 4) | ||
83 | + { | ||
84 | + nBildertool.callback = this.callback; | ||
85 | + var url = 'http://georgs_test/_module/bildertool/' + | ||
86 | + 'fakeFotoService.php?' + | ||
87 | + 'action=latest&cnt=3&limit=10&lfrom=' + thumbs.length + | ||
88 | + '&omit=3,7'; | ||
89 | + nBildertool.service (url); | ||
90 | + } | ||
91 | + | ||
92 | return false; | 92 | return false; |
93 | } | 93 | } |
94 | 94 | ||
@@ -100,4 +100,40 @@ function c_GalleryThumbs (_id, data, pos, _count) | @@ -100,4 +100,40 @@ function c_GalleryThumbs (_id, data, pos, _count) | ||
100 | 100 | ||
101 | return false; | 101 | return false; |
102 | } | 102 | } |
103 | + | ||
104 | + this.callback = function () | ||
105 | + { | ||
106 | + switch (nBildertool.req.readyState) | ||
107 | + { | ||
108 | + case 4: | ||
109 | + if (nBildertool.req.status != 200) | ||
110 | + alert ("Fehler:" + nBildertool.req.status); | ||
111 | + else | ||
112 | + { | ||
113 | + var data = nBildertool.deXmlify (nBildertool.req.responseXML); | ||
114 | + for (d in data['data']) | ||
115 | + { | ||
116 | + var expr = /(.*) [^ ]*$/; | ||
117 | + thumbs.push ( | ||
118 | + new c_GalleryThumb ( | ||
119 | + data['data'][d].getThumbUrl (), | ||
120 | + data['data'][d].getOrdnerName (0).toUpperCase (), | ||
121 | + data['data'][d].titel, | ||
122 | + data['data'][d].ffBildzeile+ | ||
123 | + ' '.substr (0, 100).replace (expr, '$1...'), | ||
124 | + data['data'][d].getShowUrl ())); | ||
125 | + } | ||
126 | + } | ||
127 | + return true; | ||
128 | + | ||
129 | + default: | ||
130 | + return false; | ||
131 | + } | ||
132 | + } | ||
133 | + | ||
134 | + nBildertool.callback = this.callback; | ||
135 | + var url = 'http://georgs_test/_module/bildertool/fakeFotoService.php?' + | ||
136 | + 'action=latest&cnt=3&limit=' + (startIdx+count+5) + '&lfrom=0' + | ||
137 | + '&omit=3,7'; | ||
138 | + nBildertool.service (url); | ||
103 | } | 139 | } |
@@ -2,6 +2,7 @@ if (typeof (nBildertool) === 'undefined') | @@ -2,6 +2,7 @@ if (typeof (nBildertool) === 'undefined') | ||
2 | nBildertool = {}; | 2 | nBildertool = {}; |
3 | 3 | ||
4 | nBildertool.req = null; | 4 | nBildertool.req = null; |
5 | +nBildertool.callback = undefined; | ||
5 | 6 | ||
6 | nBildertool.service = function (url, callback) | 7 | nBildertool.service = function (url, callback) |
7 | { | 8 | { |
@@ -36,10 +37,10 @@ nBildertool.service = function (url, callback) | @@ -36,10 +37,10 @@ nBildertool.service = function (url, callback) | ||
36 | nBildertool.req.open("GET", url, true); | 37 | nBildertool.req.open("GET", url, true); |
37 | 38 | ||
38 | // Beim abschliessen des request wird diese Funktion ausgeführt | 39 | // Beim abschliessen des request wird diese Funktion ausgeführt |
39 | - if (typeof (callback) === 'undefined') | 40 | + if (typeof (nBildertool.callback) === 'undefined') |
40 | nBildertool.req.onreadystatechange = nBildertool.cbCommon; | 41 | nBildertool.req.onreadystatechange = nBildertool.cbCommon; |
41 | else | 42 | else |
42 | - nBildertool.req.onreadystatechange = callback; | 43 | + nBildertool.req.onreadystatechange = nBildertool.callback; |
43 | 44 | ||
44 | nBildertool.req.setRequestHeader("Content-Type", | 45 | nBildertool.req.setRequestHeader("Content-Type", |
45 | "application/x-www-form-urlencoded"); | 46 | "application/x-www-form-urlencoded"); |
@@ -35,6 +35,24 @@ nBildertool.strecke = function (data) | @@ -35,6 +35,24 @@ nBildertool.strecke = function (data) | ||
35 | this.fotoCount = null; | 35 | this.fotoCount = null; |
36 | this.path = null; | 36 | this.path = null; |
37 | 37 | ||
38 | + SPECIAL_CHARS = Array ( | ||
39 | + / /g, /ä/g, /ü/g, /ö/g, /Ä/g, /Ü/g, /Ö/g, /ß/g, | ||
40 | + /\./g, /:/g, /\!/g, /\?/g, /\,/g, | ||
41 | + /`/g, /"/g, /\'/g, | ||
42 | + /é/g, /è/g, /á/g, /à/g, /ó/g, | ||
43 | + /É/g, /Á/g, /Ó/g, /È/g, /À/g, /Ò/g, | ||
44 | + /EUR/g, /¢/g, /\$/g, | ||
45 | + /@/g, /%/g, /&/g, /\+/g, /§/g, /\(/g, /\)/g); | ||
46 | + | ||
47 | + SPECIAL_CHARS_MAP = Array ( | ||
48 | + '_', 'ae', 'ue', 'oe', 'Ae', 'Ue', 'Oe', 'ss', | ||
49 | + '', '', '', '', '', | ||
50 | + '', '', '', | ||
51 | + 'e', 'e', 'a', 'a', 'o', | ||
52 | + 'E', 'A', 'O', 'E', 'A', 'O', | ||
53 | + '_euro_', '_cent_', '_dollar_', | ||
54 | + '_at_', '_prozent_', '_und_', '_und_', '_paragraph_', '', ''); | ||
55 | + | ||
38 | function getOrdnerInfo (value, idx) | 56 | function getOrdnerInfo (value, idx) |
39 | { | 57 | { |
40 | var val = value.split ('|%|'); | 58 | var val = value.split ('|%|'); |
@@ -42,35 +60,35 @@ nBildertool.strecke = function (data) | @@ -42,35 +60,35 @@ nBildertool.strecke = function (data) | ||
42 | return val[idx]; | 60 | return val[idx]; |
43 | } | 61 | } |
44 | 62 | ||
45 | - function getOrdnerId (idx) | 63 | + this.getOrdnerId = function (idx) |
46 | { | 64 | { |
47 | return getOrdnerInfo (this.ordnerId, idx); | 65 | return getOrdnerInfo (this.ordnerId, idx); |
48 | } | 66 | } |
49 | - function getConnectionId (idx) | 67 | + this.getConnectionId = function (idx) |
50 | { | 68 | { |
51 | return getOrdnerInfo (this.connectionId, idx); | 69 | return getOrdnerInfo (this.connectionId, idx); |
52 | } | 70 | } |
53 | - function getFlags (idx) | 71 | + this.getFlags = function (idx) |
54 | { | 72 | { |
55 | return getOrdnerInfo (this.flags, idx); | 73 | return getOrdnerInfo (this.flags, idx); |
56 | } | 74 | } |
57 | - function getL0Id (idx) | 75 | + this.getL0Id = function (idx) |
58 | { | 76 | { |
59 | return getOrdnerInfo (this.l0Id, idx); | 77 | return getOrdnerInfo (this.l0Id, idx); |
60 | } | 78 | } |
61 | - function getL1Id (idx) | 79 | + this.getL1Id = function (idx) |
62 | { | 80 | { |
63 | return getOrdnerInfo (this.l1Id, idx); | 81 | return getOrdnerInfo (this.l1Id, idx); |
64 | } | 82 | } |
65 | - function getL2Id (idx) | 83 | + this.getL2Id = function (idx) |
66 | { | 84 | { |
67 | return getOrdnerInfo (this.l2Id, idx); | 85 | return getOrdnerInfo (this.l2Id, idx); |
68 | } | 86 | } |
69 | - function getL3Id (idx) | 87 | + this.getL3Id = function (idx) |
70 | { | 88 | { |
71 | return getOrdnerInfo (this.l3Id, idx); | 89 | return getOrdnerInfo (this.l3Id, idx); |
72 | } | 90 | } |
73 | - function getOrdnerName (idx) | 91 | + this.getOrdnerName = function (idx) |
74 | { | 92 | { |
75 | return getOrdnerInfo (this.ordnerName, idx); | 93 | return getOrdnerInfo (this.ordnerName, idx); |
76 | } | 94 | } |
@@ -85,24 +103,34 @@ nBildertool.strecke = function (data) | @@ -85,24 +103,34 @@ nBildertool.strecke = function (data) | ||
85 | return FRONT_URL + teaserPath + '.jpeg'; | 103 | return FRONT_URL + teaserPath + '.jpeg'; |
86 | } | 104 | } |
87 | 105 | ||
106 | + this.getPath = function () | ||
107 | + { | ||
108 | + var path = this.path; | ||
109 | + | ||
110 | + for (i in SPECIAL_CHARS) | ||
111 | + path = path.replace (SPECIAL_CHARS[i], SPECIAL_CHARS_MAP[i]); | ||
112 | + | ||
113 | + return path; | ||
114 | + } | ||
115 | + | ||
88 | this.getThumbUrl = function () | 116 | this.getThumbUrl = function () |
89 | { | 117 | { |
90 | - return FRONT_URL + this.path + 'T.jpeg'; | 118 | + return FRONT_URL + this.getPath () + 'T.jpeg'; |
91 | } | 119 | } |
92 | 120 | ||
93 | this.getScreenUrl = function () | 121 | this.getScreenUrl = function () |
94 | { | 122 | { |
95 | - return FRONT_URL + this.path + 'S.jpeg'; | 123 | + return FRONT_URL + this.getPath () + 'S.jpeg'; |
96 | } | 124 | } |
97 | 125 | ||
98 | this.getDownlUrl = function () | 126 | this.getDownlUrl = function () |
99 | { | 127 | { |
100 | - return FRONT_URL + this.path + '.jpeg'; | 128 | + return FRONT_URL + this.getPath () + '.jpeg'; |
101 | } | 129 | } |
102 | 130 | ||
103 | this.getShowUrl = function () | 131 | this.getShowUrl = function () |
104 | { | 132 | { |
105 | - return FRONT_URL + this.path + '.html'; | 133 | + return FRONT_URL + this.getPath () + '.html'; |
106 | } | 134 | } |
107 | 135 | ||
108 | nBildertool.strecke.baseConstructor.call (this, data); | 136 | nBildertool.strecke.baseConstructor.call (this, data); |
@@ -96,7 +96,7 @@ nBildertool.xmlToArray = function (data) | @@ -96,7 +96,7 @@ nBildertool.xmlToArray = function (data) | ||
96 | case 'array': | 96 | case 'array': |
97 | ret[key] = nBildertool.xmlToArray (_child); break; | 97 | ret[key] = nBildertool.xmlToArray (_child); break; |
98 | case 'class': | 98 | case 'class': |
99 | - var cName = child.getAttribute ('class'); | 99 | + var cName = _child.getAttribute ('class'); |
100 | 100 | ||
101 | switch (cName) | 101 | switch (cName) |
102 | { | 102 | { |
Please
register
or
login
to post a comment