├── Demo.framer ├── framer │ ├── version │ ├── .bookmark │ ├── images │ │ ├── cursor.png │ │ ├── icon-120.png │ │ ├── icon-152.png │ │ ├── icon-180.png │ │ ├── icon-192.png │ │ ├── icon-76.png │ │ ├── cursor@2x.png │ │ ├── cursor-active.png │ │ └── cursor-active@2x.png │ ├── config.json │ ├── framer.generated.js │ ├── style.css │ ├── framer.init.js │ ├── framer.vekter.js │ └── framer.modules.js ├── images │ └── .gitkeep ├── .gitignore ├── index.html ├── app.coffee └── modules │ ├── Constraints.coffee │ └── DesignComponents.coffee ├── images ├── Button1.png ├── Card1.png ├── Card2.png ├── Card3.png ├── Sliders.png ├── States1.png ├── States2.png └── cardContent.gif ├── module.json ├── snippet.coffee ├── README.md └── DesignComponents.coffee /Demo.framer/framer/version: -------------------------------------------------------------------------------- 1 | 12 -------------------------------------------------------------------------------- /Demo.framer/images/.gitkeep: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /images/Button1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/images/Button1.png -------------------------------------------------------------------------------- /images/Card1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/images/Card1.png -------------------------------------------------------------------------------- /images/Card2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/images/Card2.png -------------------------------------------------------------------------------- /images/Card3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/images/Card3.png -------------------------------------------------------------------------------- /images/Sliders.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/images/Sliders.png -------------------------------------------------------------------------------- /images/States1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/images/States1.png -------------------------------------------------------------------------------- /images/States2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/images/States2.png -------------------------------------------------------------------------------- /images/cardContent.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/images/cardContent.gif -------------------------------------------------------------------------------- /Demo.framer/framer/.bookmark: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/.bookmark -------------------------------------------------------------------------------- /Demo.framer/framer/images/cursor.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/images/cursor.png -------------------------------------------------------------------------------- /Demo.framer/framer/images/icon-120.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/images/icon-120.png -------------------------------------------------------------------------------- /Demo.framer/framer/images/icon-152.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/images/icon-152.png -------------------------------------------------------------------------------- /Demo.framer/framer/images/icon-180.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/images/icon-180.png -------------------------------------------------------------------------------- /Demo.framer/framer/images/icon-192.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/images/icon-192.png -------------------------------------------------------------------------------- /Demo.framer/framer/images/icon-76.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/images/icon-76.png -------------------------------------------------------------------------------- /Demo.framer/framer/images/cursor@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/images/cursor@2x.png -------------------------------------------------------------------------------- /Demo.framer/framer/images/cursor-active.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/images/cursor-active.png -------------------------------------------------------------------------------- /Demo.framer/framer/images/cursor-active@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sebcglbailey/framer-DesignComponents/HEAD/Demo.framer/framer/images/cursor-active@2x.png -------------------------------------------------------------------------------- /module.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "Design Components (Symbols)", 3 | "description": "Create symbols in Framer design mode! A module for converting your designs in design mode into full scalable classes.", 4 | "author": "Sebastian Bailey", 5 | "require": "Design = require 'DesignComponents'", 6 | "install": "DesignComponents.coffee", 7 | "example": "snippet.coffee" 8 | } -------------------------------------------------------------------------------- /Demo.framer/framer/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "orientation" : 0, 3 | "updateDelay" : 0.3, 4 | "designModeSelected" : 0, 5 | "cachedDeviceHeight" : 667, 6 | "contentScale" : 1, 7 | "cachedDeviceWidth" : 375, 8 | "fullScreen" : false, 9 | "deviceType" : "apple-iphone-8-space-gray", 10 | "sharedPrototype" : 0, 11 | "propertyPanelToggleStates" : { 12 | 13 | }, 14 | "projectId" : "B5C1B068-5C3B-4653-BF76-A3B804F15F82", 15 | "deviceOrientation" : 0, 16 | "selectedHand" : "", 17 | "showBezel" : 0, 18 | "foldedCodeRanges" : [ 19 | "{37, 246}", 20 | "{348, 226}", 21 | "{649, 984}", 22 | "{1681, 381}", 23 | "{2113, 674}" 24 | ], 25 | "deviceScale" : "fit" 26 | } -------------------------------------------------------------------------------- /Demo.framer/.gitignore: -------------------------------------------------------------------------------- 1 | # Framer Git Ignore 2 | 3 | # General OSX 4 | 5 | .DS_Store 6 | .AppleDouble 7 | .LSOverride 8 | 9 | # Icon must end with two \r 10 | Icon 11 | 12 | # Thumbnails 13 | ._* 14 | 15 | # Files that might appear in the root of a volume 16 | .DocumentRevisions-V100 17 | .fseventsd 18 | .Spotlight-V100 19 | .TemporaryItems 20 | .Trashes 21 | .VolumeIcon.icns 22 | 23 | # Directories potentially created on remote AFP share 24 | .AppleDB 25 | .AppleDesktop 26 | Network Trash Folder 27 | Temporary Items 28 | .apdisk 29 | 30 | # Framer Specific 31 | .*.html 32 | .app.js 33 | framer/*.old* 34 | framer/.*.hash 35 | framer/backup.coffee 36 | framer/backups/* 37 | framer/manifest.txt 38 | framer/preview.png 39 | framer/social-*x*.png 40 | -------------------------------------------------------------------------------- /Demo.framer/framer/framer.generated.js: -------------------------------------------------------------------------------- 1 | // This is autogenerated by Framer 2 | 3 | 4 | if (!window.Framer && window._bridge) {window._bridge('runtime.error', {message:'[framer.js] Framer library missing or corrupt. Select File → Update Framer Library.'})} 5 | if (DeviceComponent) {DeviceComponent.Devices["iphone-6-silver"].deviceImageJP2 = false}; 6 | if (window.Framer) {window.Framer.Defaults.DeviceView = {"deviceScale":"fit","selectedHand":"","deviceType":"apple-iphone-8-space-gray","contentScale":1,"hideBezel":true,"orientation":0}; 7 | } 8 | if (window.Framer) {window.Framer.Defaults.DeviceComponent = {"deviceScale":"fit","selectedHand":"","deviceType":"apple-iphone-8-space-gray","contentScale":1,"hideBezel":true,"orientation":0}; 9 | } 10 | window.FramerStudioInfo = {"deviceImagesUrl":"\/_server\/resources\/DeviceImages","documentTitle":"Demo.framer"}; 11 | 12 | Framer.Device = new Framer.DeviceView(); 13 | Framer.Device.setupContext(); -------------------------------------------------------------------------------- /Demo.framer/framer/style.css: -------------------------------------------------------------------------------- 1 | * { 2 | margin: 0; 3 | padding: 0; 4 | border: none; 5 | -webkit-user-select: none; 6 | -webkit-tap-highlight-color: rgba(0,0,0,0); 7 | } 8 | 9 | body { 10 | background-color: #fff; 11 | font: 28px/1em "Helvetica"; 12 | color: gray; 13 | overflow: hidden; 14 | } 15 | 16 | a { 17 | color: gray; 18 | } 19 | 20 | body { 21 | cursor: url('images/cursor.png') 32 32, auto; 22 | cursor: -webkit-image-set( 23 | url('images/cursor.png') 1x, 24 | url('images/cursor@2x.png') 2x 25 | ) 32 32, auto; 26 | } 27 | 28 | body:active { 29 | cursor: url('images/cursor-active.png') 32 32, auto; 30 | cursor: -webkit-image-set( 31 | url('images/cursor-active.png') 1x, 32 | url('images/cursor-active@2x.png') 2x 33 | ) 32 32, auto; 34 | } 35 | 36 | .framerAlertBackground { 37 | position: absolute; top:0px; left:0px; right:0px; bottom:0px; 38 | z-index: 1000; 39 | background-color: #fff; 40 | } 41 | 42 | .framerAlert { 43 | font:400 14px/1.4 "Helvetica Neue", Helvetica, Arial, sans-serif; 44 | -webkit-font-smoothing:antialiased; 45 | color:#616367; text-align:center; 46 | position: absolute; top:40%; left:50%; width:260px; margin-left:-130px; 47 | } 48 | .framerAlert strong { font-weight:500; color:#000; margin-bottom:8px; display:block; } 49 | .framerAlert a { color:#28AFFA; } 50 | .framerAlert .btn { 51 | font-weight:500; text-decoration:none; line-height:1; 52 | display:inline-block; padding:6px 12px 7px 12px; 53 | border-radius:3px; margin-top:12px; 54 | background:#28AFFA; color:#fff; 55 | } 56 | 57 | ::-webkit-scrollbar { 58 | display: none; 59 | } -------------------------------------------------------------------------------- /Demo.framer/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | -------------------------------------------------------------------------------- /snippet.coffee: -------------------------------------------------------------------------------- 1 | # To see a full working demo of the DesignComponent module, please download the demo file at: 2 | 3 | # https://github.com/sebcglbailey/framer-DesignComponents/tree/master/Demo.framer 4 | 5 | # The demo file includes some pre-made components, and shows you how to edit and use the Design Components 6 | 7 | 8 | ### 9 | 10 | --------------------------------------- 11 | REQUIRING THE MODULE 12 | --------------------------------------- 13 | 14 | The usual line of code for requiring the module will be: 15 | 16 | Design = require "DesignComponents" 17 | 18 | ### 19 | 20 | 21 | 22 | ### 23 | 24 | --------------------------------------- 25 | NAMING CONVENTIONS 26 | --------------------------------------- 27 | 28 | For native components: 29 | 30 | Prefix the group of layers with an underscore 31 | 32 | Examples: 33 | _SliderComponent 34 | _RangeSliderComponent 35 | 36 | These will then be accessible within the code view by typing: 37 | 38 | slider = new Design.SliderComponent 39 | rangeSlider = new Design.RangeSliderComponent 40 | 41 | 42 | ------------------- 43 | 44 | 45 | For custom classes: 46 | 47 | Prefix the custom component name with "Custom_" 48 | 49 | Example: 50 | Custom_Card 51 | 52 | This will be built in code using: 53 | 54 | card = new Design.Card 55 | 56 | Child layers are accessible by name on initiating the class, and also after initilisation. 57 | 58 | card = new Design.Card 59 | avatar: 60 | image: "image_url" 61 | title: 62 | text: "Title text here" 63 | 64 | 65 | ------------------- 66 | 67 | To add states to your custom classes: 68 | 69 | Prefix the group name with "State_", and append the name with an event (optional) 70 | To give the state a name, prefix the entire group name again with the name of the state. (optional) 71 | 72 | Examples: 73 | Custom_Button 74 | Custom_Input 75 | Custom_Emoji 76 | 77 | State_Button_MouseDown 78 | Success_State_Input_Tap 79 | Error_State_Input_Tap 80 | Congrats_State_Emoji 81 | 82 | ### -------------------------------------------------------------------------------- /Demo.framer/framer/framer.init.js: -------------------------------------------------------------------------------- 1 | (function() { 2 | 3 | function isFileLoadingAllowed() { 4 | return (window.location.protocol.indexOf("file") == -1) 5 | } 6 | 7 | function isHomeScreened() { 8 | return ("standalone" in window.navigator) && window.navigator.standalone == true 9 | } 10 | 11 | function isCompatibleBrowser() { 12 | return Utils.isWebKit() 13 | } 14 | 15 | var alertNode; 16 | 17 | function dismissAlert() { 18 | alertNode.parentElement.removeChild(alertNode) 19 | loadProject() 20 | } 21 | 22 | function showAlert(html) { 23 | 24 | alertNode = document.createElement("div") 25 | 26 | alertNode.classList.add("framerAlertBackground") 27 | alertNode.innerHTML = html 28 | 29 | document.addEventListener("DOMContentLoaded", function(event) { 30 | document.body.appendChild(alertNode) 31 | }) 32 | 33 | window.dismissAlert = dismissAlert; 34 | } 35 | 36 | function showBrowserAlert() { 37 | var html = "" 38 | html += "
" 39 | html += "Error: Not A WebKit Browser" 40 | html += "Your browser is not supported.
Please use Safari or Chrome.
" 41 | html += "Try anyway" 42 | html += "
" 43 | 44 | showAlert(html) 45 | } 46 | 47 | function showFileLoadingAlert() { 48 | var html = "" 49 | html += "
" 50 | html += "Error: Local File Restrictions" 51 | html += "Preview this prototype with Framer Mirror or learn more about " 52 | html += "file restrictions.
" 53 | html += "Try anyway" 54 | html += "
" 55 | 56 | showAlert(html) 57 | } 58 | 59 | function loadProject(callback) { 60 | CoffeeScript.load("app.coffee", callback) 61 | } 62 | 63 | function setDefaultPageTitle() { 64 | // If no title was set we set it to the project folder name so 65 | // you get a nice name on iOS if you bookmark to desktop. 66 | document.addEventListener("DOMContentLoaded", function() { 67 | if (document.title == "") { 68 | if (window.FramerStudioInfo && window.FramerStudioInfo.documentTitle) { 69 | document.title = window.FramerStudioInfo.documentTitle 70 | } else { 71 | document.title = window.location.pathname.replace(/\//g, "") 72 | } 73 | } 74 | }) 75 | } 76 | 77 | function init() { 78 | 79 | if (Utils.isFramerStudio()) { 80 | return 81 | } 82 | 83 | setDefaultPageTitle() 84 | 85 | if (!isCompatibleBrowser()) { 86 | return showBrowserAlert() 87 | } 88 | 89 | if (!isFileLoadingAllowed()) { 90 | return showFileLoadingAlert() 91 | } 92 | 93 | loadProject(function(){ 94 | // CoffeeScript: Framer?.CurrentContext?.emit?("loaded:project") 95 | var context; 96 | if (typeof Framer !== "undefined" && Framer !== null) { 97 | if ((context = Framer.CurrentContext) != null) { 98 | if (typeof context.emit === "function") { 99 | context.emit("loaded:project"); 100 | } 101 | } 102 | } 103 | }) 104 | } 105 | 106 | init() 107 | 108 | })() 109 | -------------------------------------------------------------------------------- /Demo.framer/app.coffee: -------------------------------------------------------------------------------- 1 | Design = require "DesignComponents" 2 | 3 | # DEMO SETUP 4 | 5 | Layer.select(".UIKit").x = Screen.width 6 | 7 | Screen.backgroundColor = "#886AE2" 8 | 9 | scroll = new ScrollComponent 10 | size: Screen 11 | scrollHorizontal: false 12 | mouseWheelEnabled: true 13 | mouseWheelSpeedMultiplier: 0.125 14 | scroll.content.clip = false 15 | 16 | 17 | 18 | 19 | 20 | 21 | # Designing sliders in the design tab, and using the class 22 | # SLIDERS - NATIVE COMPONENTS 23 | 24 | slider = new Design.SliderComponent 25 | parent: scroll.content 26 | y: 50 27 | x: Align.center 28 | 29 | 30 | 31 | rangeSlider = new Design.RangeSliderComponent 32 | parent: scroll.content 33 | y: slider.maxY + 75 34 | x: Align.center 35 | 36 | # Designing a custom component in the design tab, and using it as a class 37 | # CARDS - CUSTOM CLASS 38 | 39 | # Recreate the card without editing the content 40 | card1 = new Design.Card 41 | parent: scroll.content 42 | name: "card1" 43 | y: rangeSlider.maxY + 50 44 | 45 | 46 | # Recreate the card and edit the content 47 | card2 = new Design.Card 48 | parent: scroll.content 49 | name: "card2" 50 | y: card1.maxY + 10 51 | avatar: 52 | borderRadius: 0 53 | image: Utils.randomImage() 54 | subheader: 55 | text: "This is a new subheader" 56 | content: 57 | text: "This is some content that has changed" 58 | 59 | 60 | # Recreate the card, edit the content, and apply some constraints to the child layers 61 | card3 = new Design.Card 62 | parent: scroll.content 63 | name: "card3" 64 | y: card2.maxY + 10 65 | avatar: 66 | borderRadius: 0 67 | image: Utils.randomImage() 68 | subheader: 69 | text: "Lorem ipsum" 70 | content: 71 | constraints: 72 | pushDown: true 73 | 74 | textString = "This is a string that can type itself\nTo show it animating over multiple lines\nWhich is really cool!" 75 | 76 | for i in [0..textString.length] 77 | do (i) -> 78 | Utils.delay i*0.1, -> 79 | card3.content.text = textString.slice 0, i 80 | 81 | # Using states on a custom class to add events 82 | # # STATES WITH CUSTOM CLASSES 83 | 84 | # # Button will have a "MouseDown" and "MouseUp" event listener 85 | button = new Design.Button 86 | parent: scroll.content 87 | name: "button" 88 | y: card3.maxY + 50 89 | x: Align.center 90 | 91 | # # # Toggle will have multiple states that it will cycle through on "Tap" 92 | toggle = new Design.Toggle 93 | parent: scroll.content 94 | name: "toggle" 95 | y: button.maxY + 50 96 | x: Align.center 97 | 98 | # Using states on a custom class without an event 99 | # STATES WITHOUT AN EVENT LISTENER 100 | 101 | 102 | # Setting the state upon initilisation 103 | emoji = new Design.Emoji 104 | parent: scroll.content 105 | y: toggle.maxY + 50 106 | x: Align.center 107 | state: "Angel" 108 | 109 | # Setting a state after initilisation 110 | emoji.state = "Wink" 111 | emoji.state = Utils.randomChoice ["Smile", "Angel", "Wink", "Unamused"] 112 | 113 | # # Animating between states 114 | emoji.onTap -> 115 | currentState = @states.current.name 116 | 117 | if currentState == "default" || currentState == "Smile" 118 | @animateState "Wink", true 119 | else if currentState == "Wink" 120 | @animateState "Angel", true 121 | else if currentState == "Angel" 122 | @animateState "Unamused", true 123 | else if currentState == "Unamused" 124 | @animateState "Smile", true 125 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # framer-DesignComponents 2 | A module for converting your designs in design mode into full scalable classes. 3 | 4 | **Supported native components:** 5 | 6 | * SliderComponent 7 | * RangeSliderComponent 8 | 9 | 10 | ### Links 11 | 12 | * [Installation](#installation) 13 | * [Native components](#native-components) 14 | * [Custom classes](#custom-classes) 15 | * [Constraints](#constraints) 16 | * [States](#states) 17 | 18 | 19 | ## Installation 20 | 21 | ### Automatic installation with [Framer Modules](https://www.framermodules.com/) 22 | 23 | 24 | Install with Framer Modules 26 | 27 | 28 | ### Manual installation 29 | 30 | Download and move the Constraints.coffee and DesignComponents.coffee files to your modules folder. 31 | 32 | At the top of your file, place this line of code: 33 | 34 | ```coffeescript 35 | Design = require "DesignComponents" 36 | ``` 37 | 38 | Done! That is all the code you need to do to get this module started. Now onto the fun stuff. 39 | 40 | 41 | 42 | ## Native components 43 | 44 | For the native slider components, all you need to do is design a slider with the correct child names inside, and prefix the whole group with an _. 45 | 46 | For example the layer structure will look like this: 47 | 48 | ![Layer List](images/Sliders.png) 49 | 50 | The _SliderComponent or _RangeSliderComponent layers are the background fill for the slider. 51 | 52 | 53 | ## Custom classes 54 | 55 | A custom class will be generated from your design, *including all of the layer's children*. You will then be able to add this class as many times as you want in the code view, without having to declare a class extension and constructor. 56 | 57 | To create a custom class in design mode, simply name the layer in design mode with the following syntax: 58 | 59 | ``` 60 | Custom_{className} 61 | ``` 62 | 63 | where {className} is replaced by the name of your class. 64 | 65 | For example: 66 | 67 | ![Custom Button](images/Button1.png) 68 | ![Custom Card](images/Card1.png) 69 | 70 | **Note:** You *do not* have to create a target for these layers. 71 | 72 | 73 | ### Using your class in your prototype 74 | 75 | To add the class to your prototype, simply create a new instance of the class as you would a layer: 76 | 77 | ```coffeescript 78 | button = new Design.Button 79 | 80 | card = new Design.Card 81 | ``` 82 | 83 | **The layers within your class are also accessible within the the creation of the new instance, and oyu can change their properties as oyu would any other layer in code.** 84 | 85 | #### Card structure in Design mode 86 | 87 | ![Custom Card](images/Card2.png) 88 | 89 | > **IMPORTANT:** Any SVG Layer in Design mode **must** be wrapped inside of a frame for this module to work. 90 | 91 | #### Editing the contents of the class in code 92 | 93 | ```coffeescript 94 | card = new Design.Card 95 | avatar: 96 | borderRadius: 0 97 | image: Utils.randomImage() 98 | subheader: 99 | text: "This is a new subheader" 100 | content: 101 | text: "This is some content that has changed" 102 | ``` 103 | 104 | ![Edited Card](images/Card3.png) 105 | 106 | 107 | ## Constraints 108 | 109 | With this module comes the ability to set constraints to your layers in code as well as design. 110 | 111 | When oyu initiate an instance of your symbol, it will automatically copy over the constraints of the design layer, but you are now able to override these upon initialisation, and later. 112 | 113 | ### Setting constraints on a new layer 114 | 115 | #### Arguments 116 | 117 | * top – the distance of the top edge from the top of the parent layer. 118 | * left – the distance of the left edge from the left of the parent layer. 119 | * bottom – the distance of the bottom edge from the bottom of the parent layer. 120 | * right – the distance of the right edge from the right of the parent layer. 121 | * centerX – the position of the layer within its parent on horizontal axis as a ratio between 0 - 1. 122 | * centerY – the position of the layer within its parent on the vertical axis as a ratio between 0 - 1. 123 | * scaleX – the width of the layer relative to its parent width as a ratio between 0 - 1. 124 | * scaleY – the height of the layer relative to its parent height as a ratio between 0 - 1. 125 | * aspectRatioLocked – the original ratio of width/height of the layer stays the same if set to true. 126 | * pushDown – If you want the layer to resize its parent when it resizes or moves, keeping the same original margin. I.e. when you add multiple lines to a text layer. NOTE: The layer cannot have a bottom constraint set for this to work. 127 | * pushRight – The same as pushDown but with the width of the parent. NOTE: The layer cannot have a right constraints set for this to work. 128 | 129 | ```coffeescript 130 | layer = new Layer 131 | size: 50 132 | 133 | layer.constraints = 134 | top: null 135 | left: 20 136 | bottom: null 137 | right: 20 138 | centerX: null 139 | centerY: 0.5 140 | scaleX: null 141 | scaleY: 0.8 142 | aspectRatioLocked: true 143 | pushDown: true 144 | pushRight: null 145 | ``` 146 | 147 | 148 | ### Setting constraints on a layer within a custom class 149 | 150 | If you are using a custom class from the Design mode, you can set the constraints upon initilisation. 151 | 152 | ```coffeescript 153 | card = new Design.Card 154 | constraints: 155 | left: 10 156 | right: 10 157 | avatar: 158 | image: Utils.randomImage() 159 | constraints: 160 | right: 15 161 | top: 15 162 | aspectRatioLocked: true 163 | content: 164 | text: "Lorem ipsum dolor sit amet.\nNew content\nMore new content" 165 | constraints: 166 | pushDown: true 167 | ``` 168 | 169 | See it in action: 170 | 171 | ![Card Expand Gif](images/cardContent.gif) 172 | 173 | 174 | 175 | ## States 176 | 177 | ### Single states 178 | 179 | The syntax for adding a single state on an event is: 180 | 181 | ``` 182 | State_{className}_{event} 183 | ``` 184 | 185 | eg: 186 | 187 | ![Single state](images/States1.png) 188 | 189 | ### Multiple states 190 | 191 | Adding multiple states for a event (toggling): 192 | 193 | ``` 194 | {stateName}_State_{className}_{event} 195 | ``` 196 | 197 | eg: 198 | 199 | ![Multiple states](images/States2.png) 200 | 201 | This will automatically add a switch event to the layer to switch the properties of the layer and all of its children upon the triggering of the event. 202 | 203 | ### Animating states 204 | 205 | By default, the design states will not animate between each other. To add default animation options to the events, simply append _Animate to the end of the layer name. 206 | 207 | **For example:** 208 | 209 | ```coffeescript 210 | {stateName}_State_{className}_{eventName}_Animate 211 | ``` 212 | 213 | With your custom classes, there is a new animate function. This will enable the class to animate itself, and all of its descendants at the same time. 214 | 215 | ```coffeescript 216 | animateState(stateName, animate, options) 217 | ``` 218 | 219 | #### Arguments 220 | 221 | * stateName – the name of the state to animate to. 222 | * animate – A boolean, set to override the default animation option for the class. (Optional) 223 | * options – animation options. (Optional) 224 | 225 | ```coffeescript 226 | layer = new Design.Class 227 | 228 | layer.animateState "Error", 229 | time: 1 230 | curve: Spring(damping: 0.8) 231 | ``` 232 | 233 | 234 | 235 | 236 | 237 | 238 | 239 | -------------------------------------------------------------------------------- /Demo.framer/modules/Constraints.coffee: -------------------------------------------------------------------------------- 1 | 2 | moveFromRef = (layer, reference, moveRef, layerRef, refType) -> 3 | 4 | originalConstraints = layer.constraintValues 5 | 6 | originalRefValue = reference[layerRef] 7 | originalLayerValue = layer[moveRef] 8 | 9 | layer[moveRef] = reference[layerRef] + layer.constraintValues[refType].value 10 | 11 | # reference.onChange layerRef, (value) -> 12 | # layer[moveRef] = originalLayerValue + (value - originalRefValue) 13 | 14 | layer.constraintValues = originalConstraints 15 | 16 | 17 | pushParent = (layer, direction) -> 18 | 19 | if direction == "down" 20 | originalY = layer.y 21 | originalHeight = layer.height 22 | 23 | layer.onChange "y", (value) -> 24 | @parent.height += value - originalY 25 | originalY = value 26 | originalHeight = @height 27 | layer.onChange "height", (value) -> 28 | @parent.height += value - originalHeight 29 | originalY = @y 30 | originalHeight = value 31 | 32 | if direction == "right" 33 | originalX = layer.x 34 | originalWidth - layer.width 35 | 36 | layer.onChange "x", (value) -> 37 | @parent.width += value - originalX 38 | originalX = value 39 | originalWidth = @width 40 | layer.onChange "width", (value) -> 41 | @parent.width += value - originalWidth 42 | originalX = @x 43 | originalWidth = value 44 | 45 | 46 | addReferenceEvents = (layer) -> 47 | 48 | originalConstraints = layer.constraintValues 49 | 50 | if layer.constraintValues?.topRef?.layer? || layer.constraintValues?.bottomRef?.layer? 51 | 52 | reference = layer.constraintValues?.topRef?.layer || layer.constraintValues?.bottomRef?.layer 53 | 54 | originalYRef = reference.y 55 | originalHeightRef = reference.height 56 | originalY = layer.y 57 | 58 | reference.onChange "y", (value) -> 59 | layer.y = originalY + (value - originalYRef) 60 | originalYRef = value 61 | originalY = layer.y 62 | 63 | unless layer.constraintValues?.topRef?.align == "y" 64 | reference.onChange "height", (value) -> 65 | layer.y = originalY + (value - originalHeightRef) 66 | originalHeightRef = value 67 | originalY = layer.y 68 | 69 | if layer.constraintValues?.topRef? && layer.constraintValues?.bottomRef? 70 | reference.onChange "height", (value) -> 71 | layer.height = value - layer.constraintValues?.topRef.value - layer.constraintValues?.bottomRef.value 72 | layer.y = reference.y + layer.constraintValues?.topRef.value 73 | originalHeightRef = value 74 | 75 | if layer.constraintValues?.leftRef?.layer? || layer.constraintValues?.rightRef?.layer? 76 | reference = layer.constraintValues?.leftRef?.layer || layer.constraintValues?.rightRef?.layer 77 | 78 | originalXRef = reference.x 79 | originalWidthRef = reference.width 80 | originalX = layer.x 81 | 82 | reference.onChange "x", (value) -> 83 | layer.x = originalX + (value - originalXRef) 84 | originalXRef = value 85 | originalX = layer.x 86 | 87 | unless layer.constraintValues?.left?.align == "x" 88 | reference.onChange "width", (value) -> 89 | layer.x = originalX + (value - originalWidthRef) 90 | originalWidthRef = value 91 | originalX = layer.x 92 | 93 | if layer.constraintValues?.leftRef? && layer.constraintValues?.rightRef? 94 | reference.onChange "width", (value) -> 95 | layer.width = value - layer.constraintValues?.leftRef.value - layer.constraintValues?.rightRef.value 96 | layer.x = reference.x + layer.constraintValues?.leftRef.value 97 | originalWidthRef = value 98 | 99 | 100 | buildConstraintsProtos = (constructorName) -> 101 | 102 | constructorName = eval constructorName 103 | 104 | constructorName::setConstraints = (options={}, origin) -> 105 | 106 | @constraintValues = 107 | top: if typeof options.top == "object" then null else if options.top? then options.top else if origin?.constraintValues? then origin.constraintValues.top else null 108 | left: if typeof options.left == "object" then null else if options.left? then options.left else if origin?.constraintValues? then origin.constraintValues.left else null 109 | bottom: if typeof options.bottom == "object" then null else if options.pushDown then null else if options.bottom? then options.bottom else if origin?.constraintValues? then origin.constraintValues.bottom else null 110 | right: if typeof options.right == "object" then null else if options.pushRight then null else if options.right? then options.right else if origin?.constraintValues? then origin.constraintValues.right else null 111 | width: @width 112 | height: @height 113 | widthFactor: if options.scaleX? then options.scaleX else if options.widthFactor? then options.widthFactor else null 114 | heightFactor: if options.scaleY? then options.scaleY else if options.heightFactor? then options.heightFactor else null 115 | centerAnchorX: if options.centerX? then options.centerX else if options.centerAnchorX? then options.centerAnchorX else null 116 | centerAnchorY: if options.centerY? then options.centerY else if options.centerAnchorY? then options.centerAnchorY else null 117 | aspectRatioLocked: if options.aspectRatioLocked? then options.aspectRatioLocked else if origin?.constraintValues then origin.constraintValues.aspectRatioLocked else false 118 | 119 | # resets 120 | values = @constraintValues 121 | if values.top? && values.bottom? 122 | @constraintValues.heightFactor = null 123 | @constraintValues.centerAnchorY = null 124 | if values.left? && values.right? 125 | @constraintValues.widthFactor = null 126 | @constraintValues.centerAnchorX = null 127 | if values.left? && values.right? && values.top? && values.bottom? 128 | @constraintValues.aspectRatioLocked = false 129 | 130 | for ref in [["top", "y", "maxY", "topRef", "bottom"], ["left", "x", "maxX", "leftRef", "right"], ["bottom", "maxY", "y", "bottomRef", "top"], ["right", "maxX", "x", "rightRef", "left"]] 131 | 132 | if typeof options[ref[0]] == "object" && options[ref[0]] != null && !options[ref[3]]? 133 | 134 | if options[ref[0]].layer? 135 | if @parent? && @parent.selectChild(options[ref[0]].layer)? 136 | layer = @parent.selectChild options[ref[0]].layer 137 | else 138 | layer = Layer.select options[ref[0]].layer 139 | else layer = @parent 140 | 141 | align = null 142 | 143 | if !options[ref[0]].value? && layer == @parent 144 | value = @[ref[1]] 145 | else if options[ref[0]].align? && options[ref[0]].value? 146 | value = options[ref[0]].value 147 | align = options[ref[0]].align 148 | else if options[ref[0]].align? 149 | value = 0 150 | align = options[ref[0]].align 151 | else if !options[ref[0]].value? && !options[ref[0]].align? 152 | value = @[ref[1]] - layer[ref[2]] 153 | align = ref[4] 154 | else 155 | value = options[ref[0]].value 156 | align = ref[4] 157 | 158 | if align == "left" then align = "x" 159 | else if align == "right" then align = "maxX" 160 | else if align == "top" then align = "y" 161 | else if align == "bottom" then align = "maxY" 162 | 163 | @constraintValues[ref[3]] = 164 | layer: layer 165 | value: value 166 | align: align 167 | 168 | @constraintValues[ref[0]] = null 169 | @constraintValues[ref[4]] = null 170 | 171 | # moveFromRef @, layer, ref[1], ref[2], ref[3] 172 | 173 | if options.pushDown? 174 | @constraintValues.bottom = null 175 | pushParent @, "down" 176 | if options.pushRight? 177 | @constraintValues.right = null 178 | pushParent @, "right" 179 | 180 | unless options.pushDown || @constraintValues.topRef || @constraintValues.bottomRef 181 | @constraintValues.bottom = if options.bottom? then options.bottom else if origin?.constraintValues? then origin.constraintValues.bottom else null 182 | unless options.pushRight || @constraintValues.leftRef || @constraintValues.rightRef 183 | @constraintValues.right = if options.right? then options.right else if origin?.constraintValues? then origin.constraintValues.right else null 184 | 185 | if @constraintValues.top == null && @constraintValues.bottom == null && @constraintValues.centerAnchorY == null && !@constraintValues.topRef && !@constraintValues.bottomRef 186 | @constraintValues.top = @y 187 | if @constraintValues.left == null && @constraintValues.right == null && @constraintValues.centerAnchorX == null && !@constraintValues.leftRef && !@constraintValues.rightRef 188 | @constraintValues.left = @x 189 | 190 | @applyConstraints() 191 | 192 | 193 | constructorName::applyConstraints = -> 194 | 195 | return if !@constraintValues 196 | 197 | values = @constraintValues 198 | 199 | if !@parent then parent = Screen else parent = @parent 200 | 201 | aspectRatio = @width / @height 202 | 203 | # position 204 | if values.top? && typeof values.top != "object" 205 | @y = values.top 206 | else if values.top == null && values.topRef?.layer? 207 | @y = values.topRef.layer[values.topRef.align] + values.topRef.value 208 | 209 | if values.left? && typeof values.left != "object" 210 | @x = values.left 211 | else if values.left == null && values.leftRef?.layer? 212 | @x = values.leftRef.layer[values.leftRef.align] + values.leftRef.value 213 | 214 | # size 215 | if values.left? && values.right? 216 | @width = parent.width - @x - values.right 217 | if values.aspectRatioLocked 218 | @height = @width / aspectRatio 219 | if values.top? && values.bottom? 220 | @height = parent.height - @y - values.bottom 221 | if values.aspectRatioLocked 222 | @width = @height * aspectRatio 223 | 224 | # if values.leftRef? && values.rightRef? 225 | # @width = parent.width - values.leftRef.value - values.rightRef.value 226 | # if values.topRef? && values.bottomRef? 227 | # @height = parent.height - values.topRef.value - values.bottomRef.value 228 | 229 | if values.widthFactor? 230 | @width = parent.width * values.widthFactor 231 | if values.heightFactor? 232 | @height = parent.height * values.heightFactor 233 | 234 | # max position 235 | if values.right? 236 | @maxX = parent.width - values.right 237 | else if values.right == null && values.rightRef?.layer? 238 | @maxX = values.rightRef.layer[values.rightRef.align] - values.rightRef.value 239 | if values.bottom? 240 | @maxY = parent.height - values.bottom 241 | else if values.bottom == null && values.bottomRef?.layer? 242 | @maxY = values.bottomRef.layer[values.bottomRef.align] - values.bottomRef.value 243 | 244 | # center position 245 | if !values.left? && !values.right? && values.centerAnchorX? 246 | @midX = parent.width * values.centerAnchorX 247 | if !values.top? && !values.bottom? && values.centerAnchorY? 248 | @midY = parent.height * values.centerAnchorY 249 | 250 | @constraintValues = values 251 | 252 | addReferenceEvents(@) 253 | 254 | 255 | layerTypes = ["Layer", "TextLayer", "ScrollComponent", "PageComponent", "SliderComponent", "RangeSliderComponent", "SVGLayer", "BackgroundLayer", "SVGPath", "SVGGroup"] 256 | for type in layerTypes 257 | buildConstraintsProtos(type) 258 | 259 | 260 | 261 | Object.defineProperty(Layer.prototype, "constraints", { 262 | 263 | get: -> return @_constraints 264 | set: (value) -> 265 | @_constraints = value 266 | @emit "change:constraints", value 267 | @setConstraints value 268 | 269 | }) -------------------------------------------------------------------------------- /DesignComponents.coffee: -------------------------------------------------------------------------------- 1 | 2 | ### 3 | ------------------ 4 | CUSTOM CLASSES 5 | ------------------ 6 | ### 7 | 8 | kit = Layer.select "*UIKit*" 9 | if kit? then kit.x = Screen.width * 1000; kit.name = ".UIKit" 10 | 11 | for layer in Layer.selectAll "@*" 12 | parent = layer.parent 13 | name = layer.name.replace "@", "" 14 | parent[name] = layer 15 | 16 | customComponents = Layer.selectAll "Custom_*" 17 | 18 | Layer::addDesignChildren = (origin) -> 19 | if !origin? then origin = @ 20 | for child in origin.selectAllChildren ("*") 21 | parent = child.parent 22 | parent[child.name] = child 23 | 24 | 25 | stateChangeProps = [ 26 | "width", "height", 27 | "opacity", 28 | "scaleX", "scaleY", "scaleZ", "scale", 29 | "skewX", "skewY", "skew", 30 | "rotationX", "rotationY", "rotationZ", "rotation", 31 | "blur", 32 | "brightness", "saturate", "hueRotate", "contrast", "invert", "grayscale", "sepia", "blending", 33 | "backgroundBlur", "backgroundBrightness", "backgroundSaturate", "backgroundHueRotate", "backgroundContrast", "backgroundInvert", "backgroundGrayscale", "backgroundSepia", 34 | "shadow1", "shadow2", "shadow3", "shadow4", "shadow5", "shadow6", "shadow7", "shadow8", "shadow9", 35 | "shadowX", "shadowY", "shadowBlur", "shadowSpread", "shadowColor", "shadowType", 36 | "shadows", 37 | "backgroundColor", "color", 38 | "borderRadius", "borderColor", "borderWidth", "borderStyle", 39 | "image", "gradient", 40 | "text", 41 | "fill", "stroke", "strokeWidth", "strokeWidthMultiplier" 42 | ] 43 | 44 | 45 | pushParent = (layer, direction) -> 46 | layer.pushValues = 47 | marginBottom: layer.parent.height - layer.maxY 48 | marginRight: layer.parent.width - layer.maxX 49 | 50 | if direction == "down" 51 | layer.onChange "y", -> 52 | @parent.height = layer.maxY + @pushValues.marginBottom 53 | layer.onChange "height", -> 54 | @parent.height = layer.maxY + @pushValues.marginBottom 55 | 56 | buildConstraintsProtos = (constructorName) -> 57 | 58 | constructorName = eval constructorName 59 | 60 | constructorName::setConstraints = (options={}, origin) -> 61 | @constraintValues = 62 | top: if typeof options?.top == "object" then null else if options?.top? && typeof options.top == "number" then options.top else origin?.constraintValues?.top || null 63 | left: if typeof options?.left == "object" then null else if options?.left? && typeof options.top == "number" then options.top else origin?.constraintValues?.left || null 64 | bottom: if typeof options?.bottom == "object" then null else if options?.pushDown then null else if options?.bottom? && typeof options.bottom == "number" then options.bottom else origin?.constraintValues?.bottom || null 65 | right: if typeof options?.right == "object" then null else if options?.pushRight then null else if options?.right? && typeof options.right == "number" then options.right else origin?.constraintValues?.right || null 66 | width: @width 67 | height: @height 68 | widthFactor: options?.scaleX || options?.widthFactor || null 69 | heightFactor: options?.scaleY ||options?.heightFactor || null 70 | centerAnchorX: options?.centerX || options?.centerAnchorX || null 71 | centerAnchorY: options?.centerY || options?.centerAnchorY || null 72 | aspectRatioLocked: if options?.aspectRatioLocked? then options.aspectRatioLocked else if origin?.constraintValues?.aspectRatioLocked? then origin.constraintValues.aspectRatioLocked else false 73 | 74 | if options.pushDown? 75 | @constraintValues.bottom = null 76 | pushParent @, "down" 77 | if options.pushRight? 78 | @constraintValues.right = null 79 | pushParent @, "right" 80 | 81 | constraints = @constraintValues 82 | textLayerAutoSize = typeof @ == TextLayer && @autoSize 83 | 84 | @onChange "y", -> 85 | @constraintValues = constraints 86 | @onChange "x", -> 87 | @constraintValues = constraints 88 | @onChange "height", -> 89 | @constraintValues = constraints 90 | @onChange "width", -> 91 | @constraintValues = constraints 92 | 93 | @applyConstraints() 94 | 95 | constructorName::applyConstraints = -> 96 | 97 | return if !@constraintValues 98 | 99 | values = @constraintValues 100 | 101 | if !@parent then parent = Screen else parent = @parent 102 | 103 | aspectRatio = @width / @height 104 | 105 | # position 106 | if values.top? && typeof values.top != "object" 107 | @y = values.top 108 | else if values.top == null && values.topRef?.layer? 109 | @y = values.topRef.layer[values.topRef.align] + values.topRef.value 110 | 111 | if values.left? && typeof values.left != "object" 112 | @x = values.left 113 | else if values.left == null && values.leftRef?.layer? 114 | @x = values.leftRef.layer[values.leftRef.align] + values.leftRef.value 115 | 116 | # size 117 | if values.left? && values.right? 118 | @width = parent.width - @x - values.right 119 | if values.aspectRatioLocked 120 | @height = @width / aspectRatio 121 | if values.top? && values.bottom? 122 | @height = parent.height - @y - values.bottom 123 | if values.aspectRatioLocked 124 | @width = @height * aspectRatio 125 | 126 | if values.widthFactor? 127 | @width = parent.width * values.widthFactor 128 | if values.heightFactor? 129 | @height = parent.height * values.heightFactor 130 | 131 | # max position 132 | if values.right? 133 | @maxX = parent.width - values.right 134 | else if values.right == null && values.rightRef?.layer? 135 | @maxX = values.rightRef.layer[values.rightRef.align] - values.rightRef.value 136 | if values.bottom? 137 | @maxY = parent.height - values.bottom 138 | else if values.bottom == null && values.bottomRef?.layer? 139 | @maxY = values.bottomRef.layer[values.bottomRef.align] - values.bottomRef.value 140 | 141 | # center position 142 | if !values.left? && !values.right? && values.centerAnchorX? 143 | @midX = parent.width * values.centerAnchorX 144 | if !values.top? && !values.bottom? && values.centerAnchorY? 145 | @midY = parent.height * values.centerAnchorY 146 | 147 | @constraintValues = values 148 | 149 | 150 | layerTypes = ["Layer", "TextLayer", "ScrollComponent", "PageComponent", "SliderComponent", "RangeSliderComponent", "SVGLayer", "BackgroundLayer", "SVGPath", "SVGGroup"] 151 | for type in layerTypes 152 | buildConstraintsProtos(type) 153 | 154 | Object.defineProperty(Layer.prototype, "constraints", { 155 | get: -> return @constraintValues 156 | set: (value) -> 157 | @_constraints = value 158 | @emit "change:constraints", value 159 | @setConstraints value 160 | }) 161 | 162 | for component in customComponents 163 | name = component.name.replace "Custom_", "" 164 | 165 | do (component, name) -> 166 | class exports[name] extends Layer 167 | constructor: (@options={}) -> 168 | super @options 169 | @props = Object.assign component.props, {parent: @options.parent || null} 170 | 171 | if @options.constraints? 172 | @constraints = @options.constraints 173 | @props = @options 174 | 175 | @addChildren() 176 | @assignChildren() 177 | @setDescendantProps() 178 | @setDescendantConstraints() 179 | 180 | @stateComponents = Layer.selectAll "*State_#{name}*" 181 | @addStates() 182 | 183 | if @options.state? 184 | @animateState @options.state, false 185 | 186 | addChildren: -> 187 | newParent = component.copy() 188 | for child in newParent.children 189 | if child instanceof SVGPath or child instanceof SVGGroup 190 | Utils.throwInStudioOrWarnInProduction "SVG '#{child.name}' in 'Custom_#{name}' must be wrapped in a Frame in order to create a Design Component Symbol" 191 | else 192 | child.parent = @ 193 | if child instanceof TextLayer && component.selectChild(child.name)? 194 | child.autoSize = true 195 | newParent.destroy() 196 | 197 | assignChildren: -> 198 | for descendant in @descendants 199 | @[descendant.name] = descendant 200 | 201 | setDescendantProps: -> 202 | for descendant in @descendants 203 | do (descendant) => 204 | if @options[descendant.name] 205 | @[descendant.name].constraints = @options[descendant.name].constraints || undefined 206 | @[descendant.name].props = @options[descendant.name] 207 | 208 | setDescendantConstraints: -> 209 | for descendant in @descendants 210 | decName = descendant.name 211 | origin = component.selectChild decName 212 | descendant.setConstraints( 213 | @options[decName]?.constraints || {}, 214 | origin 215 | ) 216 | 217 | addStates: -> 218 | @customStates = 219 | array: [] 220 | 221 | for state in @stateComponents 222 | do (state) => 223 | stateIndex = state.name.indexOf "State" 224 | if stateIndex > 0 225 | stateName = state.name.slice 0, stateIndex-1 226 | else 227 | stateName = state.name.split("State_#{name}_")[1] 228 | 229 | @customStates[stateName] = {} 230 | @customStates.array.push stateName 231 | 232 | addProps = (layer, origin) -> 233 | stateProps = {} 234 | for prop in stateChangeProps 235 | stateProps[prop] = origin[prop] 236 | 237 | if origin instanceof SVGLayer 238 | split1 = origin['html'].split(/opacity/)[1] 239 | if (split1[0] != ':') 240 | split2 = split1.split(/"/)[1] 241 | stateProps['opacity'] = split2 242 | else 243 | stateProps['opacity'] = "1.0" 244 | 245 | layer.states[stateName] = stateProps 246 | 247 | addProps @, state 248 | 249 | for descendant in state.descendants 250 | do (descendant) => 251 | addProps @[descendant.name], descendant 252 | if descendant instanceof SVGPath 253 | addProps @[descendant.name].parent._children[0], descendant.parent._children[0] 254 | 255 | @addStateEvents() 256 | 257 | addStateEvents: -> 258 | events = [] 259 | 260 | for state in @stateComponents 261 | if state.name.includes "_State_#{name}" 262 | stateName = state.name.split("_State_#{name}")[0] 263 | eventName = state.name.split("_State_#{name}")[1] 264 | else 265 | eventName = state.name.replace "State_#{name}_", "" 266 | stateName = eventName 267 | 268 | if eventName.includes "_Animate" 269 | animate = true 270 | eventName = eventName.split("_Animate")[0] 271 | else animate = false 272 | 273 | eventName = eventName.replace "_", "" 274 | 275 | @customStates[stateName].animate = animate 276 | 277 | unless events.includes eventName then events.push eventName 278 | 279 | for eventName in events 280 | 281 | do (eventName) => 282 | 283 | if Events[eventName]? && @customStates.array.includes eventName 284 | 285 | @on Events[eventName], (event, layer) -> 286 | 287 | animateBool = @customStates[eventName].animate 288 | 289 | @stateSwitch(eventName, {animate: animateBool}) 290 | @animateChildren() 291 | 292 | else if Events[eventName]? 293 | 294 | @on Events[eventName], -> 295 | currentIndex = @customStates.array.indexOf(@states.current.name) 296 | nextIndex = currentIndex + 1 297 | if nextIndex == @customStates.array.length then nextIndex = 0 298 | animateBool = @customStates[@customStates.array[nextIndex]].animate 299 | nextState = @customStates.array[nextIndex] 300 | 301 | @stateSwitch(nextState, {animate: animateBool}) 302 | @animateChildren() 303 | 304 | animateChildren: (stateName, animate, options={}) -> 305 | unless stateName? then stateName = @states.current.name 306 | unless animate? then animate = @customStates[stateName].animate 307 | if !animate then options.time = 0 308 | for dec in @descendants 309 | do (dec) => 310 | if dec instanceof SVGPath 311 | # dec.stateSwitch(stateName, {animate: animate, options: options}) 312 | 313 | dec.parent._children[0].stateSwitch(stateName, {animate: animate, options: options}) 314 | else 315 | dec.stateSwitch(stateName, {animate: animate, options: options}) 316 | 317 | animateState: (state, animate, options={}) -> 318 | 319 | if !state? || !@customStates?[state]? then return 320 | if !animate? && @customStates?[state]? then animate = @customStates[state].animate else if animate? then animate = animate else animate = false 321 | if !animate then options.time = 0 322 | 323 | @stateSwitch(state, {animate: animate, options: options}) 324 | @animateChildren(state, animate, options) 325 | 326 | @define "state", 327 | get: -> @options.state 328 | set: (value) -> 329 | @options.state = value 330 | @emit("change:state", @options.state) 331 | @animateState value 332 | 333 | 334 | 335 | customStates = Layer.selectAll "State_*" 336 | 337 | for componentState in customStates 338 | 339 | classEventName = componentState.name.replace "State_", "" 340 | if classEventName.includes "_" 341 | className = classEventName.split("_")[0] 342 | eventName = classEventName.split("_")[1] 343 | else 344 | className = classEventName 345 | 346 | 347 | ### 348 | ------------------ 349 | EXISTING CLASSES 350 | ------------------ 351 | ### 352 | 353 | 354 | components = Layer.selectAll "_*" 355 | 356 | extendSlider = (origin) -> 357 | class exports.SliderComponent extends SliderComponent 358 | 359 | constructor: (@options={}) -> 360 | super @options 361 | 362 | @knob.props = 363 | shadows: origin.knob.shadows 364 | backgroundColor: origin.knob.backgroundColor 365 | borderRadius: origin.knob.borderRadius 366 | frame: origin.knob.frame 367 | 368 | @fill.props = 369 | shadows: origin.fill.shadows 370 | backgroundColor: origin.fill.backgroundColor 371 | borderRadius: origin.fill.borderRadius 372 | frame: origin.fill.frame 373 | 374 | @props = 375 | shadows: origin.shadows 376 | backgroundColor: origin.backgroundColor 377 | borderRadius: origin.borderRadius 378 | size: origin.size 379 | 380 | @value = Utils.modulate origin.knob.midX, [0, origin.width], [@min, @max] 381 | 382 | 383 | extendRangeSlider = (origin) -> 384 | class exports.RangeSliderComponent extends RangeSliderComponent 385 | 386 | constructor: (@options={}) -> 387 | super @options 388 | 389 | @minKnob.props = 390 | shadows: origin.minKnob.shadows 391 | backgroundColor: origin.minKnob.backgroundColor 392 | borderRadius: origin.minKnob.borderRadius 393 | frame: origin.minKnob.frame 394 | @maxKnob.props = 395 | shadows: origin.maxKnob.shadows 396 | backgroundColor: origin.maxKnob.backgroundColor 397 | borderRadius: origin.maxKnob.borderRadius 398 | frame: origin.maxKnob.frame 399 | 400 | @fill.props = 401 | shadows: origin.fill.shadows 402 | backgroundColor: origin.fill.backgroundColor 403 | borderRadius: origin.fill.borderRadius 404 | frame: origin.fill.frame 405 | 406 | @props = 407 | shadows: origin.shadows 408 | backgroundColor: origin.backgroundColor 409 | borderRadius: origin.borderRadius 410 | size: origin.size 411 | 412 | @minValue = Utils.modulate origin.minKnob.midX, [0, origin.width], [@min, @max] 413 | @maxValue = Utils.modulate origin.maxKnob.midX, [0, origin.width], [@min, @max] 414 | 415 | 416 | 417 | for component in components 418 | 419 | type = component.name.replace "_", "" 420 | 421 | do (component) -> 422 | 423 | component.addDesignChildren() 424 | 425 | if type == "SliderComponent" 426 | extendSlider component 427 | else if type == "RangeSliderComponent" 428 | extendRangeSlider component 429 | -------------------------------------------------------------------------------- /Demo.framer/modules/DesignComponents.coffee: -------------------------------------------------------------------------------- 1 | 2 | ### 3 | ------------------ 4 | CUSTOM CLASSES 5 | ------------------ 6 | ### 7 | 8 | kit = Layer.select "*UIKit*" 9 | if kit? then kit.x = Screen.width * 1000; kit.name = ".UIKit" 10 | 11 | for layer in Layer.selectAll "@*" 12 | parent = layer.parent 13 | name = layer.name.replace "@", "" 14 | parent[name] = layer 15 | 16 | customComponents = Layer.selectAll "Custom_*" 17 | 18 | Layer::addDesignChildren = (origin) -> 19 | if !origin? then origin = @ 20 | for child in origin.selectAllChildren ("*") 21 | parent = child.parent 22 | parent[child.name] = child 23 | 24 | 25 | stateChangeProps = [ 26 | "width", "height", 27 | "opacity", 28 | "scaleX", "scaleY", "scaleZ", "scale", 29 | "skewX", "skewY", "skew", 30 | "rotationX", "rotationY", "rotationZ", "rotation", 31 | "blur", 32 | "brightness", "saturate", "hueRotate", "contrast", "invert", "grayscale", "sepia", "blending", 33 | "backgroundBlur", "backgroundBrightness", "backgroundSaturate", "backgroundHueRotate", "backgroundContrast", "backgroundInvert", "backgroundGrayscale", "backgroundSepia", 34 | "shadow1", "shadow2", "shadow3", "shadow4", "shadow5", "shadow6", "shadow7", "shadow8", "shadow9", 35 | "shadowX", "shadowY", "shadowBlur", "shadowSpread", "shadowColor", "shadowType", 36 | "shadows", 37 | "backgroundColor", "color", 38 | "borderRadius", "borderColor", "borderWidth", "borderStyle", 39 | "image", "gradient", 40 | "text", 41 | "fill", "stroke", "strokeWidth", "strokeWidthMultiplier" 42 | ] 43 | 44 | 45 | pushParent = (layer, direction) -> 46 | layer.pushValues = 47 | marginBottom: layer.parent.height - layer.maxY 48 | marginRight: layer.parent.width - layer.maxX 49 | 50 | if direction == "down" 51 | layer.onChange "y", -> 52 | @parent.height = layer.maxY + @pushValues.marginBottom 53 | layer.onChange "height", -> 54 | @parent.height = layer.maxY + @pushValues.marginBottom 55 | 56 | buildConstraintsProtos = (constructorName) -> 57 | 58 | constructorName = eval constructorName 59 | 60 | constructorName::setConstraints = (options={}, origin) -> 61 | @constraintValues = 62 | top: if typeof options?.top == "object" then null else if options?.top? && typeof options.top == "number" then options.top else origin?.constraintValues?.top || null 63 | left: if typeof options?.left == "object" then null else if options?.left? && typeof options.top == "number" then options.top else origin?.constraintValues?.left || null 64 | bottom: if typeof options?.bottom == "object" then null else if options?.pushDown then null else if options?.bottom? && typeof options.bottom == "number" then options.bottom else origin?.constraintValues?.bottom || null 65 | right: if typeof options?.right == "object" then null else if options?.pushRight then null else if options?.right? && typeof options.right == "number" then options.right else origin?.constraintValues?.right || null 66 | width: @width 67 | height: @height 68 | widthFactor: options?.scaleX || options?.widthFactor || null 69 | heightFactor: options?.scaleY ||options?.heightFactor || null 70 | centerAnchorX: options?.centerX || options?.centerAnchorX || null 71 | centerAnchorY: options?.centerY || options?.centerAnchorY || null 72 | aspectRatioLocked: if options?.aspectRatioLocked? then options.aspectRatioLocked else if origin?.constraintValues?.aspectRatioLocked? then origin.constraintValues.aspectRatioLocked else false 73 | 74 | if options.pushDown? 75 | @constraintValues.bottom = null 76 | pushParent @, "down" 77 | if options.pushRight? 78 | @constraintValues.right = null 79 | pushParent @, "right" 80 | 81 | constraints = @constraintValues 82 | textLayerAutoSize = typeof @ == TextLayer && @autoSize 83 | 84 | @onChange "y", -> 85 | @constraintValues = constraints 86 | @onChange "x", -> 87 | @constraintValues = constraints 88 | @onChange "height", -> 89 | @constraintValues = constraints 90 | @onChange "width", -> 91 | @constraintValues = constraints 92 | 93 | @applyConstraints() 94 | 95 | constructorName::applyConstraints = -> 96 | 97 | return if !@constraintValues 98 | 99 | values = @constraintValues 100 | 101 | if !@parent then parent = Screen else parent = @parent 102 | 103 | aspectRatio = @width / @height 104 | 105 | # position 106 | if values.top? && typeof values.top != "object" 107 | @y = values.top 108 | else if values.top == null && values.topRef?.layer? 109 | @y = values.topRef.layer[values.topRef.align] + values.topRef.value 110 | 111 | if values.left? && typeof values.left != "object" 112 | @x = values.left 113 | else if values.left == null && values.leftRef?.layer? 114 | @x = values.leftRef.layer[values.leftRef.align] + values.leftRef.value 115 | 116 | # size 117 | if values.left? && values.right? 118 | @width = parent.width - @x - values.right 119 | if values.aspectRatioLocked 120 | @height = @width / aspectRatio 121 | if values.top? && values.bottom? 122 | @height = parent.height - @y - values.bottom 123 | if values.aspectRatioLocked 124 | @width = @height * aspectRatio 125 | 126 | if values.widthFactor? 127 | @width = parent.width * values.widthFactor 128 | if values.heightFactor? 129 | @height = parent.height * values.heightFactor 130 | 131 | # max position 132 | if values.right? 133 | @maxX = parent.width - values.right 134 | else if values.right == null && values.rightRef?.layer? 135 | @maxX = values.rightRef.layer[values.rightRef.align] - values.rightRef.value 136 | if values.bottom? 137 | @maxY = parent.height - values.bottom 138 | else if values.bottom == null && values.bottomRef?.layer? 139 | @maxY = values.bottomRef.layer[values.bottomRef.align] - values.bottomRef.value 140 | 141 | # center position 142 | if !values.left? && !values.right? && values.centerAnchorX? 143 | @midX = parent.width * values.centerAnchorX 144 | if !values.top? && !values.bottom? && values.centerAnchorY? 145 | @midY = parent.height * values.centerAnchorY 146 | 147 | @constraintValues = values 148 | 149 | 150 | layerTypes = ["Layer", "TextLayer", "ScrollComponent", "PageComponent", "SliderComponent", "RangeSliderComponent", "SVGLayer", "BackgroundLayer", "SVGPath", "SVGGroup"] 151 | for type in layerTypes 152 | buildConstraintsProtos(type) 153 | 154 | Object.defineProperty(Layer.prototype, "constraints", { 155 | get: -> return @constraintValues 156 | set: (value) -> 157 | @_constraints = value 158 | @emit "change:constraints", value 159 | @setConstraints value 160 | }) 161 | 162 | for component in customComponents 163 | name = component.name.replace "Custom_", "" 164 | 165 | do (component, name) -> 166 | class exports[name] extends Layer 167 | constructor: (@options={}) -> 168 | super @options 169 | @props = Object.assign component.props, {parent: @options.parent || null} 170 | 171 | if @options.constraints? 172 | @constraints = @options.constraints 173 | @props = @options 174 | 175 | @addChildren() 176 | @assignChildren() 177 | @setDescendantProps() 178 | @setDescendantConstraints() 179 | 180 | @stateComponents = Layer.selectAll "*State_#{name}*" 181 | @addStates() 182 | 183 | if @options.state? 184 | @animateState @options.state, false 185 | 186 | addChildren: -> 187 | newParent = component.copy() 188 | for child in newParent.children 189 | if child instanceof SVGPath or child instanceof SVGGroup 190 | Utils.throwInStudioOrWarnInProduction "SVG '#{child.name}' in 'Custom_#{name}' must be wrapped in a Frame in order to create a Design Component Symbol" 191 | else 192 | child.parent = @ 193 | if child instanceof TextLayer && component.selectChild(child.name)? 194 | child.autoSize = true 195 | newParent.destroy() 196 | 197 | assignChildren: -> 198 | for descendant in @descendants 199 | @[descendant.name] = descendant 200 | 201 | setDescendantProps: -> 202 | for descendant in @descendants 203 | do (descendant) => 204 | if @options[descendant.name] 205 | @[descendant.name].constraints = @options[descendant.name].constraints || undefined 206 | @[descendant.name].props = @options[descendant.name] 207 | 208 | setDescendantConstraints: -> 209 | for descendant in @descendants 210 | decName = descendant.name 211 | origin = component.selectChild decName 212 | descendant.setConstraints( 213 | @options[decName]?.constraints || {}, 214 | origin 215 | ) 216 | 217 | addStates: -> 218 | @customStates = 219 | array: [] 220 | 221 | for state in @stateComponents 222 | do (state) => 223 | stateIndex = state.name.indexOf "State" 224 | if stateIndex > 0 225 | stateName = state.name.slice 0, stateIndex-1 226 | else 227 | stateName = state.name.split("State_#{name}_")[1] 228 | 229 | @customStates[stateName] = {} 230 | @customStates.array.push stateName 231 | 232 | addProps = (layer, origin) -> 233 | stateProps = {} 234 | for prop in stateChangeProps 235 | stateProps[prop] = origin[prop] 236 | 237 | if origin instanceof SVGLayer 238 | split1 = origin['html'].split(/opacity/)[1] 239 | if (split1[0] != ':') 240 | split2 = split1.split(/"/)[1] 241 | stateProps['opacity'] = split2 242 | else 243 | stateProps['opacity'] = "1.0" 244 | 245 | layer.states[stateName] = stateProps 246 | 247 | addProps @, state 248 | 249 | for descendant in state.descendants 250 | do (descendant) => 251 | addProps @[descendant.name], descendant 252 | if descendant instanceof SVGPath 253 | addProps @[descendant.name].parent._children[0], descendant.parent._children[0] 254 | 255 | @addStateEvents() 256 | 257 | addStateEvents: -> 258 | events = [] 259 | 260 | for state in @stateComponents 261 | if state.name.includes "_State_#{name}" 262 | stateName = state.name.split("_State_#{name}")[0] 263 | eventName = state.name.split("_State_#{name}")[1] 264 | else 265 | eventName = state.name.replace "State_#{name}_", "" 266 | stateName = eventName 267 | 268 | if eventName.includes "_Animate" 269 | animate = true 270 | eventName = eventName.split("_Animate")[0] 271 | else animate = false 272 | 273 | eventName = eventName.replace "_", "" 274 | 275 | @customStates[stateName].animate = animate 276 | 277 | unless events.includes eventName then events.push eventName 278 | 279 | for eventName in events 280 | 281 | do (eventName) => 282 | 283 | if Events[eventName]? && @customStates.array.includes eventName 284 | 285 | @on Events[eventName], (event, layer) -> 286 | 287 | animateBool = @customStates[eventName].animate 288 | 289 | @stateSwitch(eventName, {animate: animateBool}) 290 | @animateChildren() 291 | 292 | else if Events[eventName]? 293 | 294 | @on Events[eventName], -> 295 | currentIndex = @customStates.array.indexOf(@states.current.name) 296 | nextIndex = currentIndex + 1 297 | if nextIndex == @customStates.array.length then nextIndex = 0 298 | animateBool = @customStates[@customStates.array[nextIndex]].animate 299 | nextState = @customStates.array[nextIndex] 300 | 301 | @stateSwitch(nextState, {animate: animateBool}) 302 | @animateChildren() 303 | 304 | animateChildren: (stateName, animate, options={}) -> 305 | unless stateName? then stateName = @states.current.name 306 | unless animate? then animate = @customStates[stateName].animate 307 | if !animate then options.time = 0 308 | for dec in @descendants 309 | do (dec) => 310 | if dec instanceof SVGPath 311 | # dec.stateSwitch(stateName, {animate: animate, options: options}) 312 | 313 | dec.parent._children[0].stateSwitch(stateName, {animate: animate, options: options}) 314 | else 315 | dec.stateSwitch(stateName, {animate: animate, options: options}) 316 | 317 | animateState: (state, animate, options={}) -> 318 | 319 | if !state? || !@customStates?[state]? then return 320 | if !animate? && @customStates?[state]? then animate = @customStates[state].animate else if animate? then animate = animate else animate = false 321 | if !animate then options.time = 0 322 | 323 | @stateSwitch(state, {animate: animate, options: options}) 324 | @animateChildren(state, animate, options) 325 | 326 | @define "state", 327 | get: -> @options.state 328 | set: (value) -> 329 | @options.state = value 330 | @emit("change:state", @options.state) 331 | @animateState value 332 | 333 | 334 | 335 | customStates = Layer.selectAll "State_*" 336 | 337 | for componentState in customStates 338 | 339 | classEventName = componentState.name.replace "State_", "" 340 | if classEventName.includes "_" 341 | className = classEventName.split("_")[0] 342 | eventName = classEventName.split("_")[1] 343 | else 344 | className = classEventName 345 | 346 | 347 | ### 348 | ------------------ 349 | EXISTING CLASSES 350 | ------------------ 351 | ### 352 | 353 | 354 | components = Layer.selectAll "_*" 355 | 356 | extendSlider = (origin) -> 357 | class exports.SliderComponent extends SliderComponent 358 | 359 | constructor: (@options={}) -> 360 | super @options 361 | 362 | @knob.props = 363 | shadows: origin.knob.shadows 364 | backgroundColor: origin.knob.backgroundColor 365 | borderRadius: origin.knob.borderRadius 366 | frame: origin.knob.frame 367 | 368 | @fill.props = 369 | shadows: origin.fill.shadows 370 | backgroundColor: origin.fill.backgroundColor 371 | borderRadius: origin.fill.borderRadius 372 | frame: origin.fill.frame 373 | 374 | @props = 375 | shadows: origin.shadows 376 | backgroundColor: origin.backgroundColor 377 | borderRadius: origin.borderRadius 378 | size: origin.size 379 | 380 | @value = Utils.modulate origin.knob.midX, [0, origin.width], [@min, @max] 381 | 382 | 383 | extendRangeSlider = (origin) -> 384 | class exports.RangeSliderComponent extends RangeSliderComponent 385 | 386 | constructor: (@options={}) -> 387 | super @options 388 | 389 | @minKnob.props = 390 | shadows: origin.minKnob.shadows 391 | backgroundColor: origin.minKnob.backgroundColor 392 | borderRadius: origin.minKnob.borderRadius 393 | frame: origin.minKnob.frame 394 | @maxKnob.props = 395 | shadows: origin.maxKnob.shadows 396 | backgroundColor: origin.maxKnob.backgroundColor 397 | borderRadius: origin.maxKnob.borderRadius 398 | frame: origin.maxKnob.frame 399 | 400 | @fill.props = 401 | shadows: origin.fill.shadows 402 | backgroundColor: origin.fill.backgroundColor 403 | borderRadius: origin.fill.borderRadius 404 | frame: origin.fill.frame 405 | 406 | @props = 407 | shadows: origin.shadows 408 | backgroundColor: origin.backgroundColor 409 | borderRadius: origin.borderRadius 410 | size: origin.size 411 | 412 | @minValue = Utils.modulate origin.minKnob.midX, [0, origin.width], [@min, @max] 413 | @maxValue = Utils.modulate origin.maxKnob.midX, [0, origin.width], [@min, @max] 414 | 415 | 416 | 417 | for component in components 418 | 419 | type = component.name.replace "_", "" 420 | 421 | do (component) -> 422 | 423 | component.addDesignChildren() 424 | 425 | if type == "SliderComponent" 426 | extendSlider component 427 | else if type == "RangeSliderComponent" 428 | extendRangeSlider component 429 | -------------------------------------------------------------------------------- /Demo.framer/framer/framer.vekter.js: -------------------------------------------------------------------------------- 1 | (function(scope) {var __layer_0__ = new Layer({"name":".UIKit","backgroundColor":"hsl(0, 0%, 81%)","width":375,"x":717,"height":1408,"constraintValues":null,"blending":"normal","clip":true,"borderStyle":"solid"});var Custom_Card = new Layer({"parent":__layer_0__,"name":"Custom_Card","shadows":[{"spread":0,"x":0,"type":"box","y":4,"blur":6,"color":"rgba(0, 0, 0, 0.15)"}],"backgroundColor":"rgb(252, 252, 252)","width":355,"x":10,"height":117,"constraintValues":{"left":10,"height":117,"centerAnchorX":0.5,"width":355,"right":10,"top":13,"centerAnchorY":0.1071964017991004},"blending":"normal","borderRadius":5,"clip":false,"borderStyle":"solid","y":13});var __layer_1__ = new Layer({"parent":Custom_Card,"name":"arrow","backgroundColor":null,"width":11,"x":323,"height":21,"constraintValues":{"left":null,"height":21,"centerAnchorX":0.9253521126760563,"width":11,"bottom":17,"right":21,"top":null,"centerAnchorY":0.7649572649572649},"blending":"normal","clip":false,"borderStyle":"solid","y":79});var __layer_2__ = new SVGLayer({"parent":__layer_1__,"name":".SVGLayer","backgroundColor":null,"width":10.5,"stroke":"#AAA","strokeWidth":2,"htmlIntrinsicSize":{"height":21,"width":10.5},"rotation":null,"height":21,"opacity":null,"y":-0.5,"svg":"<\/path><\/svg>"});var __layer_3__ = new TextLayer({"parent":Custom_Card,"name":"content","backgroundColor":null,"width":295,"x":30,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":7,"css":{"fontSize":"14px","WebkitTextFillColor":"hsl(231, 41%, 19%)","letterSpacing":"0px","lineHeight":"1.2","fontWeight":200,"tabSize":4,"fontFamily":"\"AktivGrotesk-Light\", \"Aktiv Grotesk\", serif"}}],"text":"Content"}]},"height":16,"constraintValues":{"left":30,"height":16,"centerAnchorX":0.5,"width":295,"right":30,"top":81,"centerAnchorY":0.7606837606837606},"blending":"normal","autoSize":false,"y":81});var __layer_4__ = new TextLayer({"parent":Custom_Card,"name":"subheader","backgroundColor":null,"width":295,"x":30,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":10,"css":{"fontSize":"18px","WebkitTextFillColor":"rgb(34, 34, 34)","letterSpacing":"0px","lineHeight":"1.2","fontWeight":500,"tabSize":4,"fontFamily":"\"AktivGrotesk-Medium\", \"Aktiv Grotesk\", serif"}}],"text":"Subheading"}]},"height":21,"constraintValues":{"left":30,"height":21,"centerAnchorX":0.5,"width":295,"right":30,"top":54,"centerAnchorY":0.5512820512820513},"blending":"normal","autoSize":false,"y":54});var __layer_5__ = new TextLayer({"parent":Custom_Card,"name":"title","backgroundColor":null,"width":295,"x":30,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":5,"css":{"fontSize":"24px","WebkitTextFillColor":"hsl(229, 28%, 15%)","letterSpacing":"0px","lineHeight":"1.2","fontWeight":200,"tabSize":4,"fontFamily":"\"AktivGrotesk-Light\", \"Aktiv Grotesk\", serif"}}],"text":"Title"}]},"height":28,"constraintValues":{"left":30,"height":28,"centerAnchorX":0.5,"width":295,"right":30,"top":20,"centerAnchorY":0.2905982905982906},"blending":"normal","autoSize":false,"y":20});var __layer_6__ = new Layer({"parent":Custom_Card,"name":"avatar","backgroundColor":"rgba(0,170,255,0.5)","width":33,"x":312,"height":33,"constraintValues":{"left":null,"aspectRatioLocked":true,"height":33,"centerAnchorX":0.9253521126760563,"width":33,"bottom":74,"right":10,"top":10,"centerAnchorY":0.2264957264957265},"blending":"normal","borderRadius":20,"clip":false,"borderStyle":"solid","y":10});var __layer_7__ = new Layer({"parent":__layer_0__,"name":"State_Button_MouseUp","backgroundColor":null,"width":243,"x":66,"height":56,"constraintValues":{"left":null,"height":56,"centerAnchorX":0.5,"width":243,"top":307,"centerAnchorY":0.2379261363636364},"blending":"normal","clip":false,"borderStyle":"solid","y":307});var __layer_8__ = new Layer({"parent":__layer_7__,"name":"rectangle","shadows":[{"spread":0,"x":0,"type":"box","y":2,"blur":5,"color":"rgba(0,0,0,0.25)"}],"borderWidth":1,"backgroundColor":null,"width":243,"borderColor":"rgb(0, 0, 0)","height":55,"constraintValues":{"height":55,"centerAnchorX":0.5,"width":243,"bottom":1,"right":0,"centerAnchorY":0.4910714285714285},"blending":"normal","clip":false,"borderStyle":"solid"});var __layer_9__ = new TextLayer({"parent":__layer_8__,"name":"text","backgroundColor":null,"width":71,"x":87,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":9,"css":{"fontSize":"16px","WebkitTextFillColor":"rgb(0, 0, 0)","whiteSpace":"pre","letterSpacing":"0px","lineHeight":"1.2","tabSize":4,"fontFamily":"\".SFNSText\", \"SFProText-Regular\", \"SFUIText-Regular\", \".SFUIText\", sans-serif"}}],"text":"Click me!"}],"alignment":"center"},"height":20,"constraintValues":{"left":null,"height":20,"centerAnchorX":0.5041152263374485,"width":71,"top":null,"centerAnchorY":0.509090909090909},"blending":"normal","autoSize":true,"y":18});var __layer_10__ = new Layer({"parent":__layer_0__,"name":"State_Button_MouseDown","backgroundColor":null,"width":243,"x":66,"height":56,"constraintValues":{"left":null,"height":56,"centerAnchorX":0.5,"width":243,"top":245,"centerAnchorY":0.1938920454545454},"blending":"normal","clip":false,"borderStyle":"solid","y":245});var __layer_11__ = new Layer({"parent":__layer_10__,"name":"rectangle","shadows":[{"spread":0,"x":0,"type":"box","y":0,"blur":5,"color":"rgba(0,0,0,0.25)"}],"borderWidth":1,"backgroundColor":"hsla(0, 0%, 0%, 0.79)","width":243,"borderColor":"rgb(0, 0, 0)","height":55,"constraintValues":{"height":55,"centerAnchorX":0.5,"width":243,"bottom":0,"right":0,"top":1,"centerAnchorY":0.5089285714285714},"blending":"normal","clip":false,"borderStyle":"solid","y":1});var __layer_12__ = new TextLayer({"parent":__layer_11__,"name":"text","backgroundColor":null,"width":71,"x":87,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":9,"css":{"fontSize":"16px","WebkitTextFillColor":"hsl(0, 0%, 100%)","whiteSpace":"pre","letterSpacing":"0px","lineHeight":"1.2","tabSize":4,"fontFamily":"\".SFNSText\", \"SFProText-Regular\", \"SFUIText-Regular\", \".SFUIText\", sans-serif"}}],"text":"Click me!"}],"alignment":"center"},"height":20,"constraintValues":{"left":null,"height":20,"centerAnchorX":0.5041152263374485,"width":71,"top":null,"centerAnchorY":0.509090909090909},"blending":"normal","autoSize":true,"y":18});var __layer_13__ = new Layer({"parent":__layer_0__,"name":"Custom_Button","backgroundColor":null,"width":243,"x":66,"height":56,"constraintValues":{"left":null,"height":56,"centerAnchorX":0.5,"width":243,"top":170,"centerAnchorY":0.2071129707112971},"blending":"normal","clip":false,"borderStyle":"solid","y":170});var __layer_14__ = new Layer({"parent":__layer_13__,"name":"rectangle","shadows":[{"spread":0,"x":0,"type":"box","y":2,"blur":5,"color":"rgba(0,0,0,0.25)"}],"borderWidth":1,"backgroundColor":null,"width":243,"borderColor":"rgb(0, 0, 0)","height":55,"constraintValues":{"height":55,"centerAnchorX":0.5,"width":243,"bottom":1,"right":0,"centerAnchorY":0.4910714285714285},"blending":"normal","clip":false,"borderStyle":"solid"});var __layer_15__ = new TextLayer({"parent":__layer_14__,"name":"text","backgroundColor":null,"width":71,"x":87,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":9,"css":{"fontSize":"16px","WebkitTextFillColor":"rgb(0, 0, 0)","whiteSpace":"pre","letterSpacing":"0px","lineHeight":"1.2","tabSize":4,"fontFamily":"\".SFNSText\", \"SFProText-Regular\", \"SFUIText-Regular\", \".SFUIText\", sans-serif"}}],"text":"Click me!"}],"alignment":"center"},"height":20,"constraintValues":{"left":null,"height":20,"centerAnchorX":0.5041152263374485,"width":71,"top":null,"centerAnchorY":0.509090909090909},"blending":"normal","autoSize":true,"y":18});var __layer_16__ = new Layer({"parent":__layer_0__,"name":"Success_State_Toggle_Tap_Animate","borderWidth":1,"backgroundColor":"hsla(139, 100%, 71%, 0.5)","width":125,"x":20,"borderColor":"#222","height":125,"constraintValues":{"left":20,"aspectRatioLocked":true,"height":125,"centerAnchorX":0.22,"width":125,"top":522,"centerAnchorY":0.6114016736401674},"blending":"normal","borderRadius":15,"clip":false,"borderStyle":"solid","y":522});var __layer_17__ = new Layer({"parent":__layer_0__,"name":"Warning_State_Toggle_Tap","borderWidth":1,"backgroundColor":"hsla(54, 100%, 71%, 0.5)","width":125,"x":178,"borderColor":"#222","height":125,"constraintValues":{"left":178,"aspectRatioLocked":true,"height":125,"centerAnchorX":0.6413333333333333,"width":125,"top":522,"centerAnchorY":0.6114016736401674},"blending":"normal","borderRadius":30,"clip":false,"borderStyle":"solid","y":522});var __layer_18__ = new Layer({"parent":__layer_0__,"name":"Error_State_Toggle_Tap_Animate","borderWidth":1,"backgroundColor":"hsla(0, 100%, 71%, 0.5)","width":125,"x":20,"borderColor":"#222","height":125,"constraintValues":{"left":null,"aspectRatioLocked":true,"height":125,"centerAnchorX":0.22,"width":125,"right":230,"top":662,"centerAnchorY":0.7578451882845189},"blending":"normal","borderRadius":60,"opacity":0.6,"clip":false,"borderStyle":"solid","y":662});var __layer_19__ = new Layer({"parent":__layer_0__,"name":"Default_State_Toggle_Tap","borderWidth":1,"backgroundColor":"hsla(0, 0%, 100%, 0.5)","width":125,"x":178,"borderColor":"#222","height":125,"constraintValues":{"left":null,"aspectRatioLocked":true,"height":125,"centerAnchorX":0.6413333333333333,"width":125,"right":72,"top":662,"centerAnchorY":0.7578451882845189},"blending":"normal","clip":false,"borderStyle":"solid","y":662});var __layer_20__ = new Layer({"parent":__layer_0__,"name":"Custom_Toggle","borderWidth":1,"backgroundColor":"hsla(0, 0%, 100%, 0.5)","width":125,"x":20,"borderColor":"#222","height":125,"constraintValues":{"left":20,"aspectRatioLocked":true,"height":125,"centerAnchorX":0.1533333333333333,"width":125,"top":380,"centerAnchorY":0.6259370314842578},"blending":"normal","clip":false,"borderStyle":"solid","y":380});var __layer_21__ = new Layer({"parent":__layer_0__,"name":"_RangeSliderComponent","backgroundColor":"rgba(0,170,255,0.5)","width":295,"x":40,"height":10,"constraintValues":{"left":40,"height":10,"centerAnchorX":0.5,"width":295,"top":892,"centerAnchorY":0.9382845188284519},"blending":"normal","clip":false,"borderStyle":"solid","y":892});var __layer_22__ = new Layer({"parent":__layer_21__,"name":"fill","backgroundColor":"hsla(124, 100%, 50%, 0.5)","width":154,"x":81,"height":10,"constraintValues":{"left":null,"height":10,"centerAnchorX":0.535593220338983,"width":154,"bottom":0,"right":60,"centerAnchorY":0.5},"blending":"normal","clip":false,"borderStyle":"solid"});var __layer_23__ = new Layer({"parent":__layer_21__,"name":"maxKnob","shadows":[{"spread":0,"x":2,"type":"box","y":2,"blur":0,"color":"hsl(0, 0%, 0%)"}],"backgroundColor":"#E48B8B","width":30,"x":220,"height":30,"constraintValues":{"left":null,"aspectRatioLocked":true,"height":30,"centerAnchorX":0.7966101694915254,"width":30,"bottom":-10,"right":45,"top":-10,"centerAnchorY":0.5},"blending":"normal","clip":false,"borderStyle":"solid","y":-10});var __layer_24__ = new Layer({"parent":__layer_21__,"name":"minKnob","shadows":[{"spread":0,"x":2,"type":"box","y":2,"blur":0,"color":"hsl(0, 0%, 0%)"}],"backgroundColor":"#E48B8B","width":30,"x":66,"height":30,"constraintValues":{"left":66,"aspectRatioLocked":true,"height":30,"centerAnchorX":0.2745762711864407,"width":30,"bottom":-10,"top":-10,"centerAnchorY":0.5},"blending":"normal","clip":false,"borderStyle":"solid","y":-10});var __layer_25__ = new Layer({"parent":__layer_0__,"name":"_SliderComponent","backgroundColor":"rgba(0,170,255,0.5)","width":295,"x":40,"height":10,"constraintValues":{"left":40,"height":10,"centerAnchorX":0.5,"width":295,"top":848,"centerAnchorY":0.8922594142259415},"blending":"normal","clip":false,"borderStyle":"solid","y":848});var __layer_26__ = new Layer({"parent":__layer_25__,"name":"fill","backgroundColor":"hsla(124, 100%, 50%, 0.5)","width":148,"height":10,"constraintValues":{"height":10,"centerAnchorX":0.2508474576271186,"width":148,"bottom":0,"centerAnchorY":0.5},"blending":"normal","clip":false,"borderStyle":"solid"});var __layer_27__ = new Layer({"parent":__layer_25__,"name":"knob","shadows":[{"spread":0,"x":2,"type":"box","y":2,"blur":0,"color":"hsl(0, 0%, 0%)"}],"backgroundColor":"hsl(0, 62%, 72%)","width":30,"x":133,"height":30,"constraintValues":{"left":null,"aspectRatioLocked":true,"height":30,"centerAnchorX":0.5016949152542373,"width":30,"bottom":-10,"top":-10,"centerAnchorY":0.5},"blending":"normal","clip":false,"borderStyle":"solid","y":-10});var __layer_28__ = new TextLayer({"parent":__layer_0__,"backgroundColor":null,"width":85,"x":121,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":8,"css":{"fontSize":"16px","WebkitTextFillColor":"rgb(0, 0, 0)","whiteSpace":"pre","letterSpacing":"0px","lineHeight":"1.2","tabSize":4,"fontFamily":"\".SFNSText\", \"SFProText-Regular\", \"SFUIText-Regular\", \".SFUIText\", sans-serif"}}],"text":"😀😇😜😒"}]},"height":19,"constraintValues":{"left":121,"height":19,"centerAnchorX":0.352,"width":85,"bottom":439,"top":950,"centerAnchorY":0.6814630681818182},"blending":"normal","autoSize":true,"y":950});var __layer_29__ = new Layer({"parent":__layer_0__,"backgroundBlur":10,"name":"Custom_Emoji","backgroundColor":"rgba(0,170,255,0.5)","width":101,"x":25,"height":101,"constraintValues":{"left":25,"aspectRatioLocked":true,"height":101,"centerAnchorX":0.2013333333333333,"width":101,"bottom":328,"top":null,"centerAnchorY":0.7311789772727273},"blending":"normal","borderRadius":"50%","clip":false,"borderStyle":"solid","y":979});var __layer_30__ = new TextLayer({"parent":__layer_29__,"backgroundColor":null,"width":33,"x":34,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":2,"css":{"fontSize":"32px","WebkitTextFillColor":"rgb(0, 0, 0)","whiteSpace":"pre","letterSpacing":"0px","lineHeight":"1.2","tabSize":4,"fontFamily":"\".SFNSText\", \"SFProText-Regular\", \"SFUIText-Regular\", \".SFUIText\", sans-serif"}}],"text":"😀"}],"alignment":"center"},"height":38,"constraintValues":{"left":null,"height":38,"centerAnchorX":0.5,"width":33,"top":null,"centerAnchorY":0.5247524752475248},"blending":"normal","autoSize":true,"y":34});var __layer_31__ = new Layer({"parent":__layer_0__,"backgroundBlur":10,"name":"Angel_State_Emoji","backgroundColor":"hsla(260, 100%, 50%, 0.5)","width":101,"x":191,"height":101,"constraintValues":{"left":null,"aspectRatioLocked":true,"height":101,"centerAnchorX":0.644,"width":101,"bottom":212,"right":83,"top":null,"centerAnchorY":0.8135653409090909},"blending":"normal","borderRadius":"50%","clip":false,"borderStyle":"solid","y":1095});var __layer_32__ = new TextLayer({"parent":__layer_31__,"backgroundColor":null,"width":33,"x":34,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":2,"css":{"fontSize":"32px","WebkitTextFillColor":"rgb(0, 0, 0)","whiteSpace":"pre","letterSpacing":"0px","lineHeight":"1.2","tabSize":4,"fontFamily":"\".SFNSText\", \"SFProText-Regular\", \"SFUIText-Regular\", \".SFUIText\", sans-serif"}}],"text":"😇"}],"alignment":"center"},"height":38,"constraintValues":{"left":null,"height":38,"centerAnchorX":0.5,"width":33,"top":null,"centerAnchorY":0.5247524752475248},"blending":"normal","autoSize":true,"y":34});var __layer_33__ = new Layer({"parent":__layer_0__,"backgroundBlur":10,"name":"Smile_State_Emoji","backgroundColor":"rgba(0,170,255,0.5)","width":101,"x":25,"height":101,"constraintValues":{"left":25,"aspectRatioLocked":true,"height":101,"centerAnchorX":0.2013333333333333,"width":101,"bottom":212,"top":null,"centerAnchorY":0.8135653409090909},"blending":"normal","borderRadius":"50%","clip":false,"borderStyle":"solid","y":1095});var __layer_34__ = new TextLayer({"parent":__layer_33__,"backgroundColor":null,"width":33,"x":34,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":2,"css":{"fontSize":"32px","WebkitTextFillColor":"rgb(0, 0, 0)","whiteSpace":"pre","letterSpacing":"0px","lineHeight":"1.2","tabSize":4,"fontFamily":"\".SFNSText\", \"SFProText-Regular\", \"SFUIText-Regular\", \".SFUIText\", sans-serif"}}],"text":"😀"}],"alignment":"center"},"height":38,"constraintValues":{"left":null,"height":38,"centerAnchorX":0.5,"width":33,"top":null,"centerAnchorY":0.5247524752475248},"blending":"normal","autoSize":true,"y":34});var __layer_35__ = new Layer({"parent":__layer_0__,"backgroundBlur":10,"name":"Unamused_State_Emoji","backgroundColor":"hsla(41, 100%, 50%, 0.5)","width":101,"x":191,"height":101,"constraintValues":{"left":null,"aspectRatioLocked":true,"height":101,"centerAnchorX":0.644,"width":101,"bottom":96,"right":83,"top":null,"centerAnchorY":0.8959517045454546},"blending":"normal","borderRadius":"50%","clip":false,"borderStyle":"solid","y":1211});var __layer_36__ = new TextLayer({"parent":__layer_35__,"backgroundColor":null,"width":33,"x":34,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":2,"css":{"fontSize":"32px","WebkitTextFillColor":"rgb(0, 0, 0)","whiteSpace":"pre","letterSpacing":"0px","lineHeight":"1.2","tabSize":4,"fontFamily":"\".SFNSText\", \"SFProText-Regular\", \"SFUIText-Regular\", \".SFUIText\", sans-serif"}}],"text":"😒"}],"alignment":"center"},"height":38,"constraintValues":{"left":null,"height":38,"centerAnchorX":0.5,"width":33,"top":null,"centerAnchorY":0.5247524752475248},"blending":"normal","autoSize":true,"y":34});var __layer_37__ = new Layer({"parent":__layer_0__,"backgroundBlur":10,"name":"Wink_State_Emoji","backgroundColor":"hsla(156, 100%, 50%, 0.5)","width":101,"x":25,"height":101,"constraintValues":{"left":25,"aspectRatioLocked":true,"height":101,"centerAnchorX":0.2013333333333333,"width":101,"bottom":96,"top":null,"centerAnchorY":0.8959517045454546},"blending":"normal","borderRadius":"50%","clip":false,"borderStyle":"solid","y":1211});var __layer_38__ = new TextLayer({"parent":__layer_37__,"backgroundColor":null,"width":33,"x":34,"styledText":{"blocks":[{"inlineStyles":[{"startIndex":0,"endIndex":2,"css":{"fontSize":"32px","WebkitTextFillColor":"rgb(0, 0, 0)","whiteSpace":"pre","letterSpacing":"0px","lineHeight":"1.2","tabSize":4,"fontFamily":"\".SFNSText\", \"SFProText-Regular\", \"SFUIText-Regular\", \".SFUIText\", sans-serif"}}],"text":"😜"}],"alignment":"center"},"height":38,"constraintValues":{"left":null,"height":38,"centerAnchorX":0.5,"width":33,"top":null,"centerAnchorY":0.5247524752475248},"blending":"normal","autoSize":true,"y":34});var __layer_39__ = new Layer({"backgroundColor":"hsl(255, 67%, 65%)","width":178,"x":324,"height":184,"constraintValues":null,"blending":"normal","clip":false,"borderStyle":"solid","y":90});if(__layer_30__ !== undefined){__layer_30__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_30__","vekterClass":"TextNode","text":"😀"}};if(__layer_9__ !== undefined){__layer_9__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_9__","vekterClass":"TextNode","text":"Click me!"}};if(__layer_25__ !== undefined){__layer_25__.__framerInstanceInfo = {"hash":"#vekter|__layer_25__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_36__ !== undefined){__layer_36__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_36__","vekterClass":"TextNode","text":"😒"}};if(__layer_10__ !== undefined){__layer_10__.__framerInstanceInfo = {"hash":"#vekter|__layer_10__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_32__ !== undefined){__layer_32__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_32__","vekterClass":"TextNode","text":"😇"}};if(__layer_35__ !== undefined){__layer_35__.__framerInstanceInfo = {"hash":"#vekter|__layer_35__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_0__ !== undefined){__layer_0__.__framerInstanceInfo = {"hash":"#vekter|__layer_0__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_12__ !== undefined){__layer_12__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_12__","vekterClass":"TextNode","text":"Click me!"}};if(__layer_21__ !== undefined){__layer_21__.__framerInstanceInfo = {"hash":"#vekter|__layer_21__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_23__ !== undefined){__layer_23__.__framerInstanceInfo = {"hash":"#vekter|__layer_23__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_4__ !== undefined){__layer_4__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_4__","vekterClass":"TextNode","text":"Subheading"}};if(__layer_31__ !== undefined){__layer_31__.__framerInstanceInfo = {"hash":"#vekter|__layer_31__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_37__ !== undefined){__layer_37__.__framerInstanceInfo = {"hash":"#vekter|__layer_37__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_26__ !== undefined){__layer_26__.__framerInstanceInfo = {"hash":"#vekter|__layer_26__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_20__ !== undefined){__layer_20__.__framerInstanceInfo = {"hash":"#vekter|__layer_20__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_18__ !== undefined){__layer_18__.__framerInstanceInfo = {"hash":"#vekter|__layer_18__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_7__ !== undefined){__layer_7__.__framerInstanceInfo = {"hash":"#vekter|__layer_7__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_27__ !== undefined){__layer_27__.__framerInstanceInfo = {"hash":"#vekter|__layer_27__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_29__ !== undefined){__layer_29__.__framerInstanceInfo = {"hash":"#vekter|__layer_29__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_2__ !== undefined){__layer_2__.__framerInstanceInfo = {"hash":"#vekter|__layer_2__","vekterClass":"PathNode","framerClass":"SVGLayer"}};if(__layer_8__ !== undefined){__layer_8__.__framerInstanceInfo = {"hash":"#vekter|__layer_8__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_14__ !== undefined){__layer_14__.__framerInstanceInfo = {"hash":"#vekter|__layer_14__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_15__ !== undefined){__layer_15__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_15__","vekterClass":"TextNode","text":"Click me!"}};if(__layer_19__ !== undefined){__layer_19__.__framerInstanceInfo = {"hash":"#vekter|__layer_19__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_13__ !== undefined){__layer_13__.__framerInstanceInfo = {"hash":"#vekter|__layer_13__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_11__ !== undefined){__layer_11__.__framerInstanceInfo = {"hash":"#vekter|__layer_11__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_24__ !== undefined){__layer_24__.__framerInstanceInfo = {"hash":"#vekter|__layer_24__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_33__ !== undefined){__layer_33__.__framerInstanceInfo = {"hash":"#vekter|__layer_33__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_38__ !== undefined){__layer_38__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_38__","vekterClass":"TextNode","text":"😜"}};if(__layer_16__ !== undefined){__layer_16__.__framerInstanceInfo = {"hash":"#vekter|__layer_16__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_34__ !== undefined){__layer_34__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_34__","vekterClass":"TextNode","text":"😀"}};if(__layer_39__ !== undefined){__layer_39__.__framerInstanceInfo = {"hash":"#vekter|__layer_39__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_1__ !== undefined){__layer_1__.__framerInstanceInfo = {"hash":"#vekter|__layer_1__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_6__ !== undefined){__layer_6__.__framerInstanceInfo = {"hash":"#vekter|__layer_6__","vekterClass":"FrameNode","framerClass":"Layer"}};if(Custom_Card !== undefined){Custom_Card.__framerInstanceInfo = {"framerClass":"Layer","hash":"#vekter|Custom_Card","targetName":"Custom_Card","vekterClass":"FrameNode"}};if(__layer_17__ !== undefined){__layer_17__.__framerInstanceInfo = {"hash":"#vekter|__layer_17__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_22__ !== undefined){__layer_22__.__framerInstanceInfo = {"hash":"#vekter|__layer_22__","vekterClass":"FrameNode","framerClass":"Layer"}};if(__layer_3__ !== undefined){__layer_3__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_3__","vekterClass":"TextNode","text":"Content"}};if(__layer_28__ !== undefined){__layer_28__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_28__","vekterClass":"TextNode","text":"😀😇😜😒"}};if(__layer_5__ !== undefined){__layer_5__.__framerInstanceInfo = {"framerClass":"TextLayer","hash":"#vekter|__layer_5__","vekterClass":"TextNode","text":"Title"}};if (scope["__vekterVariables"]) { scope["__vekterVariables"].map(function(variable) { delete scope[variable] } ) };Object.assign(scope, {Custom_Card});scope["__vekterVariables"] = ["Custom_Card"];if (typeof Framer.CurrentContext.layout === 'function') {Framer.CurrentContext.layout()};})(window); -------------------------------------------------------------------------------- /Demo.framer/framer/framer.modules.js: -------------------------------------------------------------------------------- 1 | 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 0) { 563 | stateName = state.name.slice(0, stateIndex - 1); 564 | } else { 565 | stateName = state.name.split("State_" + name + "_")[1]; 566 | } 567 | _this.customStates[stateName] = {}; 568 | _this.customStates.array.push(stateName); 569 | addProps = function(layer, origin) { 570 | var len4, m, prop, stateProps; 571 | stateProps = {}; 572 | for (m = 0, len4 = stateChangeProps.length; m < len4; m++) { 573 | prop = stateChangeProps[m]; 574 | stateProps[prop] = origin[prop]; 575 | } 576 | return layer.states[stateName] = stateProps; 577 | }; 578 | addProps(_this, state); 579 | ref2 = state.descendants; 580 | results = []; 581 | for (m = 0, len4 = ref2.length; m < len4; m++) { 582 | descendant = ref2[m]; 583 | results.push((function(descendant) { 584 | return addProps(_this[descendant.name], descendant); 585 | })(descendant)); 586 | } 587 | return results; 588 | }; 589 | })(this); 590 | for (l = 0, len3 = ref1.length; l < len3; l++) { 591 | state = ref1[l]; 592 | fn1(state); 593 | } 594 | return this.addStateEvents(); 595 | }; 596 | 597 | _Class.prototype.addStateEvents = function() { 598 | var animate, eventName, events, l, len3, len4, m, ref1, results, state, stateName; 599 | events = []; 600 | ref1 = this.stateComponents; 601 | for (l = 0, len3 = ref1.length; l < len3; l++) { 602 | state = ref1[l]; 603 | if (state.name.includes("_State_" + name)) { 604 | stateName = state.name.split("_State_" + name)[0]; 605 | eventName = state.name.split("_State_" + name)[1]; 606 | } else { 607 | eventName = state.name.replace("State_" + name + "_", ""); 608 | stateName = eventName; 609 | } 610 | if (eventName.includes("_Animate")) { 611 | animate = true; 612 | eventName = eventName.split("_Animate")[0]; 613 | } else { 614 | animate = false; 615 | } 616 | eventName = eventName.replace("_", ""); 617 | this.customStates[stateName].animate = animate; 618 | if (!events.includes(eventName)) { 619 | events.push(eventName); 620 | } 621 | } 622 | results = []; 623 | for (m = 0, len4 = events.length; m < len4; m++) { 624 | eventName = events[m]; 625 | results.push((function(_this) { 626 | return function(eventName) { 627 | if ((Events[eventName] != null) && _this.customStates.array.includes(eventName)) { 628 | return _this.on(Events[eventName], function(event, layer) { 629 | var animateBool; 630 | animateBool = this.customStates[eventName].animate; 631 | this.stateSwitch(eventName, { 632 | animate: animateBool 633 | }); 634 | return this.animateChildren(); 635 | }); 636 | } else if (Events[eventName] != null) { 637 | return _this.on(Events[eventName], function() { 638 | var animateBool, currentIndex, nextIndex, nextState; 639 | currentIndex = this.customStates.array.indexOf(this.states.current.name); 640 | nextIndex = currentIndex + 1; 641 | if (nextIndex === this.customStates.array.length) { 642 | nextIndex = 0; 643 | } 644 | animateBool = this.customStates[this.customStates.array[nextIndex]].animate; 645 | nextState = this.customStates.array[nextIndex]; 646 | this.stateSwitch(nextState, { 647 | animate: animateBool 648 | }); 649 | return this.animateChildren(); 650 | }); 651 | } 652 | }; 653 | })(this)(eventName)); 654 | } 655 | return results; 656 | }; 657 | 658 | _Class.prototype.animateChildren = function(stateName, animate, options) { 659 | var dec, l, len3, ref1, results; 660 | if (options == null) { 661 | options = {}; 662 | } 663 | if (stateName == null) { 664 | stateName = this.states.current.name; 665 | } 666 | if (animate == null) { 667 | animate = this.customStates[stateName].animate; 668 | } 669 | if (!animate) { 670 | options.time = 0; 671 | } 672 | ref1 = this.descendants; 673 | results = []; 674 | for (l = 0, len3 = ref1.length; l < len3; l++) { 675 | dec = ref1[l]; 676 | results.push((function(_this) { 677 | return function(dec) { 678 | return dec.stateSwitch(stateName, { 679 | animate: animate, 680 | options: options 681 | }); 682 | }; 683 | })(this)(dec)); 684 | } 685 | return results; 686 | }; 687 | 688 | _Class.prototype.animateState = function(state, animate, options) { 689 | var ref1, ref2; 690 | if (options == null) { 691 | options = {}; 692 | } 693 | if ((state == null) || (((ref1 = this.customStates) != null ? ref1[state] : void 0) == null)) { 694 | return; 695 | } 696 | if ((animate == null) && (((ref2 = this.customStates) != null ? ref2[state] : void 0) != null)) { 697 | animate = this.customStates[state].animate; 698 | } else if (animate != null) { 699 | animate = animate; 700 | } else { 701 | animate = false; 702 | } 703 | if (!animate) { 704 | options.time = 0; 705 | } 706 | this.stateSwitch(state, { 707 | animate: animate, 708 | options: options 709 | }); 710 | return this.animateChildren(state, animate, options); 711 | }; 712 | 713 | _Class.define("state", { 714 | get: function() { 715 | return this.options.state; 716 | }, 717 | set: function(value) { 718 | this.options.state = value; 719 | this.emit("change:state", this.options.state); 720 | return this.animateState(value); 721 | } 722 | }); 723 | 724 | return _Class; 725 | 726 | })(Layer); 727 | }; 728 | for (k = 0, len2 = customComponents.length; k < len2; k++) { 729 | component = customComponents[k]; 730 | name = component.name.replace("Custom_", ""); 731 | fn(component, name); 732 | } 733 | 734 | customStates = Layer.selectAll("State_*"); 735 | 736 | for (l = 0, len3 = customStates.length; l < len3; l++) { 737 | componentState = customStates[l]; 738 | classEventName = componentState.name.replace("State_", ""); 739 | if (classEventName.includes("_")) { 740 | className = classEventName.split("_")[0]; 741 | eventName = classEventName.split("_")[1]; 742 | } else { 743 | className = classEventName; 744 | } 745 | } 746 | 747 | 748 | /* 749 | ------------------ 750 | EXISTING CLASSES 751 | ------------------ 752 | */ 753 | 754 | components = Layer.selectAll("_*"); 755 | 756 | extendSlider = function(origin) { 757 | return exports.SliderComponent = (function(superClass) { 758 | extend(SliderComponent, superClass); 759 | 760 | function SliderComponent(options1) { 761 | this.options = options1 != null ? options1 : {}; 762 | SliderComponent.__super__.constructor.call(this, this.options); 763 | this.knob.props = { 764 | shadows: origin.knob.shadows, 765 | backgroundColor: origin.knob.backgroundColor, 766 | borderRadius: origin.knob.borderRadius, 767 | frame: origin.knob.frame 768 | }; 769 | this.fill.props = { 770 | shadows: origin.fill.shadows, 771 | backgroundColor: origin.fill.backgroundColor, 772 | borderRadius: origin.fill.borderRadius, 773 | frame: origin.fill.frame 774 | }; 775 | this.props = { 776 | shadows: origin.shadows, 777 | backgroundColor: origin.backgroundColor, 778 | borderRadius: origin.borderRadius, 779 | size: origin.size 780 | }; 781 | this.value = Utils.modulate(origin.knob.midX, [0, origin.width], [this.min, this.max]); 782 | } 783 | 784 | return SliderComponent; 785 | 786 | })(SliderComponent); 787 | }; 788 | 789 | extendRangeSlider = function(origin) { 790 | return exports.RangeSliderComponent = (function(superClass) { 791 | extend(RangeSliderComponent, superClass); 792 | 793 | function RangeSliderComponent(options1) { 794 | this.options = options1 != null ? options1 : {}; 795 | RangeSliderComponent.__super__.constructor.call(this, this.options); 796 | this.minKnob.props = { 797 | shadows: origin.minKnob.shadows, 798 | backgroundColor: origin.minKnob.backgroundColor, 799 | borderRadius: origin.minKnob.borderRadius, 800 | frame: origin.minKnob.frame 801 | }; 802 | this.maxKnob.props = { 803 | shadows: origin.maxKnob.shadows, 804 | backgroundColor: origin.maxKnob.backgroundColor, 805 | borderRadius: origin.maxKnob.borderRadius, 806 | frame: origin.maxKnob.frame 807 | }; 808 | this.fill.props = { 809 | shadows: origin.fill.shadows, 810 | backgroundColor: origin.fill.backgroundColor, 811 | borderRadius: origin.fill.borderRadius, 812 | frame: origin.fill.frame 813 | }; 814 | this.props = { 815 | shadows: origin.shadows, 816 | backgroundColor: origin.backgroundColor, 817 | borderRadius: origin.borderRadius, 818 | size: origin.size 819 | }; 820 | this.minValue = Utils.modulate(origin.minKnob.midX, [0, origin.width], [this.min, this.max]); 821 | this.maxValue = Utils.modulate(origin.maxKnob.midX, [0, origin.width], [this.min, this.max]); 822 | } 823 | 824 | return RangeSliderComponent; 825 | 826 | })(RangeSliderComponent); 827 | }; 828 | 829 | fn1 = function(component) { 830 | component.addDesignChildren(); 831 | if (type === "SliderComponent") { 832 | return extendSlider(component); 833 | } else if (type === "RangeSliderComponent") { 834 | return extendRangeSlider(component); 835 | } 836 | }; 837 | for (m = 0, len4 = components.length; m < len4; m++) { 838 | component = components[m]; 839 | type = component.name.replace("_", ""); 840 | fn1(component); 841 | } 842 | 843 | 844 | },{}]},{},[]) 845 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"framer.modules.js","sources":["../../../../../Users/sebastian/Documents/Rogue One/GitHub/framer-DesignComponents/Demo.framer/modules/DesignComponents.coffee","../../../../../Users/sebastian/Documents/Rogue One/GitHub/framer-DesignComponents/Demo.framer/modules/Constraints.coffee","node_modules/browser-pack/_prelude.js"],"sourcesContent":["\n###\n------------------\nCUSTOM CLASSES\n------------------\n###\n\nkit = Layer.select \"*UIKit*\"\nif kit? then kit.x = Screen.width * 1000; kit.name = \".UIKit\"\n\nfor layer in Layer.selectAll \"@*\"\n\tparent = layer.parent\n\tname = layer.name.replace \"@\", \"\"\n\tparent[name] = layer\n\ncustomComponents = Layer.selectAll \"Custom_*\"\n\nLayer::addDesignChildren = (origin) ->\n\tif !origin? then origin = @\n\tfor child in origin.selectAllChildren (\"*\")\n\t\tparent = child.parent\n\t\tparent[child.name] = child\n\n\nstateChangeProps = [\n\t\"width\", \"height\",\n\t\"opacity\",\n\t\"scaleX\", \"scaleY\", \"scaleZ\", \"scale\",\n\t\"skewX\", \"skewY\", \"skew\",\n\t\"rotationX\", \"rotationY\", \"rotationZ\", \"rotation\",\n\t\"blur\",\n\t\"brightness\", \"saturate\", \"hueRotate\", \"contrast\", \"invert\", \"grayscale\", \"sepia\", \"blending\",\n\t\"backgroundBlur\", \"backgroundBrightness\", \"backgroundSaturate\", \"backgroundHueRotate\", \"backgroundContrast\", \"backgroundInvert\", \"backgroundGrayscale\", \"backgroundSepia\",\n\t\"shadow1\", \"shadow2\", \"shadow3\", \"shadow4\", \"shadow5\", \"shadow6\", \"shadow7\", \"shadow8\", \"shadow9\",\n\t\"shadowX\", \"shadowY\", \"shadowBlur\", \"shadowSpread\", \"shadowColor\", \"shadowType\",\n\t\"shadows\",\n\t\"backgroundColor\", \"color\",\n\t\"borderRadius\", \"borderColor\", \"borderWidth\", \"borderStyle\",\n\t\"image\", \"gradient\",\n\t\"text\"\n]\n\n\npushParent = (layer, direction) ->\n\tlayer.pushValues =\n\t\tmarginBottom: layer.parent.height - layer.maxY\n\t\tmarginRight: layer.parent.width - layer.maxX\n\n\tif direction == \"down\"\n\t\tlayer.onChange \"y\", ->\n\t\t\t@parent.height = layer.maxY + @pushValues.marginBottom\n\t\tlayer.onChange \"height\", ->\n\t\t\t@parent.height = layer.maxY + @pushValues.marginBottom\n\nbuildConstraintsProtos = (constructorName) ->\n\n\tconstructorName = eval constructorName\n\t\n\tconstructorName::setConstraints = (options={}, origin) ->\n\t\t@constraintValues =\n\t\t\ttop: if typeof options?.top == \"object\" then null else if options?.top? && typeof options.top == \"number\" then options.top else origin?.constraintValues?.top || null\n\t\t\tleft: if typeof options?.left == \"object\" then null else if options?.left? && typeof options.top == \"number\" then options.top else origin?.constraintValues?.left || null\n\t\t\tbottom: if typeof options?.bottom == \"object\" then null else if options?.pushDown then null else if options?.bottom? && typeof options.bottom == \"number\" then options.bottom else origin?.constraintValues?.bottom || null\n\t\t\tright: if typeof options?.right == \"object\" then null else if options?.pushRight then null else if options?.right? && typeof options.right == \"number\" then options.right else origin?.constraintValues?.right || null\n\t\t\twidth: @width\n\t\t\theight: @height\n\t\t\twidthFactor: options?.scaleX || options?.widthFactor || null\n\t\t\theightFactor: options?.scaleY ||options?.heightFactor || null\n\t\t\tcenterAnchorX: options?.centerX || options?.centerAnchorX || null\n\t\t\tcenterAnchorY: options?.centerY || options?.centerAnchorY || null\n\t\t\taspectRatioLocked: if options?.aspectRatioLocked? then options.aspectRatioLocked else if origin?.constraintValues?.aspectRatioLocked? then origin.constraintValues.aspectRatioLocked else false\n\n\t\tif options.pushDown?\n\t\t\t@constraintValues.bottom = null\n\t\t\tpushParent @, \"down\"\n\t\tif options.pushRight?\n\t\t\t@constraintValues.right = null\n\t\t\tpushParent @, \"right\"\n\n\t\tconstraints = @constraintValues\n\t\ttextLayerAutoSize = typeof @ == TextLayer && @autoSize\n\n\t\t@onChange \"y\", ->\n\t\t\t@constraintValues = constraints\n\t\t@onChange \"x\", ->\n\t\t\t@constraintValues = constraints\n\t\t@onChange \"height\", ->\n\t\t\t@constraintValues = constraints\n\t\t@onChange \"width\", ->\n\t\t\t@constraintValues = constraints\n\n\t\t@applyConstraints()\n\n\tconstructorName::applyConstraints = ->\n\n\t\treturn if !@constraintValues\n\n\t\tvalues = @constraintValues\n\n\t\tif !@parent then parent = Screen else parent = @parent\n\n\t\taspectRatio = @width / @height\n\n\t\t# position\n\t\tif values.top? && typeof values.top != \"object\"\n\t\t\t@y = values.top\n\t\telse if values.top == null && values.topRef?.layer?\n\t\t\t@y = values.topRef.layer[values.topRef.align] + values.topRef.value\n\n\t\tif values.left? && typeof values.left != \"object\"\n\t\t\t@x = values.left\n\t\telse if values.left == null && values.leftRef?.layer?\n\t\t\t@x = values.leftRef.layer[values.leftRef.align] + values.leftRef.value\n\n\t\t# size\n\t\tif values.left? && values.right?\n\t\t\t@width = parent.width - @x - values.right\n\t\t\tif values.aspectRatioLocked\n\t\t\t\t@height = @width / aspectRatio\n\t\tif values.top? && values.bottom?\n\t\t\t@height = parent.height - @y - values.bottom\n\t\t\tif values.aspectRatioLocked\n\t\t\t\t@width = @height * aspectRatio\n\n\t\tif values.widthFactor?\n\t\t\t@width = parent.width * values.widthFactor\n\t\tif values.heightFactor?\n\t\t\t@height = parent.height * values.heightFactor\n\n\t\t# max position\n\t\tif values.right? \n\t\t\t@maxX = parent.width - values.right\n\t\telse if values.right == null && values.rightRef?.layer?\n\t\t\t@maxX = values.rightRef.layer[values.rightRef.align] - values.rightRef.value\n\t\tif values.bottom?\n\t\t\t@maxY = parent.height - values.bottom\n\t\telse if values.bottom == null && values.bottomRef?.layer?\n\t\t\t@maxY = values.bottomRef.layer[values.bottomRef.align] - values.bottomRef.value\n\n\t\t# center position\n\t\tif !values.left? && !values.right? && values.centerAnchorX?\n\t\t\t@midX = parent.width * values.centerAnchorX\n\t\tif !values.top? && !values.bottom? && values.centerAnchorY?\n\t\t\t@midY = parent.height * values.centerAnchorY\n\n\t\t@constraintValues = values\n\n\nlayerTypes = [\"Layer\", \"TextLayer\", \"ScrollComponent\", \"PageComponent\", \"SliderComponent\", \"RangeSliderComponent\", \"SVGLayer\", \"BackgroundLayer\", \"SVGPath\", \"SVGGroup\"]\nfor type in layerTypes\n\tbuildConstraintsProtos(type)\n\nObject.defineProperty(Layer.prototype, \"constraints\", {\n\tget: -> return @constraintValues\n\tset: (value) ->\n\t\t@_constraints = value\n\t\t@emit \"change:constraints\", value\n\t\t@setConstraints value\n})\n\nfor component in customComponents\n\tname = component.name.replace \"Custom_\", \"\"\n\n\tdo (component, name) ->\n\n\t\tclass exports[name] extends Layer\n\t\t\tconstructor: (@options={}) ->\n\t\t\t\tsuper @options\n\t\t\t\t@props = Object.assign component.props, {parent: @options.parent || null}\n\n\t\t\t\tif @options.constraints?\n\t\t\t\t\t@constraints = @options.constraints\n\t\t\t\t\n\t\t\t\t@props = @options\n\n\t\t\t\t@addChildren()\n\t\t\t\t@assignChildren()\n\t\t\t\t@setDescendantProps()\n\t\t\t\t@setDescendantConstraints()\n\n\t\t\t\t@stateComponents = Layer.selectAll \"*State_#{name}*\"\n\t\t\t\t@addStates()\n\n\t\t\t\tif @options.state?\n\t\t\t\t\t@animateState @options.state, false\n\n\t\t\taddChildren: ->\n\t\t\t\tnewParent = component.copy()\n\t\t\t\tfor child in newParent.children\n\t\t\t\t\tif child instanceof SVGPath or child instanceof SVGGroup\n\t\t\t\t\t\tUtils.throwInStudioOrWarnInProduction \"SVG '#{child.name}' in  'Custom_#{name}' must be wrapped in a Frame in order to create a Design Component Symbol\"\n\t\t\t\t\telse\n\t\t\t\t\t\tchild.parent = @\n\t\t\t\t\t\tif child instanceof TextLayer && component.selectChild(child.name)?\n\t\t\t\t\t\t\tchild.autoSize = true\n\t\t\t\tnewParent.destroy()\n\n\t\t\tassignChildren: ->\n\t\t\t\tfor descendant in @descendants\n\t\t\t\t\t@[descendant.name] = descendant\n\n\t\t\tsetDescendantProps: ->\n\t\t\t\tfor descendant in @descendants\n\t\t\t\t\tdo (descendant) =>\n\t\t\t\t\t\tif @options[descendant.name]\n\t\t\t\t\t\t\t@[descendant.name].constraints = @options[descendant.name].constraints || undefined\n\t\t\t\t\t\t\t@[descendant.name].props = @options[descendant.name]\n\n\t\t\tsetDescendantConstraints: ->\n\t\t\t\tfor descendant in @descendants\n\t\t\t\t\tdecName = descendant.name\n\t\t\t\t\torigin = component.selectChild decName\n\t\t\t\t\tdescendant.setConstraints(\n\t\t\t\t\t\t@options[decName]?.constraints || {},\n\t\t\t\t\t\torigin\n\t\t\t\t\t)\n\n\t\t\taddStates: ->\n\t\t\t\t@customStates =\n\t\t\t\t\tarray: []\n\n\t\t\t\tfor state in @stateComponents\n\t\t\t\t\tdo (state) =>\n\t\t\t\t\t\tstateIndex = state.name.indexOf \"State\"\n\t\t\t\t\t\tif stateIndex > 0\n\t\t\t\t\t\t\tstateName = state.name.slice 0, stateIndex-1\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tstateName = state.name.split(\"State_#{name}_\")[1]\n\n\t\t\t\t\t\t@customStates[stateName] = {}\n\t\t\t\t\t\t@customStates.array.push stateName\n\n\t\t\t\t\t\taddProps = (layer, origin) ->\n\t\t\t\t\t\t\tstateProps = {}\n\t\t\t\t\t\t\tfor prop in stateChangeProps\n\t\t\t\t\t\t\t\tstateProps[prop] = origin[prop]\n\t\t\t\t\t\t\tlayer.states[stateName] = stateProps\n\n\t\t\t\t\t\taddProps @, state\n\n\t\t\t\t\t\tfor descendant in state.descendants\n\t\t\t\t\t\t\tdo (descendant) =>\n\t\t\t\t\t\t\t\taddProps @[descendant.name], descendant\n\n\t\t\t\t@addStateEvents()\n\n\t\t\taddStateEvents: ->\n\t\t\t\tevents = []\n\n\t\t\t\tfor state in @stateComponents\n\t\t\t\t\tif state.name.includes \"_State_#{name}\"\n\t\t\t\t\t\tstateName = state.name.split(\"_State_#{name}\")[0]\n\t\t\t\t\t\teventName = state.name.split(\"_State_#{name}\")[1]\n\t\t\t\t\telse\n\t\t\t\t\t\teventName = state.name.replace \"State_#{name}_\", \"\"\n\t\t\t\t\t\tstateName = eventName\n\n\t\t\t\t\tif eventName.includes \"_Animate\"\n\t\t\t\t\t\tanimate = true\n\t\t\t\t\t\teventName = eventName.split(\"_Animate\")[0]\n\t\t\t\t\telse animate = false\n\t\t\t\t\t\n\t\t\t\t\teventName = eventName.replace \"_\", \"\"\n\n\t\t\t\t\t@customStates[stateName].animate = animate\n\n\t\t\t\t\tunless events.includes eventName then events.push eventName\n\n\t\t\t\tfor eventName in events\n\n\t\t\t\t\tdo (eventName) =>\n\n\t\t\t\t\t\tif Events[eventName]? && @customStates.array.includes eventName\n\n\t\t\t\t\t\t\t@on Events[eventName], (event, layer) ->\n\n\t\t\t\t\t\t\t\tanimateBool = @customStates[eventName].animate\n\t\t\t\t\t\t\t\t@stateSwitch(eventName, {animate: animateBool})\n\t\t\t\t\t\t\t\t@animateChildren()\n\n\t\t\t\t\t\telse if Events[eventName]?\n\n\t\t\t\t\t\t\t@on Events[eventName], ->\n\t\t\t\t\t\t\t\tcurrentIndex = @customStates.array.indexOf(@states.current.name)\n\t\t\t\t\t\t\t\tnextIndex = currentIndex + 1\n\t\t\t\t\t\t\t\tif nextIndex == @customStates.array.length then nextIndex = 0\n\t\t\t\t\t\t\t\tanimateBool = @customStates[@customStates.array[nextIndex]].animate\n\t\t\t\t\t\t\t\tnextState = @customStates.array[nextIndex]\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t@stateSwitch(nextState, {animate: animateBool})\n\t\t\t\t\t\t\t\t@animateChildren()\n\n\t\t\tanimateChildren: (stateName, animate, options={}) ->\n\t\t\t\tunless stateName? then stateName = @states.current.name\n\t\t\t\tunless animate? then animate = @customStates[stateName].animate\n\t\t\t\tif !animate then options.time = 0\n\t\t\t\tfor dec in @descendants\n\t\t\t\t\tdo (dec) =>\n\t\t\t\t\t\tdec.stateSwitch(stateName, {animate: animate, options: options})\n\n\t\t\tanimateState: (state, animate, options={}) ->\n\n\t\t\t\tif !state? || !@customStates?[state]? then return\n\t\t\t\tif !animate? && @customStates?[state]? then animate = @customStates[state].animate else if animate? then animate = animate else animate = false\n\t\t\t\tif !animate then options.time = 0\n\n\t\t\t\t@stateSwitch(state, {animate: animate, options: options})\n\t\t\t\t@animateChildren(state, animate, options)\n\n\t\t\t@define \"state\",\n\t\t\t\tget: -> @options.state\n\t\t\t\tset: (value) ->\n\t\t\t\t\t@options.state = value\n\t\t\t\t\t@emit(\"change:state\", @options.state)\n\t\t\t\t\t@animateState value\n\n\n\ncustomStates = Layer.selectAll \"State_*\"\n\nfor componentState in customStates\n\n\tclassEventName = componentState.name.replace \"State_\", \"\"\n\tif classEventName.includes \"_\"\n\t\tclassName = classEventName.split(\"_\")[0]\n\t\teventName = classEventName.split(\"_\")[1]\n\telse\n\t\tclassName = classEventName\n\n\n###\n------------------\nEXISTING CLASSES\n------------------\n###\n\n\ncomponents = Layer.selectAll \"_*\"\n\nextendSlider = (origin) ->\n\tclass exports.SliderComponent extends SliderComponent\n\n\t\tconstructor: (@options={}) ->\n\t\t\tsuper @options\n\n\t\t\t@knob.props =\n\t\t\t\tshadows: origin.knob.shadows\n\t\t\t\tbackgroundColor: origin.knob.backgroundColor\n\t\t\t\tborderRadius: origin.knob.borderRadius\n\t\t\t\tframe: origin.knob.frame\n\n\t\t\t@fill.props =\n\t\t\t\tshadows: origin.fill.shadows\n\t\t\t\tbackgroundColor: origin.fill.backgroundColor\n\t\t\t\tborderRadius: origin.fill.borderRadius\n\t\t\t\tframe: origin.fill.frame\n\n\t\t\t@props =\n\t\t\t\tshadows: origin.shadows\n\t\t\t\tbackgroundColor: origin.backgroundColor\n\t\t\t\tborderRadius: origin.borderRadius\n\t\t\t\tsize: origin.size\n\n\t\t\t@value = Utils.modulate origin.knob.midX, [0, origin.width], [@min, @max]\n\n\nextendRangeSlider = (origin) ->\n\tclass exports.RangeSliderComponent extends RangeSliderComponent\n\n\t\tconstructor: (@options={}) ->\n\t\t\tsuper @options\n\n\t\t\t@minKnob.props =\n\t\t\t\tshadows: origin.minKnob.shadows\n\t\t\t\tbackgroundColor: origin.minKnob.backgroundColor\n\t\t\t\tborderRadius: origin.minKnob.borderRadius\n\t\t\t\tframe: origin.minKnob.frame\n\t\t\t@maxKnob.props =\n\t\t\t\tshadows: origin.maxKnob.shadows\n\t\t\t\tbackgroundColor: origin.maxKnob.backgroundColor\n\t\t\t\tborderRadius: origin.maxKnob.borderRadius\n\t\t\t\tframe: origin.maxKnob.frame\n\n\t\t\t@fill.props =\n\t\t\t\tshadows: origin.fill.shadows\n\t\t\t\tbackgroundColor: origin.fill.backgroundColor\n\t\t\t\tborderRadius: origin.fill.borderRadius\n\t\t\t\tframe: origin.fill.frame\n\n\t\t\t@props =\n\t\t\t\tshadows: origin.shadows\n\t\t\t\tbackgroundColor: origin.backgroundColor\n\t\t\t\tborderRadius: origin.borderRadius\n\t\t\t\tsize: origin.size\n\t\t\t\t\n\t\t\t@minValue = Utils.modulate origin.minKnob.midX, [0, origin.width], [@min, @max]\n\t\t\t@maxValue = Utils.modulate origin.maxKnob.midX, [0, origin.width], [@min, @max]\n\n\n\nfor component in components\n\n\ttype = component.name.replace \"_\", \"\"\n\n\tdo (component) ->\n\n\t\tcomponent.addDesignChildren()\n\n\t\tif type == \"SliderComponent\"\n\t\t\textendSlider component\n\t\telse if type == \"RangeSliderComponent\"\n\t\t\textendRangeSlider component\n\n\n\n\n\n\n\n\n\n","\nmoveFromRef = (layer, reference, moveRef, layerRef, refType) ->\n\n\toriginalConstraints = layer.constraintValues\n\n\toriginalRefValue = reference[layerRef]\n\toriginalLayerValue = layer[moveRef]\n\n\tlayer[moveRef] = reference[layerRef] + layer.constraintValues[refType].value\n\n\t# reference.onChange layerRef, (value) ->\n\t# \tlayer[moveRef] = originalLayerValue + (value - originalRefValue)\n\n\tlayer.constraintValues = originalConstraints\n\n\npushParent = (layer, direction) ->\n\n\tif direction == \"down\"\n\t\toriginalY = layer.y\n\t\toriginalHeight = layer.height\n\n\t\tlayer.onChange \"y\", (value) ->\n\t\t\t@parent.height += value - originalY\n\t\t\toriginalY = value\n\t\t\toriginalHeight = @height\n\t\tlayer.onChange \"height\", (value) ->\n\t\t\t@parent.height += value - originalHeight\n\t\t\toriginalY = @y\n\t\t\toriginalHeight = value\n\t\n\tif direction == \"right\"\n\t\toriginalX = layer.x\n\t\toriginalWidth - layer.width\n\n\t\tlayer.onChange \"x\", (value) ->\n\t\t\t@parent.width += value - originalX\n\t\t\toriginalX = value\n\t\t\toriginalWidth = @width\n\t\tlayer.onChange \"width\", (value) ->\n\t\t\t@parent.width += value - originalWidth\n\t\t\toriginalX = @x\n\t\t\toriginalWidth = value\n\n\naddReferenceEvents = (layer) ->\n\n\toriginalConstraints = layer.constraintValues\n\n\tif layer.constraintValues?.topRef?.layer? || layer.constraintValues?.bottomRef?.layer?\n\n\t\treference = layer.constraintValues?.topRef?.layer || layer.constraintValues?.bottomRef?.layer\n\n\t\toriginalYRef = reference.y\n\t\toriginalHeightRef = reference.height\n\t\toriginalY = layer.y\n\n\t\treference.onChange \"y\", (value) ->\n\t\t\tlayer.y = originalY + (value - originalYRef)\n\t\t\toriginalYRef = value\n\t\t\toriginalY = layer.y\n\n\t\tunless layer.constraintValues?.topRef?.align == \"y\"\n\t\t\treference.onChange \"height\", (value) ->\n\t\t\t\tlayer.y = originalY + (value - originalHeightRef)\n\t\t\t\toriginalHeightRef = value\n\t\t\t\toriginalY = layer.y\n\n\t\tif layer.constraintValues?.topRef? && layer.constraintValues?.bottomRef?\n\t\t\treference.onChange \"height\", (value) ->\n\t\t\t\tlayer.height = value - layer.constraintValues?.topRef.value - layer.constraintValues?.bottomRef.value\n\t\t\t\tlayer.y = reference.y + layer.constraintValues?.topRef.value\n\t\t\t\toriginalHeightRef = value\n\n\tif layer.constraintValues?.leftRef?.layer? || layer.constraintValues?.rightRef?.layer?\n\t\treference = layer.constraintValues?.leftRef?.layer || layer.constraintValues?.rightRef?.layer\n\n\t\toriginalXRef = reference.x\n\t\toriginalWidthRef = reference.width\n\t\toriginalX = layer.x\n\n\t\treference.onChange \"x\", (value) ->\n\t\t\tlayer.x = originalX + (value - originalXRef)\n\t\t\toriginalXRef = value\n\t\t\toriginalX = layer.x\n\n\t\tunless layer.constraintValues?.left?.align == \"x\"\n\t\t\treference.onChange \"width\", (value) ->\n\t\t\t\tlayer.x = originalX + (value - originalWidthRef)\n\t\t\t\toriginalWidthRef = value\n\t\t\t\toriginalX = layer.x\n\n\t\tif layer.constraintValues?.leftRef? && layer.constraintValues?.rightRef?\n\t\t\treference.onChange \"width\", (value) ->\n\t\t\t\tlayer.width = value - layer.constraintValues?.leftRef.value - layer.constraintValues?.rightRef.value\n\t\t\t\tlayer.x = reference.x + layer.constraintValues?.leftRef.value\n\t\t\t\toriginalWidthRef = value\n\n\nbuildConstraintsProtos = (constructorName) ->\n\n\tconstructorName = eval constructorName\n\n\tconstructorName::setConstraints = (options={}, origin) ->\n\n\t\t@constraintValues =\n\t\t\ttop: if typeof options.top == \"object\" then null else if options.top? then options.top else if origin?.constraintValues? then origin.constraintValues.top else null\n\t\t\tleft: if typeof options.left == \"object\" then null else if options.left? then options.left else if origin?.constraintValues? then origin.constraintValues.left else null\n\t\t\tbottom: if typeof options.bottom == \"object\" then null else if options.pushDown then null else if options.bottom? then options.bottom else if origin?.constraintValues? then origin.constraintValues.bottom else null\n\t\t\tright: if typeof options.right == \"object\" then null else if options.pushRight then null  else if options.right? then options.right else if origin?.constraintValues? then origin.constraintValues.right else null\n\t\t\twidth: @width\n\t\t\theight: @height\n\t\t\twidthFactor: if options.scaleX? then options.scaleX else if options.widthFactor? then options.widthFactor else null\n\t\t\theightFactor: if options.scaleY? then options.scaleY else if options.heightFactor? then options.heightFactor else null\n\t\t\tcenterAnchorX: if options.centerX? then options.centerX else if options.centerAnchorX? then options.centerAnchorX else null\n\t\t\tcenterAnchorY: if options.centerY? then options.centerY else if options.centerAnchorY? then options.centerAnchorY else null\n\t\t\taspectRatioLocked: if options.aspectRatioLocked? then options.aspectRatioLocked else if origin?.constraintValues then origin.constraintValues.aspectRatioLocked else false\n\n\t\t# resets\n\t\tvalues = @constraintValues\n\t\tif values.top? && values.bottom?\n\t\t\t@constraintValues.heightFactor = null\n\t\t\t@constraintValues.centerAnchorY = null\n\t\tif values.left? && values.right?\n\t\t\t@constraintValues.widthFactor = null\n\t\t\t@constraintValues.centerAnchorX = null\n\t\tif values.left? && values.right? && values.top? && values.bottom?\n\t\t\t@constraintValues.aspectRatioLocked = false\n\n\t\tfor ref in [[\"top\", \"y\", \"maxY\", \"topRef\", \"bottom\"], [\"left\", \"x\", \"maxX\", \"leftRef\", \"right\"], [\"bottom\", \"maxY\", \"y\", \"bottomRef\", \"top\"], [\"right\", \"maxX\", \"x\", \"rightRef\", \"left\"]]\n\n\t\t\tif typeof options[ref[0]] == \"object\" && options[ref[0]] != null && !options[ref[3]]?\n\n\t\t\t\tif options[ref[0]].layer?\n\t\t\t\t\tif @parent? && @parent.selectChild(options[ref[0]].layer)?\n\t\t\t\t\t\tlayer = @parent.selectChild options[ref[0]].layer\n\t\t\t\t\telse\n\t\t\t\t\t\tlayer = Layer.select options[ref[0]].layer\n\t\t\t\telse layer = @parent\n\n\t\t\t\talign = null\n\n\t\t\t\tif !options[ref[0]].value? && layer == @parent\n\t\t\t\t\tvalue = @[ref[1]]\n\t\t\t\telse if options[ref[0]].align? && options[ref[0]].value?\n\t\t\t\t\tvalue = options[ref[0]].value\n\t\t\t\t\talign = options[ref[0]].align\n\t\t\t\telse if options[ref[0]].align?\n\t\t\t\t\tvalue = 0\n\t\t\t\t\talign = options[ref[0]].align\n\t\t\t\telse if !options[ref[0]].value? && !options[ref[0]].align?\n\t\t\t\t\tvalue = @[ref[1]] - layer[ref[2]]\n\t\t\t\t\talign = ref[4]\n\t\t\t\telse\n\t\t\t\t\tvalue = options[ref[0]].value\n\t\t\t\t\talign = ref[4]\n\n\t\t\t\tif align == \"left\" then align = \"x\"\n\t\t\t\telse if align == \"right\" then align = \"maxX\"\n\t\t\t\telse if align == \"top\" then align = \"y\"\n\t\t\t\telse if align == \"bottom\" then align = \"maxY\"\n\n\t\t\t\t@constraintValues[ref[3]] =\n\t\t\t\t\tlayer: layer\n\t\t\t\t\tvalue: value\n\t\t\t\t\talign: align\n\n\t\t\t\t@constraintValues[ref[0]] = null\n\t\t\t\t@constraintValues[ref[4]] = null\n\n\t\t\t\t# moveFromRef @, layer, ref[1], ref[2], ref[3]\n\n\t\tif options.pushDown?\n\t\t\t@constraintValues.bottom = null\n\t\t\tpushParent @, \"down\"\n\t\tif options.pushRight?\n\t\t\t@constraintValues.right = null\n\t\t\tpushParent @, \"right\"\n\n\t\tunless options.pushDown || @constraintValues.topRef || @constraintValues.bottomRef\n\t\t\t@constraintValues.bottom = if options.bottom? then options.bottom else if origin?.constraintValues? then origin.constraintValues.bottom else null\n\t\tunless options.pushRight || @constraintValues.leftRef || @constraintValues.rightRef\n\t\t\t@constraintValues.right = if options.right? then options.right else if origin?.constraintValues? then origin.constraintValues.right else null\n\n\t\tif @constraintValues.top == null && @constraintValues.bottom == null && @constraintValues.centerAnchorY == null && !@constraintValues.topRef && !@constraintValues.bottomRef\n\t\t\t@constraintValues.top = @y\n\t\tif @constraintValues.left == null && @constraintValues.right == null && @constraintValues.centerAnchorX == null && !@constraintValues.leftRef && !@constraintValues.rightRef\n\t\t\t@constraintValues.left = @x\n\n\t\t@applyConstraints()\n\n\n\tconstructorName::applyConstraints = ->\n\n\t\treturn if !@constraintValues\n\n\t\tvalues = @constraintValues\n\n\t\tif !@parent then parent = Screen else parent = @parent\n\n\t\taspectRatio = @width / @height\n\n\t\t# position\n\t\tif values.top? && typeof values.top != \"object\"\n\t\t\t@y = values.top\n\t\telse if values.top == null && values.topRef?.layer?\n\t\t\t@y = values.topRef.layer[values.topRef.align] + values.topRef.value\n\n\t\tif values.left? && typeof values.left != \"object\"\n\t\t\t@x = values.left\n\t\telse if values.left == null && values.leftRef?.layer?\n\t\t\t@x = values.leftRef.layer[values.leftRef.align] + values.leftRef.value\n\n\t\t# size\n\t\tif values.left? && values.right?\n\t\t\t@width = parent.width - @x - values.right\n\t\t\tif values.aspectRatioLocked\n\t\t\t\t@height = @width / aspectRatio\n\t\tif values.top? && values.bottom?\n\t\t\t@height = parent.height - @y - values.bottom\n\t\t\tif values.aspectRatioLocked\n\t\t\t\t@width = @height * aspectRatio\n\n\t\t# if values.leftRef? && values.rightRef?\n\t\t# \t@width = parent.width - values.leftRef.value - values.rightRef.value\n\t\t# if values.topRef? && values.bottomRef?\n\t\t# \t@height = parent.height - values.topRef.value - values.bottomRef.value\n\n\t\tif values.widthFactor?\n\t\t\t@width = parent.width * values.widthFactor\n\t\tif values.heightFactor?\n\t\t\t@height = parent.height * values.heightFactor\n\n\t\t# max position\n\t\tif values.right? \n\t\t\t@maxX = parent.width - values.right\n\t\telse if values.right == null && values.rightRef?.layer?\n\t\t\t@maxX = values.rightRef.layer[values.rightRef.align] - values.rightRef.value\n\t\tif values.bottom?\n\t\t\t@maxY = parent.height - values.bottom\n\t\telse if values.bottom == null && values.bottomRef?.layer?\n\t\t\t@maxY = values.bottomRef.layer[values.bottomRef.align] - values.bottomRef.value\n\n\t\t# center position\n\t\tif !values.left? && !values.right? && values.centerAnchorX?\n\t\t\t@midX = parent.width * values.centerAnchorX\n\t\tif !values.top? && !values.bottom? && values.centerAnchorY?\n\t\t\t@midY = parent.height * values.centerAnchorY\n\n\t\t@constraintValues = values\n\n\t\taddReferenceEvents(@)\n\n\nlayerTypes = [\"Layer\", \"TextLayer\", \"ScrollComponent\", \"PageComponent\", \"SliderComponent\", \"RangeSliderComponent\", \"SVGLayer\", \"BackgroundLayer\", \"SVGPath\", \"SVGGroup\"]\nfor type in layerTypes\n\tbuildConstraintsProtos(type)\n\n\n\nObject.defineProperty(Layer.prototype, \"constraints\", {\n\n\tget: -> return @_constraints\n\tset: (value) ->\n\t\t@_constraints = value\n\t\t@emit \"change:constraints\", value\n\t\t@setConstraints value\n\n})","(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})"],"names":[],"mappings":"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"} 846 | --------------------------------------------------------------------------------