mirror of
https://github.com/penpot/penpot.git
synced 2025-01-24 23:49:45 -05:00
259 lines
11 KiB
Clojure
259 lines
11 KiB
Clojure
;; This Source Code Form is subject to the terms of the Mozilla Public
|
|
;; License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
;; file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
;;
|
|
;; Copyright (c) KALEIDOS INC
|
|
|
|
(ns frontend-tests.plugins.context-shapes-test
|
|
(:require
|
|
[app.common.math :as m]
|
|
[app.common.test-helpers.files :as cthf]
|
|
[app.common.test-helpers.ids-map :as cthi]
|
|
[app.common.test-helpers.shapes :as cths]
|
|
[app.common.uuid :as uuid]
|
|
[app.main.store :as st]
|
|
[app.plugins.api :as api]
|
|
[cljs.test :as t :include-macros true]
|
|
[frontend-tests.helpers.state :as ths]))
|
|
|
|
(t/deftest test-common-shape-properties
|
|
(let [;; ==== Setup
|
|
store
|
|
(ths/setup-store (cthf/sample-file :file1 :page-label :page1))
|
|
|
|
_ (set! st/state store)
|
|
|
|
context (api/create-context "TEST")
|
|
|
|
page (. context -currentPage)
|
|
|
|
shape (.createRectangle context)
|
|
|
|
get-shape-path
|
|
#(vector :workspace-data :pages-index (aget page "$id") :objects (aget shape "$id") %)]
|
|
|
|
(t/testing "Basic shape properites"
|
|
(t/testing " - name"
|
|
(set! (.-name shape) "TEST")
|
|
(t/is (= (.-name shape) "TEST"))
|
|
(t/is (= (get-in @store (get-shape-path :name)) "TEST")))
|
|
|
|
(t/testing " - x"
|
|
(set! (.-x shape) 10)
|
|
(t/is (= (.-x shape) 10))
|
|
(t/is (= (get-in @store (get-shape-path :x)) 10))
|
|
|
|
(set! (.-x shape) "fail")
|
|
(t/is (= (.-x shape) 10))
|
|
(t/is (= (get-in @store (get-shape-path :x)) 10)))
|
|
|
|
(t/testing " - y"
|
|
(set! (.-y shape) 50)
|
|
(t/is (= (.-y shape) 50))
|
|
(t/is (= (get-in @store (get-shape-path :y)) 50))
|
|
|
|
(set! (.-y shape) "fail")
|
|
(t/is (= (.-y shape) 50))
|
|
(t/is (= (get-in @store (get-shape-path :y)) 50)))
|
|
|
|
(t/testing " - resize"
|
|
(.resize shape 250 300)
|
|
(t/is (= (.-width shape) 250))
|
|
(t/is (= (.-height shape) 300))
|
|
(t/is (= (get-in @store (get-shape-path :width)) 250))
|
|
(t/is (= (get-in @store (get-shape-path :height)) 300))
|
|
|
|
(.resize shape 0 0)
|
|
(t/is (= (.-width shape) 250))
|
|
(t/is (= (.-height shape) 300))
|
|
(t/is (= (get-in @store (get-shape-path :width)) 250))
|
|
(t/is (= (get-in @store (get-shape-path :height)) 300)))
|
|
|
|
(t/testing " - blocked"
|
|
(set! (.-blocked shape) true)
|
|
(t/is (= (.-blocked shape) true))
|
|
(t/is (= (get-in @store (get-shape-path :blocked)) true))
|
|
|
|
(set! (.-blocked shape) false)
|
|
(t/is (= (.-blocked shape) false))
|
|
(t/is (= (get-in @store (get-shape-path :blocked)) false)))
|
|
|
|
(t/testing " - hidden"
|
|
(set! (.-hidden shape) true)
|
|
(t/is (= (.-hidden shape) true))
|
|
(t/is (= (get-in @store (get-shape-path :hidden)) true))
|
|
|
|
(set! (.-hidden shape) false)
|
|
(t/is (= (.-hidden shape) false))
|
|
(t/is (= (get-in @store (get-shape-path :hidden)) false)))
|
|
|
|
(t/testing " - proportionLock"
|
|
(set! (.-proportionLock shape) true)
|
|
(t/is (= (.-proportionLock shape) true))
|
|
(t/is (= (get-in @store (get-shape-path :proportion-lock)) true)))
|
|
|
|
(t/testing " - constraintsHorizontal"
|
|
(set! (.-constraintsHorizontal shape) "fail")
|
|
(t/is (not= (.-constraintsHorizontal shape) "fail"))
|
|
(t/is (not= (get-in @store (get-shape-path :constraints-h)) "fail"))
|
|
|
|
(set! (.-constraintsHorizontal shape) "right")
|
|
(t/is (= (.-constraintsHorizontal shape) "right"))
|
|
(t/is (= (get-in @store (get-shape-path :constraints-h)) :right)))
|
|
|
|
(t/testing " - constraintsVertical"
|
|
(set! (.-constraintsVertical shape) "fail")
|
|
(t/is (not= (.-constraintsVertical shape) "fail"))
|
|
(t/is (not= (get-in @store (get-shape-path :constraints-v)) "fail"))
|
|
|
|
(set! (.-constraintsVertical shape) "bottom")
|
|
(t/is (= (.-constraintsVertical shape) "bottom"))
|
|
(t/is (= (get-in @store (get-shape-path :constraints-v)) :bottom)))
|
|
|
|
(t/testing " - borderRadius"
|
|
(set! (.-borderRadius shape) 10)
|
|
(t/is (= (.-borderRadius shape) 10))
|
|
(t/is (= (get-in @store (get-shape-path :rx)) 10))
|
|
|
|
(set! (.-borderRadiusTopLeft shape) 20)
|
|
(t/is (= (.-borderRadiusTopLeft shape) 20))
|
|
(t/is (= (get-in @store (get-shape-path :rx)) nil))
|
|
(t/is (= (get-in @store (get-shape-path :r1)) 20))
|
|
(t/is (= (get-in @store (get-shape-path :r2)) 10))
|
|
(t/is (= (get-in @store (get-shape-path :r3)) 10))
|
|
(t/is (= (get-in @store (get-shape-path :r4)) 10))
|
|
|
|
(set! (.-borderRadiusTopRight shape) 30)
|
|
(set! (.-borderRadiusBottomRight shape) 40)
|
|
(set! (.-borderRadiusBottomLeft shape) 50)
|
|
(t/is (= (.-borderRadiusTopRight shape) 30))
|
|
(t/is (= (.-borderRadiusBottomRight shape) 40))
|
|
(t/is (= (.-borderRadiusBottomLeft shape) 50))
|
|
|
|
(t/is (= (get-in @store (get-shape-path :rx)) nil))
|
|
(t/is (= (get-in @store (get-shape-path :r1)) 20))
|
|
(t/is (= (get-in @store (get-shape-path :r2)) 30))
|
|
(t/is (= (get-in @store (get-shape-path :r3)) 40))
|
|
(t/is (= (get-in @store (get-shape-path :r4)) 50)))
|
|
|
|
(t/testing " - opacity"
|
|
(set! (.-opacity shape) 0.5)
|
|
(t/is (= (.-opacity shape) 0.5))
|
|
(t/is (= (get-in @store (get-shape-path :opacity)) 0.5)))
|
|
|
|
(t/testing " - blendMode"
|
|
(set! (.-blendMode shape) "multiply")
|
|
(t/is (= (.-blendMode shape) "multiply"))
|
|
(t/is (= (get-in @store (get-shape-path :blend-mode)) :multiply))
|
|
|
|
(set! (.-blendMode shape) "fail")
|
|
(t/is (= (.-blendMode shape) "multiply"))
|
|
(t/is (= (get-in @store (get-shape-path :blend-mode)) :multiply)))
|
|
|
|
(t/testing " - shadows"
|
|
(let [shadow #js {:style "drop-shadow"
|
|
:color #js {:color "#FABADA" :opacity 1}}]
|
|
(set! (.-shadows shape) #js [shadow])
|
|
(let [shadow-id (uuid/uuid (aget (aget (aget shape "shadows") 0) "id"))]
|
|
(t/is (= (-> (. shape -shadows) (aget 0) (aget "style")) "drop-shadow"))
|
|
(t/is (= (get-in @store (get-shape-path :shadow)) [{:id shadow-id
|
|
:style :drop-shadow
|
|
:offset-x 4
|
|
:offset-y 4
|
|
:blur 4
|
|
:spread 0
|
|
:color {:color "#fabada" :opacity 1}
|
|
:hidden false}]))))
|
|
(let [shadow #js {:style "fail"}]
|
|
(set! (.-shadows shape) #js [shadow])
|
|
(t/is (= (-> (. shape -shadows) (aget 0) (aget "style")) "drop-shadow"))))
|
|
|
|
(t/testing " - blur"
|
|
(set! (.-blur shape) #js {:value 10})
|
|
(t/is (= (-> (. shape -blur) (aget "type")) "layer-blur"))
|
|
(t/is (= (-> (. shape -blur) (aget "value")) 10))
|
|
(t/is (= (-> (. shape -blur) (aget "hidden")) false))
|
|
(let [id (-> (. shape -blur) (aget "id") uuid/uuid)]
|
|
(t/is (= (get-in @store (get-shape-path :blur)) {:id id :type :layer-blur :value 10 :hidden false}))))
|
|
|
|
(t/testing " - exports"
|
|
(set! (.-exports shape) #js [#js {:type "pdf" :scale 2 :suffix "test"}])
|
|
(t/is (= (-> (. shape -exports) (aget 0) (aget "type")) "pdf"))
|
|
(t/is (= (-> (. shape -exports) (aget 0) (aget "scale")) 2))
|
|
(t/is (= (-> (. shape -exports) (aget 0) (aget "suffix")) "test"))
|
|
(t/is (= (get-in @store (get-shape-path :exports)) [{:type :pdf :scale 2 :suffix "test"}]))
|
|
|
|
(set! (.-exports shape) #js [#js {:type 10 :scale 2 :suffix "test"}])
|
|
(t/is (= (get-in @store (get-shape-path :exports)) [{:type :pdf :scale 2 :suffix "test"}])))
|
|
|
|
(t/testing " - flipX"
|
|
(set! (.-flipX shape) true)
|
|
(t/is (= (.-flipX shape) true))
|
|
(t/is (= (get-in @store (get-shape-path :flip-x)) true)))
|
|
|
|
(t/testing " - flipY"
|
|
(set! (.-flipY shape) true)
|
|
(t/is (= (.-flipY shape) true))
|
|
(t/is (= (get-in @store (get-shape-path :flip-y)) true)))
|
|
|
|
(t/testing " - rotation"
|
|
(set! (.-rotation shape) 45)
|
|
(t/is (= (.-rotation shape) 45))
|
|
(t/is (= (get-in @store (get-shape-path :rotation)) 45))
|
|
|
|
(set! (.-rotation shape) 0)
|
|
(t/is (= (.-rotation shape) 0))
|
|
(t/is (= (get-in @store (get-shape-path :rotation)) 0)))
|
|
|
|
(t/testing " - fills"
|
|
(set! (.-fills shape) #js [#js {:fillColor 100}])
|
|
(t/is (= (get-in @store (get-shape-path :fills)) [{:fill-color "#B1B2B5" :fill-opacity 1}]))
|
|
(t/is (= (-> (. shape -fills) (aget 0) (aget "fillColor")) "#B1B2B5"))
|
|
|
|
(set! (.-fills shape) #js [#js {:fillColor "#fabada" :fillOpacity 1}])
|
|
(t/is (= (get-in @store (get-shape-path :fills)) [{:fill-color "#fabada" :fill-opacity 1}]))
|
|
(t/is (= (-> (. shape -fills) (aget 0) (aget "fillColor")) "#fabada"))
|
|
(t/is (= (-> (. shape -fills) (aget 0) (aget "fillOpacity")) 1)))
|
|
|
|
(t/testing " - strokes"
|
|
(set! (.-strokes shape) #js [#js {:strokeColor "#fabada" :strokeOpacity 1 :strokeWidth 5}])
|
|
(t/is (= (get-in @store (get-shape-path :strokes)) [{:stroke-color "#fabada" :stroke-opacity 1 :stroke-width 5}]))
|
|
(t/is (= (-> (. shape -strokes) (aget 0) (aget "strokeColor")) "#fabada"))
|
|
(t/is (= (-> (. shape -strokes) (aget 0) (aget "strokeOpacity")) 1))
|
|
(t/is (= (-> (. shape -strokes) (aget 0) (aget "strokeWidth")) 5))))
|
|
|
|
(t/testing "Relative properties"
|
|
(let [frame (.createFrame context)]
|
|
(set! (.-x frame) 100)
|
|
(set! (.-y frame) 200)
|
|
(t/is (= (.-x frame) 100))
|
|
(t/is (= (.-y frame) 200))
|
|
(.appendChild frame shape)
|
|
|
|
(t/testing " - frameX"
|
|
(set! (.-frameX shape) 10)
|
|
(t/is (m/close? (.-frameX shape) 10))
|
|
(t/is (m/close? (.-x shape) 110))
|
|
(t/is (m/close? (get-in @store (get-shape-path :x)) 110)))
|
|
|
|
(t/testing " - frameY"
|
|
(set! (.-frameY shape) 20)
|
|
(t/is (m/close? (.-frameY shape) 20))
|
|
(t/is (m/close? (.-y shape) 220))
|
|
(t/is (m/close? (get-in @store (get-shape-path :y)) 220)))
|
|
|
|
(t/testing " - parentX"
|
|
(set! (.-parentX shape) 30)
|
|
(t/is (m/close? (.-parentX shape) 30))
|
|
(t/is (m/close? (.-x shape) 130))
|
|
(t/is (m/close? (get-in @store (get-shape-path :x)) 130)))
|
|
|
|
(t/testing " - parentY"
|
|
(set! (.-parentY shape) 40)
|
|
(t/is (m/close? (.-parentY shape) 40))
|
|
(t/is (m/close? (.-y shape) 240))
|
|
(t/is (m/close? (get-in @store (get-shape-path :y)) 240)))))
|
|
|
|
(t/testing "Clone")
|
|
(t/testing "Remove")))
|
|
|