| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | /********************************************************************** | 
					
						
							|  |  |  | *  | 
					
						
							|  |  |  | * | 
					
						
							|  |  |  | * | 
					
						
							|  |  |  | **********************************************************************/ | 
					
						
							|  |  |  | ((typeof define)[0]=='u'?function(f){module.exports=f(require)}:define) | 
					
						
							|  |  |  | (function(require){ var module={} // make module AMD/node compatible...
 | 
					
						
							|  |  |  | /*********************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-28 16:18:08 +03:00
										 |  |  | // XXX should we guard against loading in node???
 | 
					
						
							|  |  |  | if(typeof(window) == 'undefined'){ | 
					
						
							|  |  |  | 	return | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | var object = require('lib/object') | 
					
						
							|  |  |  | var actions = require('lib/actions') | 
					
						
							|  |  |  | var features = require('lib/features') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var core = require('features/core') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-26 04:13:08 +03:00
										 |  |  | var ribbons = require('imagegrid/ribbons') | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-27 06:50:29 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-17 04:53:00 +03:00
										 |  |  | /*********************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var RibbonsClassPrototype = { | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 	// This is needed to calculate image size when no images are loaded... 
 | 
					
						
							|  |  |  | 	createImage: function(){ | 
					
						
							|  |  |  | 		// XXX
 | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-27 06:50:29 +03:00
										 |  |  | 	// XXX
 | 
					
						
							| 
									
										
										
										
											2017-05-17 04:53:00 +03:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2017-05-26 04:13:08 +03:00
										 |  |  | RibbonsClassPrototype.__proto__ = ribbons.BaseRibbons.prototype.__proto__ | 
					
						
							| 
									
										
										
										
											2017-05-17 04:53:00 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var RibbonsPrototype = { | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 	viewer: null, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	createImage: RibbonsClassPrototype.createImage, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-27 06:50:29 +03:00
										 |  |  | 	// XXX
 | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	__init__: function(viewer, images){ | 
					
						
							|  |  |  | 		// XXX
 | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2017-05-17 04:53:00 +03:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2017-05-26 04:13:08 +03:00
										 |  |  | RibbonsPrototype.__proto__ = ribbons.BaseRibbons.prototype | 
					
						
							| 
									
										
										
										
											2017-05-17 04:53:00 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var Ribbons = | 
					
						
							|  |  |  | module.Ribbons = | 
					
						
							|  |  |  | object.makeConstructor('Ribbons',  | 
					
						
							|  |  |  | 	RibbonsClassPrototype, | 
					
						
							|  |  |  | 	RibbonsPrototype) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | /*********************************************************************/ | 
					
						
							| 
									
										
										
										
											2017-06-27 01:38:57 +03:00
										 |  |  | // NOTE: some features that depend on ribbon geometry will not work 
 | 
					
						
							|  |  |  | // 		with this...
 | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | var RenderActions = actions.Actions({ | 
					
						
							| 
									
										
										
										
											2017-05-27 06:50:29 +03:00
										 |  |  | 	get dom(){ | 
					
						
							|  |  |  | 		return this.ribbons ? this.ribbons.viewer : undefined }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 	load: [ | 
					
						
							| 
									
										
										
										
											2017-05-26 17:40:53 +03:00
										 |  |  | 		function(data){ | 
					
						
							| 
									
										
										
										
											2017-05-27 06:50:29 +03:00
										 |  |  | 			return function(){ | 
					
						
							|  |  |  | 				// XXX setup .ribbons
 | 
					
						
							|  |  |  | 				var viewer = data.viewer | 
					
						
							|  |  |  | 				viewer = viewer == null && this.ribbons != null  | 
					
						
							|  |  |  | 					? this.dom  | 
					
						
							|  |  |  | 					: viewer | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(this.ribbons == null){ | 
					
						
							|  |  |  | 					this.ribbons = Ribbons(viewer, this.images) | 
					
						
							|  |  |  | 					// XXX is this correct???
 | 
					
						
							|  |  |  | 					//this.ribbons.__image_updaters = [this.updateImage.bind(this)]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					//this.ribbons.clear()
 | 
					
						
							|  |  |  | 					this.ribbons.images = this.images | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				this.reload() | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 		}], | 
					
						
							|  |  |  | 	reload: [ | 
					
						
							|  |  |  | 		function(){ | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 			// full reload...
 | 
					
						
							|  |  |  | 			if(force == 'full'){ | 
					
						
							|  |  |  | 				//this.stop()
 | 
					
						
							|  |  |  | 				/* | 
					
						
							|  |  |  | 				killAllWorkers() | 
					
						
							|  |  |  | 					.done(function(){ | 
					
						
							|  |  |  | 						reload()  | 
					
						
							|  |  |  | 					}) | 
					
						
							|  |  |  | 				*/ | 
					
						
							|  |  |  | 				return location.reload() | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if(!this.ribbons){ | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	refresh: [ | 
					
						
							|  |  |  | 		function(){ | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 			if(!this.ribbons){ | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	clear: [ | 
					
						
							|  |  |  | 		function(){ | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 			if(!this.ribbons){ | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	resizing: [ | 
					
						
							| 
									
										
										
										
											2018-02-13 01:14:35 +03:00
										 |  |  | 		core.Event(function(unit, size, overflow){ | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			// This is a resizing protocol root function.
 | 
					
						
							|  |  |  | 			//
 | 
					
						
							|  |  |  | 			// This will never be used directly, but will wrap protocol user
 | 
					
						
							|  |  |  | 			// functions.
 | 
					
						
							|  |  |  | 			//
 | 
					
						
							|  |  |  | 			// As an example see: .viewScale(..)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			// XXX stop current animation...
 | 
					
						
							|  |  |  | 			// XXX
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			// XXX call .resizingDone(..) when animations done...
 | 
					
						
							|  |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		})], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	viewScale: ['- Zoom/', | 
					
						
							|  |  |  | 		function(scale){  | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 			if(!this.ribbons){ | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			if(scale == null || scale == '?'){ | 
					
						
							|  |  |  | 				return // XXX get scale...
 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			this.resizing.chainCall(this, function(){ | 
					
						
							|  |  |  | 				// XXX set scale...
 | 
					
						
							|  |  |  | 			}, 'scale', scale) | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	fitImage: ['Zoom/Fit image', | 
					
						
							|  |  |  | 		function(count, overflow){  | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 			if(!this.ribbons){ | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			if(count == '?'){ | 
					
						
							|  |  |  | 				return // XXX get size...
 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			this.resizing.chainCall(this, function(){ | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 				if(count != null){ | 
					
						
							|  |  |  | 					overflow = overflow == false ? 0 : overflow | 
					
						
							|  |  |  | 					var o = overflow != null ? overflow  | 
					
						
							|  |  |  | 						: count % 2 != 1 ? 0 | 
					
						
							|  |  |  | 						: (this.config['fit-overflow'] || 0) | 
					
						
							|  |  |  | 					count += o | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				// set the scale...
 | 
					
						
							|  |  |  | 				// XXX
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				// refresh image previews...
 | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 				// XXX
 | 
					
						
							|  |  |  | 			}, 'screenwidth', count, overflow) | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	fitRibbon: ['Zoom/Fit ribbon vertically', | 
					
						
							|  |  |  | 		function(count, whole){  | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 			if(!this.ribbons){ | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			if(count == '?'){ | 
					
						
							|  |  |  | 				return // XXX get size...
 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			this.resizing.chainCall(this, function(){ | 
					
						
							|  |  |  | 				// XXX set size...
 | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				// XXX refresh image previews...
 | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			}, 'screenheight', count, whole) | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-27 06:50:29 +03:00
										 |  |  | 	// XXX do we need updateImage here???
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 	centerImage: ['- Interface/Center an image in ribbon horizontally', | 
					
						
							|  |  |  | 		function(target, align, offset, scale){  | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 			if(!this.ribbons){ | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	centerRibbon: ['- Interface/Center a ribbon vertically', | 
					
						
							|  |  |  | 		function(target){  | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 			if(!this.ribbons){ | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ribbonRotation: ['- Interface|Ribbon/',  | 
					
						
							|  |  |  | 		function(angle){  | 
					
						
							| 
									
										
										
										
											2017-07-29 21:39:47 +03:00
										 |  |  | 			if(!this.ribbons){ | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var Render =  | 
					
						
							|  |  |  | module.Render = core.ImageGridFeatures.Feature({ | 
					
						
							|  |  |  | 	title: '', | 
					
						
							|  |  |  | 	doc: '', | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-26 04:13:08 +03:00
										 |  |  | 	tag: 'ui-blank-render', | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 	exclusive: ['ui-render'], | 
					
						
							|  |  |  | 	depends: [ | 
					
						
							|  |  |  | 		// XXX
 | 
					
						
							|  |  |  | 	], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	actions: RenderActions,  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	handlers: [ | 
					
						
							| 
									
										
										
										
											2017-07-30 01:07:47 +03:00
										 |  |  | 		[[ | 
					
						
							|  |  |  | 			'shiftImageTo', | 
					
						
							|  |  |  | 			'shiftImageUp', | 
					
						
							|  |  |  | 			'shiftImageDown', | 
					
						
							|  |  |  | 			'shiftImageLeft', | 
					
						
							|  |  |  | 			'shiftImageRight', | 
					
						
							|  |  |  | 		], function(){ | 
					
						
							|  |  |  | 			// XXX stub...
 | 
					
						
							|  |  |  | 			//this.reload()
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-16 01:46:51 +03:00
										 |  |  | 		// XXX
 | 
					
						
							|  |  |  | 	], | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /********************************************************************** | 
					
						
							|  |  |  | * vim:set ts=4 sw=4 :                               */ return module }) |