utopia 2.5.5 → 2.6.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +1 -2
- data/Gemfile +1 -0
- data/Rakefile +2 -0
- data/docs/code/Utopia.html +439 -433
- data/docs/code/Utopia/Command.html +201 -195
- data/docs/code/Utopia/Command/Environment.html +244 -244
- data/docs/code/Utopia/Command/Server.html +202 -202
- data/docs/code/Utopia/Command/Server/Create.html +192 -192
- data/docs/code/Utopia/Command/Server/Update.html +235 -235
- data/docs/code/Utopia/Command/Site.html +269 -263
- data/docs/code/Utopia/Command/Site/Create.html +192 -192
- data/docs/code/Utopia/Command/Site/Update.html +246 -246
- data/docs/code/Utopia/Command/Top.html +244 -244
- data/docs/code/Utopia/Content.html +636 -630
- data/docs/code/Utopia/Content/Document.html +1411 -1407
- data/docs/code/Utopia/Content/Document/State.html +1048 -1048
- data/docs/code/Utopia/Content/Link.html +1023 -1023
- data/docs/code/Utopia/Content/Links.html +629 -623
- data/docs/code/Utopia/Content/MarkupParser.html +702 -702
- data/docs/code/Utopia/Content/MarkupParser/ParsedTag.html +375 -375
- data/docs/code/Utopia/Content/MarkupParser/UnbalancedTagError.html +523 -523
- data/docs/code/Utopia/Content/Namespace.html +416 -416
- data/docs/code/Utopia/Content/Node.html +952 -952
- data/docs/code/Utopia/Content/Node/Context.html +790 -790
- data/docs/code/Utopia/Content/Response.html +686 -686
- data/docs/code/Utopia/Content/SymbolicHash.html +365 -365
- data/docs/code/Utopia/Content/Tags.html +134 -134
- data/docs/code/Utopia/Content/UnbalancedTagError.html +270 -270
- data/docs/code/Utopia/ContentLength.html +298 -294
- data/docs/code/Utopia/Controller.html +657 -651
- data/docs/code/Utopia/Controller/Actions.html +260 -260
- data/docs/code/Utopia/Controller/Actions/Action.html +785 -779
- data/docs/code/Utopia/Controller/Actions/ClassMethods.html +360 -360
- data/docs/code/Utopia/Controller/Base.html +989 -989
- data/docs/code/Utopia/Controller/Respond.html +264 -254
- data/docs/code/Utopia/Controller/Respond/ClassMethods.html +207 -207
- data/docs/code/Utopia/Controller/Respond/Converter.html +219 -219
- data/docs/code/Utopia/Controller/Respond/Converter/Callback.html +425 -425
- data/docs/code/Utopia/Controller/Respond/Converter/ToJSON.html +323 -317
- data/docs/code/Utopia/Controller/Respond/Passthrough.html +266 -260
- data/docs/code/Utopia/Controller/Respond/Responder.html +449 -443
- data/docs/code/Utopia/Controller/Rewrite.html +260 -260
- data/docs/code/Utopia/Controller/Rewrite/ClassMethods.html +216 -216
- data/docs/code/Utopia/Controller/Rewrite/ExtractPrefixRule.html +303 -303
- data/docs/code/Utopia/Controller/Rewrite/Rewriter.html +402 -402
- data/docs/code/Utopia/Controller/Rewrite/Rule.html +193 -193
- data/docs/code/Utopia/Controller/Variables.html +428 -428
- data/docs/code/Utopia/Controllers.html +216 -216
- data/docs/code/Utopia/Exceptions.html +125 -125
- data/docs/code/Utopia/Exceptions/Handler.html +405 -405
- data/docs/code/Utopia/Exceptions/Mailer.html +400 -394
- data/docs/code/Utopia/Extensions.html +116 -116
- data/docs/code/Utopia/Extensions/ArraySplit.html +164 -164
- data/docs/code/Utopia/Extensions/DateTimeComparison.html +173 -173
- data/docs/code/Utopia/Extensions/TimeDateComparison.html +173 -173
- data/docs/code/Utopia/HTTP.html +193 -187
- data/docs/code/Utopia/HTTP/Status.html +355 -355
- data/docs/code/Utopia/Locale.html +522 -522
- data/docs/code/Utopia/Localization.html +886 -880
- data/docs/code/Utopia/Localization/Wrapper.html +403 -403
- data/docs/code/Utopia/Logger.html +185 -185
- data/docs/code/Utopia/Logger/CompactFormatter.html +290 -290
- data/docs/code/Utopia/Path.html +2562 -2556
- data/docs/code/Utopia/Path/Matcher.html +395 -395
- data/docs/code/Utopia/Path/Matcher/MatchData.html +418 -418
- data/docs/code/Utopia/Redirection.html +148 -142
- data/docs/code/Utopia/Redirection/ClientRedirect.html +594 -594
- data/docs/code/Utopia/Redirection/DirectoryIndex.html +265 -265
- data/docs/code/Utopia/Redirection/Errors.html +391 -385
- data/docs/code/Utopia/Redirection/Moved.html +265 -265
- data/docs/code/Utopia/Redirection/RequestFailure.html +201 -201
- data/docs/code/Utopia/Redirection/Rewrite.html +265 -265
- data/docs/code/Utopia/Session.html +723 -717
- data/docs/code/Utopia/Session/LazyHash.html +709 -709
- data/docs/code/Utopia/Setup.html +783 -777
- data/docs/code/Utopia/Static.html +516 -510
- data/docs/code/Utopia/Static/LocalFile.html +875 -869
- data/docs/code/Utopia/Static/MimeTypeLoader.html +427 -427
- data/docs/code/Utopia/Static/MimeTypeLoader/ExpansionError.html +123 -123
- data/docs/code/_index.html +757 -757
- data/docs/code/class_list.html +51 -51
- data/docs/code/css/full_list.css +58 -58
- data/docs/code/css/style.css +496 -499
- data/docs/code/file.README.html +72 -70
- data/docs/code/file_list.html +56 -56
- data/docs/code/frames.html +17 -17
- data/docs/code/index.html +72 -70
- data/docs/code/js/app.js +292 -248
- data/docs/code/js/full_list.js +216 -216
- data/docs/code/js/jquery.js +3 -3
- data/docs/code/method_list.html +3443 -3443
- data/docs/code/top-level-namespace.html +109 -109
- data/docs/index.html +2 -2
- data/docs/wiki.html +2 -2
- data/docs/wiki/edit.html +1 -1
- data/docs/wiki/javascript.html +153 -0
- data/docs/wiki/javascript/index.html +153 -0
- data/documentation/.yarnrc +1 -0
- data/documentation/Gemfile +1 -0
- data/documentation/config/environment.rb +1 -0
- data/documentation/pages/wiki/content.md +1 -1
- data/documentation/pages/wiki/javascript/content.md +75 -0
- data/documentation/pages/wiki/links.yaml +3 -1
- data/lib/utopia/command/site.rb +4 -4
- data/lib/utopia/version.rb +1 -1
- data/setup/site/.yarnrc +1 -0
- data/setup/site/tasks/yarn.rake +32 -0
- data/spec/utopia/command_spec.rb +2 -2
- metadata +8 -9
- data/docs/wiki/bower-integration.html +0 -74
- data/docs/wiki/bower-integration/index.html +0 -74
- data/documentation/.bowerrc +0 -4
- data/documentation/pages/wiki/bower-integration/content.md +0 -25
- data/setup/.bowerrc +0 -3
- data/setup/site/.bowerrc +0 -4
- data/setup/site/tasks/bower.rake +0 -45
@@ -1,110 +1,110 @@
|
|
1
|
-
<!DOCTYPE html>
|
2
|
-
<html>
|
3
|
-
<head>
|
4
|
-
<meta charset="utf-8">
|
5
|
-
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
6
|
-
<title>
|
7
|
-
Top Level Namespace
|
8
|
-
|
9
|
-
— Documentation by YARD 0.9.
|
10
|
-
|
11
|
-
</title>
|
12
|
-
|
13
|
-
<link rel="stylesheet" href="css/style.css" type="text/css" charset="utf-8" />
|
14
|
-
|
15
|
-
<link rel="stylesheet" href="css/common.css" type="text/css" charset="utf-8" />
|
16
|
-
|
17
|
-
<script type="text/javascript" charset="utf-8">
|
18
|
-
pathId = "";
|
19
|
-
relpath = '';
|
20
|
-
</script>
|
21
|
-
|
22
|
-
|
23
|
-
<script type="text/javascript" charset="utf-8" src="js/jquery.js"></script>
|
24
|
-
|
25
|
-
<script type="text/javascript" charset="utf-8" src="js/app.js"></script>
|
26
|
-
|
27
|
-
|
28
|
-
</head>
|
29
|
-
<body>
|
30
|
-
<div class="nav_wrap">
|
31
|
-
<iframe id="nav" src="class_list.html?1"></iframe>
|
32
|
-
<div id="resizer"></div>
|
33
|
-
</div>
|
34
|
-
|
35
|
-
<div id="main" tabindex="-1">
|
36
|
-
<div id="header">
|
37
|
-
<div id="menu">
|
38
|
-
|
39
|
-
<a href="_index.html">Index</a> »
|
40
|
-
|
41
|
-
|
42
|
-
<span class="title">Top Level Namespace</span>
|
43
|
-
|
44
|
-
</div>
|
45
|
-
|
46
|
-
<div id="search">
|
47
|
-
|
48
|
-
<a class="full_list_link" id="class_list_link"
|
49
|
-
href="class_list.html">
|
50
|
-
|
51
|
-
<svg width="24" height="24">
|
52
|
-
<rect x="0" y="4" width="24" height="4" rx="1" ry="1"></rect>
|
53
|
-
<rect x="0" y="12" width="24" height="4" rx="1" ry="1"></rect>
|
54
|
-
<rect x="0" y="20" width="24" height="4" rx="1" ry="1"></rect>
|
55
|
-
</svg>
|
56
|
-
</a>
|
57
|
-
|
58
|
-
</div>
|
59
|
-
<div class="clear"></div>
|
60
|
-
</div>
|
61
|
-
|
62
|
-
<div id="content"><h1>Top Level Namespace
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
</h1>
|
67
|
-
<div class="box_info">
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
</div>
|
80
|
-
|
81
|
-
<h2>Defined Under Namespace</h2>
|
82
|
-
<p class="children">
|
83
|
-
|
84
|
-
|
85
|
-
<strong class="modules">Modules:</strong> <span class='object_link'><a href="Utopia.html" title="Utopia (module)">Utopia</a></span>
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
</p>
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
</div>
|
101
|
-
|
102
|
-
<div id="footer">
|
103
|
-
Generated on Sat Mar
|
104
|
-
<a href="http://yardoc.org" title="Yay! A Ruby Documentation Tool" target="_parent">yard</a>
|
105
|
-
0.9.
|
106
|
-
</div>
|
107
|
-
|
108
|
-
</div>
|
109
|
-
</body>
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<meta charset="utf-8">
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
6
|
+
<title>
|
7
|
+
Top Level Namespace
|
8
|
+
|
9
|
+
— Documentation by YARD 0.9.18
|
10
|
+
|
11
|
+
</title>
|
12
|
+
|
13
|
+
<link rel="stylesheet" href="css/style.css" type="text/css" charset="utf-8" />
|
14
|
+
|
15
|
+
<link rel="stylesheet" href="css/common.css" type="text/css" charset="utf-8" />
|
16
|
+
|
17
|
+
<script type="text/javascript" charset="utf-8">
|
18
|
+
pathId = "";
|
19
|
+
relpath = '';
|
20
|
+
</script>
|
21
|
+
|
22
|
+
|
23
|
+
<script type="text/javascript" charset="utf-8" src="js/jquery.js"></script>
|
24
|
+
|
25
|
+
<script type="text/javascript" charset="utf-8" src="js/app.js"></script>
|
26
|
+
|
27
|
+
|
28
|
+
</head>
|
29
|
+
<body>
|
30
|
+
<div class="nav_wrap">
|
31
|
+
<iframe id="nav" src="class_list.html?1"></iframe>
|
32
|
+
<div id="resizer"></div>
|
33
|
+
</div>
|
34
|
+
|
35
|
+
<div id="main" tabindex="-1">
|
36
|
+
<div id="header">
|
37
|
+
<div id="menu">
|
38
|
+
|
39
|
+
<a href="_index.html">Index</a> »
|
40
|
+
|
41
|
+
|
42
|
+
<span class="title">Top Level Namespace</span>
|
43
|
+
|
44
|
+
</div>
|
45
|
+
|
46
|
+
<div id="search">
|
47
|
+
|
48
|
+
<a class="full_list_link" id="class_list_link"
|
49
|
+
href="class_list.html">
|
50
|
+
|
51
|
+
<svg width="24" height="24">
|
52
|
+
<rect x="0" y="4" width="24" height="4" rx="1" ry="1"></rect>
|
53
|
+
<rect x="0" y="12" width="24" height="4" rx="1" ry="1"></rect>
|
54
|
+
<rect x="0" y="20" width="24" height="4" rx="1" ry="1"></rect>
|
55
|
+
</svg>
|
56
|
+
</a>
|
57
|
+
|
58
|
+
</div>
|
59
|
+
<div class="clear"></div>
|
60
|
+
</div>
|
61
|
+
|
62
|
+
<div id="content"><h1>Top Level Namespace
|
63
|
+
|
64
|
+
|
65
|
+
|
66
|
+
</h1>
|
67
|
+
<div class="box_info">
|
68
|
+
|
69
|
+
|
70
|
+
|
71
|
+
|
72
|
+
|
73
|
+
|
74
|
+
|
75
|
+
|
76
|
+
|
77
|
+
|
78
|
+
|
79
|
+
</div>
|
80
|
+
|
81
|
+
<h2>Defined Under Namespace</h2>
|
82
|
+
<p class="children">
|
83
|
+
|
84
|
+
|
85
|
+
<strong class="modules">Modules:</strong> <span class='object_link'><a href="Utopia.html" title="Utopia (module)">Utopia</a></span>
|
86
|
+
|
87
|
+
|
88
|
+
|
89
|
+
|
90
|
+
</p>
|
91
|
+
|
92
|
+
|
93
|
+
|
94
|
+
|
95
|
+
|
96
|
+
|
97
|
+
|
98
|
+
|
99
|
+
|
100
|
+
</div>
|
101
|
+
|
102
|
+
<div id="footer">
|
103
|
+
Generated on Sat Mar 9 12:01:52 2019 by
|
104
|
+
<a href="http://yardoc.org" title="Yay! A Ruby Documentation Tool" target="_parent">yard</a>
|
105
|
+
0.9.18 (ruby-2.6.1).
|
106
|
+
</div>
|
107
|
+
|
108
|
+
</div>
|
109
|
+
</body>
|
110
110
|
</html>
|
data/docs/index.html
CHANGED
@@ -50,7 +50,7 @@
|
|
50
50
|
<li><a href="wiki/faq/what-is-xnode/index.html">What is <code>.xnode</code>?</a></li>
|
51
51
|
</ul>
|
52
52
|
</li>
|
53
|
-
<li><a href="wiki/
|
53
|
+
<li><a href="wiki/javascript/index.html">Installing JavaScript Libraries</a></li>
|
54
54
|
<li><a href="wiki/testing/index.html">Website Tests</a></li>
|
55
55
|
<li><a href="wiki/updating-utopia/index.html">Updating Your Site</a></li>
|
56
56
|
</ul>
|
@@ -84,7 +84,7 @@
|
|
84
84
|
|
85
85
|
|
86
86
|
<footer>
|
87
|
-
Last Modified:
|
87
|
+
Last Modified: 2019-03-09 11:28:57 +1300 —
|
88
88
|
</footer>
|
89
89
|
|
90
90
|
</div>
|
data/docs/wiki.html
CHANGED
@@ -50,7 +50,7 @@
|
|
50
50
|
<li><a href="wiki/faq/what-is-xnode/index.html">What is <code>.xnode</code>?</a></li>
|
51
51
|
</ul>
|
52
52
|
</li>
|
53
|
-
<li><a href="wiki/
|
53
|
+
<li><a href="wiki/javascript/index.html">Installing JavaScript Libraries</a></li>
|
54
54
|
<li><a href="wiki/testing/index.html">Website Tests</a></li>
|
55
55
|
<li><a href="wiki/updating-utopia/index.html">Updating Your Site</a></li>
|
56
56
|
</ul>
|
@@ -84,7 +84,7 @@
|
|
84
84
|
|
85
85
|
|
86
86
|
<footer>
|
87
|
-
Last Modified:
|
87
|
+
Last Modified: 2019-03-09 11:28:57 +1300 —
|
88
88
|
</footer>
|
89
89
|
|
90
90
|
</div>
|
data/docs/wiki/edit.html
CHANGED
@@ -73,7 +73,7 @@ Reading these pages in order will give you an overview of the design of Utopia,
|
|
73
73
|
- [Server Setup](server-setup/)
|
74
74
|
- [Your First Page](your-first-page/)
|
75
75
|
- [What is `.xnode`?](faq/what-is-xnode/)
|
76
|
-
- [Installing JavaScript Libraries](
|
76
|
+
- [Installing JavaScript Libraries](javascript/)
|
77
77
|
- [Website Tests](testing/)
|
78
78
|
- [Updating Your Site](updating-utopia/)
|
79
79
|
|
@@ -0,0 +1,153 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
|
5
|
+
<title>Javascript - Utopia</title>
|
6
|
+
|
7
|
+
<meta charset="UTF-8"/>
|
8
|
+
|
9
|
+
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous"/>
|
10
|
+
|
11
|
+
<link rel="icon" type="image/png" href="../_static/icon.png"/>
|
12
|
+
<link rel="stylesheet" href="../_static/site.css" type="text/css" media="screen"/>
|
13
|
+
|
14
|
+
<script src="../_components/jquery/jquery.min.js"></script>
|
15
|
+
<script src="../_components/jquery-syntax/jquery.syntax.min.js"></script>
|
16
|
+
|
17
|
+
<script type="text/javascript">
|
18
|
+
//<![CDATA[
|
19
|
+
jQuery(function($) {
|
20
|
+
$.syntax();
|
21
|
+
});
|
22
|
+
//]]>
|
23
|
+
</script>
|
24
|
+
</head>
|
25
|
+
|
26
|
+
<body class="">
|
27
|
+
<header>
|
28
|
+
<img src="../_static/utopia.svg"/>
|
29
|
+
</header>
|
30
|
+
|
31
|
+
<div id="page">
|
32
|
+
|
33
|
+
<nav>
|
34
|
+
› <a href="../wiki.html">Wiki</a> › <a href="javascript.html">JavaScript</a></nav>
|
35
|
+
|
36
|
+
|
37
|
+
<h1 id="yarn-integration">Yarn Integration</h1>
|
38
|
+
|
39
|
+
<p>Utopia integrates with Yarn and provides a rake task to simplify deployment packages distributed using <code>yarn</code> that implement the <code>dist</code> sub-directory convention.</p>
|
40
|
+
|
41
|
+
<p>By default, utopia includes a <code>.yarnrc</code> file which installs modules into <code>lib/components</code>. This code can then be copied into <code>public/_components</code> using <code>rake yarn:update</code>.</p>
|
42
|
+
|
43
|
+
<h2 id="installing-yarn">Installing Yarn</h2>
|
44
|
+
|
45
|
+
<p>If you don’t already have yarn installed, make sure you have npm installed and then run the following command:</p>
|
46
|
+
|
47
|
+
<pre><code>$ sudo npm install -g yarn
|
48
|
+
</code></pre>
|
49
|
+
|
50
|
+
<h2 id="installing-jquery">Installing jQuery</h2>
|
51
|
+
|
52
|
+
<p>Firstly, ensure your project has a <code>package.json</code> file:</p>
|
53
|
+
|
54
|
+
<pre><code>$ yarn init
|
55
|
+
</code></pre>
|
56
|
+
|
57
|
+
<p>Then install jquery using <code>yarn</code>:</p>
|
58
|
+
|
59
|
+
<pre><code>$ bower install jquery
|
60
|
+
</code></pre>
|
61
|
+
|
62
|
+
<p>Copy the distribution scripts to <code>public/_components</code>:</p>
|
63
|
+
|
64
|
+
<pre><code>$ rake yarn:update
|
65
|
+
</code></pre>
|
66
|
+
|
67
|
+
<p>Then add the appropriate <code><script></code> tags to <code>pages/_page.xnode</code>:</p>
|
68
|
+
|
69
|
+
<pre><code class="language-html"><script type="text/javascript" src="/_components/jquery/jquery.min.js"></script>
|
70
|
+
</code></pre>
|
71
|
+
|
72
|
+
<h3 id="what-does-rake-yarnupdate-do">What does <code>rake yarn:update</code> do?</h3>
|
73
|
+
|
74
|
+
<p>This task copies only the contents of the <code>dist</code> directory. This ensures that you only get files intended for distribution. If the bower package doesn’t have a <code>dist</code> directory, the entire contents is copied.</p>
|
75
|
+
|
76
|
+
<pre><code class="syntax brush-ruby">
|
77
|
+
namespace :yarn do
|
78
|
+
desc 'Load the .bowerrc file and setup the environment for other tasks.'
|
79
|
+
task :environment do
|
80
|
+
@yarn_package_root = SITE_ROOT + "lib/components"
|
81
|
+
@yarn_install_root = SITE_ROOT + "public/_components"
|
82
|
+
end
|
83
|
+
|
84
|
+
desc 'Update the bower packages and link into the public directory.'
|
85
|
+
task :update => :environment do
|
86
|
+
require 'fileutils'
|
87
|
+
require 'utopia/path'
|
88
|
+
|
89
|
+
@yarn_package_root.children.select(&:directory?).collect(&:basename).each do |package_directory|
|
90
|
+
install_path = @yarn_install_root + package_directory
|
91
|
+
package_path = @yarn_package_root + package_directory
|
92
|
+
dist_path = package_path + 'dist'
|
93
|
+
|
94
|
+
FileUtils::Verbose.rm_rf install_path
|
95
|
+
FileUtils::Verbose.mkpath(install_path.dirname)
|
96
|
+
|
97
|
+
# If a package has a dist directory, we only symlink that... otherwise we have to do the entire package, and hope that bower's ignore was setup correctly:
|
98
|
+
if File.exist? dist_path
|
99
|
+
link_path = Utopia::Path.shortest_path(dist_path, install_path)
|
100
|
+
else
|
101
|
+
link_path = Utopia::Path.shortest_path(package_path, install_path)
|
102
|
+
end
|
103
|
+
|
104
|
+
FileUtils::Verbose.cp_r File.expand_path(link_path, install_path), install_path
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|
108
|
+
</code></pre>
|
109
|
+
|
110
|
+
|
111
|
+
<h2 id="using-javascript">Using JavaScript</h2>
|
112
|
+
|
113
|
+
<p>You can use JavaScript by embedding it directly into your HTML, or by creating a JavaScript source file and referencing that.</p>
|
114
|
+
|
115
|
+
<h3 id="embedding-code">Embedding Code</h3>
|
116
|
+
|
117
|
+
<p>In your HTML view:</p>
|
118
|
+
|
119
|
+
<pre><code class="language-trenni"><html>
|
120
|
+
<body>
|
121
|
+
<script type="text/javascript">
|
122
|
+
//<![CDATA[
|
123
|
+
console.log("Hello World")
|
124
|
+
//]]>
|
125
|
+
</script>
|
126
|
+
</body>
|
127
|
+
</html>
|
128
|
+
</code></pre>
|
129
|
+
|
130
|
+
<h3 id="external-script">External Script</h3>
|
131
|
+
|
132
|
+
<p>In <code>script.js</code>:</p>
|
133
|
+
|
134
|
+
<pre><code class="language-javascript">console.log("Hello World")
|
135
|
+
</code></pre>
|
136
|
+
|
137
|
+
<p>In your HTML view:</p>
|
138
|
+
|
139
|
+
<pre><code class="language-trenni"><html>
|
140
|
+
<body>
|
141
|
+
<script type="text/javascript" src="script.js"></script>
|
142
|
+
</body>
|
143
|
+
</html>
|
144
|
+
</code></pre>
|
145
|
+
|
146
|
+
|
147
|
+
<footer>
|
148
|
+
Last Modified: 2019-03-09 11:29:35 +1300 —
|
149
|
+
</footer>
|
150
|
+
|
151
|
+
</div>
|
152
|
+
</body>
|
153
|
+
</html>
|
@@ -0,0 +1,153 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
|
5
|
+
<title>Javascript - Utopia</title>
|
6
|
+
|
7
|
+
<meta charset="UTF-8"/>
|
8
|
+
|
9
|
+
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous"/>
|
10
|
+
|
11
|
+
<link rel="icon" type="image/png" href="../../_static/icon.png"/>
|
12
|
+
<link rel="stylesheet" href="../../_static/site.css" type="text/css" media="screen"/>
|
13
|
+
|
14
|
+
<script src="../../_components/jquery/jquery.min.js"></script>
|
15
|
+
<script src="../../_components/jquery-syntax/jquery.syntax.min.js"></script>
|
16
|
+
|
17
|
+
<script type="text/javascript">
|
18
|
+
//<![CDATA[
|
19
|
+
jQuery(function($) {
|
20
|
+
$.syntax();
|
21
|
+
});
|
22
|
+
//]]>
|
23
|
+
</script>
|
24
|
+
</head>
|
25
|
+
|
26
|
+
<body class="">
|
27
|
+
<header>
|
28
|
+
<img src="../../_static/utopia.svg"/>
|
29
|
+
</header>
|
30
|
+
|
31
|
+
<div id="page">
|
32
|
+
|
33
|
+
<nav>
|
34
|
+
› <a href="../../wiki.html">Wiki</a> › <a href="../javascript.html">JavaScript</a></nav>
|
35
|
+
|
36
|
+
|
37
|
+
<h1 id="yarn-integration">Yarn Integration</h1>
|
38
|
+
|
39
|
+
<p>Utopia integrates with Yarn and provides a rake task to simplify deployment packages distributed using <code>yarn</code> that implement the <code>dist</code> sub-directory convention.</p>
|
40
|
+
|
41
|
+
<p>By default, utopia includes a <code>.yarnrc</code> file which installs modules into <code>lib/components</code>. This code can then be copied into <code>public/_components</code> using <code>rake yarn:update</code>.</p>
|
42
|
+
|
43
|
+
<h2 id="installing-yarn">Installing Yarn</h2>
|
44
|
+
|
45
|
+
<p>If you don’t already have yarn installed, make sure you have npm installed and then run the following command:</p>
|
46
|
+
|
47
|
+
<pre><code>$ sudo npm install -g yarn
|
48
|
+
</code></pre>
|
49
|
+
|
50
|
+
<h2 id="installing-jquery">Installing jQuery</h2>
|
51
|
+
|
52
|
+
<p>Firstly, ensure your project has a <code>package.json</code> file:</p>
|
53
|
+
|
54
|
+
<pre><code>$ yarn init
|
55
|
+
</code></pre>
|
56
|
+
|
57
|
+
<p>Then install jquery using <code>yarn</code>:</p>
|
58
|
+
|
59
|
+
<pre><code>$ bower install jquery
|
60
|
+
</code></pre>
|
61
|
+
|
62
|
+
<p>Copy the distribution scripts to <code>public/_components</code>:</p>
|
63
|
+
|
64
|
+
<pre><code>$ rake yarn:update
|
65
|
+
</code></pre>
|
66
|
+
|
67
|
+
<p>Then add the appropriate <code><script></code> tags to <code>pages/_page.xnode</code>:</p>
|
68
|
+
|
69
|
+
<pre><code class="language-html"><script type="text/javascript" src="/_components/jquery/jquery.min.js"></script>
|
70
|
+
</code></pre>
|
71
|
+
|
72
|
+
<h3 id="what-does-rake-yarnupdate-do">What does <code>rake yarn:update</code> do?</h3>
|
73
|
+
|
74
|
+
<p>This task copies only the contents of the <code>dist</code> directory. This ensures that you only get files intended for distribution. If the bower package doesn’t have a <code>dist</code> directory, the entire contents is copied.</p>
|
75
|
+
|
76
|
+
<pre><code class="syntax brush-ruby">
|
77
|
+
namespace :yarn do
|
78
|
+
desc 'Load the .bowerrc file and setup the environment for other tasks.'
|
79
|
+
task :environment do
|
80
|
+
@yarn_package_root = SITE_ROOT + "lib/components"
|
81
|
+
@yarn_install_root = SITE_ROOT + "public/_components"
|
82
|
+
end
|
83
|
+
|
84
|
+
desc 'Update the bower packages and link into the public directory.'
|
85
|
+
task :update => :environment do
|
86
|
+
require 'fileutils'
|
87
|
+
require 'utopia/path'
|
88
|
+
|
89
|
+
@yarn_package_root.children.select(&:directory?).collect(&:basename).each do |package_directory|
|
90
|
+
install_path = @yarn_install_root + package_directory
|
91
|
+
package_path = @yarn_package_root + package_directory
|
92
|
+
dist_path = package_path + 'dist'
|
93
|
+
|
94
|
+
FileUtils::Verbose.rm_rf install_path
|
95
|
+
FileUtils::Verbose.mkpath(install_path.dirname)
|
96
|
+
|
97
|
+
# If a package has a dist directory, we only symlink that... otherwise we have to do the entire package, and hope that bower's ignore was setup correctly:
|
98
|
+
if File.exist? dist_path
|
99
|
+
link_path = Utopia::Path.shortest_path(dist_path, install_path)
|
100
|
+
else
|
101
|
+
link_path = Utopia::Path.shortest_path(package_path, install_path)
|
102
|
+
end
|
103
|
+
|
104
|
+
FileUtils::Verbose.cp_r File.expand_path(link_path, install_path), install_path
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|
108
|
+
</code></pre>
|
109
|
+
|
110
|
+
|
111
|
+
<h2 id="using-javascript">Using JavaScript</h2>
|
112
|
+
|
113
|
+
<p>You can use JavaScript by embedding it directly into your HTML, or by creating a JavaScript source file and referencing that.</p>
|
114
|
+
|
115
|
+
<h3 id="embedding-code">Embedding Code</h3>
|
116
|
+
|
117
|
+
<p>In your HTML view:</p>
|
118
|
+
|
119
|
+
<pre><code class="language-trenni"><html>
|
120
|
+
<body>
|
121
|
+
<script type="text/javascript">
|
122
|
+
//<![CDATA[
|
123
|
+
console.log("Hello World")
|
124
|
+
//]]>
|
125
|
+
</script>
|
126
|
+
</body>
|
127
|
+
</html>
|
128
|
+
</code></pre>
|
129
|
+
|
130
|
+
<h3 id="external-script">External Script</h3>
|
131
|
+
|
132
|
+
<p>In <code>script.js</code>:</p>
|
133
|
+
|
134
|
+
<pre><code class="language-javascript">console.log("Hello World")
|
135
|
+
</code></pre>
|
136
|
+
|
137
|
+
<p>In your HTML view:</p>
|
138
|
+
|
139
|
+
<pre><code class="language-trenni"><html>
|
140
|
+
<body>
|
141
|
+
<script type="text/javascript" src="script.js"></script>
|
142
|
+
</body>
|
143
|
+
</html>
|
144
|
+
</code></pre>
|
145
|
+
|
146
|
+
|
147
|
+
<footer>
|
148
|
+
Last Modified: 2019-03-09 11:29:35 +1300 —
|
149
|
+
</footer>
|
150
|
+
|
151
|
+
</div>
|
152
|
+
</body>
|
153
|
+
</html>
|