elm-pages 2.1.11 → 3.0.0-beta.1

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 (161) hide show
  1. package/codegen/elm-pages-codegen.js +38507 -0
  2. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateData.elmi +0 -0
  3. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateData.elmo +0 -0
  4. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateDataTest.elmi +0 -0
  5. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateDataTest.elmo +0 -0
  6. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Reporter.elmi +0 -0
  7. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Reporter.elmo +0 -0
  8. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Runner.elmi +0 -0
  9. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Runner.elmo +0 -0
  10. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/d.dat +0 -0
  11. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/i.dat +0 -0
  12. package/generator/{template/public/style.css → dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/lock} +0 -0
  13. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/o.dat +0 -0
  14. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm.json +1 -0
  15. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/Reporter.elm.js +6795 -0
  16. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/Runner.elm.js +25651 -0
  17. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/node_runner.js +110 -0
  18. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/node_supervisor.js +187 -0
  19. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/package.json +1 -0
  20. package/generator/dead-code-review/elm-stuff/tests-0.19.1/src/Reporter.elm +26 -0
  21. package/generator/dead-code-review/elm-stuff/tests-0.19.1/src/Runner.elm +62 -0
  22. package/generator/dead-code-review/elm.json +35 -0
  23. package/generator/dead-code-review/src/Pages/Review/DeadCodeEliminateData.elm +181 -0
  24. package/generator/dead-code-review/src/ReviewConfig.elm +9 -0
  25. package/generator/dead-code-review/tests/Pages/Review/DeadCodeEliminateDataTest.elm +455 -0
  26. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Internal-RoutePattern.elmi +0 -0
  27. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Internal-RoutePattern.elmo +0 -0
  28. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-NoContractViolations.elmi +0 -0
  29. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-NoContractViolations.elmo +0 -0
  30. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-NoContractViolationsTest.elmi +0 -0
  31. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-NoContractViolationsTest.elmo +0 -0
  32. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Reporter.elmi +0 -0
  33. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Reporter.elmo +0 -0
  34. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Runner.elmi +0 -0
  35. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Runner.elmo +0 -0
  36. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/d.dat +0 -0
  37. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/i.dat +0 -0
  38. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/lock +0 -0
  39. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/o.dat +0 -0
  40. package/generator/review/elm-stuff/tests-0.19.1/elm.json +1 -0
  41. package/generator/review/elm-stuff/tests-0.19.1/js/Reporter.elm.js +6795 -0
  42. package/generator/review/elm-stuff/tests-0.19.1/js/Runner.elm.js +27617 -0
  43. package/generator/review/elm-stuff/tests-0.19.1/js/node_runner.js +110 -0
  44. package/generator/review/elm-stuff/tests-0.19.1/js/node_supervisor.js +187 -0
  45. package/generator/review/elm-stuff/tests-0.19.1/js/package.json +1 -0
  46. package/generator/review/elm-stuff/tests-0.19.1/src/Reporter.elm +26 -0
  47. package/generator/review/elm-stuff/tests-0.19.1/src/Runner.elm +62 -0
  48. package/generator/review/elm.json +13 -4
  49. package/{src → generator/review/src}/Pages/Review/NoContractViolations.elm +148 -148
  50. package/generator/review/tests/Pages/Review/NoContractViolationsTest.elm +331 -0
  51. package/generator/src/RouteBuilder.elm +420 -0
  52. package/generator/src/SharedTemplate.elm +4 -5
  53. package/generator/src/SiteConfig.elm +3 -9
  54. package/generator/src/build.js +308 -95
  55. package/generator/src/cli.js +103 -8
  56. package/generator/src/codegen.js +192 -35
  57. package/generator/src/compile-elm.js +183 -31
  58. package/generator/src/dev-server.js +353 -96
  59. package/generator/src/elm-application.json +3 -1
  60. package/generator/src/elm-codegen.js +34 -0
  61. package/generator/src/elm-file-constants.js +2 -0
  62. package/generator/src/error-formatter.js +20 -1
  63. package/generator/src/generate-template-module-connector.js +125 -927
  64. package/generator/src/hello.ts +5 -0
  65. package/generator/src/pre-render-html.js +58 -104
  66. package/generator/src/render-worker.js +27 -13
  67. package/generator/src/render.js +252 -197
  68. package/generator/src/request-cache-fs.js +18 -0
  69. package/generator/src/request-cache.js +128 -56
  70. package/generator/src/rewrite-client-elm-json.js +49 -0
  71. package/generator/src/route-codegen-helpers.js +62 -1
  72. package/generator/static-code/dev-style.css +22 -0
  73. package/generator/static-code/elm-pages.js +43 -39
  74. package/generator/static-code/hmr.js +98 -88
  75. package/generator/template/app/Api.elm +25 -0
  76. package/generator/template/app/ErrorPage.elm +38 -0
  77. package/generator/template/app/Route/Index.elm +87 -0
  78. package/generator/template/{src → app}/Shared.elm +34 -13
  79. package/generator/template/app/Site.elm +19 -0
  80. package/generator/template/{src → app}/View.elm +0 -0
  81. package/generator/template/elm-pages.config.mjs +5 -0
  82. package/generator/template/elm.json +1 -0
  83. package/generator/template/{public/index.js → index.ts} +7 -3
  84. package/generator/template/package.json +4 -4
  85. package/generator/template/public/favicon.ico +0 -0
  86. package/generator/template/public/images/icon-png.png +0 -0
  87. package/generator/template/src/.gitkeep +0 -0
  88. package/generator/template/style.css +4 -0
  89. package/package.json +33 -23
  90. package/src/ApiRoute.elm +176 -43
  91. package/src/BuildError.elm +10 -1
  92. package/src/CookieParser.elm +84 -0
  93. package/src/DataSource/Env.elm +38 -0
  94. package/src/DataSource/File.elm +27 -16
  95. package/src/DataSource/Glob.elm +126 -80
  96. package/src/DataSource/Http.elm +283 -304
  97. package/src/DataSource/Internal/Glob.elm +5 -21
  98. package/src/DataSource/Internal/Request.elm +25 -0
  99. package/src/DataSource/Port.elm +17 -14
  100. package/src/DataSource.elm +55 -318
  101. package/src/Form/Field.elm +717 -0
  102. package/src/Form/FieldStatus.elm +36 -0
  103. package/src/Form/FieldView.elm +417 -0
  104. package/src/Form/FormData.elm +22 -0
  105. package/src/Form/Validation.elm +391 -0
  106. package/src/Form/Value.elm +118 -0
  107. package/src/Form.elm +1683 -0
  108. package/src/FormData.elm +58 -0
  109. package/src/FormDecoder.elm +102 -0
  110. package/src/Head/Seo.elm +12 -4
  111. package/src/Head.elm +12 -2
  112. package/src/HtmlPrinter.elm +1 -1
  113. package/src/Internal/ApiRoute.elm +17 -4
  114. package/src/Internal/Request.elm +7 -0
  115. package/src/PageServerResponse.elm +68 -0
  116. package/src/Pages/ContentCache.elm +1 -229
  117. package/src/Pages/Fetcher.elm +58 -0
  118. package/src/Pages/FormState.elm +256 -0
  119. package/src/Pages/Generate.elm +800 -0
  120. package/src/Pages/Internal/Form.elm +17 -0
  121. package/src/Pages/Internal/NotFoundReason.elm +3 -55
  122. package/src/Pages/Internal/Platform/Cli.elm +777 -579
  123. package/src/Pages/Internal/Platform/Effect.elm +5 -5
  124. package/src/Pages/Internal/Platform/StaticResponses.elm +178 -394
  125. package/src/Pages/Internal/Platform/ToJsPayload.elm +24 -23
  126. package/src/Pages/Internal/Platform.elm +1244 -504
  127. package/src/Pages/Internal/ResponseSketch.elm +19 -0
  128. package/src/Pages/Internal/RoutePattern.elm +596 -45
  129. package/src/Pages/Manifest.elm +26 -0
  130. package/src/Pages/Msg.elm +79 -0
  131. package/src/Pages/ProgramConfig.elm +67 -14
  132. package/src/Pages/SiteConfig.elm +3 -6
  133. package/src/Pages/StaticHttp/Request.elm +4 -2
  134. package/src/Pages/StaticHttpRequest.elm +50 -215
  135. package/src/Pages/Transition.elm +70 -0
  136. package/src/Path.elm +1 -0
  137. package/src/Pattern.elm +98 -0
  138. package/src/RenderRequest.elm +2 -2
  139. package/src/RequestsAndPending.elm +111 -9
  140. package/src/Server/Request.elm +1253 -0
  141. package/src/Server/Response.elm +292 -0
  142. package/src/Server/Session.elm +316 -0
  143. package/src/Server/SetCookie.elm +169 -0
  144. package/src/TerminalText.elm +1 -1
  145. package/src/Test/Html/Internal/ElmHtml/Markdown.elm +0 -1
  146. package/src/Test/Html/Internal/ElmHtml/ToString.elm +1 -1
  147. package/generator/src/Page.elm +0 -359
  148. package/generator/src/codegen-template-module.js +0 -183
  149. package/generator/src/elm-pages-js-minified.js +0 -1
  150. package/generator/template/src/Api.elm +0 -14
  151. package/generator/template/src/Page/Index.elm +0 -69
  152. package/generator/template/src/Site.elm +0 -41
  153. package/src/DataSource/ServerRequest.elm +0 -60
  154. package/src/Internal/OptimizedDecoder.elm +0 -18
  155. package/src/KeepOrDiscard.elm +0 -6
  156. package/src/OptimizedDecoder/Pipeline.elm +0 -335
  157. package/src/OptimizedDecoder.elm +0 -818
  158. package/src/Pages/Internal/ApplicationType.elm +0 -6
  159. package/src/Pages/Secrets.elm +0 -83
  160. package/src/Secrets.elm +0 -111
  161. package/src/SecretsDict.elm +0 -45
@@ -0,0 +1,455 @@
1
+ module Pages.Review.DeadCodeEliminateDataTest exposing (all)
2
+
3
+ import Pages.Review.DeadCodeEliminateData exposing (rule)
4
+ import Review.Test
5
+ import Test exposing (Test, describe, test)
6
+
7
+
8
+ all : Test
9
+ all =
10
+ describe "dead code elimination"
11
+ [ test "replaces data record setter" <|
12
+ \() ->
13
+ """module Route.Index exposing (Data, Model, Msg, route)
14
+
15
+ import DataSource exposing (DataSource)
16
+ import RouteBuilder exposing (Page, StaticPayload, single)
17
+ import Pages.PageUrl exposing (PageUrl)
18
+ import Pages.Url
19
+ import Path
20
+ import Route exposing (Route)
21
+ import Shared
22
+ import View exposing (View)
23
+
24
+
25
+ type alias Model =
26
+ {}
27
+
28
+
29
+ type alias Msg =
30
+ ()
31
+
32
+
33
+ type alias RouteParams =
34
+ {}
35
+
36
+
37
+ type alias Data =
38
+ ()
39
+
40
+
41
+ route : StatelessRoute RouteParams Data ActionData
42
+ route =
43
+ single
44
+ { head = head
45
+ , data = data
46
+ }
47
+ |> RouteBuilder.buildNoState { view = view }
48
+
49
+
50
+ data : DataSource Data
51
+ data =
52
+ DataSource.succeed ()
53
+ """
54
+ |> Review.Test.run rule
55
+ |> Review.Test.expectErrors
56
+ [ Review.Test.error
57
+ { message = "Codemod"
58
+ , details =
59
+ [ "" ]
60
+ , under =
61
+ """data = data
62
+ }"""
63
+ }
64
+ |> Review.Test.whenFixed
65
+ """module Route.Index exposing (Data, Model, Msg, route)
66
+
67
+ import DataSource exposing (DataSource)
68
+ import RouteBuilder exposing (Page, StaticPayload, single)
69
+ import Pages.PageUrl exposing (PageUrl)
70
+ import Pages.Url
71
+ import Path
72
+ import Route exposing (Route)
73
+ import Shared
74
+ import View exposing (View)
75
+
76
+
77
+ type alias Model =
78
+ {}
79
+
80
+
81
+ type alias Msg =
82
+ ()
83
+
84
+
85
+ type alias RouteParams =
86
+ {}
87
+
88
+
89
+ type alias Data =
90
+ ()
91
+
92
+
93
+ route : StatelessRoute RouteParams Data ActionData
94
+ route =
95
+ single
96
+ { head = head
97
+ , data = DataSource.fail ""
98
+ }
99
+ |> RouteBuilder.buildNoState { view = view }
100
+
101
+
102
+ data : DataSource Data
103
+ data =
104
+ DataSource.succeed ()
105
+ """
106
+ ]
107
+ , test "replaces data record setter with non-empty RouteParams" <|
108
+ \() ->
109
+ """module Route.Blog.Slug_ exposing (Data, Model, Msg, route)
110
+
111
+ import DataSource exposing (DataSource)
112
+ import RouteBuilder exposing (Page, StaticPayload)
113
+ import Pages.PageUrl exposing (PageUrl)
114
+ import Pages.Url
115
+ import Path
116
+ import Route exposing (Route)
117
+ import Shared
118
+ import View exposing (View)
119
+
120
+
121
+ type alias Model =
122
+ {}
123
+
124
+
125
+ type alias Msg =
126
+ ()
127
+
128
+
129
+ type alias RouteParams =
130
+ { slug : String }
131
+
132
+
133
+ type alias Data =
134
+ ()
135
+
136
+
137
+ route : StatelessRoute RouteParams Data ActionData
138
+ route =
139
+ RouteBuilder.preRender
140
+ { data = data
141
+ , head = head
142
+ , pages = pages
143
+ }
144
+ |> RouteBuilder.buildNoState { view = view }
145
+
146
+
147
+ data : DataSource Data
148
+ data =
149
+ DataSource.succeed ()
150
+ """
151
+ |> Review.Test.run rule
152
+ |> Review.Test.expectErrors
153
+ [ Review.Test.error
154
+ { message = "Codemod"
155
+ , details =
156
+ [ "" ]
157
+ , under =
158
+ """data = data"""
159
+ }
160
+ |> Review.Test.whenFixed
161
+ """module Route.Blog.Slug_ exposing (Data, Model, Msg, route)
162
+
163
+ import DataSource exposing (DataSource)
164
+ import RouteBuilder exposing (Page, StaticPayload)
165
+ import Pages.PageUrl exposing (PageUrl)
166
+ import Pages.Url
167
+ import Path
168
+ import Route exposing (Route)
169
+ import Shared
170
+ import View exposing (View)
171
+
172
+
173
+ type alias Model =
174
+ {}
175
+
176
+
177
+ type alias Msg =
178
+ ()
179
+
180
+
181
+ type alias RouteParams =
182
+ { slug : String }
183
+
184
+
185
+ type alias Data =
186
+ ()
187
+
188
+
189
+ route : StatelessRoute RouteParams Data ActionData
190
+ route =
191
+ RouteBuilder.preRender
192
+ { data = \\_ -> DataSource.fail ""
193
+ , head = head
194
+ , pages = pages
195
+ }
196
+ |> RouteBuilder.buildNoState { view = view }
197
+
198
+
199
+ data : DataSource Data
200
+ data =
201
+ DataSource.succeed ()
202
+ """
203
+ ]
204
+ , test "replaces data record setter with RouteBuilder.serverRendered" <|
205
+ \() ->
206
+ """module Route.Login exposing (Data, Model, Msg, route)
207
+
208
+ type alias Model =
209
+ {}
210
+
211
+
212
+ type alias Msg =
213
+ ()
214
+
215
+
216
+ type alias RouteParams =
217
+ {}
218
+
219
+
220
+ route : StatelessRoute RouteParams Data ActionData
221
+ route =
222
+ RouteBuilder.serverRender
223
+ { head = head
224
+ , data = data
225
+ , action = action
226
+ }
227
+ |> RouteBuilder.buildNoState { view = view }
228
+ """
229
+ |> Review.Test.run rule
230
+ |> Review.Test.expectErrors
231
+ [ Review.Test.error
232
+ { message = "Codemod"
233
+ , details =
234
+ [ "" ]
235
+ , under =
236
+ """data = data
237
+ ,"""
238
+ }
239
+ |> Review.Test.whenFixed
240
+ """module Route.Login exposing (Data, Model, Msg, route)
241
+
242
+ type alias Model =
243
+ {}
244
+
245
+
246
+ type alias Msg =
247
+ ()
248
+
249
+
250
+ type alias RouteParams =
251
+ {}
252
+
253
+
254
+ route : StatelessRoute RouteParams Data ActionData
255
+ route =
256
+ RouteBuilder.serverRender
257
+ { head = head
258
+ , data = \\_ -> Request.oneOf []
259
+ , action = action
260
+ }
261
+ |> RouteBuilder.buildNoState { view = view }
262
+ """
263
+ , Review.Test.error
264
+ { message = "Codemod"
265
+ , details =
266
+ [ "" ]
267
+ , under =
268
+ """action = action
269
+ }"""
270
+ }
271
+ |> Review.Test.whenFixed
272
+ """module Route.Login exposing (Data, Model, Msg, route)
273
+
274
+ type alias Model =
275
+ {}
276
+
277
+
278
+ type alias Msg =
279
+ ()
280
+
281
+
282
+ type alias RouteParams =
283
+ {}
284
+
285
+
286
+ route : StatelessRoute RouteParams Data ActionData
287
+ route =
288
+ RouteBuilder.serverRender
289
+ { head = head
290
+ , data = data
291
+ , action = \\_ -> Request.oneOf []
292
+ }
293
+ |> RouteBuilder.buildNoState { view = view }
294
+ """
295
+ ]
296
+ , test "no Request.oneOf fix after replacement is made" <|
297
+ \() ->
298
+ """module Route.Login exposing (Data, Model, Msg, route)
299
+
300
+ type alias Model =
301
+ {}
302
+
303
+
304
+ type alias Msg =
305
+ ()
306
+
307
+
308
+ type alias RouteParams =
309
+ {}
310
+
311
+
312
+ route : StatelessRoute RouteParams Data ActionData
313
+ route =
314
+ RouteBuilder.serverRender
315
+ { head = head
316
+ , data = \\_ -> Request.oneOf []
317
+ }
318
+ |> RouteBuilder.buildNoState { view = view }
319
+ """
320
+ |> Review.Test.run rule
321
+ |> Review.Test.expectNoErrors
322
+ , test "no fix after replacement is made" <|
323
+ \() ->
324
+ """module Route.Index exposing (Data, Model, Msg, route)
325
+
326
+ import DataSource exposing (DataSource)
327
+ import RouteBuilder exposing (Page, StaticPayload)
328
+ import Pages.PageUrl exposing (PageUrl)
329
+ import Pages.Url
330
+ import Path
331
+ import Route exposing (Route)
332
+ import Shared
333
+ import View exposing (View)
334
+
335
+
336
+ type alias Model =
337
+ {}
338
+
339
+
340
+ type alias Msg =
341
+ ()
342
+
343
+
344
+ type alias RouteParams =
345
+ {}
346
+
347
+
348
+ type alias Data =
349
+ ()
350
+
351
+
352
+ route : StatelessRoute RouteParams Data ActionData
353
+ route =
354
+ RouteBuilder.single
355
+ { head = head
356
+ , data = DataSource.fail ""
357
+ }
358
+ |> RouteBuilder.buildNoState { view = view }
359
+
360
+
361
+ data : DataSource Data
362
+ data =
363
+ DataSource.succeed ()
364
+ """
365
+ |> Review.Test.run rule
366
+ |> Review.Test.expectNoErrors
367
+ , test "replaces data record setter in Shared module" <|
368
+ \() ->
369
+ """module Shared exposing (Data, Model, Msg, template)
370
+
371
+ import Browser.Navigation
372
+ import DataSource
373
+ import Html exposing (Html)
374
+ import Html.Styled
375
+ import Pages.Flags
376
+ import Pages.PageUrl exposing (PageUrl)
377
+ import Path exposing (Path)
378
+ import Route exposing (Route)
379
+ import SharedTemplate exposing (SharedTemplate)
380
+ import TableOfContents
381
+ import View exposing (View)
382
+ import View.Header
383
+
384
+
385
+ template : SharedTemplate Msg Model Data msg
386
+ template =
387
+ { init = init
388
+ , update = update
389
+ , view = view
390
+ , data = data
391
+ , subscriptions = subscriptions
392
+ , onPageChange = Just OnPageChange
393
+ }
394
+
395
+
396
+ type alias Data =
397
+ TableOfContents.TableOfContents TableOfContents.Data
398
+
399
+
400
+ type alias Model =
401
+ { showMobileMenu : Bool
402
+ , counter : Int
403
+ , navigationKey : Maybe Browser.Navigation.Key
404
+ }
405
+ """
406
+ |> Review.Test.run rule
407
+ |> Review.Test.expectErrors
408
+ [ Review.Test.error
409
+ { message = "Codemod"
410
+ , details =
411
+ [ "" ]
412
+ , under =
413
+ """data = data
414
+ ,"""
415
+ }
416
+ |> Review.Test.whenFixed
417
+ """module Shared exposing (Data, Model, Msg, template)
418
+
419
+ import Browser.Navigation
420
+ import DataSource
421
+ import Html exposing (Html)
422
+ import Html.Styled
423
+ import Pages.Flags
424
+ import Pages.PageUrl exposing (PageUrl)
425
+ import Path exposing (Path)
426
+ import Route exposing (Route)
427
+ import SharedTemplate exposing (SharedTemplate)
428
+ import TableOfContents
429
+ import View exposing (View)
430
+ import View.Header
431
+
432
+
433
+ template : SharedTemplate Msg Model Data msg
434
+ template =
435
+ { init = init
436
+ , update = update
437
+ , view = view
438
+ , data = DataSource.fail ""
439
+ , subscriptions = subscriptions
440
+ , onPageChange = Just OnPageChange
441
+ }
442
+
443
+
444
+ type alias Data =
445
+ TableOfContents.TableOfContents TableOfContents.Data
446
+
447
+
448
+ type alias Model =
449
+ { showMobileMenu : Bool
450
+ , counter : Int
451
+ , navigationKey : Maybe Browser.Navigation.Key
452
+ }
453
+ """
454
+ ]
455
+ ]
@@ -0,0 +1 @@
1
+ {"type":"application","source-directories":["../../src","../../tests","../../../../src","src"],"elm-version":"0.19.1","dependencies":{"direct":{"elm/core":"1.0.5","elm/html":"1.0.0","elm/json":"1.1.3","elm/regex":"1.0.0","elm-community/result-extra":"2.4.0","elm-explorations/test":"1.2.2","jfmengels/elm-review":"2.4.2","mdgriffith/elm-codegen":"2.0.0","mpizenberg/elm-test-runner":"5.0.0","stil4m/elm-syntax":"7.2.5","the-sett/elm-syntax-dsl":"6.0.2"},"indirect":{"Chadtech/elm-bool-extra":"2.4.2","elm/parser":"1.1.0","elm/project-metadata-utils":"1.0.2","elm/random":"1.0.0","elm/time":"1.0.0","elm/virtual-dom":"1.0.3","elm-community/basics-extra":"4.1.0","elm-community/list-extra":"8.6.0","elm-community/maybe-extra":"5.3.0","miniBill/elm-unicode":"1.0.2","rtfeldman/elm-hex":"1.0.0","stil4m/structured-writer":"1.0.3","the-sett/elm-pretty-printer":"3.0.0"}},"test-dependencies":{"direct":{},"indirect":{}}}