-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathframer.modules.js
126 lines (110 loc) · 13.3 KB
/
framer.modules.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({"Pointer":[function(require,module,exports){
exports.Pointer = (function() {
var clientCoords, coords, offsetArgumentError, offsetCoords, screenArgumentError;
function Pointer() {}
Pointer.screen = function(event, layer) {
var e, screenCoords;
if (!((event != null) && (layer != null))) {
screenArgumentError();
}
e = offsetCoords(event);
if (e.x && e.y) {
screenCoords = layer.screenFrame;
e.x += screenCoords.x;
e.y += screenCoords.y;
} else {
e = clientCoords(event);
}
return e;
};
Pointer.offset = function(event, layer) {
var e, targetScreenCoords;
if (!((event != null) && (layer != null))) {
offsetArgumentError();
}
e = offsetCoords(event);
if (!((e.x != null) && (e.y != null))) {
e = clientCoords(event);
targetScreenCoords = layer.screenFrame;
e.x -= targetScreenCoords.x;
e.y -= targetScreenCoords.y;
}
return e;
};
offsetCoords = function(ev) {
var e;
e = Events.touchEvent(ev);
return coords(e.offsetX, e.offsetY);
};
clientCoords = function(ev) {
var e;
e = Events.touchEvent(ev);
return coords(e.clientX, e.clientY);
};
coords = function(x, y) {
return {
x: x,
y: y
};
};
screenArgumentError = function() {
error(null);
return console.error("Pointer.screen() Error: You must pass event & layer arguments. \n\nExample: layer.on Events.TouchStart,(event,layer) -> Pointer.screen(event, layer)");
};
offsetArgumentError = function() {
error(null);
return console.error("Pointer.offset() Error: You must pass event & layer arguments. \n\nExample: layer.on Events.TouchStart,(event,layer) -> Pointer.offset(event, layer)");
};
return Pointer;
})();
},{}],"androidRipple":[function(require,module,exports){
var Pointer;
Pointer = require("Pointer").Pointer;
exports.Ripple = function(event, layer) {
var animation, color, eventCoords, pressFeedback, rippleCircle;
eventCoords = Pointer.offset(event, layer);
color = "black";
animation = {
curve: "ease-out",
time: .8
};
pressFeedback = new Layer({
superLayer: this,
name: "pressFeedback",
width: layer.width,
height: layer.height,
opacity: 0,
backgroundColor: color
});
pressFeedback.states.add({
pressed: {
opacity: .04
}
});
pressFeedback.states["switch"]("pressed", animation);
rippleCircle = new Layer({
superLayer: this,
name: "rippleCircle",
borderRadius: "50%",
midX: eventCoords.x,
midY: eventCoords.y,
opacity: .16,
backgroundColor: color
});
rippleCircle.states.add({
pressed: {
scale: layer.width / 60,
opacity: 0
}
});
rippleCircle.states["switch"]("pressed", animation);
return Utils.delay(0.3, function() {
pressFeedback.states.next("default", animation);
return pressFeedback.on(Events.AnimationEnd, function() {
rippleCircle.destroy();
return pressFeedback.destroy();
});
});
};
},{"Pointer":"Pointer"}]},{},[])
//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","/Users/aaronjames/Dropbox/Framer/Simple-Android-Ripple/androidRipple-Sample-Project.framer/modules/Pointer.coffee","/Users/aaronjames/Dropbox/Framer/Simple-Android-Ripple/androidRipple-Sample-Project.framer/modules/androidRipple.coffee"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","##############################################################################\n# Created by Jordan Robert Dobson on 14 August 2015\n# \n# Use to normalize screen & offset x,y values from click or touch events.\n#\n# To Get Started...\n#\n# 1. Place this file in Framer Studio modules directory\n#\n# 2. In your project include:\n#     {Pointer} = require \"Pointer\"\n#\n# 3. For screen coordinates: \n#     btn.on Events.Click, (event, layer) -> print Pointer.screen(event, layer)\n# \n# 4. For layer offset coordinates: \n#     btn.on Events.Click, (event, layer) -> print Pointer.offset(event, layer)\n#\n##############################################################################\n\nclass exports.Pointer\n\n\t##############################################################################\n\t# Public Methods #############################################################\n\n\t@screen = (event, layer) ->\n\t\tscreenArgumentError() unless event? and layer?\n\t\te = offsetCoords event\n\t\tif e.x and e.y\n\t\t\t# Mouse Event\n\t\t\tscreenCoords = layer.screenFrame\n\t\t\te.x += screenCoords.x\n\t\t\te.y += screenCoords.y\n\t\telse\n\t\t\t# Touch Event\n\t\t\te = clientCoords event\n\t\treturn e\n\t\t\t\n\t@offset = (event, layer) ->\n\t\toffsetArgumentError() unless event? and layer?\n\t\te = offsetCoords event\n\t\tunless e.x? and e.y?\n\t\t\t# Touch Event\n\t\t\te = clientCoords event\n\t\t\ttargetScreenCoords = layer.screenFrame\n\t\t\te.x -= targetScreenCoords.x\n\t\t\te.y -= targetScreenCoords.y\n\t\treturn e\n\t\n\t##############################################################################\n\t# Private Helper Methods #####################################################\n\t\n\toffsetCoords = (ev)  -> e = Events.touchEvent ev; return coords e.offsetX, e.offsetY\n\tclientCoords = (ev)  -> e = Events.touchEvent ev; return coords e.clientX, e.clientY\n\tcoords       = (x,y) -> return x:x, y:y\n\t\n\t##############################################################################\n\t# Error Handler Methods ######################################################\n\t\n\tscreenArgumentError = ->\n\t\terror null\n\t\tconsole.error \"\"\"\n\t\t\tPointer.screen() Error: You must pass event & layer arguments. \\n\n\t\t\tExample: layer.on Events.TouchStart,(event,layer) -> Pointer.screen(event, layer)\"\"\"\n\t\t\t\n\toffsetArgumentError = ->\n\t\terror null\n\t\tconsole.error \"\"\"\n\t\t\tPointer.offset() Error: You must pass event & layer arguments. \\n\n\t\t\tExample: layer.on Events.TouchStart,(event,layer) -> Pointer.offset(event, layer)\"\"\"","# Module created by Aaron James | April 16th, 2016\n#\n# Pointer Module by Jordan Dobson is required for this module\n# Install this module first here: http://bit.ly/1lgmNpT\n#\n# Add the following line at the top of your project to access this module:\n# android = require \"androidRipple\"\n#\n# To add ripple to layer, use this line of code:\n# layerName.on(Events.Click, android.ripple)\n# Replace layerName with the name of your layer\n#\n# Available options:\n# You can use any Event with this module\n\n{Pointer} = require \"Pointer\"\n\n# create ripple function\nexports.Ripple = (event, layer) ->\n\teventCoords = Pointer.offset(event, layer)\n\n\t# Change color of ripple\n\tcolor = \"black\"\n\tanimation = curve: \"ease-out\", time: .8\n\n\t# Create layers on Click\n\tpressFeedback = new Layer\n\t\tsuperLayer: @\n\t\tname: \"pressFeedback\"\n\t\twidth: layer.width\n\t\theight: layer.height\n\t\topacity: 0\n\t\tbackgroundColor: color\n\tpressFeedback.states.add\n\t\tpressed: opacity: .04\n\tpressFeedback.states.switch(\"pressed\", animation)\n\n\trippleCircle = new Layer\n\t\tsuperLayer: @\n\t\tname: \"rippleCircle\"\n\t\tborderRadius: \"50%\"\n\t\tmidX: eventCoords.x\n\t\tmidY: eventCoords.y\n\t\topacity: .16\n\t\tbackgroundColor: color\n\trippleCircle.states.add\n\t\tpressed: scale: layer.width / 60, opacity: 0,\n\trippleCircle.states.switch(\"pressed\", animation)\n\n\t# Destroy layers after Click\n\tUtils.delay 0.3, ->\n\t\tpressFeedback.states.next(\"default\", animation)\n\t\tpressFeedback.on Events.AnimationEnd, ->\n\t\t\trippleCircle.destroy()\n\t\t\tpressFeedback.destroy()\n"]}