1
0
mirror of https://github.com/Jermolene/TiddlyWiki5 synced 2025-01-19 05:32:51 +00:00
TiddlyWiki5/js/macros/chooser.js
Jeremy Ruston b513daaff8 Added an experimental fisheye menu chooser
I'm starting to experiment with interactive features so that I can
finalise the macro architecture. I'm trying to design for touch first;
this menu swipes in from the left
2012-03-07 17:44:12 +00:00

106 lines
2.8 KiB
JavaScript

/*\
title: js/macros/chooser.js
\*/
(function(){
/*jslint node: true */
"use strict";
var Renderer = require("../Renderer.js").Renderer,
Dependencies = require("../Dependencies.js").Dependencies,
Tiddler = require("../Tiddler.js").Tiddler,
utils = require("../Utils.js");
function positionChooserPanel(macroNode,x,y) {
var domWrapper = macroNode.domNode,
heightWrapper = domWrapper.offsetHeight,
rectWrapper = domWrapper.getBoundingClientRect(),
domPanel = macroNode.content[0].domNode,
heightPanel = domPanel.offsetHeight,
rectPanel = domPanel.getBoundingClientRect();
// Make the coordinates relative to the wrapper
x = x - rectWrapper.left;
y = y - rectWrapper.top;
// Scale the panel to fit
var scaleFactor = heightWrapper/heightPanel;
// Scale up as we move right
var expandFactor = ((100+x)/100);
// Set up the transform
var scale = scaleFactor * expandFactor,
translate = (y / scale) - ((y/heightWrapper) * heightPanel);
domPanel.style.webkitTransformOrigin = "0 0";
domPanel.style.webkitTransform = "scale(" + scale + ") translateY(" + translate + "px)";
}
function loadContent(macroNode) {
var nodes = [];
macroNode.store.forEachTiddler("title",function(title,tiddler) {
nodes.push(Renderer.ElementNode("li",{},[
Renderer.TextNode(title)
]));
});
var wrapper = Renderer.ElementNode("ul",{},nodes);
wrapper.execute(macroNode.parents,macroNode.store.getTiddler(macroNode.tiddlerTitle));
macroNode.content = [wrapper];
macroNode.content[0].renderInDom(macroNode.domNode);
}
function removeContent(macroNode) {
macroNode.domNode.removeChild(macroNode.content[0].domNode);
macroNode.content = [];
}
exports.macro = {
name: "chooser",
wrapperTag: "div",
params: {
},
events: {
touchstart: function(event) {
this.domNode.style.backgroundColor = "red";
loadContent(this);
positionChooserPanel(this,event.touches[0].pageX,event.touches[0].pageY);
event.preventDefault();
return false;
},
touchmove: function(event) {
positionChooserPanel(this,event.touches[0].pageX,event.touches[0].pageY);
event.preventDefault();
return false;
},
touchend: function(event) {
this.domNode.style.backgroundColor = "blue";
removeContent(this);
event.preventDefault();
return false;
},
mouseover: function(event) {
if(event.target === this.domNode) {
loadContent(this);
positionChooserPanel(this,event.clientX,event.clientY);
event.preventDefault();
return false;
}
},
mousemove: function(event) {
positionChooserPanel(this,event.clientX,event.clientY);
event.preventDefault();
return false;
},
mouseout: function(event) {
if(!utils.domContains(this.domNode,event.relatedTarget)) {
removeContent(this);
event.preventDefault();
return false;
}
}
},
execute: function() {
return [];
}
};
})();