firefly-compiler 0.5.39 → 0.5.40

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (129) hide show
  1. package/.hintrc +4 -4
  2. package/.vscode/settings.json +4 -4
  3. package/bin/Release.ff +157 -157
  4. package/bin/firefly.mjs +1 -1
  5. package/compiler/Builder.ff +275 -275
  6. package/compiler/Compiler.ff +234 -234
  7. package/compiler/Dependencies.ff +186 -186
  8. package/compiler/DependencyLock.ff +17 -17
  9. package/compiler/JsEmitter.ff +1437 -1437
  10. package/compiler/LspHook.ff +202 -202
  11. package/compiler/ModuleCache.ff +178 -178
  12. package/compiler/Workspace.ff +88 -88
  13. package/core/.firefly/include/package.json +5 -5
  14. package/core/.firefly/package.ff +2 -2
  15. package/core/Any.ff +25 -25
  16. package/core/Array.ff +298 -298
  17. package/core/Atomic.ff +63 -63
  18. package/core/Box.ff +7 -7
  19. package/core/BrowserSystem.ff +40 -40
  20. package/core/BuildSystem.ff +156 -156
  21. package/core/Crypto.ff +94 -94
  22. package/core/Equal.ff +41 -41
  23. package/core/Error.ff +25 -25
  24. package/core/HttpClient.ff +142 -142
  25. package/core/Instant.ff +24 -24
  26. package/core/Js.ff +305 -305
  27. package/core/JsSystem.ff +135 -135
  28. package/core/Json.ff +423 -423
  29. package/core/List.ff +482 -482
  30. package/core/Lock.ff +108 -108
  31. package/core/NodeSystem.ff +198 -198
  32. package/core/Ordering.ff +160 -160
  33. package/core/Path.ff +377 -378
  34. package/core/Queue.ff +90 -90
  35. package/core/Random.ff +140 -140
  36. package/core/RbMap.ff +216 -216
  37. package/core/Show.ff +44 -44
  38. package/core/SourceLocation.ff +68 -68
  39. package/core/Task.ff +165 -165
  40. package/experimental/benchmarks/ListGrab.ff +23 -23
  41. package/experimental/benchmarks/ListGrab.java +55 -55
  42. package/experimental/benchmarks/Pyrotek45.ff +30 -30
  43. package/experimental/benchmarks/Pyrotek45.java +64 -64
  44. package/experimental/bidirectional/Bidi.ff +88 -88
  45. package/experimental/lines/Main.ff +40 -40
  46. package/experimental/random/Index.ff +53 -53
  47. package/experimental/random/Process.ff +120 -120
  48. package/experimental/random/RunLength.ff +65 -65
  49. package/experimental/random/Scrape.ff +51 -51
  50. package/experimental/random/Symbols.ff +73 -73
  51. package/experimental/random/Tensor.ff +52 -52
  52. package/experimental/random/Units.ff +36 -36
  53. package/experimental/s3/S3TestAuthorizationHeader.ff +39 -39
  54. package/experimental/s3/S3TestPut.ff +16 -16
  55. package/experimental/tests/TestJson.ff +26 -26
  56. package/firefly.sh +0 -0
  57. package/fireflysite/.firefly/package.ff +4 -4
  58. package/fireflysite/CommunityOverview.ff +20 -20
  59. package/fireflysite/CountingButtonDemo.ff +58 -58
  60. package/fireflysite/DocumentParser.ff +325 -325
  61. package/fireflysite/ExamplesOverview.ff +40 -40
  62. package/fireflysite/FrontPage.ff +344 -344
  63. package/fireflysite/GettingStarted.ff +45 -45
  64. package/fireflysite/Guide.ff +456 -456
  65. package/fireflysite/Main.ff +163 -163
  66. package/fireflysite/MatchingPasswordsDemo.ff +82 -82
  67. package/fireflysite/PackagesOverview.ff +49 -49
  68. package/fireflysite/PostgresqlDemo.ff +34 -34
  69. package/fireflysite/ReferenceAll.ff +18 -18
  70. package/fireflysite/ReferenceIntroduction.ff +11 -11
  71. package/fireflysite/Styles.ff +567 -567
  72. package/fireflysite/Test.ff +121 -121
  73. package/fireflysite/assets/markdown/reference/BaseTypes.md +209 -209
  74. package/fireflysite/assets/markdown/reference/EmittedJavascript.md +65 -65
  75. package/fireflysite/assets/markdown/reference/Exceptions.md +101 -101
  76. package/fireflysite/assets/markdown/reference/FunctionsAndMethods.md +364 -364
  77. package/fireflysite/assets/markdown/reference/JavascriptInterop.md +235 -235
  78. package/fireflysite/assets/markdown/reference/ModulesAndPackages.md +162 -162
  79. package/fireflysite/assets/markdown/reference/OldStructuredConcurrency.md +48 -48
  80. package/fireflysite/assets/markdown/reference/PatternMatching.md +224 -224
  81. package/fireflysite/assets/markdown/reference/StatementsAndExpressions.md +86 -86
  82. package/fireflysite/assets/markdown/reference/StructuredConcurrency.md +99 -99
  83. package/fireflysite/assets/markdown/reference/TraitsAndInstances.md +100 -100
  84. package/fireflysite/assets/markdown/reference/UserDefinedTypes.md +184 -184
  85. package/fireflysite/assets/markdown/scratch/ControlFlow.md +136 -136
  86. package/fireflysite/assets/markdown/scratch/Toc.md +40 -40
  87. package/lsp/.firefly/package.ff +1 -1
  88. package/lsp/CompletionHandler.ff +827 -827
  89. package/lsp/Handler.ff +714 -714
  90. package/lsp/HoverHandler.ff +79 -79
  91. package/lsp/LanguageServer.ff +272 -272
  92. package/lsp/SignatureHelpHandler.ff +55 -55
  93. package/lsp/SymbolHandler.ff +181 -181
  94. package/lsp/TestReferences.ff +17 -17
  95. package/lsp/TestReferencesCase.ff +7 -7
  96. package/lsp/stderr.txt +1 -1
  97. package/lsp/stdout.txt +34 -34
  98. package/lux/.firefly/package.ff +1 -1
  99. package/lux/Css.ff +648 -648
  100. package/lux/CssTest.ff +48 -48
  101. package/lux/Lux.ff +608 -608
  102. package/lux/LuxEvent.ff +79 -79
  103. package/lux/Main.ff +123 -123
  104. package/lux/Main2.ff +143 -143
  105. package/lux/TestDry.ff +28 -28
  106. package/output/js/ff/compiler/Builder.mjs +36 -36
  107. package/output/js/ff/core/Path.mjs +0 -2
  108. package/package.json +1 -1
  109. package/rpc/.firefly/package.ff +1 -1
  110. package/rpc/Rpc.ff +70 -70
  111. package/s3/.firefly/package.ff +1 -1
  112. package/s3/S3.ff +92 -92
  113. package/vscode/LICENSE.txt +21 -21
  114. package/vscode/Prepublish.ff +15 -15
  115. package/vscode/README.md +16 -16
  116. package/vscode/client/package-lock.json +544 -544
  117. package/vscode/client/package.json +22 -22
  118. package/vscode/client/src/extension.ts +104 -104
  119. package/vscode/icons/firefly-icon.svg +10 -10
  120. package/vscode/language-configuration.json +61 -61
  121. package/vscode/package-lock.json +3623 -3623
  122. package/vscode/package.json +1 -1
  123. package/vscode/snippets.json +241 -241
  124. package/vscode/syntaxes/firefly-markdown-injection.json +45 -45
  125. package/webserver/.firefly/include/package.json +5 -5
  126. package/webserver/.firefly/package.ff +2 -2
  127. package/webserver/WebServer.ff +647 -647
  128. package/websocket/.firefly/package.ff +1 -1
  129. package/websocket/WebSocket.ff +100 -100
@@ -1,163 +1,163 @@
1
- import WebServer from ff:webserver
2
- import Lux from ff:lux
3
- import Css from ff:lux
4
- import Guide
5
- import GettingStarted
6
- import ReferenceAll
7
- import ExamplesOverview
8
- import PackagesOverview
9
- import CommunityOverview
10
- import FrontPage
11
- import Styles
12
-
13
- nodeMain(system: NodeSystem): Unit {
14
- let host = system.arguments().grab(0)
15
- let port = system.arguments().grab(1).grabInt()
16
- let cacheSalt = system.crypto().randomBuffer(16)
17
- system.writeLine("Listening on " + host + ":" + port)
18
- WebServer.new(system, host, port).listen {request =>
19
- let path = request.readPath()
20
- let segments = path.split('/').filter {s => s != "" && s != "." && s != ".."}
21
- segments.{
22
- | _ {
23
- !request.readHeader("host").contains("www.firefly-lang.org") &&
24
- !request.readHeader("host").any {_.startsWith("localhost")}
25
- } =>
26
- let parameters = if(request.readRawQueryString().size() == 0) {""} else {
27
- "?" + request.readRawQueryString()
28
- }
29
- request.writeHeader("Location", "https://www.firefly-lang.org" + path + parameters)
30
- request.writeStatus("302 Found")
31
- | ["js", ...] =>
32
- let asset = if(path == "/js/ff/fireflysite/Main.mjs" && system.assets().exists("/js/Main.bundle.js")) {
33
- "/js/Main.bundle.js"
34
- } else {
35
- path
36
- }
37
- serveAsset(system, cacheSalt, request, "text/javascript; charset=UTF-8", asset)
38
- | ["favicon.ico"] =>
39
- serveAsset(system, cacheSalt, request, "image/png", "/assets/image/firefly-logo-notext.png")
40
- | ["assets", "font", "firefly-mono.woff2"] =>
41
- serveAsset(system, cacheSalt, request, "font/woff2", "/assets/font/gf-noto-sans-mono-latin.woff2")
42
- | ["assets", "font", "firefly-sans.woff2"] =>
43
- serveAsset(system, cacheSalt, request, "font/woff2", "/assets/font/gf-nunito-sans-latin.woff2")
44
- | ["assets", ...rest] => serveAssets(system, cacheSalt, request, rest)
45
- | _ {serveGuide(system, request)} =>
46
- | _ =>
47
- request.writeText("404 Not Found")
48
- request.writeStatus("404 Not Found")
49
- }
50
- }
51
- }
52
-
53
- guides = [
54
- Guide("/front/", [FrontPage.new()])
55
- Guide("/getting-started/", [GettingStarted.new()])
56
- Guide("/examples/", ExamplesOverview.mock())
57
- Guide("/reference/", ReferenceAll.mock())
58
- Guide("/packages/", [PackagesOverview.new()])
59
- Guide("/community/", [CommunityOverview.new()])
60
- ]
61
-
62
- serveGuide(system: NodeSystem, request: WebRequest[WebResponse]): Bool {
63
- let demos = ExamplesOverview.demos()
64
- mutable served = False
65
- guides.each {guide =>
66
- if(isGuidePath(request.readPath(), guide.prefix)):
67
- let kebab = request.readPath().dropFirst(guide.prefix.size())
68
- let htmlAndCss = Lux.renderToString(system) {lux =>
69
- Guide.render(lux, system.httpClient(), guide.prefix, kebab, guides, demos)
70
- }
71
- let title = guide.documents.find {d =>
72
- Guide.kebabCase(d.heading()) == kebab
73
- }.map {_.title(guide)}.else {guide.title()}
74
- serveGuideHtml(title, htmlAndCss.first, htmlAndCss.second, request)
75
- served = True
76
- }
77
- served
78
- }
79
-
80
- browserMain(system: BrowserSystem): Unit {
81
- let demos = ExamplesOverview.demos()
82
- guides.collect {guide =>
83
- if(isGuidePath(system.urlPath(), guide.prefix)):
84
- Lux.renderById(system, "main") {lux =>
85
- let kebab = system.urlPath().dropFirst(guide.prefix.size())
86
- Guide.render(lux, system.httpClient(), guide.prefix, kebab, guides, demos)
87
- }
88
- }
89
- }
90
-
91
- isGuidePath(path: String, prefix: String): Bool {
92
- //Log.debug(path + " vs. " + prefix)
93
- path.startsWith(prefix) || (prefix == "/front/" && (path == "/" || path == "/index.html")) // Why is index.html requested
94
- }
95
-
96
- buildMain(system: BuildSystem) {
97
- let browser = system.compileForBrowser("Main.ff") // .bundle()
98
- let assets = AssetSystem.create()
99
- .addAssets("/js/", browser.assets())
100
- .addAssets("/assets/", system.packageAssets().assets("/assets/"))
101
- system.setAssets(assets)
102
- }
103
-
104
- serveAssets(system: NodeSystem, salt: Buffer, request: WebRequest[WebResponse], segments: List[String]): Unit {
105
- let asset = "/assets/" + segments.join("/")
106
- if(!system.assets().exists(asset)) {
107
- request.writeStatus("404 Not Found")
108
- } else:
109
-
110
- guessContentType(asset).or {
111
- request.writeStatus("404 Not Found")
112
- }: contentType =>
113
-
114
- serveAsset(system, salt, request, contentType, asset)
115
- }
116
-
117
- guessContentType(path: String): Option[String] {
118
- path.split('.').last().flatMap {
119
- | "md" => Some("text/markdown")
120
- | "png" => Some("image/png")
121
- | "webp" => Some("image/webp")
122
- | "ttf" => Some("font/ttf")
123
- | _ => None
124
- }
125
- }
126
-
127
- serveAsset(system: NodeSystem, salt: Buffer, request: WebRequest[WebResponse], contentType: String, asset: String): Unit {
128
- let etag = "\"" + system.crypto().hmacSha256(salt, asset.toBuffer()).toHex() + "\""
129
- request.writeHeader("Content-Type", contentType)
130
- if(request.readHeader("host") == Some("localhost:8080")) {
131
- request.writeHeader("Cache-Control", "no-cache")
132
- } else {
133
- request.writeHeader("Cache-Control", "public, max-age=60, must-revalidate")
134
- request.writeHeader("ETag", etag)
135
- }
136
- if(request.readHeader("if-none-match").any {_.trim() == etag}) {
137
- request.writeStatus("304 Not Modified")
138
- } else {
139
- request.writeStream(system.assets().readStream(asset))
140
- }
141
- }
142
-
143
- serveGuideHtml(title: String, contentHtml: String, styleTags: String, request: WebRequest[WebResponse]): Unit {
144
- request.writeHeader("Content-Type", "text/html; charset=UTF-8")
145
- request.writeText("<!doctype html>")
146
- request.writeText("<html lang='en' style='background-color: #ffffff; color: #333333; width: 100%; height: 100%; color-scheme: light;'>")
147
- request.writeText("<head>")
148
- request.writeText("<title>" + title + "</title>")
149
- request.writeText("<meta name='viewport' content='width=device-width, initial-scale=1.0'>")
150
- request.writeText("<meta name='theme-color' content='#ecc45e'>")
151
- request.writeText("<script type='module' src='/js/ff/fireflysite/Main.mjs'></script>")
152
- request.writeText("<link rel='preload' href='/assets/font/firefly-mono.woff2' as='font' crossorigin='anonymous'>")
153
- request.writeText("<link rel='preload' href='/assets/font/firefly-sans.woff2' as='font' crossorigin='anonymous'>")
154
- request.writeText("<link rel='preload' href='/assets/image/firefly-logo-yellow.webp' as='image'>")
155
- request.writeText("<style>@font-face { font-family: 'Firefly Mono'; font-display: fallback; src: url('/assets/font/firefly-mono.woff2'); }</style>")
156
- request.writeText("<style>@font-face { font-family: 'Firefly Sans'; font-display: fallback; src: url('/assets/font/firefly-sans.woff2'); }</style>")
157
- request.writeText(styleTags)
158
- request.writeText("</head>")
159
- request.writeText("<body style='margin: 0; padding: 0; width: 100%; height: 100%; touch-action: manipulation;'>")
160
- request.writeText("<div id='main'>" + contentHtml + "</div>")
161
- request.writeText("</body>")
162
- request.writeText("</html>")
163
- }
1
+ import WebServer from ff:webserver
2
+ import Lux from ff:lux
3
+ import Css from ff:lux
4
+ import Guide
5
+ import GettingStarted
6
+ import ReferenceAll
7
+ import ExamplesOverview
8
+ import PackagesOverview
9
+ import CommunityOverview
10
+ import FrontPage
11
+ import Styles
12
+
13
+ nodeMain(system: NodeSystem): Unit {
14
+ let host = system.arguments().grab(0)
15
+ let port = system.arguments().grab(1).grabInt()
16
+ let cacheSalt = system.crypto().randomBuffer(16)
17
+ system.writeLine("Listening on " + host + ":" + port)
18
+ WebServer.new(system, host, port).listen {request =>
19
+ let path = request.readPath()
20
+ let segments = path.split('/').filter {s => s != "" && s != "." && s != ".."}
21
+ segments.{
22
+ | _ {
23
+ !request.readHeader("host").contains("www.firefly-lang.org") &&
24
+ !request.readHeader("host").any {_.startsWith("localhost")}
25
+ } =>
26
+ let parameters = if(request.readRawQueryString().size() == 0) {""} else {
27
+ "?" + request.readRawQueryString()
28
+ }
29
+ request.writeHeader("Location", "https://www.firefly-lang.org" + path + parameters)
30
+ request.writeStatus("302 Found")
31
+ | ["js", ...] =>
32
+ let asset = if(path == "/js/ff/fireflysite/Main.mjs" && system.assets().exists("/js/Main.bundle.js")) {
33
+ "/js/Main.bundle.js"
34
+ } else {
35
+ path
36
+ }
37
+ serveAsset(system, cacheSalt, request, "text/javascript; charset=UTF-8", asset)
38
+ | ["favicon.ico"] =>
39
+ serveAsset(system, cacheSalt, request, "image/png", "/assets/image/firefly-logo-notext.png")
40
+ | ["assets", "font", "firefly-mono.woff2"] =>
41
+ serveAsset(system, cacheSalt, request, "font/woff2", "/assets/font/gf-noto-sans-mono-latin.woff2")
42
+ | ["assets", "font", "firefly-sans.woff2"] =>
43
+ serveAsset(system, cacheSalt, request, "font/woff2", "/assets/font/gf-nunito-sans-latin.woff2")
44
+ | ["assets", ...rest] => serveAssets(system, cacheSalt, request, rest)
45
+ | _ {serveGuide(system, request)} =>
46
+ | _ =>
47
+ request.writeText("404 Not Found")
48
+ request.writeStatus("404 Not Found")
49
+ }
50
+ }
51
+ }
52
+
53
+ guides = [
54
+ Guide("/front/", [FrontPage.new()])
55
+ Guide("/getting-started/", [GettingStarted.new()])
56
+ Guide("/examples/", ExamplesOverview.mock())
57
+ Guide("/reference/", ReferenceAll.mock())
58
+ Guide("/packages/", [PackagesOverview.new()])
59
+ Guide("/community/", [CommunityOverview.new()])
60
+ ]
61
+
62
+ serveGuide(system: NodeSystem, request: WebRequest[WebResponse]): Bool {
63
+ let demos = ExamplesOverview.demos()
64
+ mutable served = False
65
+ guides.each {guide =>
66
+ if(isGuidePath(request.readPath(), guide.prefix)):
67
+ let kebab = request.readPath().dropFirst(guide.prefix.size())
68
+ let htmlAndCss = Lux.renderToString(system) {lux =>
69
+ Guide.render(lux, system.httpClient(), guide.prefix, kebab, guides, demos)
70
+ }
71
+ let title = guide.documents.find {d =>
72
+ Guide.kebabCase(d.heading()) == kebab
73
+ }.map {_.title(guide)}.else {guide.title()}
74
+ serveGuideHtml(title, htmlAndCss.first, htmlAndCss.second, request)
75
+ served = True
76
+ }
77
+ served
78
+ }
79
+
80
+ browserMain(system: BrowserSystem): Unit {
81
+ let demos = ExamplesOverview.demos()
82
+ guides.collect {guide =>
83
+ if(isGuidePath(system.urlPath(), guide.prefix)):
84
+ Lux.renderById(system, "main") {lux =>
85
+ let kebab = system.urlPath().dropFirst(guide.prefix.size())
86
+ Guide.render(lux, system.httpClient(), guide.prefix, kebab, guides, demos)
87
+ }
88
+ }
89
+ }
90
+
91
+ isGuidePath(path: String, prefix: String): Bool {
92
+ //Log.debug(path + " vs. " + prefix)
93
+ path.startsWith(prefix) || (prefix == "/front/" && (path == "/" || path == "/index.html")) // Why is index.html requested
94
+ }
95
+
96
+ buildMain(system: BuildSystem) {
97
+ let browser = system.compileForBrowser("Main.ff") // .bundle()
98
+ let assets = AssetSystem.create()
99
+ .addAssets("/js/", browser.assets())
100
+ .addAssets("/assets/", system.packageAssets().assets("/assets/"))
101
+ system.setAssets(assets)
102
+ }
103
+
104
+ serveAssets(system: NodeSystem, salt: Buffer, request: WebRequest[WebResponse], segments: List[String]): Unit {
105
+ let asset = "/assets/" + segments.join("/")
106
+ if(!system.assets().exists(asset)) {
107
+ request.writeStatus("404 Not Found")
108
+ } else:
109
+
110
+ guessContentType(asset).or {
111
+ request.writeStatus("404 Not Found")
112
+ }: contentType =>
113
+
114
+ serveAsset(system, salt, request, contentType, asset)
115
+ }
116
+
117
+ guessContentType(path: String): Option[String] {
118
+ path.split('.').last().flatMap {
119
+ | "md" => Some("text/markdown")
120
+ | "png" => Some("image/png")
121
+ | "webp" => Some("image/webp")
122
+ | "ttf" => Some("font/ttf")
123
+ | _ => None
124
+ }
125
+ }
126
+
127
+ serveAsset(system: NodeSystem, salt: Buffer, request: WebRequest[WebResponse], contentType: String, asset: String): Unit {
128
+ let etag = "\"" + system.crypto().hmacSha256(salt, asset.toBuffer()).toHex() + "\""
129
+ request.writeHeader("Content-Type", contentType)
130
+ if(request.readHeader("host") == Some("localhost:8080")) {
131
+ request.writeHeader("Cache-Control", "no-cache")
132
+ } else {
133
+ request.writeHeader("Cache-Control", "public, max-age=60, must-revalidate")
134
+ request.writeHeader("ETag", etag)
135
+ }
136
+ if(request.readHeader("if-none-match").any {_.trim() == etag}) {
137
+ request.writeStatus("304 Not Modified")
138
+ } else {
139
+ request.writeStream(system.assets().readStream(asset))
140
+ }
141
+ }
142
+
143
+ serveGuideHtml(title: String, contentHtml: String, styleTags: String, request: WebRequest[WebResponse]): Unit {
144
+ request.writeHeader("Content-Type", "text/html; charset=UTF-8")
145
+ request.writeText("<!doctype html>")
146
+ request.writeText("<html lang='en' style='background-color: #ffffff; color: #333333; width: 100%; height: 100%; color-scheme: light;'>")
147
+ request.writeText("<head>")
148
+ request.writeText("<title>" + title + "</title>")
149
+ request.writeText("<meta name='viewport' content='width=device-width, initial-scale=1.0'>")
150
+ request.writeText("<meta name='theme-color' content='#ecc45e'>")
151
+ request.writeText("<script type='module' src='/js/ff/fireflysite/Main.mjs'></script>")
152
+ request.writeText("<link rel='preload' href='/assets/font/firefly-mono.woff2' as='font' crossorigin='anonymous'>")
153
+ request.writeText("<link rel='preload' href='/assets/font/firefly-sans.woff2' as='font' crossorigin='anonymous'>")
154
+ request.writeText("<link rel='preload' href='/assets/image/firefly-logo-yellow.webp' as='image'>")
155
+ request.writeText("<style>@font-face { font-family: 'Firefly Mono'; font-display: fallback; src: url('/assets/font/firefly-mono.woff2'); }</style>")
156
+ request.writeText("<style>@font-face { font-family: 'Firefly Sans'; font-display: fallback; src: url('/assets/font/firefly-sans.woff2'); }</style>")
157
+ request.writeText(styleTags)
158
+ request.writeText("</head>")
159
+ request.writeText("<body style='margin: 0; padding: 0; width: 100%; height: 100%; touch-action: manipulation;'>")
160
+ request.writeText("<div id='main'>" + contentHtml + "</div>")
161
+ request.writeText("</body>")
162
+ request.writeText("</html>")
163
+ }
@@ -1,82 +1,82 @@
1
- import Guide
2
- import Lux from ff:lux
3
- import LuxEvent from ff:lux
4
-
5
- name = "Matching passwords"
6
-
7
- new(): Demo {
8
- Demo(
9
- name
10
- {render(_)}
11
- )
12
- }
13
-
14
- render(lux: Lux): Unit {
15
- function passwordInput(password: String, setPassword: String => Unit) {
16
- lux.div {
17
- lux.input {
18
- lux.set("type", "password")
19
- lux.set("autocomplete", "new-password")
20
- lux.setValue(password)
21
- lux.onInput {event =>
22
- setPassword(event.text())
23
- }
24
- }
25
- }
26
- }
27
- lux.form {
28
- lux.useState(""): password1, setPassword1 =>
29
- lux.useState(""): password2, setPassword2 =>
30
- passwordInput(password1, setPassword1)
31
- passwordInput(password2, setPassword2)
32
- lux.div {
33
- if(password1 != password2) {
34
- lux.text("Passwords don't match!")
35
- } elseIf {password2.size() != 0} {
36
- lux.text("Passwords match!")
37
- }
38
- }
39
- }
40
- }
41
-
42
- newDocument(): Document {
43
- ReadyDocument([
44
- Section(name, [
45
- Paragraph([Text("Two passwords fields and a check that they match.")])
46
- ])
47
- Section("Demo", [
48
- LuxDemo(name)
49
- ])
50
- Section("Code", [
51
- CodeBlock("""
52
- render(lux: Lux): Unit {
53
- function passwordInput(password: String, setPassword: String => Unit) {
54
- lux.div {
55
- lux.input {
56
- lux.set("type", "password")
57
- lux.set("autocomplete", "new-password")
58
- lux.setValue(password)
59
- lux.onInput {event =>
60
- setPassword(event.text())
61
- }
62
- }
63
- }
64
- }
65
- lux.form {
66
- lux.useState(""): password1, setPassword1 =>
67
- lux.useState(""): password2, setPassword2 =>
68
- passwordInput(password1, setPassword1)
69
- passwordInput(password2, setPassword2)
70
- lux.div {
71
- if(password1 != password2) {
72
- lux.text("Passwords don't match!")
73
- } elseIf {password2.size() != 0} {
74
- lux.text("Passwords match!")
75
- }
76
- }
77
- }
78
- }
79
- """, firefly = True)
80
- ])
81
- ])
82
- }
1
+ import Guide
2
+ import Lux from ff:lux
3
+ import LuxEvent from ff:lux
4
+
5
+ name = "Matching passwords"
6
+
7
+ new(): Demo {
8
+ Demo(
9
+ name
10
+ {render(_)}
11
+ )
12
+ }
13
+
14
+ render(lux: Lux): Unit {
15
+ function passwordInput(password: String, setPassword: String => Unit) {
16
+ lux.div {
17
+ lux.input {
18
+ lux.set("type", "password")
19
+ lux.set("autocomplete", "new-password")
20
+ lux.setValue(password)
21
+ lux.onInput {event =>
22
+ setPassword(event.text())
23
+ }
24
+ }
25
+ }
26
+ }
27
+ lux.form {
28
+ lux.useState(""): password1, setPassword1 =>
29
+ lux.useState(""): password2, setPassword2 =>
30
+ passwordInput(password1, setPassword1)
31
+ passwordInput(password2, setPassword2)
32
+ lux.div {
33
+ if(password1 != password2) {
34
+ lux.text("Passwords don't match!")
35
+ } elseIf {password2.size() != 0} {
36
+ lux.text("Passwords match!")
37
+ }
38
+ }
39
+ }
40
+ }
41
+
42
+ newDocument(): Document {
43
+ ReadyDocument([
44
+ Section(name, [
45
+ Paragraph([Text("Two passwords fields and a check that they match.")])
46
+ ])
47
+ Section("Demo", [
48
+ LuxDemo(name)
49
+ ])
50
+ Section("Code", [
51
+ CodeBlock("""
52
+ render(lux: Lux): Unit {
53
+ function passwordInput(password: String, setPassword: String => Unit) {
54
+ lux.div {
55
+ lux.input {
56
+ lux.set("type", "password")
57
+ lux.set("autocomplete", "new-password")
58
+ lux.setValue(password)
59
+ lux.onInput {event =>
60
+ setPassword(event.text())
61
+ }
62
+ }
63
+ }
64
+ }
65
+ lux.form {
66
+ lux.useState(""): password1, setPassword1 =>
67
+ lux.useState(""): password2, setPassword2 =>
68
+ passwordInput(password1, setPassword1)
69
+ passwordInput(password2, setPassword2)
70
+ lux.div {
71
+ if(password1 != password2) {
72
+ lux.text("Passwords don't match!")
73
+ } elseIf {password2.size() != 0} {
74
+ lux.text("Passwords match!")
75
+ }
76
+ }
77
+ }
78
+ }
79
+ """, firefly = True)
80
+ ])
81
+ ])
82
+ }
@@ -1,49 +1,49 @@
1
- import Guide
2
- import CountingButtonDemo
3
- import MatchingPasswordsDemo
4
-
5
- new(): Document {
6
- ReadyDocument([
7
- Section("Packages", [
8
- Paragraph([
9
- Text("Here you'll eventually find the package index.")
10
- Text("For now, here's a short list of essential packages.")
11
- ])
12
- ])
13
- Section("ff:core", [
14
- Paragraph([
15
- Text("The standard library of Firefly.")
16
- ])
17
- ])
18
- Section("ff:webserver", [
19
- Paragraph([
20
- Text("A webserver package. Has HTTPS and WebSocket support.")
21
- ])
22
- ])
23
- Section("ff:websocket", [
24
- Paragraph([
25
- Text("A package for making websocket connections.")
26
- ])
27
- ])
28
- Section("ff:postgresql", [
29
- Paragraph([
30
- Text("A package for connecting to PostgreSQL. Has connection pool support.")
31
- ])
32
- ])
33
- Section("ff:lux", [
34
- Paragraph([
35
- Text("A package for building interactive web interfaces.")
36
- ])
37
- ])
38
- Section("ff:rpc", [
39
- Paragraph([
40
- Text("A package for type safe remote procedure calls.")
41
- ])
42
- ])
43
- Section("ff:unsafejs", [
44
- Paragraph([
45
- Text("A FFI package for JavaScript.")
46
- ])
47
- ])
48
- ])
49
- }
1
+ import Guide
2
+ import CountingButtonDemo
3
+ import MatchingPasswordsDemo
4
+
5
+ new(): Document {
6
+ ReadyDocument([
7
+ Section("Packages", [
8
+ Paragraph([
9
+ Text("Here you'll eventually find the package index.")
10
+ Text("For now, here's a short list of essential packages.")
11
+ ])
12
+ ])
13
+ Section("ff:core", [
14
+ Paragraph([
15
+ Text("The standard library of Firefly.")
16
+ ])
17
+ ])
18
+ Section("ff:webserver", [
19
+ Paragraph([
20
+ Text("A webserver package. Has HTTPS and WebSocket support.")
21
+ ])
22
+ ])
23
+ Section("ff:websocket", [
24
+ Paragraph([
25
+ Text("A package for making websocket connections.")
26
+ ])
27
+ ])
28
+ Section("ff:postgresql", [
29
+ Paragraph([
30
+ Text("A package for connecting to PostgreSQL. Has connection pool support.")
31
+ ])
32
+ ])
33
+ Section("ff:lux", [
34
+ Paragraph([
35
+ Text("A package for building interactive web interfaces.")
36
+ ])
37
+ ])
38
+ Section("ff:rpc", [
39
+ Paragraph([
40
+ Text("A package for type safe remote procedure calls.")
41
+ ])
42
+ ])
43
+ Section("ff:unsafejs", [
44
+ Paragraph([
45
+ Text("A FFI package for JavaScript.")
46
+ ])
47
+ ])
48
+ ])
49
+ }