annotate client/digitallibrary/jquery/jquery.digilib.js @ 607:dc6b2e7f3621 jquery

highlight hovered buttons
author hertzhaft
date Sun, 16 Jan 2011 14:05:17 +0100
parents d08d095430c3
children 5de82bb5022d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
1 /*
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
2 * digilib jQuery plugin
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
3 *
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
4 */
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
5
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
6 (function($) {
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
7 var buttons = {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
8 reference : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
9 onclick : "javascript:getRefWin()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
10 tooltip : "get a reference URL",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
11 img : "reference.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
12 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
13 zoomin : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
14 onclick : "javascript:dl.zoomBy(1.4)",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
15 tooltip : "zoom in",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
16 img : "zoom-in.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
17 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
18 zoomout : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
19 onclick : "javascript:zoomBy(0.7)",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
20 tooltip : "zoom out",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
21 img : "zoom-out.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
22 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
23 zoomarea : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
24 onclick : "javascript:zoomArea()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
25 tooltip : "zoom area",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
26 img : "zoom-area.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
27 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
28 zoomfull : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
29 onclick : "javascript:zoomFullpage()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
30 tooltip : "view the whole image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
31 img : "zoom-full.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
32 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
33 pagewidth : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
34 onclick : "javascript:zoomFullpage('width')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
35 tooltip : "page width",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
36 img : "pagewidth.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
37 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
38 back : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
39 onclick : "javascript:gotoPage('-1')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
40 tooltip : "goto previous image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
41 img : "back.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
42 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
43 fwd : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
44 onclick : "javascript:gotoPage('+1')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
45 tooltip : "goto next image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
46 img : "fwd.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
47 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
48 page : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
49 onclick : "javascript:gotoPageWin()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
50 tooltip : "specify image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
51 img : "page.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
52 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
53 bird : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
54 onclick : "javascript:toggleBirdDiv()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
55 tooltip : "show bird's eye view",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
56 img : "birds-eye.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
57 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
58 help : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
59 onclick : "javascript:toggleAboutDiv()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
60 tooltip : "about Digilib",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
61 img : "help.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
62 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
63 reset : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
64 onclick : "javascript:resetImage()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
65 tooltip : "reset image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
66 img : "reset.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
67 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
68 mark : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
69 onclick : "javascript:setMark()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
70 tooltip : "set a mark",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
71 img : "mark.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
72 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
73 delmark : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
74 onclick : "javascript:removeMark()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
75 tooltip : "delete the last mark",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
76 img : "delmark.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
77 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
78 hmir : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
79 onclick : "javascript:mirror('h')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
80 tooltip : "mirror horizontally",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
81 img : "mirror-horizontal.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
82 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
83 vmir : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
84 onclick : "javascript:mirror('v')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
85 tooltip : "mirror vertically",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
86 img : "mirror-vertical.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
87 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
88 rot : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
89 onclick : "javascript:setParamWin('rot', 'Rotate (0..360) clockwise')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
90 tooltip : "rotate image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
91 img : "rotate.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
92 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
93 brgt : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
94 onclick : "javascript:setParamWin('brgt', 'Brightness (-255..255)')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
95 tooltip : "set brightness",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
96 img : "brightness.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
97 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
98 cont : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
99 onclick : "javascript:setParamWin('cont', 'Contrast (0..8)')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
100 tooltip : "set contrast",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
101 img : "contrast.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
102 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
103 rgb : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
104 onclick : "javascript:setParamWin('rgb', '...')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
105 tooltip : "set rgb values",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
106 img : "rgb.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
107 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
108 quality : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
109 onclick : "javascript:setQualityWin('Quality (0..2)')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
110 tooltip : "set image quality",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
111 img : "quality.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
112 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
113 size : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
114 onclick : "javascript:toggleSizeMenu()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
115 tooltip : "set page size",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
116 img : "size.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
117 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
118 calibrationx : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
119 onclick : "javascript:calibrate('x')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
120 tooltip : "calibrate screen x-ratio",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
121 img : "calibration-x.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
122 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
123 scale : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
124 onclick : "javascript:toggleScaleMenu()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
125 tooltip : "change image scale",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
126 img : "original-size.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
127 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
128 options : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
129 onclick : "javascript:toggleOptionDiv()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
130 tooltip : "hide options",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
131 img : "options.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
132 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
133 SEP : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
134 img : "sep.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
135 }
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
136 };
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
137
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
138 var defaults = {
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
139 // base URL to Scaler servlet
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
140 'scalerBaseUrl' : 'http://digilib.mpiwg-berlin.mpg.de/digitallibrary/servlet/Scaler',
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
141 // list of Scaler parameters
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
142 'scalerParamNames' : ['fn','pn','dw','dh','ww','wh','wx','wy','ws','mo',
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
143 'rot','cont','brgt','rgbm','rgba','ddpi','ddpix','ddpiy'],
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
144 // mode of operation.
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
145 // fullscreen: takes parameters from page URL, keeps state in page URL
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
146 // embedded: takes parameters from Javascript options, keeps state inside object
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
147 'interactionMode' : 'fullscreen',
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
148 // buttons
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
149 'buttons' : buttons,
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
150 // path to button images (must end with a slash)
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
151 'buttonsImagePath' : '../greyskin/',
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
152 // button groups
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
153 'buttonsStandard' : ["reference","zoomin","zoomout","zoomarea","zoomfull","pagewidth","back","fwd","page","bird","SEP","help","reset","options"],
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
154 'buttonsSpecial' : ["mark","delmark","hmir","vmir","rot","brgt","cont","rgb","quality","size","calibrationx","scale","SEP","options"],
604
13c8b1ad99d4 work on button creation
robcast
parents: 603
diff changeset
155 'buttonsCustom' : []
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
156 };
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
157
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
158 // parameters from the query string
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
159 var queryParams = {};
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
160
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
161 // affine geometry classes
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
162 var geom = dlGeometry();
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
163
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
164 var methods = {
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
165 // digilib initialization
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
166 init : function(options) {
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
167 // settings for this digilib instance are merged from defaults and options
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
168 var settings = $.extend({}, defaults, options);
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
169 var isFullscreen = settings.interactionMode === 'fullscreen';
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
170 if (isFullscreen) {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
171 queryParams = parseQueryParams();
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
172 };
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
173 return this.each(function() {
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
174 var $elem = $(this);
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
175 var data = $elem.data('digilib');
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
176 var elemSettings;
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
177 // if the plugin hasn't been initialized yet
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
178 if (!data) {
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
179 // merge query parameters
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
180 if (isFullscreen) {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
181 elemSettings = $.extend({}, settings, queryParams);
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
182 } else {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
183 elemSettings = $.extend({}, settings, parseImgParams($elem));
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
184 };
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
185 // store in data element
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
186 $elem.data('digilib', {
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
187 target : $elem,
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
188 settings : elemSettings
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
189 });
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
190 }
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
191 // create HTML structure
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
192 setupScalerDiv($elem, elemSettings);
604
13c8b1ad99d4 work on button creation
robcast
parents: 603
diff changeset
193 setupButtons($elem, elemSettings, 'buttonsStandard');
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
194 });
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
195 },
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
196
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
197 // clean up digilib
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
198 destroy : function() {
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
199 return this.each(function(){
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
200 var $this = $(this);
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
201 var data = $this.data('digilib');
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
202 // Namespacing FTW
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
203 $(window).unbind('.digilib'); // unbinds all digilibs(?)
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
204 data.digilib.remove();
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
205 $this.removeData('digilib');
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
206 });
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
207 }
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
208 };
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
209
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
210 // returns parameters from page url
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
211 var parseQueryParams = function() {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
212 return parseQueryString(location.search.slice(1));
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
213 };
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
214
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
215 // returns parameters taken from embedded img-element
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
216 var parseImgParams = function($elem) {
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
217 var src = $elem.find('img').first().attr('src');
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
218 if (!src) {
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
219 return null;
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
220 }
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
221 var pos = src.indexOf('?');
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
222 var query = (pos < 0) ? '' : src.substring(pos + 1);
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
223 var scalerUrl = src.substring(0, pos);
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
224 var hash = parseQueryString(query);
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
225 hash.scalerBaseUrl = scalerUrl;
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
226 // console.log(hash);
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
227 return hash;
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
228 };
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
229
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
230 // parses query parameter string into parameter object
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
231 var parseQueryString = function(query) {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
232 var pairs = query.split("&");
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
233 var hash = {};
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
234 for (var i = 0; i < pairs.length; i++) {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
235 var pair = pairs[i].split("=");
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
236 if (pair.length === 2) {
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
237 hash[pair[0]] = pair[1];
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
238 };
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
239 };
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
240 return hash;
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
241 };
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
242
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
243 // returns URL and query string for Scaler
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
244 var getScalerString = function (settings) {
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
245 var url = settings.scalerBaseUrl + '?';
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
246 var i, parm, latter;
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
247 // go through param names and get values from settings
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
248 for (i = 0; i < settings.scalerParamNames.length; ++i) {
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
249 parm = settings.scalerParamNames[i];
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
250 if (settings[parm]) {
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
251 // first parm gets no '&'
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
252 url += latter ? '&' : '';
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
253 latter = 1;
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
254 // add parm=val
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
255 url += parm + '=' + settings[parm];
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
256 }
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
257 }
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
258 return url;
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
259 };
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
260
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
261 // returns maximum size for scaler img in fullscreen mode
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
262 var getFullscreenImgSize = function($elem) {
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
263 var winH = $(window).height();
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
264 var winW = $(window).width();
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
265 // TODO: account for borders?
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
266 return geom.size(winW, winH);
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
267 };
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
268
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
269 // creates HTML structure for digilib in elem
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
270 var setupScalerDiv = function ($elem, settings) {
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
271 var rewrite;
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
272 if (settings.interactionMode === 'fullscreen') {
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
273 // fullscreen
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
274 var imgSize = getFullscreenImgSize($elem);
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
275 settings.dw = imgSize.width;
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
276 settings.dh = imgSize.height;
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
277 $img = $('<img/>');
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
278 var scalerUrl = getScalerString(settings);
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
279 $img.attr('src', scalerUrl);
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
280 $img.addClass('pic');
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
281 } else {
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
282 // embedded mode -- try to keep img tag
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
283 var $img = $elem.find('img');
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
284 if ($img.length > 0) {
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
285 console.debug("img detach:",$img);
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
286 $img.detach();
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
287 $img.addClass('picsi');
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
288 } else {
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
289 $img = $('<img/>');
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
290 var scalerUrl = getScalerString(settings);
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
291 $img.attr('src', scalerUrl);
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
292 $img.addClass('pic');
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
293 }
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
294 }
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
295 // create new html
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
296 $elem.empty(); // TODO: should we keep stuff for customization?
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
297 var $scaler = $('<div class="scaler"/>');
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
298 $elem.append($scaler);
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
299 $scaler.append($img);
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
300 $img.load(scalerImgLoadedFn(settings));
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
301 };
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
302
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
303 // creates HTML structure for buttons in elem
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
304 var setupButtons = function ($elem, settings, buttonGroup) {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
305 if (settings.interactionMode === 'fullscreen') {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
306 // fullscreen -- create new
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
307 var $buttonsDiv = $('<div class="buttons"></div>');
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
308 $elem.append($buttonsDiv);
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
309 var buttonNames = settings[buttonGroup];
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
310 for (var i = 0; i < buttonNames.length; i++) {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
311 var buttonName = buttonNames[i];
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
312 var buttonSettings = settings.buttons[buttonName];
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
313 // construct the button html
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
314 var $button = $('<div class="button"></div>');
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
315 var $a = $('<a/>');
607
dc6b2e7f3621 highlight hovered buttons
hertzhaft
parents: 606
diff changeset
316 var $img = $('<img class="button"/>');
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
317 $buttonsDiv.append($button);
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
318 $button.append($a);
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
319 $a.append($img);
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
320 // add attributes and bindings
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
321 $button.attr('title', buttonSettings.tooltip);
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
322 $button.addClass('button-' + buttonName);
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
323 // let the clicked <a> element know about the digilib context
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
324 $a.data('digilib', { 'name' : buttonName, 'settings' : settings } );
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
325 $a.bind('click', function() {
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
326 // get the context settings
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
327 var data = $(this).data('digilib');
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
328 // find the action for the clicked element
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
329 console.log(data.settings.buttons[data.name].onclick);
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
330 });
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
331 // binding mit closure
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
332 //(function(){ var action = buttonSettings.onclick;
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
333 // $a.bind('click', function(){ console.log( action )} );
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
334 //})();
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
335 $img.attr('src', settings.buttonsImagePath + buttonSettings.img);
604
13c8b1ad99d4 work on button creation
robcast
parents: 603
diff changeset
336 };
13c8b1ad99d4 work on button creation
robcast
parents: 603
diff changeset
337 }
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
338 return $buttonsDiv;
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
339 };
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
340
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
341 // returns function for load event of scaler img
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
342 var scalerImgLoadedFn = function(settings) {
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
343 return function() {
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
344 console.debug("img loaded! settings=", settings);
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
345 };
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
346 };
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
347 // hook plugin into jquery
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
348 $.fn.digilib = function(method) {
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
349 if (methods[method]) {
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
350 return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
351 } else if (typeof(method) === 'object' || !method) {
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
352 return methods.init.apply(this, arguments);
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
353 } else {
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
354 $.error( 'Method ' + method + ' does not exist on jQuery.digilib' );
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
355 }
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
356 };
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
357
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
358 })(jQuery);