elm-pages 3.0.0-beta.32 → 3.0.0-beta.34

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 (42) hide show
  1. package/README.md +1 -1
  2. package/codegen/elm-pages-codegen.cjs +10 -78
  3. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/d.dat +0 -0
  4. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/node_runner.js +1 -1
  5. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/node_supervisor.js +1 -1
  6. package/generator/dead-code-review/elm.json +1 -1
  7. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/d.dat +0 -0
  8. package/generator/review/elm-stuff/tests-0.19.1/js/node_runner.js +1 -1
  9. package/generator/review/elm-stuff/tests-0.19.1/js/node_supervisor.js +1 -1
  10. package/generator/review/elm.json +1 -1
  11. package/generator/src/RouteBuilder.elm +2 -2
  12. package/generator/src/compatibility-key.js +2 -2
  13. package/generator/src/render.js +1 -0
  14. package/generator/src/request-cache.js +20 -6
  15. package/generator/static-code/elm-pages.js +10 -0
  16. package/package.json +3 -3
  17. package/src/BackendTask/Http.elm +8 -2
  18. package/src/Internal/Field.elm +19 -0
  19. package/src/Internal/Input.elm +81 -0
  20. package/src/Pages/Form.elm +229 -0
  21. package/src/Pages/Internal/Msg.elm +70 -61
  22. package/src/Pages/Internal/Platform/Cli.elm +423 -425
  23. package/src/Pages/Internal/Platform/CompatibilityKey.elm +1 -1
  24. package/src/Pages/Internal/Platform/GeneratorApplication.elm +1 -5
  25. package/src/Pages/Internal/Platform.elm +119 -100
  26. package/src/Pages/ProgramConfig.elm +12 -5
  27. package/src/Pages/StaticHttpRequest.elm +0 -1
  28. package/src/Pages/Transition.elm +9 -1
  29. package/src/PagesMsg.elm +0 -10
  30. package/src/RequestsAndPending.elm +31 -3
  31. package/src/Scaffold/Form.elm +9 -9
  32. package/src/Server/Request.elm +57 -61
  33. package/src/Form/Field.elm +0 -729
  34. package/src/Form/FieldStatus.elm +0 -36
  35. package/src/Form/FieldView.elm +0 -497
  36. package/src/Form/FormData.elm +0 -22
  37. package/src/Form/Validation.elm +0 -391
  38. package/src/Form/Value.elm +0 -118
  39. package/src/Form.elm +0 -1558
  40. package/src/FormDecoder.elm +0 -102
  41. package/src/Pages/FormState.elm +0 -257
  42. package/src/Pages/Internal/Form.elm +0 -37
@@ -1,391 +0,0 @@
1
- module Form.Validation exposing
2
- ( Combined, Field, Validation
3
- , andMap, andThen, fail, fromMaybe, fromResult, map, map2, parseWithError, succeed, succeed2, withError, withErrorIf, withFallback
4
- , value, fieldName, fieldStatus
5
- , map3, map4, map5, map6, map7, map8, map9
6
- , global
7
- , mapWithNever
8
- )
9
-
10
- {-|
11
-
12
-
13
- ## Validations
14
-
15
- @docs Combined, Field, Validation
16
-
17
- @docs andMap, andThen, fail, fromMaybe, fromResult, map, map2, parseWithError, succeed, succeed2, withError, withErrorIf, withFallback
18
-
19
-
20
- ## Field Metadata
21
-
22
- @docs value, fieldName, fieldStatus
23
-
24
-
25
- ## Mapping
26
-
27
- @docs map3, map4, map5, map6, map7, map8, map9
28
-
29
-
30
- ## Global Validation
31
-
32
- @docs global
33
-
34
-
35
- ## Temporary?
36
-
37
- @docs mapWithNever
38
-
39
- -}
40
-
41
- import Dict exposing (Dict)
42
- import Form.FieldStatus exposing (FieldStatus)
43
- import Pages.Internal.Form exposing (ViewField)
44
-
45
-
46
- {-| -}
47
- type alias Combined error parsed =
48
- Validation error parsed Never Never
49
-
50
-
51
- {-| -}
52
- type alias Field error parsed kind =
53
- Validation error parsed kind { field : kind }
54
-
55
-
56
- {-| -}
57
- type alias Validation error parsed kind constraints =
58
- Pages.Internal.Form.Validation error parsed kind constraints
59
-
60
-
61
- {-| -}
62
- fieldName : Field error parsed kind -> String
63
- fieldName (Pages.Internal.Form.Validation _ name _) =
64
- name
65
- |> Maybe.withDefault ""
66
-
67
-
68
- {-| -}
69
- fieldStatus : Field error parsed kind -> FieldStatus
70
- fieldStatus (Pages.Internal.Form.Validation viewField _ _) =
71
- viewField
72
- |> expectViewField
73
- |> .status
74
-
75
-
76
- expectViewField : Maybe (ViewField kind) -> ViewField kind
77
- expectViewField viewField =
78
- case viewField of
79
- Just justViewField ->
80
- justViewField
81
-
82
- Nothing ->
83
- expectViewField viewField
84
-
85
-
86
- {-| -}
87
- succeed : parsed -> Combined error parsed
88
- succeed parsed =
89
- Pages.Internal.Form.Validation Nothing Nothing ( Just parsed, Dict.empty )
90
-
91
-
92
- {-| -}
93
- succeed2 : parsed -> Validation error parsed kind constraints
94
- succeed2 parsed =
95
- Pages.Internal.Form.Validation Nothing Nothing ( Just parsed, Dict.empty )
96
-
97
-
98
- {-| -}
99
- global : Field error () Never
100
- global =
101
- Pages.Internal.Form.Validation Nothing
102
- (Just "$$global$$")
103
- ( Just ()
104
- , Dict.empty
105
- )
106
-
107
-
108
- {-| -}
109
- withFallback : parsed -> Validation error parsed named constraints -> Validation error parsed named constraints
110
- withFallback parsed (Pages.Internal.Form.Validation viewField name ( maybeParsed, errors )) =
111
- Pages.Internal.Form.Validation viewField
112
- name
113
- ( maybeParsed
114
- |> Maybe.withDefault parsed
115
- |> Just
116
- , errors
117
- )
118
-
119
-
120
- {-| -}
121
- value : Validation error parsed named constraint -> Maybe parsed
122
- value (Pages.Internal.Form.Validation _ _ ( maybeParsed, _ )) =
123
- maybeParsed
124
-
125
-
126
- {-| -}
127
- parseWithError : parsed -> ( String, error ) -> Combined error parsed
128
- parseWithError parsed ( key, error ) =
129
- Pages.Internal.Form.Validation Nothing Nothing ( Just parsed, Dict.singleton key [ error ] )
130
-
131
-
132
- {-| -}
133
- fail : error -> Field error parsed1 field -> Combined error parsed
134
- fail parsed (Pages.Internal.Form.Validation _ key _) =
135
- Pages.Internal.Form.Validation Nothing Nothing ( Nothing, Dict.singleton (key |> Maybe.withDefault "") [ parsed ] )
136
-
137
-
138
- {-| -}
139
- withError : Field error parsed1 field -> error -> Validation error parsed2 named constraints -> Validation error parsed2 named constraints
140
- withError (Pages.Internal.Form.Validation _ key _) error (Pages.Internal.Form.Validation viewField name ( maybeParsedA, errorsA )) =
141
- Pages.Internal.Form.Validation viewField name ( maybeParsedA, errorsA |> insertIfNonempty (key |> Maybe.withDefault "") [ error ] )
142
-
143
-
144
- {-| -}
145
- withErrorIf : Bool -> Field error ignored field -> error -> Validation error parsed named constraints -> Validation error parsed named constraints
146
- withErrorIf includeError (Pages.Internal.Form.Validation _ key _) error (Pages.Internal.Form.Validation viewField name ( maybeParsedA, errorsA )) =
147
- Pages.Internal.Form.Validation viewField
148
- name
149
- ( maybeParsedA
150
- , if includeError then
151
- errorsA |> insertIfNonempty (key |> Maybe.withDefault "") [ error ]
152
-
153
- else
154
- errorsA
155
- )
156
-
157
-
158
-
159
- --map : (parsed -> mapped) -> Validation error parsed named -> Validation error mapped named
160
-
161
-
162
- {-| -}
163
- map : (parsed -> mapped) -> Validation error parsed named constraint -> Validation error mapped named constraint
164
- map mapFn (Pages.Internal.Form.Validation _ name ( maybeParsedA, errorsA )) =
165
- Pages.Internal.Form.Validation Nothing name ( Maybe.map mapFn maybeParsedA, errorsA )
166
-
167
-
168
- {-| -}
169
- mapWithNever : (parsed -> mapped) -> Validation error parsed named constraint -> Validation error mapped Never Never
170
- mapWithNever mapFn (Pages.Internal.Form.Validation _ name ( maybeParsedA, errorsA )) =
171
- Pages.Internal.Form.Validation Nothing name ( Maybe.map mapFn maybeParsedA, errorsA )
172
-
173
-
174
- {-| -}
175
- fromResult : Field error (Result error parsed) kind -> Combined error parsed
176
- fromResult fieldResult =
177
- fieldResult
178
- |> andThen
179
- (\parsedValue ->
180
- case parsedValue of
181
- Ok okValue ->
182
- succeed okValue
183
-
184
- Err error ->
185
- fail error fieldResult
186
- )
187
-
188
-
189
- {-| -}
190
- andMap : Validation error a named1 constraints1 -> Validation error (a -> b) named2 constraints2 -> Combined error b
191
- andMap =
192
- map2 (|>)
193
-
194
-
195
- {-| -}
196
- andThen : (parsed -> Validation error mapped named1 constraints1) -> Validation error parsed named2 constraints2 -> Combined error mapped
197
- andThen andThenFn (Pages.Internal.Form.Validation _ _ ( maybeParsed, errors )) =
198
- case maybeParsed of
199
- Just parsed ->
200
- andThenFn parsed
201
- |> (\(Pages.Internal.Form.Validation _ _ ( andThenParsed, andThenErrors )) ->
202
- Pages.Internal.Form.Validation Nothing Nothing ( andThenParsed, mergeErrors errors andThenErrors )
203
- )
204
-
205
- Nothing ->
206
- Pages.Internal.Form.Validation Nothing Nothing ( Nothing, errors )
207
-
208
-
209
- {-| -}
210
- map2 : (a -> b -> c) -> Validation error a named1 constraints1 -> Validation error b named2 constraints2 -> Combined error c
211
- map2 f (Pages.Internal.Form.Validation _ _ ( maybeParsedA, errorsA )) (Pages.Internal.Form.Validation _ _ ( maybeParsedB, errorsB )) =
212
- Pages.Internal.Form.Validation Nothing
213
- Nothing
214
- ( Maybe.map2 f maybeParsedA maybeParsedB
215
- , mergeErrors errorsA errorsB
216
- )
217
-
218
-
219
- {-| -}
220
- map3 :
221
- (a1 -> a2 -> a3 -> a4)
222
- -> Validation error a1 named1 constraints1
223
- -> Validation error a2 named2 constraints2
224
- -> Validation error a3 named3 constraints3
225
- -> Combined error a4
226
- map3 f validation1 validation2 validation3 =
227
- succeed f
228
- |> andMap validation1
229
- |> andMap validation2
230
- |> andMap validation3
231
-
232
-
233
- {-| -}
234
- map4 :
235
- (a1 -> a2 -> a3 -> a4 -> a5)
236
- -> Validation error a1 named1 constraints1
237
- -> Validation error a2 named2 constraints2
238
- -> Validation error a3 named3 constraints3
239
- -> Validation error a4 named4 constraints4
240
- -> Combined error a5
241
- map4 f validation1 validation2 validation3 validation4 =
242
- succeed f
243
- |> andMap validation1
244
- |> andMap validation2
245
- |> andMap validation3
246
- |> andMap validation4
247
-
248
-
249
- {-| -}
250
- map5 :
251
- (a1 -> a2 -> a3 -> a4 -> a5 -> a6)
252
- -> Validation error a1 named1 constraints1
253
- -> Validation error a2 named2 constraints2
254
- -> Validation error a3 named3 constraints3
255
- -> Validation error a4 named4 constraints4
256
- -> Validation error a5 named5 constraints5
257
- -> Combined error a6
258
- map5 f validation1 validation2 validation3 validation4 validation5 =
259
- succeed f
260
- |> andMap validation1
261
- |> andMap validation2
262
- |> andMap validation3
263
- |> andMap validation4
264
- |> andMap validation5
265
-
266
-
267
- {-| -}
268
- map6 :
269
- (a1 -> a2 -> a3 -> a4 -> a5 -> a6 -> a7)
270
- -> Validation error a1 named1 constraints1
271
- -> Validation error a2 named2 constraints2
272
- -> Validation error a3 named3 constraints3
273
- -> Validation error a4 named4 constraints4
274
- -> Validation error a5 named5 constraints5
275
- -> Validation error a6 named6 constraints6
276
- -> Combined error a7
277
- map6 f validation1 validation2 validation3 validation4 validation5 validation6 =
278
- succeed f
279
- |> andMap validation1
280
- |> andMap validation2
281
- |> andMap validation3
282
- |> andMap validation4
283
- |> andMap validation5
284
- |> andMap validation6
285
-
286
-
287
- {-| -}
288
- map7 :
289
- (a1 -> a2 -> a3 -> a4 -> a5 -> a6 -> a7 -> a8)
290
- -> Validation error a1 named1 constraints1
291
- -> Validation error a2 named2 constraints2
292
- -> Validation error a3 named3 constraints3
293
- -> Validation error a4 named4 constraints4
294
- -> Validation error a5 named5 constraints5
295
- -> Validation error a6 named6 constraints6
296
- -> Validation error a7 named7 constraints7
297
- -> Combined error a8
298
- map7 f validation1 validation2 validation3 validation4 validation5 validation6 validation7 =
299
- succeed f
300
- |> andMap validation1
301
- |> andMap validation2
302
- |> andMap validation3
303
- |> andMap validation4
304
- |> andMap validation5
305
- |> andMap validation6
306
- |> andMap validation7
307
-
308
-
309
- {-| -}
310
- map8 :
311
- (a1 -> a2 -> a3 -> a4 -> a5 -> a6 -> a7 -> a8 -> a9)
312
- -> Validation error a1 named1 constraints1
313
- -> Validation error a2 named2 constraints2
314
- -> Validation error a3 named3 constraints3
315
- -> Validation error a4 named4 constraints4
316
- -> Validation error a5 named5 constraints5
317
- -> Validation error a6 named6 constraints6
318
- -> Validation error a7 named7 constraints7
319
- -> Validation error a8 named8 constraints8
320
- -> Combined error a9
321
- map8 f validation1 validation2 validation3 validation4 validation5 validation6 validation7 validation8 =
322
- succeed f
323
- |> andMap validation1
324
- |> andMap validation2
325
- |> andMap validation3
326
- |> andMap validation4
327
- |> andMap validation5
328
- |> andMap validation6
329
- |> andMap validation7
330
- |> andMap validation8
331
-
332
-
333
- {-| -}
334
- map9 :
335
- (a1 -> a2 -> a3 -> a4 -> a5 -> a6 -> a7 -> a8 -> a9 -> a10)
336
- -> Validation error a1 named1 constraints1
337
- -> Validation error a2 named2 constraints2
338
- -> Validation error a3 named3 constraints3
339
- -> Validation error a4 named4 constraints4
340
- -> Validation error a5 named5 constraints5
341
- -> Validation error a6 named6 constraints6
342
- -> Validation error a7 named7 constraints7
343
- -> Validation error a8 named8 constraints8
344
- -> Validation error a9 named9 constraints9
345
- -> Combined error a10
346
- map9 f validation1 validation2 validation3 validation4 validation5 validation6 validation7 validation8 validation9 =
347
- succeed f
348
- |> andMap validation1
349
- |> andMap validation2
350
- |> andMap validation3
351
- |> andMap validation4
352
- |> andMap validation5
353
- |> andMap validation6
354
- |> andMap validation7
355
- |> andMap validation8
356
- |> andMap validation9
357
-
358
-
359
- {-| -}
360
- fromMaybe : Maybe parsed -> Combined error parsed
361
- fromMaybe maybe =
362
- Pages.Internal.Form.Validation Nothing Nothing ( maybe, Dict.empty )
363
-
364
-
365
- {-| -}
366
- mergeErrors : Dict comparable (List value) -> Dict comparable (List value) -> Dict comparable (List value)
367
- mergeErrors errors1 errors2 =
368
- Dict.merge
369
- (\key entries soFar ->
370
- soFar |> insertIfNonempty key entries
371
- )
372
- (\key entries1 entries2 soFar ->
373
- soFar |> insertIfNonempty key (entries1 ++ entries2)
374
- )
375
- (\key entries soFar ->
376
- soFar |> insertIfNonempty key entries
377
- )
378
- errors1
379
- errors2
380
- Dict.empty
381
-
382
-
383
- {-| -}
384
- insertIfNonempty : comparable -> List value -> Dict comparable (List value) -> Dict comparable (List value)
385
- insertIfNonempty key values dict =
386
- if values |> List.isEmpty then
387
- dict
388
-
389
- else
390
- dict
391
- |> Dict.insert key values
@@ -1,118 +0,0 @@
1
- module Form.Value exposing
2
- ( Value, date, float, int, string, bool, toString
3
- , compare
4
- )
5
-
6
- {-|
7
-
8
- @docs Value, date, float, int, string, bool, toString
9
-
10
-
11
- ## Comparison
12
-
13
- @docs compare
14
-
15
- -}
16
-
17
- import Date exposing (Date)
18
-
19
-
20
- type Kind
21
- = StringValue
22
- | DateValue
23
- | IntValue
24
- | FloatValue
25
- | BoolValue
26
-
27
-
28
- {-| -}
29
- type Value dataType
30
- = Value Kind String
31
-
32
-
33
- {-| -}
34
- toString : Value dataType -> String
35
- toString (Value _ rawValue) =
36
- rawValue
37
-
38
-
39
- {-| -}
40
- date : Date -> Value Date
41
- date date_ =
42
- date_
43
- |> Date.toIsoString
44
- |> Value DateValue
45
-
46
-
47
- {-| -}
48
- float : Float -> Value Float
49
- float float_ =
50
- float_
51
- |> String.fromFloat
52
- |> Value FloatValue
53
-
54
-
55
- {-| -}
56
- int : Int -> Value Int
57
- int int_ =
58
- int_
59
- |> String.fromInt
60
- |> Value IntValue
61
-
62
-
63
- {-| -}
64
- bool : Bool -> Value Bool
65
- bool bool_ =
66
- (case bool_ of
67
- True ->
68
- "on"
69
-
70
- False ->
71
- ""
72
- )
73
- |> Value BoolValue
74
-
75
-
76
- {-| -}
77
- string : String -> Value String
78
- string string_ =
79
- string_
80
- |> Value StringValue
81
-
82
-
83
- {-| You probably don't need this helper as it's mostly useful for internal implementation.
84
- -}
85
- compare : String -> Value value -> Order
86
- compare a (Value kind rawValue) =
87
- case kind of
88
- IntValue ->
89
- case ( String.toInt a, String.toInt rawValue ) of
90
- ( Just parsedA, Just parsedB ) ->
91
- Basics.compare parsedA parsedB
92
-
93
- _ ->
94
- LT
95
-
96
- StringValue ->
97
- -- the phantom types in the Field API don't ever run this, so it won't be called there
98
- -- Just in case anyone calls it, it delegates to Basics.compare
99
- Basics.compare a rawValue
100
-
101
- BoolValue ->
102
- -- the phantom types in the Field API don't ever run this, so it won't be called there
103
- -- Just in case anyone calls it, it delegates to Basics.compare
104
- Basics.compare a rawValue
105
-
106
- DateValue ->
107
- Result.map2 Date.compare
108
- (Date.fromIsoString a)
109
- (Date.fromIsoString rawValue)
110
- |> Result.withDefault LT
111
-
112
- FloatValue ->
113
- case ( String.toFloat a, String.toFloat rawValue ) of
114
- ( Just parsedA, Just parsedB ) ->
115
- Basics.compare parsedA parsedB
116
-
117
- _ ->
118
- LT