Zacetek
commit
10b0dc9eda
|
@ -0,0 +1,13 @@
|
||||||
|
/resources/public/js/compiled/**
|
||||||
|
figwheel_server.log
|
||||||
|
pom.xml
|
||||||
|
*jar
|
||||||
|
/lib/
|
||||||
|
/classes/
|
||||||
|
/out/
|
||||||
|
/target/
|
||||||
|
.lein-deps-sum
|
||||||
|
.lein-repl-history
|
||||||
|
.lein-plugins/
|
||||||
|
.repl
|
||||||
|
.nrepl-port
|
|
@ -0,0 +1,39 @@
|
||||||
|
# sliva
|
||||||
|
|
||||||
|
FIXME: Write a one-line description of your library/project.
|
||||||
|
|
||||||
|
## Overview
|
||||||
|
|
||||||
|
FIXME: Write a paragraph about the library/project and highlight its goals.
|
||||||
|
|
||||||
|
## Setup
|
||||||
|
|
||||||
|
To get an interactive development environment run:
|
||||||
|
|
||||||
|
lein figwheel
|
||||||
|
|
||||||
|
and open your browser at [localhost:3449](http://localhost:3449/).
|
||||||
|
This will auto compile and send all changes to the browser without the
|
||||||
|
need to reload. After the compilation process is complete, you will
|
||||||
|
get a Browser Connected REPL. An easy way to try it is:
|
||||||
|
|
||||||
|
(js/alert "Am I connected?")
|
||||||
|
|
||||||
|
and you should see an alert in the browser window.
|
||||||
|
|
||||||
|
To clean all compiled files:
|
||||||
|
|
||||||
|
lein clean
|
||||||
|
|
||||||
|
To create a production build run:
|
||||||
|
|
||||||
|
lein do clean, cljsbuild once min
|
||||||
|
|
||||||
|
And open your browser in `resources/public/index.html`. You will not
|
||||||
|
get live reloading, nor a REPL.
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
Copyright © 2014 FIXME
|
||||||
|
|
||||||
|
Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.
|
|
@ -0,0 +1,42 @@
|
||||||
|
(ns user
|
||||||
|
(:require
|
||||||
|
[figwheel-sidecar.repl-api :as f]))
|
||||||
|
|
||||||
|
;; user is a namespace that the Clojure runtime looks for and
|
||||||
|
;; loads if its available
|
||||||
|
|
||||||
|
;; You can place helper functions in here. This is great for starting
|
||||||
|
;; and stopping your webserver and other development services
|
||||||
|
|
||||||
|
;; The definitions in here will be available if you run "lein repl" or launch a
|
||||||
|
;; Clojure repl some other way
|
||||||
|
|
||||||
|
;; You have to ensure that the libraries you :require are listed in your dependencies
|
||||||
|
|
||||||
|
;; Once you start down this path
|
||||||
|
;; you will probably want to look at
|
||||||
|
;; tools.namespace https://github.com/clojure/tools.namespace
|
||||||
|
;; and Component https://github.com/stuartsierra/component
|
||||||
|
|
||||||
|
|
||||||
|
(defn fig-start
|
||||||
|
"This starts the figwheel server and watch based auto-compiler."
|
||||||
|
[]
|
||||||
|
;; this call will only work are long as your :cljsbuild and
|
||||||
|
;; :figwheel configurations are at the top level of your project.clj
|
||||||
|
;; and are not spread across different lein profiles
|
||||||
|
|
||||||
|
;; otherwise you can pass a configuration into start-figwheel! manually
|
||||||
|
(f/start-figwheel!))
|
||||||
|
|
||||||
|
(defn fig-stop
|
||||||
|
"Stop the figwheel server and watch based auto-compiler."
|
||||||
|
[]
|
||||||
|
(f/stop-figwheel!))
|
||||||
|
|
||||||
|
;; if you are in an nREPL environment you will need to make sure you
|
||||||
|
;; have setup piggieback for this to work
|
||||||
|
(defn cljs-repl
|
||||||
|
"Launch a ClojureScript REPL that is connected to your build and host environment."
|
||||||
|
[]
|
||||||
|
(f/cljs-repl))
|
|
@ -0,0 +1,105 @@
|
||||||
|
(defproject sliva "0.1.0-SNAPSHOT"
|
||||||
|
:description "FIXME: write this!"
|
||||||
|
:url "http://example.com/FIXME"
|
||||||
|
:license {:name "Eclipse Public License"
|
||||||
|
:url "http://www.eclipse.org/legal/epl-v10.html"}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
:min-lein-version "2.7.1"
|
||||||
|
|
||||||
|
:dependencies [[org.clojure/clojure "1.9.0-beta4"]
|
||||||
|
[org.clojure/clojurescript "1.9.946"]
|
||||||
|
[org.clojure/core.async "0.3.443"]]
|
||||||
|
|
||||||
|
:plugins [[lein-figwheel "0.5.14"]
|
||||||
|
[lein-cljsbuild "1.1.7" :exclusions [[org.clojure/clojure]]]]
|
||||||
|
|
||||||
|
:source-paths ["src"]
|
||||||
|
|
||||||
|
:cljsbuild {:builds
|
||||||
|
[{:id "dev"
|
||||||
|
:source-paths ["src"]
|
||||||
|
|
||||||
|
;; The presence of a :figwheel configuration here
|
||||||
|
;; will cause figwheel to inject the figwheel client
|
||||||
|
;; into your build
|
||||||
|
:figwheel {:on-jsload "sliva.core/on-js-reload"
|
||||||
|
;; :open-urls will pop open your application
|
||||||
|
;; in the default browser once Figwheel has
|
||||||
|
;; started and compiled your application.
|
||||||
|
;; Comment this out once it no longer serves you.
|
||||||
|
:open-urls ["http://localhost:3449/index.html"]}
|
||||||
|
|
||||||
|
:compiler {:main sliva.core
|
||||||
|
:asset-path "js/compiled/out"
|
||||||
|
:output-to "resources/public/js/compiled/sliva.js"
|
||||||
|
:output-dir "resources/public/js/compiled/out"
|
||||||
|
:source-map-timestamp true
|
||||||
|
;; To console.log CLJS data-structures make sure you enable devtools in Chrome
|
||||||
|
;; https://github.com/binaryage/cljs-devtools
|
||||||
|
:preloads [devtools.preload]}}
|
||||||
|
;; This next build is a compressed minified build for
|
||||||
|
;; production. You can build this with:
|
||||||
|
;; lein cljsbuild once min
|
||||||
|
{:id "min"
|
||||||
|
:source-paths ["src"]
|
||||||
|
:compiler {:output-to "resources/public/js/compiled/sliva.js"
|
||||||
|
:main sliva.core
|
||||||
|
:optimizations :advanced
|
||||||
|
:pretty-print false}}]}
|
||||||
|
|
||||||
|
:figwheel {;; :http-server-root "public" ;; default and assumes "resources"
|
||||||
|
;; :server-port 3449 ;; default
|
||||||
|
;; :server-ip "127.0.0.1"
|
||||||
|
|
||||||
|
:css-dirs ["resources/public/css"] ;; watch and update CSS
|
||||||
|
|
||||||
|
;; Start an nREPL server into the running figwheel process
|
||||||
|
;; :nrepl-port 7888
|
||||||
|
|
||||||
|
;; Server Ring Handler (optional)
|
||||||
|
;; if you want to embed a ring handler into the figwheel http-kit
|
||||||
|
;; server, this is for simple ring servers, if this
|
||||||
|
|
||||||
|
;; doesn't work for you just run your own server :) (see lein-ring)
|
||||||
|
|
||||||
|
;; :ring-handler hello_world.server/handler
|
||||||
|
|
||||||
|
;; To be able to open files in your editor from the heads up display
|
||||||
|
;; you will need to put a script on your path.
|
||||||
|
;; that script will have to take a file path and a line number
|
||||||
|
;; ie. in ~/bin/myfile-opener
|
||||||
|
;; #! /bin/sh
|
||||||
|
;; emacsclient -n +$2 $1
|
||||||
|
;;
|
||||||
|
;; :open-file-command "myfile-opener"
|
||||||
|
|
||||||
|
;; if you are using emacsclient you can just use
|
||||||
|
;; :open-file-command "emacsclient"
|
||||||
|
|
||||||
|
;; if you want to disable the REPL
|
||||||
|
;; :repl false
|
||||||
|
|
||||||
|
;; to configure a different figwheel logfile path
|
||||||
|
;; :server-logfile "tmp/logs/figwheel-logfile.log"
|
||||||
|
|
||||||
|
;; to pipe all the output to the repl
|
||||||
|
;; :server-logfile false
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
;; Setting up nREPL for Figwheel and ClojureScript dev
|
||||||
|
;; Please see:
|
||||||
|
;; https://github.com/bhauman/lein-figwheel/wiki/Using-the-Figwheel-REPL-within-NRepl
|
||||||
|
:profiles {:dev {:dependencies [[binaryage/devtools "0.9.4"]
|
||||||
|
[figwheel-sidecar "0.5.14"]
|
||||||
|
[com.cemerick/piggieback "0.2.2"]]
|
||||||
|
;; need to add dev source path here to get user.clj loaded
|
||||||
|
:source-paths ["src" "dev"]
|
||||||
|
;; for CIDER
|
||||||
|
;; :plugins [[cider/cider-nrepl "0.12.0"]]
|
||||||
|
:repl-options {:nrepl-middleware [cemerick.piggieback/wrap-cljs-repl]}
|
||||||
|
;; need to add the compliled assets to the :clean-targets
|
||||||
|
:clean-targets ^{:protect false} ["resources/public/js/compiled"
|
||||||
|
:target-path]}})
|
|
@ -0,0 +1,2 @@
|
||||||
|
/* some style */
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<link rel="icon" href="https://clojurescript.org/images/cljs-logo-icon-32.png">
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<meta name="title" content="sliva">
|
||||||
|
<title>sliva</title>
|
||||||
|
<link href="css/style.css" rel="stylesheet" type="text/css">
|
||||||
|
</head>
|
||||||
|
<body style="margin: 0">
|
||||||
|
<script type="text/javascript" src="js/three.min.js"></script>
|
||||||
|
<script src="js/compiled/sliva.js" type="text/javascript"></script>
|
||||||
|
</body>
|
||||||
|
</html>
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,14 @@
|
||||||
|
(ns sliva.core
|
||||||
|
(:require ))
|
||||||
|
|
||||||
|
(enable-console-print!)
|
||||||
|
|
||||||
|
(defonce app-state (atom {:text "Hello world!"}))
|
||||||
|
|
||||||
|
(console.log (:text @app-state))
|
||||||
|
|
||||||
|
(defn on-js-reload []
|
||||||
|
;; optionally touch your app-state to force rerendering depending on
|
||||||
|
;; your application
|
||||||
|
;; (swap! app-state update-in [:__figwheel_counter] inc)
|
||||||
|
)
|
Loading…
Reference in New Issue