How to show the full resolution image at clicking on thumnail

There are 5 copies of the same images are placed in a folder i.e. large(1024768),medium(500375),small(240180),thu mnail(7575),square(10050) in size…
The following code upload number of Geocoded images(square size) when the page loads.I want when someone click on the any Geocoded image on the page ,it should show the large image(1024
768) of the same.And further click on the large image it must show again the square size image of the same.
Following is the actual code.It is in .js file.

  1. var epsg4326 = new OpenLayers.Projection(“EPSG:4326”);
  2. var OSVMain = (function() {
  3. var map, markers, map_move_timeout;
    
  4. var photos = {};
    
  5. function mapChange() {
    
  6.     if( map_move_timeout )
    
  7.         clearTimeout(map_move_timeout);
    
  8.     map_move_timeout = setTimeout(mapChangeTimeout, 500);
    
  9.     updateLinks();
    
  10. }
    
  11. function updateLinks() {
    
  12.     var center = OSV.getMapCenter(map);
    
  13.     var zoom = map.getZoom();
    
  14.     $('#permalink').attr('href',OSV.getURLBase()+'?lat='+center.lat+'&lon='+center.lon+'&zoom='+zoom);
    
  15.     $('#kmllink').attr('href',getLocateLink('kml'));
    
  16. }
    
  17. function getLocateLink(format) {
    
  18.     var extent = OSV.getMapExtent(map);
    
  19.     var url = OSV.getURLBase()+'/api/photos/locate.'+format+'?bbox=';
    
  20.     url += [ extent.left, extent.bottom, extent.right, extent.top].join(',');
    
  21.     return url;
    
  22. }
    
  23. function mapChangeTimeout() {
    
  24.     map_move_timeout = null;
    
  25.     var url = getLocateLink('json');
    
  26.     $.get( url, null, photosLoaded, 'json' );
    
  27. }
    
  28. function photosLoaded(json) {
    
  29.     var new_photos = {};
    
  30.     var size = new OpenLayers.Size(50, 50);
    
  31.     var offset = new OpenLayers.Pixel(-25, -25);
    
  32.     for( var i = 0, l = json.length; i < l; ++i ) {
    
  33.         var p = new OSVPhoto(json[i]);
    
  34.         if( photos[p.data.id] ) {
    
  35.             new_photos[p.data.id] = photos[p.data.id];
    
  36.             photos[p.data.id] = null;
    
  37.         } else {
    
  38.             var position = new OpenLayers.LonLat(p.data.lon,p.data.lat);
    
  39.             var icon = new OpenLayers.Icon(p.url('square'), size, offset);
    
  40.             p.marker  = new OpenLayers.Marker(position.clone().transform(epsg4326, map.getProjectionObject()), icon);
    
  41.             new_photos[p.data.id] = p;
    
  42.             markers.addMarker(p.marker);
    
  43.         }
    
  44.     }
    
  45.     for( var k in photos ) {
    
  46.         var p = photos[k];
    
  47.         if( p && p.marker )
    
  48.             markers.removeMarker(p.marker);
    
  49.     }
    
  50.     photos = new_photos;
    
  51. }
    
  52. function setup() {
    
  53.     var vectors;
    
  54.     var popup;
    
  55.     map = new OpenLayers.Map($('#map').get(0), {
    
  56.         controls: [
    
  57.             new OpenLayers.Control.ArgParser(),
    
  58.             new OpenLayers.Control.Attribution(),
    
  59.             new OpenLayers.Control.LayerSwitcher(),
    
  60.             new OpenLayers.Control.Navigation(),
    
  61.             new OpenLayers.Control.PanZoomBar()
    
  62.         ],
    
  63.         units: "m",
    
  64.         maxResolution: 156543.0339,
    
  65.         numZoomLevels: 20,
    
  66.         displayProjection: new OpenLayers.Projection("EPSG:4326")
    
  67.     });
    
  68.     var mapnik = new OpenLayers.Layer.OSM.Mapnik("Mapnik", {
    
  69.         displayOutsideMaxExtent: true,
    
  70.         wrapDateLine: true
    
  71.     });
    
  72.     map.addLayer(mapnik);
    
  73.     var osmarender = new OpenLayers.Layer.OSM.Osmarender("Osmarender", {
    
  74.         displayOutsideMaxExtent: true,
    
  75.         wrapDateLine: true
    
  76.     });
    
  77.     map.addLayer(osmarender);
    
  78.     var numZoomLevels = Math.max(mapnik.numZoomLevels, osmarender.numZoomLevels);
    
  79.     var start = OSV.getStartLocation();
    
  80.     var numzoom = map.getNumZoomLevels();
    
  81.     if (start.zoom >= numzoom) start.zoom = numzoom - 1;
    
  82.     map.setCenter(start.pos.clone().transform(epsg4326, map.getProjectionObject()), start.zoom);
    
  83.     OSV.setupMapEventHandlers(map);
    
  84.     map.events.register("moveend", map, mapChange);
    
  85.     map.events.register("zoomend", map, mapChange);
    
  86.     mapChange();
    
  87.     markers = new OpenLayers.Layer.Markers("Markers", {
    
  88.         displayInLayerSwitcher: false,
    
  89.         numZoomLevels: numZoomLevels,
    
  90.         maxExtent: new OpenLayers.Bounds(-20037508,-20037508,20037508,20037508),
    
  91.         maxResolution: 156543,
    
  92.         units: "m",
    
  93.         projection: "EPSG:900913"
    
  94.     });
    
  95.     map.addLayer(markers);
    
  96. }
    
  97. return {
    
  98.     setup: setup,
    
  99.     1:1
    
  100. };
    
  101. })();
  102. $(function(){
  103. OSVMain.setup();
    
  104. });

Any suggestions ?
Thanking you