[pLog-svn] r1096 - in plugins/trunk/flickr: . install js
js/annotation
mark at devel.plogworld.net
mark at devel.plogworld.net
Tue Feb 15 18:21:04 GMT 2005
Author: mark
Date: 2005-02-15 18:21:03 +0000 (Tue, 15 Feb 2005)
New Revision: 1096
Added:
plugins/trunk/flickr/js/
plugins/trunk/flickr/js/annotation/
plugins/trunk/flickr/js/annotation/annotation.js
Removed:
plugins/trunk/flickr/install/js/
Modified:
plugins/trunk/flickr/readme.txt
Log:
move /js from /install to root of flickr plugin. And also modify readme.txt regarding to this change.
Added: plugins/trunk/flickr/js/annotation/annotation.js
===================================================================
--- plugins/trunk/flickr/js/annotation/annotation.js 2005-02-15 18:18:55 UTC (rev 1095)
+++ plugins/trunk/flickr/js/annotation/annotation.js 2005-02-15 18:21:03 UTC (rev 1096)
@@ -0,0 +1,127 @@
+var aI = {
+
+ init: function() {
+ if (!document.getElementById ||
+ !document.createElement ||
+ !document.getElementsByTagName)
+ return;
+ var anni = document.getElementsByTagName('img');
+ for (var i=0;i<anni.length;i++) {
+ if ((anni[i].className.search(/\bannotated\b/) != -1) &&
+ (anni[i].getAttribute('usemap') != null)) {
+ aI.prepImage(anni[i]);
+ }
+ }
+ },
+
+ prepImage: function(img) {
+ var mapName = img.getAttribute('usemap');
+ var mapObj = document.getElementById(mapName);
+ var areas = mapObj.getElementsByTagName('area');
+ img.areas = [];
+ for (var j=areas.length-1;j>=0;j--) {
+ if (areas[j].getAttribute('shape').toLowerCase() == 'rect') {
+ var coo = areas[j].getAttribute('coords').split(',');
+ if (coo.length != 4) break;
+ var a = document.createElement('a');
+ a.associatedCoords = coo;
+ a.style.width = (parseInt(coo[2]) - parseInt(coo[0])) + 'px';
+ a.style.height = (parseInt(coo[3]) - parseInt(coo[1])) + 'px';
+ var thisAreaPosition = aI.__getAreaPosition(img,coo);
+ a.style.left = thisAreaPosition[0] + 'px';
+ a.style.top = thisAreaPosition[1] + 'px';
+ a.className = 'annotation';
+ var href = areas[j].getAttribute('href');
+ if (href) {
+ a.href = href;
+ } else {
+ // set an explicit href, otherwise it doesn't count as a link
+ // for IE
+ a.href = "#";
+ }
+ a.title = areas[j].getAttribute('title');
+ var s = document.createElement('span');
+ s.appendChild(document.createTextNode(''));
+ a.appendChild(s);
+
+ img.areas[img.areas.length] = a;
+ document.getElementsByTagName('body')[0].appendChild(a);
+
+ aI.addEvent(a,"mouseover",
+ function() {
+ clearTimeout(aI.hiderTimeout);
+ }
+ );
+
+ if ((typeof showNiceTitle == 'function') &&
+ (typeof hideNiceTitle == 'function')) {
+ a.setAttribute('nicetitle',a.title);
+ a.title = '';
+ aI.addEvent(a,"mouseover",showNiceTitle);
+ aI.addEvent(a,"mouseout",hideNiceTitle);
+ }
+
+ }
+ }
+
+ aI.addEvent(img,"mouseover",aI.showAreas);
+ aI.addEvent(img,"mouseout",aI.hideAreas);
+ },
+
+ __getAreaPosition: function(img,coo) {
+ var aleft = (img.offsetLeft + parseInt(coo[0]));
+ var atop = (img.offsetTop + parseInt(coo[1]));
+ var oo = img;
+ while (oo.offsetParent) {
+ oo = oo.offsetParent;
+ aleft += oo.offsetLeft;
+ atop += oo.offsetTop;
+ }
+ return [aleft,atop];
+ },
+
+ __setAreas: function(t,disp) {
+ if (!t || !t.areas) return;
+ for (var i=0;i<t.areas.length;i++) {
+ t.areas[i].style.display = disp;
+ }
+ },
+
+ showAreas: function(e) {
+ var t = null;
+ if (e && e.target) t = e.target;
+ if (window.event && window.event.srcElement) t = window.event.srcElement;
+ // Recalculate area positions
+ for (var k=0;k<t.areas.length;k++) {
+ var thisAreaPosition = aI.__getAreaPosition(t,t.areas[k].associatedCoords);
+ t.areas[k].style.left = thisAreaPosition[0] + 'px';
+ t.areas[k].style.top = thisAreaPosition[1] + 'px';
+
+ }
+ aI.__setAreas(t,'block');
+ },
+ hideAreas: function(e) {
+ var t = null;
+ if (e && e.target) t = e.target;
+ if (window.event && window.event.srcElement) t = window.event.srcElement;
+ clearTimeout(aI.hiderTimeout);
+ aI.hiderTimeout = setTimeout(
+ function() { aI.__setAreas(t,'none') }, 300);
+ },
+
+ addEvent: function(elm, evType, fn, useCapture) {
+ // cross-browser event handling for IE5+, NS6 and Mozilla
+ // By Scott Andrew
+ if (elm.addEventListener){
+ elm.addEventListener(evType, fn, useCapture);
+ return true;
+ } else if (elm.attachEvent){
+ var r = elm.attachEvent("on"+evType, fn);
+ return r;
+ } else {
+ elm['on'+evType] = fn;
+ }
+ }
+}
+
+aI.addEvent(window,"load",aI.init);
Modified: plugins/trunk/flickr/readme.txt
===================================================================
--- plugins/trunk/flickr/readme.txt 2005-02-15 18:18:55 UTC (rev 1095)
+++ plugins/trunk/flickr/readme.txt 2005-02-15 18:21:03 UTC (rev 1096)
@@ -8,11 +8,10 @@
Install:
1. Copy the install/templates/flickr.template to your plog template folder.
-2. Copy the install/js/*.* to your plog installation /js folder.
-3. Add the following to your header.template to include the javascript
- <script type="text/javascript" src="js/annotation/annotation.js"></script>
-4. Add the content of install/css/annotation.css to your template style.css.
-5. Configurate your Flickr plugin in your pLog control center
+2. Add the following to your header.template to include the javascript
+ <script type="text/javascript" src="plugins/flickr/js/annotation/annotation.js"></script>
+3. Add the content of install/css/annotation.css to your template style.css.
+4. Configurate your Flickr plugin in your pLog control center
Usage:
Use the following URL to call your pLog Flickr Plugin Page
More information about the pLog-svn
mailing list