mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2024-12-24 17:10:29 +00:00
Add a cecily view
Finally, the start of a proper 2D ZUI view. It's going to replace the current "zoomin" storyview
This commit is contained in:
parent
d1c396507b
commit
999d63c0f0
99
core/modules/macros/list/listviews/cecily.js
Normal file
99
core/modules/macros/list/listviews/cecily.js
Normal file
@ -0,0 +1,99 @@
|
||||
/*\
|
||||
title: $:/core/modules/macros/list/listviews/cecily.js
|
||||
type: application/javascript
|
||||
module-type: listview
|
||||
|
||||
Views the list through a 2D map
|
||||
|
||||
\*/
|
||||
(function(){
|
||||
|
||||
/*jslint node: true, browser: true */
|
||||
/*global $tw: false */
|
||||
"use strict";
|
||||
|
||||
function CecilyListView(listMacro) {
|
||||
// The list macro we're attached to
|
||||
this.listMacro = listMacro;
|
||||
// Prepare the list frame
|
||||
var listFrameDomNode = this.listMacro.listFrame.domNode
|
||||
listFrameDomNode.style.position = "relative";
|
||||
listFrameDomNode.style.width = "100%"; // TODO: This isn't the best way to set the width and height
|
||||
listFrameDomNode.style.height = "400px";
|
||||
// Prepare the nozzle for dispensing new tiddlers onto the map
|
||||
this.newTiddlerPosition = {x: 0, y: 0};
|
||||
// Position the initial list entries on the map
|
||||
this.loadMap();
|
||||
this.map.positions["HelloThere"] = {x: 250, y: 50, w: 300, h: 300};
|
||||
this.saveMap();
|
||||
for(var t=0; t<listFrameDomNode.children.length; t++) {
|
||||
var title = this.listMacro.listFrame.children[t].listElementInfo.title,
|
||||
domNode = listFrameDomNode.children[t];
|
||||
this.positionTiddler(title,domNode);
|
||||
}
|
||||
};
|
||||
|
||||
CecilyListView.prototype.getMapTiddlerTitle = function() {
|
||||
return this.listMacro.params.map || "$:/TiddlerMap";
|
||||
};
|
||||
|
||||
CecilyListView.prototype.loadMap = function() {
|
||||
this.map = this.listMacro.wiki.getTiddlerData(this.getMapTiddlerTitle(),{positions: []});
|
||||
};
|
||||
|
||||
CecilyListView.prototype.saveMap = function() {
|
||||
this.listMacro.wiki.setTiddlerData(this.getMapTiddlerTitle(),this.map);
|
||||
};
|
||||
|
||||
// Get the position of a particular tiddler
|
||||
CecilyListView.prototype.lookupTiddlerInMap = function(title,domNode) {
|
||||
// First try looking it up in the map
|
||||
if(this.map.positions[title]) {
|
||||
return this.map.positions[title];
|
||||
}
|
||||
// If the tiddler wasn't in the map we'll have to compute it
|
||||
var newPosition;
|
||||
switch(this.map.positionNew) {
|
||||
default: // "below"
|
||||
newPosition = {
|
||||
x: this.newTiddlerPosition.x,
|
||||
y: this.newTiddlerPosition.y,
|
||||
w: 300,
|
||||
h: 300
|
||||
};
|
||||
this.newTiddlerPosition.y += domNode.offsetHeight/2;
|
||||
break;
|
||||
}
|
||||
// Return the position
|
||||
return newPosition || {
|
||||
x: 0,
|
||||
y: 0,
|
||||
w: 300,
|
||||
h: 300
|
||||
};
|
||||
};
|
||||
|
||||
CecilyListView.prototype.positionTiddler = function(title,domNode) {
|
||||
var pos = this.lookupTiddlerInMap(title,domNode);
|
||||
domNode.style.position = "absolute";
|
||||
domNode.style[$tw.browser.transform] = "translateX(" + pos.x + "px) translateY(" + pos.y + "px)";
|
||||
};
|
||||
|
||||
CecilyListView.prototype.insert = function(index) {
|
||||
var listElementNode = this.listMacro.listFrame.children[index],
|
||||
targetElement = listElementNode.domNode;
|
||||
// Animate the insertion
|
||||
var d = $tw.config.preferences.animationDuration + "ms";
|
||||
targetElement.style[$tw.browser.transition] = "";
|
||||
targetElement.style[$tw.browser.transformorigin] = "0% 0%";
|
||||
targetElement.style.opacity = "0.0";
|
||||
$tw.utils.forceLayout(targetElement);
|
||||
targetElement.style[$tw.browser.transition] = "opacity " + d + " ease-out";
|
||||
targetElement.style.opacity = "1.0";
|
||||
// Position the dom node
|
||||
this.positionTiddler(listElementNode.listElementInfo.title,targetElement);
|
||||
};
|
||||
|
||||
exports["cecily"] = CecilyListView;
|
||||
|
||||
})();
|
Loading…
Reference in New Issue
Block a user