| 
									
										
										
										
											2017-06-28 03:51:50 +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 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // NOTE: this needs preact.js to be loaded by index.html
 | 
					
						
							|  |  |  | if(typeof(preact) == 'undefined'){ | 
					
						
							|  |  |  | 	console.error('Preact.js required but not present.') | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | var h = preact.h | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-28 03:51:50 +03:00
										 |  |  | var object = require('lib/object') | 
					
						
							|  |  |  | var actions = require('lib/actions') | 
					
						
							|  |  |  | var features = require('lib/features') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var core = require('features/core') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var ribbons = require('imagegrid/ribbons') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*********************************************************************/ | 
					
						
							| 
									
										
										
										
											2017-07-02 04:36:39 +03:00
										 |  |  | // Preact Components...
 | 
					
						
							|  |  |  | // 
 | 
					
						
							|  |  |  | // XXX at this point this is an experiment...
 | 
					
						
							|  |  |  | // XXX Questions:
 | 
					
						
							|  |  |  | // 		- do we do align in the Preact render or outside?
 | 
					
						
							|  |  |  | // 		- do we update preview in Preact render or outside?
 | 
					
						
							|  |  |  | // 		
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // render:
 | 
					
						
							|  |  |  | // 	- ribbon-set
 | 
					
						
							|  |  |  | // 	- ribbon-locator
 | 
					
						
							|  |  |  | // 	- current-indicator (???)
 | 
					
						
							|  |  |  | class IGRibbonSet extends preact.Component { | 
					
						
							|  |  |  | 	render(props, state){ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // render:
 | 
					
						
							|  |  |  | // 	- ribbon
 | 
					
						
							|  |  |  | // 	- images
 | 
					
						
							|  |  |  | // 	- image marks
 | 
					
						
							|  |  |  | class IGRibbon extends preact.Component { | 
					
						
							|  |  |  | 	render(props, state){ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // render:
 | 
					
						
							|  |  |  | // 	- image
 | 
					
						
							|  |  |  | class IGImage extends preact.Component { | 
					
						
							|  |  |  | 	render(props, state){ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // render:
 | 
					
						
							|  |  |  | // 	- image mark
 | 
					
						
							|  |  |  | class IGImageMark extends preact.Component { | 
					
						
							|  |  |  | 	render(props, state){ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //---------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2017-06-28 03:51:50 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | var RibbonsClassPrototype = { | 
					
						
							|  |  |  | 	// XXX
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | RibbonsClassPrototype.__proto__ = ribbons.BaseRibbons.prototype.__proto__ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var RibbonsPrototype = { | 
					
						
							|  |  |  | 	// XXX
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | RibbonsPrototype.__proto__ = ribbons.BaseRibbons.prototype | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var Ribbons = | 
					
						
							|  |  |  | module.Ribbons = | 
					
						
							|  |  |  | object.makeConstructor('Ribbons',  | 
					
						
							|  |  |  | 	RibbonsClassPrototype, | 
					
						
							|  |  |  | 	RibbonsPrototype) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*********************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var RenderActions = actions.Actions({ | 
					
						
							|  |  |  | 	get dom(){ | 
					
						
							|  |  |  | 		return this.ribbons ? this.ribbons.viewer : undefined }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	load: [ | 
					
						
							|  |  |  | 		function(data){ | 
					
						
							|  |  |  | 			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() | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	reload: [ | 
					
						
							|  |  |  | 		function(){ | 
					
						
							|  |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	refresh: [ | 
					
						
							|  |  |  | 		function(){ | 
					
						
							|  |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	clear: [ | 
					
						
							|  |  |  | 		function(){ | 
					
						
							|  |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	resizing: [ | 
					
						
							|  |  |  | 		core.notUserCallable(function(unit, size, overflow){ | 
					
						
							|  |  |  | 			// 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){  | 
					
						
							|  |  |  | 			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){  | 
					
						
							|  |  |  | 			if(count == '?'){ | 
					
						
							|  |  |  | 				return // XXX get size...
 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			this.resizing.chainCall(this, function(){ | 
					
						
							|  |  |  | 				// XXX
 | 
					
						
							|  |  |  | 			}, 'screenwidth', count, overflow) | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	fitRibbon: ['Zoom/Fit ribbon vertically', | 
					
						
							|  |  |  | 		function(count, whole){  | 
					
						
							|  |  |  | 			if(count == '?'){ | 
					
						
							|  |  |  | 				return // XXX get size...
 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			this.resizing.chainCall(this, function(){ | 
					
						
							|  |  |  | 				// XXX set size...
 | 
					
						
							|  |  |  | 			}, 'screenheight', count, whole) | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// XXX do we need updateImage here???
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	centerImage: ['- Interface/Center an image in ribbon horizontally', | 
					
						
							|  |  |  | 		function(target, align, offset, scale){  | 
					
						
							|  |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 	centerRibbon: ['- Interface/Center a ribbon vertically', | 
					
						
							|  |  |  | 		function(target){  | 
					
						
							|  |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ribbonRotation: ['- Interface|Ribbon/',  | 
					
						
							|  |  |  | 		function(angle){  | 
					
						
							|  |  |  | 			// XXX
 | 
					
						
							|  |  |  | 		}], | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var Render =  | 
					
						
							|  |  |  | module.Render = core.ImageGridFeatures.Feature({ | 
					
						
							|  |  |  | 	title: '', | 
					
						
							|  |  |  | 	doc: '', | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	tag: 'ui-preact-render', | 
					
						
							|  |  |  | 	exclusive: ['ui-render'], | 
					
						
							|  |  |  | 	depends: [ | 
					
						
							|  |  |  | 		// XXX
 | 
					
						
							|  |  |  | 	], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	actions: RenderActions,  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	handlers: [ | 
					
						
							|  |  |  | 		// XXX
 | 
					
						
							|  |  |  | 	], | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /********************************************************************** | 
					
						
							|  |  |  | * vim:set ts=4 sw=4 :                               */ return module }) |