diff options
Diffstat (limited to 'frontend')
-rw-r--r-- | frontend/elm.json | 8 | ||||
-rw-r--r-- | frontend/index.html | 14 | ||||
-rw-r--r-- | frontend/main.js | 4743 | ||||
-rw-r--r-- | frontend/src/Cart.elm | 7 | ||||
-rw-r--r-- | frontend/src/Catalog.elm | 62 | ||||
-rw-r--r-- | frontend/src/Checkout.elm | 7 | ||||
-rw-r--r-- | frontend/src/Icons.elm | 15 | ||||
-rw-r--r-- | frontend/src/Login.elm | 41 | ||||
-rw-r--r-- | frontend/src/Main.elm | 125 | ||||
-rw-r--r-- | frontend/src/Product.elm | 35 | ||||
-rw-r--r-- | frontend/src/Signup.elm | 49 | ||||
-rw-r--r-- | frontend/src/Styles.elm | 104 | ||||
-rw-r--r-- | frontend/src/Utils.elm | 45 |
13 files changed, 4746 insertions, 509 deletions
diff --git a/frontend/elm.json b/frontend/elm.json index 64ee788..eec5f83 100644 --- a/frontend/elm.json +++ b/frontend/elm.json | |||
@@ -6,18 +6,22 @@ | |||
6 | "elm-version": "0.19.1", | 6 | "elm-version": "0.19.1", |
7 | "dependencies": { | 7 | "dependencies": { |
8 | "direct": { | 8 | "direct": { |
9 | "1602/elm-feather": "2.3.5", | ||
9 | "elm/browser": "1.0.2", | 10 | "elm/browser": "1.0.2", |
10 | "elm/core": "1.0.5", | 11 | "elm/core": "1.0.5", |
11 | "elm/html": "1.0.0", | 12 | "elm/html": "1.0.0", |
12 | "elm/http": "2.0.0", | 13 | "elm/http": "2.0.0", |
13 | "elm/json": "1.1.3", | 14 | "elm/json": "1.1.3", |
14 | "elm/url": "1.0.0" | 15 | "elm/url": "1.0.0", |
16 | "rtfeldman/elm-css": "16.1.0" | ||
15 | }, | 17 | }, |
16 | "indirect": { | 18 | "indirect": { |
17 | "elm/bytes": "1.0.8", | 19 | "elm/bytes": "1.0.8", |
18 | "elm/file": "1.0.5", | 20 | "elm/file": "1.0.5", |
21 | "elm/svg": "1.0.1", | ||
19 | "elm/time": "1.0.0", | 22 | "elm/time": "1.0.0", |
20 | "elm/virtual-dom": "1.0.2" | 23 | "elm/virtual-dom": "1.0.2", |
24 | "rtfeldman/elm-hex": "1.0.0" | ||
21 | } | 25 | } |
22 | }, | 26 | }, |
23 | "test-dependencies": { | 27 | "test-dependencies": { |
diff --git a/frontend/index.html b/frontend/index.html index be32ef3..38203b9 100644 --- a/frontend/index.html +++ b/frontend/index.html | |||
@@ -3,18 +3,12 @@ | |||
3 | <head> | 3 | <head> |
4 | <meta charset="utf-8"> | 4 | <meta charset="utf-8"> |
5 | <title>hello-world</title> | 5 | <title>hello-world</title> |
6 | <script type="module" src="https://unpkg.com/@google/model-viewer/dist/model-viewer.min.js"></script> | ||
7 | <script src="main.js"></script> | ||
6 | </head> | 8 | </head> |
7 | <body> | 9 | <body> |
8 | <script type="module" src="https://unpkg.com/@google/model-viewer/dist/model-viewer.min.js"></script> | 10 | <script>var app = Elm.Main.init();</script> |
9 | <div id="elm" /> | ||
10 | <model-viewer | ||
11 | src="https://poly.googleusercontent.com/downloads/c/fp/1606938083820086/9ycLAR71SmR/7wwOehn8nNN/Bedroom.gltf" | ||
12 | ios-src="https://poly.googleusercontent.com/downloads/c/fp/1606938083820086/9ycLAR71SmR/cTuWg1jk4jo/Bedroom.usdz" | ||
13 | alt="Bedroom by Poly by Google" | ||
14 | background-color="##607d8b" | ||
15 | camera-controls | ||
16 | auto-rotate > | ||
17 | </model-viewer> | ||
18 | </body> | 11 | </body> |
19 | </html> | 12 | </html> |
20 | 13 | ||
14 | |||
diff --git a/frontend/main.js b/frontend/main.js index 8224ee0..931d7ae 100644 --- a/frontend/main.js +++ b/frontend/main.js | |||
@@ -4547,7 +4547,44 @@ function _Url_percentDecode(string) | |||
4547 | { | 4547 | { |
4548 | return $elm$core$Maybe$Nothing; | 4548 | return $elm$core$Maybe$Nothing; |
4549 | } | 4549 | } |
4550 | }var $author$project$Main$LinkClicked = function (a) { | 4550 | } |
4551 | |||
4552 | |||
4553 | var _Bitwise_and = F2(function(a, b) | ||
4554 | { | ||
4555 | return a & b; | ||
4556 | }); | ||
4557 | |||
4558 | var _Bitwise_or = F2(function(a, b) | ||
4559 | { | ||
4560 | return a | b; | ||
4561 | }); | ||
4562 | |||
4563 | var _Bitwise_xor = F2(function(a, b) | ||
4564 | { | ||
4565 | return a ^ b; | ||
4566 | }); | ||
4567 | |||
4568 | function _Bitwise_complement(a) | ||
4569 | { | ||
4570 | return ~a; | ||
4571 | }; | ||
4572 | |||
4573 | var _Bitwise_shiftLeftBy = F2(function(offset, a) | ||
4574 | { | ||
4575 | return a << offset; | ||
4576 | }); | ||
4577 | |||
4578 | var _Bitwise_shiftRightBy = F2(function(offset, a) | ||
4579 | { | ||
4580 | return a >> offset; | ||
4581 | }); | ||
4582 | |||
4583 | var _Bitwise_shiftRightZfBy = F2(function(offset, a) | ||
4584 | { | ||
4585 | return a >>> offset; | ||
4586 | }); | ||
4587 | var $author$project$Main$LinkClicked = function (a) { | ||
4551 | return {$: 'LinkClicked', a: a}; | 4588 | return {$: 'LinkClicked', a: a}; |
4552 | }; | 4589 | }; |
4553 | var $author$project$Main$UrlChanged = function (a) { | 4590 | var $author$project$Main$UrlChanged = function (a) { |
@@ -5343,9 +5380,9 @@ var $elm$core$Task$perform = F2( | |||
5343 | }); | 5380 | }); |
5344 | var $elm$browser$Browser$application = _Browser_application; | 5381 | var $elm$browser$Browser$application = _Browser_application; |
5345 | var $author$project$Main$HomePage = {$: 'HomePage'}; | 5382 | var $author$project$Main$HomePage = {$: 'HomePage'}; |
5346 | var $author$project$Main$Model = F8( | 5383 | var $author$project$Main$Model = F9( |
5347 | function (key, url, location, loginModel, catalogModel, productModel, signupModel, cartModel) { | 5384 | function (key, url, location, loginModel, catalogModel, productModel, signupModel, cartModel, checkoutModel) { |
5348 | return {cartModel: cartModel, catalogModel: catalogModel, key: key, location: location, loginModel: loginModel, productModel: productModel, signupModel: signupModel, url: url}; | 5385 | return {cartModel: cartModel, catalogModel: catalogModel, checkoutModel: checkoutModel, key: key, location: location, loginModel: loginModel, productModel: productModel, signupModel: signupModel, url: url}; |
5349 | }); | 5386 | }); |
5350 | var $author$project$Cart$Model = F2( | 5387 | var $author$project$Cart$Model = F2( |
5351 | function (pageStatus, products) { | 5388 | function (pageStatus, products) { |
@@ -5353,12 +5390,29 @@ var $author$project$Cart$Model = F2( | |||
5353 | }); | 5390 | }); |
5354 | var $author$project$Cart$NotLoaded = {$: 'NotLoaded'}; | 5391 | var $author$project$Cart$NotLoaded = {$: 'NotLoaded'}; |
5355 | var $author$project$Cart$init = A2($author$project$Cart$Model, $author$project$Cart$NotLoaded, _List_Nil); | 5392 | var $author$project$Cart$init = A2($author$project$Cart$Model, $author$project$Cart$NotLoaded, _List_Nil); |
5356 | var $author$project$Catalog$Model = F2( | 5393 | var $author$project$Catalog$Model = F3( |
5357 | function (pageStatus, products) { | 5394 | function (pageStatus, products, filters) { |
5358 | return {pageStatus: pageStatus, products: products}; | 5395 | return {filters: filters, pageStatus: pageStatus, products: products}; |
5359 | }); | 5396 | }); |
5360 | var $author$project$Catalog$NotLoaded = {$: 'NotLoaded'}; | 5397 | var $author$project$Catalog$NotLoaded = {$: 'NotLoaded'}; |
5361 | var $author$project$Catalog$init = A2($author$project$Catalog$Model, $author$project$Catalog$NotLoaded, _List_Nil); | 5398 | var $author$project$Catalog$Filters = F2( |
5399 | function (price, rating) { | ||
5400 | return {price: price, rating: rating}; | ||
5401 | }); | ||
5402 | var $elm$core$Basics$negate = function (n) { | ||
5403 | return -n; | ||
5404 | }; | ||
5405 | var $author$project$Catalog$defaultFilters = A2( | ||
5406 | $author$project$Catalog$Filters, | ||
5407 | _Utils_Tuple2(-1, 100000), | ||
5408 | _Utils_Tuple2(0, 5)); | ||
5409 | var $author$project$Catalog$init = A3($author$project$Catalog$Model, $author$project$Catalog$NotLoaded, _List_Nil, $author$project$Catalog$defaultFilters); | ||
5410 | var $author$project$Checkout$Model = F3( | ||
5411 | function (pageStatus, paymentMode, cartTotal) { | ||
5412 | return {cartTotal: cartTotal, pageStatus: pageStatus, paymentMode: paymentMode}; | ||
5413 | }); | ||
5414 | var $author$project$Checkout$NotLoaded = {$: 'NotLoaded'}; | ||
5415 | var $author$project$Checkout$init = A3($author$project$Checkout$Model, $author$project$Checkout$NotLoaded, 'Cash', 0); | ||
5362 | var $author$project$Login$Model = F3( | 5416 | var $author$project$Login$Model = F3( |
5363 | function (username, password, loginStatus) { | 5417 | function (username, password, loginStatus) { |
5364 | return {loginStatus: loginStatus, password: password, username: username}; | 5418 | return {loginStatus: loginStatus, password: password, username: username}; |
@@ -5371,14 +5425,11 @@ var $author$project$Product$Model = F6( | |||
5371 | }); | 5425 | }); |
5372 | var $author$project$Product$NotLoaded = {$: 'NotLoaded'}; | 5426 | var $author$project$Product$NotLoaded = {$: 'NotLoaded'}; |
5373 | var $author$project$Product$NotSubmitted = {$: 'NotSubmitted'}; | 5427 | var $author$project$Product$NotSubmitted = {$: 'NotSubmitted'}; |
5374 | var $author$project$Product$Product = F5( | 5428 | var $author$project$Product$Product = F7( |
5375 | function (id, name, kind, price, description) { | 5429 | function (id, name, kind, price, description, src, iosSrc) { |
5376 | return {description: description, id: id, kind: kind, name: name, price: price}; | 5430 | return {description: description, id: id, iosSrc: iosSrc, kind: kind, name: name, price: price, src: src}; |
5377 | }); | 5431 | }); |
5378 | var $elm$core$Basics$negate = function (n) { | 5432 | var $author$project$Product$emptyProduct = A7($author$project$Product$Product, -1, '', $elm$core$Maybe$Nothing, 0, $elm$core$Maybe$Nothing, '', ''); |
5379 | return -n; | ||
5380 | }; | ||
5381 | var $author$project$Product$emptyProduct = A5($author$project$Product$Product, -1, '', $elm$core$Maybe$Nothing, 0, $elm$core$Maybe$Nothing); | ||
5382 | var $author$project$Product$init = A6($author$project$Product$Model, $author$project$Product$NotLoaded, $author$project$Product$emptyProduct, _List_Nil, 0, '', $author$project$Product$NotSubmitted); | 5433 | var $author$project$Product$init = A6($author$project$Product$Model, $author$project$Product$NotLoaded, $author$project$Product$emptyProduct, _List_Nil, 0, '', $author$project$Product$NotSubmitted); |
5383 | var $author$project$Signup$Empty = {$: 'Empty'}; | 5434 | var $author$project$Signup$Empty = {$: 'Empty'}; |
5384 | var $author$project$Signup$Model = F6( | 5435 | var $author$project$Signup$Model = F6( |
@@ -5394,10 +5445,11 @@ var $author$project$Main$init = F3( | |||
5394 | var signup = $author$project$Signup$init; | 5445 | var signup = $author$project$Signup$init; |
5395 | var product = $author$project$Product$init; | 5446 | var product = $author$project$Product$init; |
5396 | var login = $author$project$Login$init; | 5447 | var login = $author$project$Login$init; |
5448 | var checkout = $author$project$Checkout$init; | ||
5397 | var catalog = $author$project$Catalog$init; | 5449 | var catalog = $author$project$Catalog$init; |
5398 | var cart = $author$project$Cart$init; | 5450 | var cart = $author$project$Cart$init; |
5399 | return _Utils_Tuple2( | 5451 | return _Utils_Tuple2( |
5400 | A8($author$project$Main$Model, key, url, start, login, catalog, product, signup, cart), | 5452 | A9($author$project$Main$Model, key, url, start, login, catalog, product, signup, cart, checkout), |
5401 | $elm$core$Platform$Cmd$none); | 5453 | $elm$core$Platform$Cmd$none); |
5402 | }); | 5454 | }); |
5403 | var $elm$core$Platform$Sub$batch = _Platform_batch; | 5455 | var $elm$core$Platform$Sub$batch = _Platform_batch; |
@@ -5413,6 +5465,10 @@ var $author$project$Main$CatalogMessage = function (a) { | |||
5413 | return {$: 'CatalogMessage', a: a}; | 5465 | return {$: 'CatalogMessage', a: a}; |
5414 | }; | 5466 | }; |
5415 | var $author$project$Main$CatalogPage = {$: 'CatalogPage'}; | 5467 | var $author$project$Main$CatalogPage = {$: 'CatalogPage'}; |
5468 | var $author$project$Main$CheckoutMessage = function (a) { | ||
5469 | return {$: 'CheckoutMessage', a: a}; | ||
5470 | }; | ||
5471 | var $author$project$Main$CheckoutPage = {$: 'CheckoutPage'}; | ||
5416 | var $author$project$Main$LoginMessage = function (a) { | 5472 | var $author$project$Main$LoginMessage = function (a) { |
5417 | return {$: 'LoginMessage', a: a}; | 5473 | return {$: 'LoginMessage', a: a}; |
5418 | }; | 5474 | }; |
@@ -5426,44 +5482,9 @@ var $author$project$Main$ProductPage = function (a) { | |||
5426 | var $author$project$Main$SignupMessage = function (a) { | 5482 | var $author$project$Main$SignupMessage = function (a) { |
5427 | return {$: 'SignupMessage', a: a}; | 5483 | return {$: 'SignupMessage', a: a}; |
5428 | }; | 5484 | }; |
5429 | var $author$project$Cart$CartLoaded = function (a) { | 5485 | var $author$project$Checkout$AmountLoaded = function (a) { |
5430 | return {$: 'CartLoaded', a: a}; | 5486 | return {$: 'AmountLoaded', a: a}; |
5431 | }; | ||
5432 | var $author$project$Cart$Product = F5( | ||
5433 | function (id, name, kind, price, description) { | ||
5434 | return {description: description, id: id, kind: kind, name: name, price: price}; | ||
5435 | }); | ||
5436 | var $elm$json$Json$Decode$field = _Json_decodeField; | ||
5437 | var $elm$json$Json$Decode$float = _Json_decodeFloat; | ||
5438 | var $elm$json$Json$Decode$int = _Json_decodeInt; | ||
5439 | var $elm$json$Json$Decode$map5 = _Json_map5; | ||
5440 | var $elm$json$Json$Decode$null = _Json_decodeNull; | ||
5441 | var $elm$json$Json$Decode$oneOf = _Json_oneOf; | ||
5442 | var $elm$json$Json$Decode$nullable = function (decoder) { | ||
5443 | return $elm$json$Json$Decode$oneOf( | ||
5444 | _List_fromArray( | ||
5445 | [ | ||
5446 | $elm$json$Json$Decode$null($elm$core$Maybe$Nothing), | ||
5447 | A2($elm$json$Json$Decode$map, $elm$core$Maybe$Just, decoder) | ||
5448 | ])); | ||
5449 | }; | 5487 | }; |
5450 | var $elm$json$Json$Decode$string = _Json_decodeString; | ||
5451 | var $author$project$Cart$decodeProduct = A6( | ||
5452 | $elm$json$Json$Decode$map5, | ||
5453 | $author$project$Cart$Product, | ||
5454 | A2($elm$json$Json$Decode$field, 'id', $elm$json$Json$Decode$int), | ||
5455 | A2($elm$json$Json$Decode$field, 'name', $elm$json$Json$Decode$string), | ||
5456 | A2( | ||
5457 | $elm$json$Json$Decode$field, | ||
5458 | 'kind', | ||
5459 | $elm$json$Json$Decode$nullable($elm$json$Json$Decode$string)), | ||
5460 | A2($elm$json$Json$Decode$field, 'price', $elm$json$Json$Decode$float), | ||
5461 | A2( | ||
5462 | $elm$json$Json$Decode$field, | ||
5463 | 'description', | ||
5464 | $elm$json$Json$Decode$nullable($elm$json$Json$Decode$string))); | ||
5465 | var $elm$json$Json$Decode$list = _Json_decodeList; | ||
5466 | var $author$project$Cart$decodeResponse = $elm$json$Json$Decode$list($author$project$Cart$decodeProduct); | ||
5467 | var $elm$http$Http$BadStatus_ = F2( | 5488 | var $elm$http$Http$BadStatus_ = F2( |
5468 | function (a, b) { | 5489 | function (a, b) { |
5469 | return {$: 'BadStatus_', a: a, b: b}; | 5490 | return {$: 'BadStatus_', a: a, b: b}; |
@@ -6079,7 +6100,7 @@ var $elm$http$Http$expectJson = F2( | |||
6079 | A2($elm$json$Json$Decode$decodeString, decoder, string)); | 6100 | A2($elm$json$Json$Decode$decodeString, decoder, string)); |
6080 | })); | 6101 | })); |
6081 | }); | 6102 | }); |
6082 | var $elm$core$Debug$log = _Debug_log; | 6103 | var $elm$json$Json$Decode$float = _Json_decodeFloat; |
6083 | var $elm$http$Http$Request = function (a) { | 6104 | var $elm$http$Http$Request = function (a) { |
6084 | return {$: 'Request', a: a}; | 6105 | return {$: 'Request', a: a}; |
6085 | }; | 6106 | }; |
@@ -6248,6 +6269,63 @@ var $elm$http$Http$riskyRequest = function (r) { | |||
6248 | $elm$http$Http$Request( | 6269 | $elm$http$Http$Request( |
6249 | {allowCookiesFromOtherDomains: true, body: r.body, expect: r.expect, headers: r.headers, method: r.method, timeout: r.timeout, tracker: r.tracker, url: r.url})); | 6270 | {allowCookiesFromOtherDomains: true, body: r.body, expect: r.expect, headers: r.headers, method: r.method, timeout: r.timeout, tracker: r.tracker, url: r.url})); |
6250 | }; | 6271 | }; |
6272 | var $author$project$Checkout$fetchAmount = $elm$http$Http$riskyRequest( | ||
6273 | { | ||
6274 | body: $elm$http$Http$emptyBody, | ||
6275 | expect: A2($elm$http$Http$expectJson, $author$project$Checkout$AmountLoaded, $elm$json$Json$Decode$float), | ||
6276 | headers: _List_Nil, | ||
6277 | method: 'GET', | ||
6278 | timeout: $elm$core$Maybe$Nothing, | ||
6279 | tracker: $elm$core$Maybe$Nothing, | ||
6280 | url: 'http://127.0.0.1:7878/cart/total' | ||
6281 | }); | ||
6282 | var $author$project$Cart$CartLoaded = function (a) { | ||
6283 | return {$: 'CartLoaded', a: a}; | ||
6284 | }; | ||
6285 | var $author$project$Cart$CartListing = F2( | ||
6286 | function (productItem, quantity) { | ||
6287 | return {productItem: productItem, quantity: quantity}; | ||
6288 | }); | ||
6289 | var $author$project$Cart$Product = F5( | ||
6290 | function (id, name, kind, price, description) { | ||
6291 | return {description: description, id: id, kind: kind, name: name, price: price}; | ||
6292 | }); | ||
6293 | var $elm$json$Json$Decode$field = _Json_decodeField; | ||
6294 | var $elm$json$Json$Decode$int = _Json_decodeInt; | ||
6295 | var $elm$json$Json$Decode$map5 = _Json_map5; | ||
6296 | var $elm$json$Json$Decode$null = _Json_decodeNull; | ||
6297 | var $elm$json$Json$Decode$oneOf = _Json_oneOf; | ||
6298 | var $elm$json$Json$Decode$nullable = function (decoder) { | ||
6299 | return $elm$json$Json$Decode$oneOf( | ||
6300 | _List_fromArray( | ||
6301 | [ | ||
6302 | $elm$json$Json$Decode$null($elm$core$Maybe$Nothing), | ||
6303 | A2($elm$json$Json$Decode$map, $elm$core$Maybe$Just, decoder) | ||
6304 | ])); | ||
6305 | }; | ||
6306 | var $elm$json$Json$Decode$string = _Json_decodeString; | ||
6307 | var $author$project$Cart$decodeProduct = A6( | ||
6308 | $elm$json$Json$Decode$map5, | ||
6309 | $author$project$Cart$Product, | ||
6310 | A2($elm$json$Json$Decode$field, 'id', $elm$json$Json$Decode$int), | ||
6311 | A2($elm$json$Json$Decode$field, 'name', $elm$json$Json$Decode$string), | ||
6312 | A2( | ||
6313 | $elm$json$Json$Decode$field, | ||
6314 | 'kind', | ||
6315 | $elm$json$Json$Decode$nullable($elm$json$Json$Decode$string)), | ||
6316 | A2($elm$json$Json$Decode$field, 'price', $elm$json$Json$Decode$float), | ||
6317 | A2( | ||
6318 | $elm$json$Json$Decode$field, | ||
6319 | 'description', | ||
6320 | $elm$json$Json$Decode$nullable($elm$json$Json$Decode$string))); | ||
6321 | var $elm$json$Json$Decode$list = _Json_decodeList; | ||
6322 | var $author$project$Cart$decodeResponse = $elm$json$Json$Decode$list( | ||
6323 | A3( | ||
6324 | $elm$json$Json$Decode$map2, | ||
6325 | $author$project$Cart$CartListing, | ||
6326 | A2($elm$json$Json$Decode$field, 'product_item', $author$project$Cart$decodeProduct), | ||
6327 | A2($elm$json$Json$Decode$field, 'quantity', $elm$json$Json$Decode$int))); | ||
6328 | var $elm$core$Debug$log = _Debug_log; | ||
6251 | var $author$project$Cart$fetchCartItems = function () { | 6329 | var $author$project$Cart$fetchCartItems = function () { |
6252 | var _v0 = A2($elm$core$Debug$log, 'cart', 'fetching cart items'); | 6330 | var _v0 = A2($elm$core$Debug$log, 'cart', 'fetching cart items'); |
6253 | return $elm$http$Http$riskyRequest( | 6331 | return $elm$http$Http$riskyRequest( |
@@ -6264,8 +6342,9 @@ var $author$project$Cart$fetchCartItems = function () { | |||
6264 | var $author$project$Product$ListingLoaded = function (a) { | 6342 | var $author$project$Product$ListingLoaded = function (a) { |
6265 | return {$: 'ListingLoaded', a: a}; | 6343 | return {$: 'ListingLoaded', a: a}; |
6266 | }; | 6344 | }; |
6267 | var $author$project$Product$decodeProduct = A6( | 6345 | var $elm$json$Json$Decode$map7 = _Json_map7; |
6268 | $elm$json$Json$Decode$map5, | 6346 | var $author$project$Product$decodeProduct = A8( |
6347 | $elm$json$Json$Decode$map7, | ||
6269 | $author$project$Product$Product, | 6348 | $author$project$Product$Product, |
6270 | A2($elm$json$Json$Decode$field, 'id', $elm$json$Json$Decode$int), | 6349 | A2($elm$json$Json$Decode$field, 'id', $elm$json$Json$Decode$int), |
6271 | A2($elm$json$Json$Decode$field, 'name', $elm$json$Json$Decode$string), | 6350 | A2($elm$json$Json$Decode$field, 'name', $elm$json$Json$Decode$string), |
@@ -6277,7 +6356,9 @@ var $author$project$Product$decodeProduct = A6( | |||
6277 | A2( | 6356 | A2( |
6278 | $elm$json$Json$Decode$field, | 6357 | $elm$json$Json$Decode$field, |
6279 | 'description', | 6358 | 'description', |
6280 | $elm$json$Json$Decode$nullable($elm$json$Json$Decode$string))); | 6359 | $elm$json$Json$Decode$nullable($elm$json$Json$Decode$string)), |
6360 | A2($elm$json$Json$Decode$field, 'src', $elm$json$Json$Decode$string), | ||
6361 | A2($elm$json$Json$Decode$field, 'ios_src', $elm$json$Json$Decode$string)); | ||
6281 | var $elm$http$Http$request = function (r) { | 6362 | var $elm$http$Http$request = function (r) { |
6282 | return $elm$http$Http$command( | 6363 | return $elm$http$Http$command( |
6283 | $elm$http$Http$Request( | 6364 | $elm$http$Http$Request( |
@@ -6301,12 +6382,13 @@ var $author$project$Product$fetchListing = function (id) { | |||
6301 | var $author$project$Catalog$ProductsLoaded = function (a) { | 6382 | var $author$project$Catalog$ProductsLoaded = function (a) { |
6302 | return {$: 'ProductsLoaded', a: a}; | 6383 | return {$: 'ProductsLoaded', a: a}; |
6303 | }; | 6384 | }; |
6304 | var $author$project$Catalog$Product = F5( | 6385 | var $author$project$Catalog$Product = F6( |
6305 | function (id, name, kind, price, description) { | 6386 | function (id, name, kind, price, description, averageRating) { |
6306 | return {description: description, id: id, kind: kind, name: name, price: price}; | 6387 | return {averageRating: averageRating, description: description, id: id, kind: kind, name: name, price: price}; |
6307 | }); | 6388 | }); |
6308 | var $author$project$Catalog$decodeProduct = A6( | 6389 | var $elm$json$Json$Decode$map6 = _Json_map6; |
6309 | $elm$json$Json$Decode$map5, | 6390 | var $author$project$Catalog$decodeProduct = A7( |
6391 | $elm$json$Json$Decode$map6, | ||
6310 | $author$project$Catalog$Product, | 6392 | $author$project$Catalog$Product, |
6311 | A2($elm$json$Json$Decode$field, 'id', $elm$json$Json$Decode$int), | 6393 | A2($elm$json$Json$Decode$field, 'id', $elm$json$Json$Decode$int), |
6312 | A2($elm$json$Json$Decode$field, 'name', $elm$json$Json$Decode$string), | 6394 | A2($elm$json$Json$Decode$field, 'name', $elm$json$Json$Decode$string), |
@@ -6318,7 +6400,11 @@ var $author$project$Catalog$decodeProduct = A6( | |||
6318 | A2( | 6400 | A2( |
6319 | $elm$json$Json$Decode$field, | 6401 | $elm$json$Json$Decode$field, |
6320 | 'description', | 6402 | 'description', |
6321 | $elm$json$Json$Decode$nullable($elm$json$Json$Decode$string))); | 6403 | $elm$json$Json$Decode$nullable($elm$json$Json$Decode$string)), |
6404 | A2( | ||
6405 | $elm$json$Json$Decode$field, | ||
6406 | 'average_rating', | ||
6407 | $elm$json$Json$Decode$nullable($elm$json$Json$Decode$float))); | ||
6322 | var $author$project$Catalog$decodeResponse = $elm$json$Json$Decode$list($author$project$Catalog$decodeProduct); | 6408 | var $author$project$Catalog$decodeResponse = $elm$json$Json$Decode$list($author$project$Catalog$decodeProduct); |
6323 | var $author$project$Catalog$fetchProducts = function () { | 6409 | var $author$project$Catalog$fetchProducts = function () { |
6324 | var _v0 = A2($elm$core$Debug$log, 'err', 'fetching products'); | 6410 | var _v0 = A2($elm$core$Debug$log, 'err', 'fetching products'); |
@@ -6643,6 +6729,10 @@ var $author$project$Main$parseRoute = $elm$url$Url$Parser$oneOf( | |||
6643 | $elm$url$Url$Parser$s('signup')), | 6729 | $elm$url$Url$Parser$s('signup')), |
6644 | A2( | 6730 | A2( |
6645 | $elm$url$Url$Parser$map, | 6731 | $elm$url$Url$Parser$map, |
6732 | $author$project$Main$CheckoutPage, | ||
6733 | $elm$url$Url$Parser$s('checkout')), | ||
6734 | A2( | ||
6735 | $elm$url$Url$Parser$map, | ||
6646 | $author$project$Main$ProductPage, | 6736 | $author$project$Main$ProductPage, |
6647 | A2( | 6737 | A2( |
6648 | $elm$url$Url$Parser$slash, | 6738 | $elm$url$Url$Parser$slash, |
@@ -6727,10 +6817,32 @@ var $author$project$Main$tryLogout = $elm$http$Http$riskyRequest( | |||
6727 | }); | 6817 | }); |
6728 | var $author$project$Cart$Loaded = {$: 'Loaded'}; | 6818 | var $author$project$Cart$Loaded = {$: 'Loaded'}; |
6729 | var $author$project$Cart$Loading = {$: 'Loading'}; | 6819 | var $author$project$Cart$Loading = {$: 'Loading'}; |
6820 | var $author$project$Cart$AddToCartSuccess = function (a) { | ||
6821 | return {$: 'AddToCartSuccess', a: a}; | ||
6822 | }; | ||
6823 | var $elm$http$Http$stringBody = _Http_pair; | ||
6824 | var $author$project$Cart$addToCart = function (id) { | ||
6825 | var _v0 = A2( | ||
6826 | $elm$core$Debug$log, | ||
6827 | 'err', | ||
6828 | 'adding to cart: ' + $elm$core$String$fromInt(id)); | ||
6829 | return $elm$http$Http$riskyRequest( | ||
6830 | { | ||
6831 | body: A2( | ||
6832 | $elm$http$Http$stringBody, | ||
6833 | 'applcation/json', | ||
6834 | $elm$core$String$fromInt(id)), | ||
6835 | expect: $elm$http$Http$expectWhatever($author$project$Cart$AddToCartSuccess), | ||
6836 | headers: _List_Nil, | ||
6837 | method: 'POST', | ||
6838 | timeout: $elm$core$Maybe$Nothing, | ||
6839 | tracker: $elm$core$Maybe$Nothing, | ||
6840 | url: 'http://127.0.0.1:7878/cart/add' | ||
6841 | }); | ||
6842 | }; | ||
6730 | var $author$project$Cart$CartItemRemoved = function (a) { | 6843 | var $author$project$Cart$CartItemRemoved = function (a) { |
6731 | return {$: 'CartItemRemoved', a: a}; | 6844 | return {$: 'CartItemRemoved', a: a}; |
6732 | }; | 6845 | }; |
6733 | var $elm$http$Http$stringBody = _Http_pair; | ||
6734 | var $author$project$Cart$removeProduct = function (id) { | 6846 | var $author$project$Cart$removeProduct = function (id) { |
6735 | var _v0 = A2($elm$core$Debug$log, 'cart', 'fetching cart items'); | 6847 | var _v0 = A2($elm$core$Debug$log, 'cart', 'fetching cart items'); |
6736 | return $elm$http$Http$riskyRequest( | 6848 | return $elm$http$Http$riskyRequest( |
@@ -6779,6 +6891,17 @@ var $author$project$Cart$update = F2( | |||
6779 | model, | 6891 | model, |
6780 | {pageStatus: $author$project$Cart$Loading}), | 6892 | {pageStatus: $author$project$Cart$Loading}), |
6781 | $author$project$Cart$fetchCartItems); | 6893 | $author$project$Cart$fetchCartItems); |
6894 | case 'FetchCartItems': | ||
6895 | return _Utils_Tuple2( | ||
6896 | _Utils_update( | ||
6897 | model, | ||
6898 | {pageStatus: $author$project$Cart$Loading}), | ||
6899 | $author$project$Cart$fetchCartItems); | ||
6900 | case 'AddToCartPressed': | ||
6901 | var id = msg.a; | ||
6902 | return _Utils_Tuple2( | ||
6903 | model, | ||
6904 | $author$project$Cart$addToCart(id)); | ||
6782 | default: | 6905 | default: |
6783 | return _Utils_Tuple2( | 6906 | return _Utils_Tuple2( |
6784 | _Utils_update( | 6907 | _Utils_update( |
@@ -6789,32 +6912,174 @@ var $author$project$Cart$update = F2( | |||
6789 | }); | 6912 | }); |
6790 | var $author$project$Catalog$Loaded = {$: 'Loaded'}; | 6913 | var $author$project$Catalog$Loaded = {$: 'Loaded'}; |
6791 | var $author$project$Catalog$Loading = {$: 'Loading'}; | 6914 | var $author$project$Catalog$Loading = {$: 'Loading'}; |
6915 | var $elm$core$Basics$always = F2( | ||
6916 | function (a, _v0) { | ||
6917 | return a; | ||
6918 | }); | ||
6919 | var $elm$core$Tuple$mapFirst = F2( | ||
6920 | function (func, _v0) { | ||
6921 | var x = _v0.a; | ||
6922 | var y = _v0.b; | ||
6923 | return _Utils_Tuple2( | ||
6924 | func(x), | ||
6925 | y); | ||
6926 | }); | ||
6927 | var $elm$core$Tuple$mapSecond = F2( | ||
6928 | function (func, _v0) { | ||
6929 | var x = _v0.a; | ||
6930 | var y = _v0.b; | ||
6931 | return _Utils_Tuple2( | ||
6932 | x, | ||
6933 | func(y)); | ||
6934 | }); | ||
6792 | var $author$project$Catalog$update = F2( | 6935 | var $author$project$Catalog$update = F2( |
6793 | function (msg, model) { | 6936 | function (msg, model) { |
6794 | if (msg.$ === 'ProductsLoaded') { | 6937 | switch (msg.$) { |
6795 | var res = msg.a; | 6938 | case 'ProductsLoaded': |
6796 | if (res.$ === 'Ok') { | 6939 | var res = msg.a; |
6797 | var s = res.a; | 6940 | if (res.$ === 'Ok') { |
6941 | var s = res.a; | ||
6942 | return _Utils_Tuple2( | ||
6943 | _Utils_update( | ||
6944 | model, | ||
6945 | {pageStatus: $author$project$Catalog$Loaded, products: s}), | ||
6946 | $elm$core$Platform$Cmd$none); | ||
6947 | } else { | ||
6948 | var e = res.a; | ||
6949 | var _v2 = A2($elm$core$Debug$log, 'error', e); | ||
6950 | return _Utils_Tuple2( | ||
6951 | _Utils_update( | ||
6952 | model, | ||
6953 | {pageStatus: $author$project$Catalog$NotLoaded}), | ||
6954 | $elm$core$Platform$Cmd$none); | ||
6955 | } | ||
6956 | case 'FetchProducts': | ||
6798 | return _Utils_Tuple2( | 6957 | return _Utils_Tuple2( |
6799 | _Utils_update( | 6958 | _Utils_update( |
6800 | model, | 6959 | model, |
6801 | {pageStatus: $author$project$Catalog$Loaded, products: s}), | 6960 | {pageStatus: $author$project$Catalog$Loading}), |
6961 | $author$project$Catalog$fetchProducts); | ||
6962 | case 'ChangePriceLower': | ||
6963 | var v = msg.a; | ||
6964 | var fs = model.filters; | ||
6965 | var nfs = _Utils_update( | ||
6966 | fs, | ||
6967 | { | ||
6968 | price: A2( | ||
6969 | $elm$core$Tuple$mapFirst, | ||
6970 | $elm$core$Basics$always(v), | ||
6971 | fs.price) | ||
6972 | }); | ||
6973 | return _Utils_Tuple2( | ||
6974 | _Utils_update( | ||
6975 | model, | ||
6976 | {filters: nfs}), | ||
6802 | $elm$core$Platform$Cmd$none); | 6977 | $elm$core$Platform$Cmd$none); |
6803 | } else { | 6978 | case 'ChangePriceUpper': |
6804 | var e = res.a; | 6979 | var v = msg.a; |
6805 | var _v2 = A2($elm$core$Debug$log, 'error', e); | 6980 | var fs = model.filters; |
6981 | var nfs = _Utils_update( | ||
6982 | fs, | ||
6983 | { | ||
6984 | price: A2( | ||
6985 | $elm$core$Tuple$mapSecond, | ||
6986 | $elm$core$Basics$always(v), | ||
6987 | fs.price) | ||
6988 | }); | ||
6806 | return _Utils_Tuple2( | 6989 | return _Utils_Tuple2( |
6807 | _Utils_update( | 6990 | _Utils_update( |
6808 | model, | 6991 | model, |
6809 | {pageStatus: $author$project$Catalog$NotLoaded}), | 6992 | {filters: nfs}), |
6810 | $elm$core$Platform$Cmd$none); | 6993 | $elm$core$Platform$Cmd$none); |
6811 | } | 6994 | case 'ChangeRatingLower': |
6812 | } else { | 6995 | var v = msg.a; |
6813 | return _Utils_Tuple2( | 6996 | var fs = model.filters; |
6814 | _Utils_update( | 6997 | var nfs = _Utils_update( |
6998 | fs, | ||
6999 | { | ||
7000 | rating: A2( | ||
7001 | $elm$core$Tuple$mapFirst, | ||
7002 | $elm$core$Basics$always(v), | ||
7003 | fs.rating) | ||
7004 | }); | ||
7005 | return _Utils_Tuple2( | ||
7006 | _Utils_update( | ||
7007 | model, | ||
7008 | {filters: nfs}), | ||
7009 | $elm$core$Platform$Cmd$none); | ||
7010 | default: | ||
7011 | var v = msg.a; | ||
7012 | var fs = model.filters; | ||
7013 | var nfs = _Utils_update( | ||
7014 | fs, | ||
7015 | { | ||
7016 | rating: A2( | ||
7017 | $elm$core$Tuple$mapSecond, | ||
7018 | $elm$core$Basics$always(v), | ||
7019 | fs.rating) | ||
7020 | }); | ||
7021 | return _Utils_Tuple2( | ||
7022 | _Utils_update( | ||
7023 | model, | ||
7024 | {filters: nfs}), | ||
7025 | $elm$core$Platform$Cmd$none); | ||
7026 | } | ||
7027 | }); | ||
7028 | var $author$project$Checkout$Loading = {$: 'Loading'}; | ||
7029 | var $author$project$Checkout$CheckoutSuccessful = function (a) { | ||
7030 | return {$: 'CheckoutSuccessful', a: a}; | ||
7031 | }; | ||
7032 | var $author$project$Checkout$tryCheckout = function (pm) { | ||
7033 | return $elm$http$Http$riskyRequest( | ||
7034 | { | ||
7035 | body: A2($elm$http$Http$stringBody, 'application/json', pm), | ||
7036 | expect: $elm$http$Http$expectWhatever($author$project$Checkout$CheckoutSuccessful), | ||
7037 | headers: _List_Nil, | ||
7038 | method: 'POST', | ||
7039 | timeout: $elm$core$Maybe$Nothing, | ||
7040 | tracker: $elm$core$Maybe$Nothing, | ||
7041 | url: 'http://127.0.0.1:7878/transaction/checkout' | ||
7042 | }); | ||
7043 | }; | ||
7044 | var $author$project$Checkout$update = F2( | ||
7045 | function (msg, model) { | ||
7046 | switch (msg.$) { | ||
7047 | case 'CheckoutPressed': | ||
7048 | return _Utils_Tuple2( | ||
6815 | model, | 7049 | model, |
6816 | {pageStatus: $author$project$Catalog$Loading}), | 7050 | $author$project$Checkout$tryCheckout(model.paymentMode)); |
6817 | $author$project$Catalog$fetchProducts); | 7051 | case 'CheckoutSuccessful': |
7052 | return _Utils_Tuple2(model, $elm$core$Platform$Cmd$none); | ||
7053 | case 'AmountLoaded': | ||
7054 | var res = msg.a; | ||
7055 | if (res.$ === 'Ok') { | ||
7056 | var v = res.a; | ||
7057 | return _Utils_Tuple2( | ||
7058 | _Utils_update( | ||
7059 | model, | ||
7060 | {cartTotal: v}), | ||
7061 | $elm$core$Platform$Cmd$none); | ||
7062 | } else { | ||
7063 | return _Utils_Tuple2( | ||
7064 | _Utils_update( | ||
7065 | model, | ||
7066 | {pageStatus: $author$project$Checkout$NotLoaded}), | ||
7067 | $elm$core$Platform$Cmd$none); | ||
7068 | } | ||
7069 | case 'FetchAmount': | ||
7070 | var _v2 = A2($elm$core$Debug$log, 'err', 'fetching checkout amount'); | ||
7071 | return _Utils_Tuple2( | ||
7072 | _Utils_update( | ||
7073 | model, | ||
7074 | {pageStatus: $author$project$Checkout$Loading}), | ||
7075 | $author$project$Checkout$fetchAmount); | ||
7076 | default: | ||
7077 | var s = msg.a; | ||
7078 | return _Utils_Tuple2( | ||
7079 | _Utils_update( | ||
7080 | model, | ||
7081 | {paymentMode: s}), | ||
7082 | $elm$core$Platform$Cmd$none); | ||
6818 | } | 7083 | } |
6819 | }); | 7084 | }); |
6820 | var $author$project$Login$InvalidLogin = {$: 'InvalidLogin'}; | 7085 | var $author$project$Login$InvalidLogin = {$: 'InvalidLogin'}; |
@@ -7309,7 +7574,9 @@ var $author$project$Main$update = F2( | |||
7309 | return _Utils_Tuple2(model, $author$project$Main$tryLogout); | 7574 | return _Utils_Tuple2(model, $author$project$Main$tryLogout); |
7310 | case 'LogoutSuccess': | 7575 | case 'LogoutSuccess': |
7311 | return _Utils_Tuple2( | 7576 | return _Utils_Tuple2( |
7312 | model, | 7577 | _Utils_update( |
7578 | model, | ||
7579 | {loginModel: $author$project$Login$init}), | ||
7313 | A2($elm$browser$Browser$Navigation$replaceUrl, model.key, '/login')); | 7580 | A2($elm$browser$Browser$Navigation$replaceUrl, model.key, '/login')); |
7314 | case 'UrlChanged': | 7581 | case 'UrlChanged': |
7315 | var url = msg.a; | 7582 | var url = msg.a; |
@@ -7348,6 +7615,15 @@ var $author$project$Main$update = F2( | |||
7348 | model, | 7615 | model, |
7349 | {location: $author$project$Main$CartPage}), | 7616 | {location: $author$project$Main$CartPage}), |
7350 | cmd); | 7617 | cmd); |
7618 | case 'CheckoutPage': | ||
7619 | var _v5 = parsedUrl.a; | ||
7620 | var cmd = A2($elm$core$Platform$Cmd$map, $author$project$Main$CheckoutMessage, $author$project$Checkout$fetchAmount); | ||
7621 | var _v6 = A2($elm$core$Debug$log, 'err', 'loading checkout page ...'); | ||
7622 | return _Utils_Tuple2( | ||
7623 | _Utils_update( | ||
7624 | model, | ||
7625 | {location: $author$project$Main$CheckoutPage}), | ||
7626 | cmd); | ||
7351 | default: | 7627 | default: |
7352 | var p = parsedUrl.a; | 7628 | var p = parsedUrl.a; |
7353 | return _Utils_Tuple2( | 7629 | return _Utils_Tuple2( |
@@ -7365,12 +7641,12 @@ var $author$project$Main$update = F2( | |||
7365 | } | 7641 | } |
7366 | case 'LoginMessage': | 7642 | case 'LoginMessage': |
7367 | var lm = msg.a; | 7643 | var lm = msg.a; |
7368 | var _v5 = A2($author$project$Login$update, lm, model.loginModel); | 7644 | var _v7 = A2($author$project$Login$update, lm, model.loginModel); |
7369 | var lmn = _v5.a; | 7645 | var lmn = _v7.a; |
7370 | var cmd = _v5.b; | 7646 | var cmd = _v7.b; |
7371 | var redir = function () { | 7647 | var redir = function () { |
7372 | var _v6 = lmn.loginStatus; | 7648 | var _v8 = lmn.loginStatus; |
7373 | if (_v6.$ === 'LoggedIn') { | 7649 | if (_v8.$ === 'LoggedIn') { |
7374 | return A2($elm$browser$Browser$Navigation$replaceUrl, model.key, '/catalog'); | 7650 | return A2($elm$browser$Browser$Navigation$replaceUrl, model.key, '/catalog'); |
7375 | } else { | 7651 | } else { |
7376 | return $elm$core$Platform$Cmd$none; | 7652 | return $elm$core$Platform$Cmd$none; |
@@ -7388,12 +7664,12 @@ var $author$project$Main$update = F2( | |||
7388 | ]))); | 7664 | ]))); |
7389 | case 'SignupMessage': | 7665 | case 'SignupMessage': |
7390 | var sm = msg.a; | 7666 | var sm = msg.a; |
7391 | var _v7 = A2($author$project$Signup$update, sm, model.signupModel); | 7667 | var _v9 = A2($author$project$Signup$update, sm, model.signupModel); |
7392 | var smn = _v7.a; | 7668 | var smn = _v9.a; |
7393 | var cmd = _v7.b; | 7669 | var cmd = _v9.b; |
7394 | var redir = function () { | 7670 | var redir = function () { |
7395 | var _v8 = smn.status; | 7671 | var _v10 = smn.status; |
7396 | if (_v8.$ === 'CreatedSuccessfully') { | 7672 | if (_v10.$ === 'CreatedSuccessfully') { |
7397 | return A2($elm$browser$Browser$Navigation$replaceUrl, model.key, '/login'); | 7673 | return A2($elm$browser$Browser$Navigation$replaceUrl, model.key, '/login'); |
7398 | } else { | 7674 | } else { |
7399 | return $elm$core$Platform$Cmd$none; | 7675 | return $elm$core$Platform$Cmd$none; |
@@ -7411,9 +7687,9 @@ var $author$project$Main$update = F2( | |||
7411 | ]))); | 7687 | ]))); |
7412 | case 'CatalogMessage': | 7688 | case 'CatalogMessage': |
7413 | var cm = msg.a; | 7689 | var cm = msg.a; |
7414 | var _v9 = A2($author$project$Catalog$update, cm, model.catalogModel); | 7690 | var _v11 = A2($author$project$Catalog$update, cm, model.catalogModel); |
7415 | var cmn = _v9.a; | 7691 | var cmn = _v11.a; |
7416 | var cmd = _v9.b; | 7692 | var cmd = _v11.b; |
7417 | return _Utils_Tuple2( | 7693 | return _Utils_Tuple2( |
7418 | _Utils_update( | 7694 | _Utils_update( |
7419 | model, | 7695 | model, |
@@ -7421,14 +7697,25 @@ var $author$project$Main$update = F2( | |||
7421 | A2($elm$core$Platform$Cmd$map, $author$project$Main$CatalogMessage, cmd)); | 7697 | A2($elm$core$Platform$Cmd$map, $author$project$Main$CatalogMessage, cmd)); |
7422 | case 'CartMessage': | 7698 | case 'CartMessage': |
7423 | var cm = msg.a; | 7699 | var cm = msg.a; |
7424 | var _v10 = A2($author$project$Cart$update, cm, model.cartModel); | 7700 | var _v12 = A2($author$project$Cart$update, cm, model.cartModel); |
7425 | var cmn = _v10.a; | 7701 | var cmn = _v12.a; |
7426 | var cmd = _v10.b; | 7702 | var cmd = _v12.b; |
7427 | return _Utils_Tuple2( | 7703 | return _Utils_Tuple2( |
7428 | _Utils_update( | 7704 | _Utils_update( |
7429 | model, | 7705 | model, |
7430 | {cartModel: cmn}), | 7706 | {cartModel: cmn}), |
7431 | A2($elm$core$Platform$Cmd$map, $author$project$Main$CartMessage, cmd)); | 7707 | A2($elm$core$Platform$Cmd$map, $author$project$Main$CartMessage, cmd)); |
7708 | case 'CheckoutMessage': | ||
7709 | var cm = msg.a; | ||
7710 | var _v13 = A2($author$project$Checkout$update, cm, model.checkoutModel); | ||
7711 | var cmn = _v13.a; | ||
7712 | var cmd = _v13.b; | ||
7713 | var _v14 = A2($elm$core$Debug$log, 'err', 'received checkout message ...'); | ||
7714 | return _Utils_Tuple2( | ||
7715 | _Utils_update( | ||
7716 | model, | ||
7717 | {checkoutModel: cmn}), | ||
7718 | A2($elm$core$Platform$Cmd$map, $author$project$Main$CheckoutMessage, cmd)); | ||
7432 | default: | 7719 | default: |
7433 | var pm = msg.a; | 7720 | var pm = msg.a; |
7434 | var redir = function () { | 7721 | var redir = function () { |
@@ -7438,9 +7725,9 @@ var $author$project$Main$update = F2( | |||
7438 | return $elm$core$Platform$Cmd$none; | 7725 | return $elm$core$Platform$Cmd$none; |
7439 | } | 7726 | } |
7440 | }(); | 7727 | }(); |
7441 | var _v11 = A2($author$project$Product$update, pm, model.productModel); | 7728 | var _v15 = A2($author$project$Product$update, pm, model.productModel); |
7442 | var pmn = _v11.a; | 7729 | var pmn = _v15.a; |
7443 | var cmd = _v11.b; | 7730 | var cmd = _v15.b; |
7444 | return _Utils_Tuple2( | 7731 | return _Utils_Tuple2( |
7445 | _Utils_update( | 7732 | _Utils_update( |
7446 | model, | 7733 | model, |
@@ -7453,62 +7740,2986 @@ var $author$project$Main$update = F2( | |||
7453 | ]))); | 7740 | ]))); |
7454 | } | 7741 | } |
7455 | }); | 7742 | }); |
7456 | var $elm$html$Html$a = _VirtualDom_node('a'); | 7743 | var $rtfeldman$elm_css$VirtualDom$Styled$Node = F3( |
7457 | var $elm$html$Html$b = _VirtualDom_node('b'); | 7744 | function (a, b, c) { |
7458 | var $elm$html$Html$Attributes$stringProperty = F2( | 7745 | return {$: 'Node', a: a, b: b, c: c}; |
7459 | function (key, string) { | 7746 | }); |
7747 | var $rtfeldman$elm_css$VirtualDom$Styled$node = $rtfeldman$elm_css$VirtualDom$Styled$Node; | ||
7748 | var $rtfeldman$elm_css$Html$Styled$node = $rtfeldman$elm_css$VirtualDom$Styled$node; | ||
7749 | var $rtfeldman$elm_css$Html$Styled$a = $rtfeldman$elm_css$Html$Styled$node('a'); | ||
7750 | var $rtfeldman$elm_css$Html$Styled$div = $rtfeldman$elm_css$Html$Styled$node('div'); | ||
7751 | var $rtfeldman$elm_css$VirtualDom$Styled$Attribute = F3( | ||
7752 | function (a, b, c) { | ||
7753 | return {$: 'Attribute', a: a, b: b, c: c}; | ||
7754 | }); | ||
7755 | var $elm$virtual_dom$VirtualDom$property = F2( | ||
7756 | function (key, value) { | ||
7460 | return A2( | 7757 | return A2( |
7461 | _VirtualDom_property, | 7758 | _VirtualDom_property, |
7759 | _VirtualDom_noInnerHtmlOrFormAction(key), | ||
7760 | _VirtualDom_noJavaScriptOrHtmlUri(value)); | ||
7761 | }); | ||
7762 | var $rtfeldman$elm_css$VirtualDom$Styled$property = F2( | ||
7763 | function (key, value) { | ||
7764 | return A3( | ||
7765 | $rtfeldman$elm_css$VirtualDom$Styled$Attribute, | ||
7766 | A2($elm$virtual_dom$VirtualDom$property, key, value), | ||
7767 | _List_Nil, | ||
7768 | ''); | ||
7769 | }); | ||
7770 | var $rtfeldman$elm_css$Html$Styled$Attributes$stringProperty = F2( | ||
7771 | function (key, string) { | ||
7772 | return A2( | ||
7773 | $rtfeldman$elm_css$VirtualDom$Styled$property, | ||
7462 | key, | 7774 | key, |
7463 | $elm$json$Json$Encode$string(string)); | 7775 | $elm$json$Json$Encode$string(string)); |
7464 | }); | 7776 | }); |
7465 | var $elm$html$Html$Attributes$href = function (url) { | 7777 | var $rtfeldman$elm_css$Html$Styled$Attributes$href = function (url) { |
7466 | return A2( | 7778 | return A2($rtfeldman$elm_css$Html$Styled$Attributes$stringProperty, 'href', url); |
7467 | $elm$html$Html$Attributes$stringProperty, | 7779 | }; |
7468 | 'href', | 7780 | var $rtfeldman$elm_css$Html$Styled$li = $rtfeldman$elm_css$Html$Styled$node('li'); |
7469 | _VirtualDom_noJavaScriptUri(url)); | 7781 | var $rtfeldman$elm_css$VirtualDom$Styled$KeyedNode = F3( |
7782 | function (a, b, c) { | ||
7783 | return {$: 'KeyedNode', a: a, b: b, c: c}; | ||
7784 | }); | ||
7785 | var $rtfeldman$elm_css$VirtualDom$Styled$KeyedNodeNS = F4( | ||
7786 | function (a, b, c, d) { | ||
7787 | return {$: 'KeyedNodeNS', a: a, b: b, c: c, d: d}; | ||
7788 | }); | ||
7789 | var $rtfeldman$elm_css$VirtualDom$Styled$NodeNS = F4( | ||
7790 | function (a, b, c, d) { | ||
7791 | return {$: 'NodeNS', a: a, b: b, c: c, d: d}; | ||
7792 | }); | ||
7793 | var $rtfeldman$elm_css$VirtualDom$Styled$Unstyled = function (a) { | ||
7794 | return {$: 'Unstyled', a: a}; | ||
7470 | }; | 7795 | }; |
7471 | var $elm$virtual_dom$VirtualDom$map = _VirtualDom_map; | 7796 | var $elm$virtual_dom$VirtualDom$map = _VirtualDom_map; |
7472 | var $elm$html$Html$map = $elm$virtual_dom$VirtualDom$map; | 7797 | var $elm$virtual_dom$VirtualDom$mapAttribute = _VirtualDom_mapAttribute; |
7473 | var $elm$html$Html$div = _VirtualDom_node('div'); | 7798 | var $rtfeldman$elm_css$VirtualDom$Styled$mapAttribute = F2( |
7799 | function (transform, _v0) { | ||
7800 | var prop = _v0.a; | ||
7801 | var styles = _v0.b; | ||
7802 | var classname = _v0.c; | ||
7803 | return A3( | ||
7804 | $rtfeldman$elm_css$VirtualDom$Styled$Attribute, | ||
7805 | A2($elm$virtual_dom$VirtualDom$mapAttribute, transform, prop), | ||
7806 | styles, | ||
7807 | classname); | ||
7808 | }); | ||
7809 | var $rtfeldman$elm_css$VirtualDom$Styled$map = F2( | ||
7810 | function (transform, vdomNode) { | ||
7811 | switch (vdomNode.$) { | ||
7812 | case 'Node': | ||
7813 | var elemType = vdomNode.a; | ||
7814 | var properties = vdomNode.b; | ||
7815 | var children = vdomNode.c; | ||
7816 | return A3( | ||
7817 | $rtfeldman$elm_css$VirtualDom$Styled$Node, | ||
7818 | elemType, | ||
7819 | A2( | ||
7820 | $elm$core$List$map, | ||
7821 | $rtfeldman$elm_css$VirtualDom$Styled$mapAttribute(transform), | ||
7822 | properties), | ||
7823 | A2( | ||
7824 | $elm$core$List$map, | ||
7825 | $rtfeldman$elm_css$VirtualDom$Styled$map(transform), | ||
7826 | children)); | ||
7827 | case 'NodeNS': | ||
7828 | var ns = vdomNode.a; | ||
7829 | var elemType = vdomNode.b; | ||
7830 | var properties = vdomNode.c; | ||
7831 | var children = vdomNode.d; | ||
7832 | return A4( | ||
7833 | $rtfeldman$elm_css$VirtualDom$Styled$NodeNS, | ||
7834 | ns, | ||
7835 | elemType, | ||
7836 | A2( | ||
7837 | $elm$core$List$map, | ||
7838 | $rtfeldman$elm_css$VirtualDom$Styled$mapAttribute(transform), | ||
7839 | properties), | ||
7840 | A2( | ||
7841 | $elm$core$List$map, | ||
7842 | $rtfeldman$elm_css$VirtualDom$Styled$map(transform), | ||
7843 | children)); | ||
7844 | case 'KeyedNode': | ||
7845 | var elemType = vdomNode.a; | ||
7846 | var properties = vdomNode.b; | ||
7847 | var children = vdomNode.c; | ||
7848 | return A3( | ||
7849 | $rtfeldman$elm_css$VirtualDom$Styled$KeyedNode, | ||
7850 | elemType, | ||
7851 | A2( | ||
7852 | $elm$core$List$map, | ||
7853 | $rtfeldman$elm_css$VirtualDom$Styled$mapAttribute(transform), | ||
7854 | properties), | ||
7855 | A2( | ||
7856 | $elm$core$List$map, | ||
7857 | function (_v1) { | ||
7858 | var key = _v1.a; | ||
7859 | var child = _v1.b; | ||
7860 | return _Utils_Tuple2( | ||
7861 | key, | ||
7862 | A2($rtfeldman$elm_css$VirtualDom$Styled$map, transform, child)); | ||
7863 | }, | ||
7864 | children)); | ||
7865 | case 'KeyedNodeNS': | ||
7866 | var ns = vdomNode.a; | ||
7867 | var elemType = vdomNode.b; | ||
7868 | var properties = vdomNode.c; | ||
7869 | var children = vdomNode.d; | ||
7870 | return A4( | ||
7871 | $rtfeldman$elm_css$VirtualDom$Styled$KeyedNodeNS, | ||
7872 | ns, | ||
7873 | elemType, | ||
7874 | A2( | ||
7875 | $elm$core$List$map, | ||
7876 | $rtfeldman$elm_css$VirtualDom$Styled$mapAttribute(transform), | ||
7877 | properties), | ||
7878 | A2( | ||
7879 | $elm$core$List$map, | ||
7880 | function (_v2) { | ||
7881 | var key = _v2.a; | ||
7882 | var child = _v2.b; | ||
7883 | return _Utils_Tuple2( | ||
7884 | key, | ||
7885 | A2($rtfeldman$elm_css$VirtualDom$Styled$map, transform, child)); | ||
7886 | }, | ||
7887 | children)); | ||
7888 | default: | ||
7889 | var vdom = vdomNode.a; | ||
7890 | return $rtfeldman$elm_css$VirtualDom$Styled$Unstyled( | ||
7891 | A2($elm$virtual_dom$VirtualDom$map, transform, vdom)); | ||
7892 | } | ||
7893 | }); | ||
7894 | var $rtfeldman$elm_css$Html$Styled$map = $rtfeldman$elm_css$VirtualDom$Styled$map; | ||
7895 | var $elm$core$List$singleton = function (value) { | ||
7896 | return _List_fromArray( | ||
7897 | [value]); | ||
7898 | }; | ||
7899 | var $elm$core$List$isEmpty = function (xs) { | ||
7900 | if (!xs.b) { | ||
7901 | return true; | ||
7902 | } else { | ||
7903 | return false; | ||
7904 | } | ||
7905 | }; | ||
7906 | var $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyles = F2( | ||
7907 | function (_v0, styles) { | ||
7908 | var newStyles = _v0.b; | ||
7909 | var classname = _v0.c; | ||
7910 | return $elm$core$List$isEmpty(newStyles) ? styles : A3($elm$core$Dict$insert, classname, newStyles, styles); | ||
7911 | }); | ||
7912 | var $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute = function (_v0) { | ||
7913 | var val = _v0.a; | ||
7914 | return val; | ||
7915 | }; | ||
7916 | var $elm$virtual_dom$VirtualDom$keyedNode = function (tag) { | ||
7917 | return _VirtualDom_keyedNode( | ||
7918 | _VirtualDom_noScript(tag)); | ||
7919 | }; | ||
7920 | var $elm$virtual_dom$VirtualDom$keyedNodeNS = F2( | ||
7921 | function (namespace, tag) { | ||
7922 | return A2( | ||
7923 | _VirtualDom_keyedNodeNS, | ||
7924 | namespace, | ||
7925 | _VirtualDom_noScript(tag)); | ||
7926 | }); | ||
7927 | var $elm$virtual_dom$VirtualDom$node = function (tag) { | ||
7928 | return _VirtualDom_node( | ||
7929 | _VirtualDom_noScript(tag)); | ||
7930 | }; | ||
7931 | var $elm$virtual_dom$VirtualDom$nodeNS = function (tag) { | ||
7932 | return _VirtualDom_nodeNS( | ||
7933 | _VirtualDom_noScript(tag)); | ||
7934 | }; | ||
7935 | var $rtfeldman$elm_css$VirtualDom$Styled$accumulateKeyedStyledHtml = F2( | ||
7936 | function (_v6, _v7) { | ||
7937 | var key = _v6.a; | ||
7938 | var html = _v6.b; | ||
7939 | var pairs = _v7.a; | ||
7940 | var styles = _v7.b; | ||
7941 | switch (html.$) { | ||
7942 | case 'Unstyled': | ||
7943 | var vdom = html.a; | ||
7944 | return _Utils_Tuple2( | ||
7945 | A2( | ||
7946 | $elm$core$List$cons, | ||
7947 | _Utils_Tuple2(key, vdom), | ||
7948 | pairs), | ||
7949 | styles); | ||
7950 | case 'Node': | ||
7951 | var elemType = html.a; | ||
7952 | var properties = html.b; | ||
7953 | var children = html.c; | ||
7954 | var combinedStyles = A3($elm$core$List$foldl, $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyles, styles, properties); | ||
7955 | var _v9 = A3( | ||
7956 | $elm$core$List$foldl, | ||
7957 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyledHtml, | ||
7958 | _Utils_Tuple2(_List_Nil, combinedStyles), | ||
7959 | children); | ||
7960 | var childNodes = _v9.a; | ||
7961 | var finalStyles = _v9.b; | ||
7962 | var vdom = A3( | ||
7963 | $elm$virtual_dom$VirtualDom$node, | ||
7964 | elemType, | ||
7965 | A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties), | ||
7966 | $elm$core$List$reverse(childNodes)); | ||
7967 | return _Utils_Tuple2( | ||
7968 | A2( | ||
7969 | $elm$core$List$cons, | ||
7970 | _Utils_Tuple2(key, vdom), | ||
7971 | pairs), | ||
7972 | finalStyles); | ||
7973 | case 'NodeNS': | ||
7974 | var ns = html.a; | ||
7975 | var elemType = html.b; | ||
7976 | var properties = html.c; | ||
7977 | var children = html.d; | ||
7978 | var combinedStyles = A3($elm$core$List$foldl, $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyles, styles, properties); | ||
7979 | var _v10 = A3( | ||
7980 | $elm$core$List$foldl, | ||
7981 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyledHtml, | ||
7982 | _Utils_Tuple2(_List_Nil, combinedStyles), | ||
7983 | children); | ||
7984 | var childNodes = _v10.a; | ||
7985 | var finalStyles = _v10.b; | ||
7986 | var vdom = A4( | ||
7987 | $elm$virtual_dom$VirtualDom$nodeNS, | ||
7988 | ns, | ||
7989 | elemType, | ||
7990 | A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties), | ||
7991 | $elm$core$List$reverse(childNodes)); | ||
7992 | return _Utils_Tuple2( | ||
7993 | A2( | ||
7994 | $elm$core$List$cons, | ||
7995 | _Utils_Tuple2(key, vdom), | ||
7996 | pairs), | ||
7997 | finalStyles); | ||
7998 | case 'KeyedNode': | ||
7999 | var elemType = html.a; | ||
8000 | var properties = html.b; | ||
8001 | var children = html.c; | ||
8002 | var combinedStyles = A3($elm$core$List$foldl, $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyles, styles, properties); | ||
8003 | var _v11 = A3( | ||
8004 | $elm$core$List$foldl, | ||
8005 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateKeyedStyledHtml, | ||
8006 | _Utils_Tuple2(_List_Nil, combinedStyles), | ||
8007 | children); | ||
8008 | var childNodes = _v11.a; | ||
8009 | var finalStyles = _v11.b; | ||
8010 | var vdom = A3( | ||
8011 | $elm$virtual_dom$VirtualDom$keyedNode, | ||
8012 | elemType, | ||
8013 | A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties), | ||
8014 | $elm$core$List$reverse(childNodes)); | ||
8015 | return _Utils_Tuple2( | ||
8016 | A2( | ||
8017 | $elm$core$List$cons, | ||
8018 | _Utils_Tuple2(key, vdom), | ||
8019 | pairs), | ||
8020 | finalStyles); | ||
8021 | default: | ||
8022 | var ns = html.a; | ||
8023 | var elemType = html.b; | ||
8024 | var properties = html.c; | ||
8025 | var children = html.d; | ||
8026 | var combinedStyles = A3($elm$core$List$foldl, $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyles, styles, properties); | ||
8027 | var _v12 = A3( | ||
8028 | $elm$core$List$foldl, | ||
8029 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateKeyedStyledHtml, | ||
8030 | _Utils_Tuple2(_List_Nil, combinedStyles), | ||
8031 | children); | ||
8032 | var childNodes = _v12.a; | ||
8033 | var finalStyles = _v12.b; | ||
8034 | var vdom = A4( | ||
8035 | $elm$virtual_dom$VirtualDom$keyedNodeNS, | ||
8036 | ns, | ||
8037 | elemType, | ||
8038 | A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties), | ||
8039 | $elm$core$List$reverse(childNodes)); | ||
8040 | return _Utils_Tuple2( | ||
8041 | A2( | ||
8042 | $elm$core$List$cons, | ||
8043 | _Utils_Tuple2(key, vdom), | ||
8044 | pairs), | ||
8045 | finalStyles); | ||
8046 | } | ||
8047 | }); | ||
8048 | var $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyledHtml = F2( | ||
8049 | function (html, _v0) { | ||
8050 | var nodes = _v0.a; | ||
8051 | var styles = _v0.b; | ||
8052 | switch (html.$) { | ||
8053 | case 'Unstyled': | ||
8054 | var vdomNode = html.a; | ||
8055 | return _Utils_Tuple2( | ||
8056 | A2($elm$core$List$cons, vdomNode, nodes), | ||
8057 | styles); | ||
8058 | case 'Node': | ||
8059 | var elemType = html.a; | ||
8060 | var properties = html.b; | ||
8061 | var children = html.c; | ||
8062 | var combinedStyles = A3($elm$core$List$foldl, $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyles, styles, properties); | ||
8063 | var _v2 = A3( | ||
8064 | $elm$core$List$foldl, | ||
8065 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyledHtml, | ||
8066 | _Utils_Tuple2(_List_Nil, combinedStyles), | ||
8067 | children); | ||
8068 | var childNodes = _v2.a; | ||
8069 | var finalStyles = _v2.b; | ||
8070 | var vdomNode = A3( | ||
8071 | $elm$virtual_dom$VirtualDom$node, | ||
8072 | elemType, | ||
8073 | A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties), | ||
8074 | $elm$core$List$reverse(childNodes)); | ||
8075 | return _Utils_Tuple2( | ||
8076 | A2($elm$core$List$cons, vdomNode, nodes), | ||
8077 | finalStyles); | ||
8078 | case 'NodeNS': | ||
8079 | var ns = html.a; | ||
8080 | var elemType = html.b; | ||
8081 | var properties = html.c; | ||
8082 | var children = html.d; | ||
8083 | var combinedStyles = A3($elm$core$List$foldl, $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyles, styles, properties); | ||
8084 | var _v3 = A3( | ||
8085 | $elm$core$List$foldl, | ||
8086 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyledHtml, | ||
8087 | _Utils_Tuple2(_List_Nil, combinedStyles), | ||
8088 | children); | ||
8089 | var childNodes = _v3.a; | ||
8090 | var finalStyles = _v3.b; | ||
8091 | var vdomNode = A4( | ||
8092 | $elm$virtual_dom$VirtualDom$nodeNS, | ||
8093 | ns, | ||
8094 | elemType, | ||
8095 | A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties), | ||
8096 | $elm$core$List$reverse(childNodes)); | ||
8097 | return _Utils_Tuple2( | ||
8098 | A2($elm$core$List$cons, vdomNode, nodes), | ||
8099 | finalStyles); | ||
8100 | case 'KeyedNode': | ||
8101 | var elemType = html.a; | ||
8102 | var properties = html.b; | ||
8103 | var children = html.c; | ||
8104 | var combinedStyles = A3($elm$core$List$foldl, $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyles, styles, properties); | ||
8105 | var _v4 = A3( | ||
8106 | $elm$core$List$foldl, | ||
8107 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateKeyedStyledHtml, | ||
8108 | _Utils_Tuple2(_List_Nil, combinedStyles), | ||
8109 | children); | ||
8110 | var childNodes = _v4.a; | ||
8111 | var finalStyles = _v4.b; | ||
8112 | var vdomNode = A3( | ||
8113 | $elm$virtual_dom$VirtualDom$keyedNode, | ||
8114 | elemType, | ||
8115 | A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties), | ||
8116 | $elm$core$List$reverse(childNodes)); | ||
8117 | return _Utils_Tuple2( | ||
8118 | A2($elm$core$List$cons, vdomNode, nodes), | ||
8119 | finalStyles); | ||
8120 | default: | ||
8121 | var ns = html.a; | ||
8122 | var elemType = html.b; | ||
8123 | var properties = html.c; | ||
8124 | var children = html.d; | ||
8125 | var combinedStyles = A3($elm$core$List$foldl, $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyles, styles, properties); | ||
8126 | var _v5 = A3( | ||
8127 | $elm$core$List$foldl, | ||
8128 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateKeyedStyledHtml, | ||
8129 | _Utils_Tuple2(_List_Nil, combinedStyles), | ||
8130 | children); | ||
8131 | var childNodes = _v5.a; | ||
8132 | var finalStyles = _v5.b; | ||
8133 | var vdomNode = A4( | ||
8134 | $elm$virtual_dom$VirtualDom$keyedNodeNS, | ||
8135 | ns, | ||
8136 | elemType, | ||
8137 | A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties), | ||
8138 | $elm$core$List$reverse(childNodes)); | ||
8139 | return _Utils_Tuple2( | ||
8140 | A2($elm$core$List$cons, vdomNode, nodes), | ||
8141 | finalStyles); | ||
8142 | } | ||
8143 | }); | ||
8144 | var $elm$core$Dict$singleton = F2( | ||
8145 | function (key, value) { | ||
8146 | return A5($elm$core$Dict$RBNode_elm_builtin, $elm$core$Dict$Black, key, value, $elm$core$Dict$RBEmpty_elm_builtin, $elm$core$Dict$RBEmpty_elm_builtin); | ||
8147 | }); | ||
8148 | var $rtfeldman$elm_css$VirtualDom$Styled$stylesFromPropertiesHelp = F2( | ||
8149 | function (candidate, properties) { | ||
8150 | stylesFromPropertiesHelp: | ||
8151 | while (true) { | ||
8152 | if (!properties.b) { | ||
8153 | return candidate; | ||
8154 | } else { | ||
8155 | var _v1 = properties.a; | ||
8156 | var styles = _v1.b; | ||
8157 | var classname = _v1.c; | ||
8158 | var rest = properties.b; | ||
8159 | if ($elm$core$String$isEmpty(classname)) { | ||
8160 | var $temp$candidate = candidate, | ||
8161 | $temp$properties = rest; | ||
8162 | candidate = $temp$candidate; | ||
8163 | properties = $temp$properties; | ||
8164 | continue stylesFromPropertiesHelp; | ||
8165 | } else { | ||
8166 | var $temp$candidate = $elm$core$Maybe$Just( | ||
8167 | _Utils_Tuple2(classname, styles)), | ||
8168 | $temp$properties = rest; | ||
8169 | candidate = $temp$candidate; | ||
8170 | properties = $temp$properties; | ||
8171 | continue stylesFromPropertiesHelp; | ||
8172 | } | ||
8173 | } | ||
8174 | } | ||
8175 | }); | ||
8176 | var $rtfeldman$elm_css$VirtualDom$Styled$stylesFromProperties = function (properties) { | ||
8177 | var _v0 = A2($rtfeldman$elm_css$VirtualDom$Styled$stylesFromPropertiesHelp, $elm$core$Maybe$Nothing, properties); | ||
8178 | if (_v0.$ === 'Nothing') { | ||
8179 | return $elm$core$Dict$empty; | ||
8180 | } else { | ||
8181 | var _v1 = _v0.a; | ||
8182 | var classname = _v1.a; | ||
8183 | var styles = _v1.b; | ||
8184 | return A2($elm$core$Dict$singleton, classname, styles); | ||
8185 | } | ||
8186 | }; | ||
8187 | var $elm$virtual_dom$VirtualDom$text = _VirtualDom_text; | ||
8188 | var $rtfeldman$elm_css$Css$Structure$compactHelp = F2( | ||
8189 | function (declaration, _v0) { | ||
8190 | var keyframesByName = _v0.a; | ||
8191 | var declarations = _v0.b; | ||
8192 | switch (declaration.$) { | ||
8193 | case 'StyleBlockDeclaration': | ||
8194 | var _v2 = declaration.a; | ||
8195 | var properties = _v2.c; | ||
8196 | return $elm$core$List$isEmpty(properties) ? _Utils_Tuple2(keyframesByName, declarations) : _Utils_Tuple2( | ||
8197 | keyframesByName, | ||
8198 | A2($elm$core$List$cons, declaration, declarations)); | ||
8199 | case 'MediaRule': | ||
8200 | var styleBlocks = declaration.b; | ||
8201 | return A2( | ||
8202 | $elm$core$List$all, | ||
8203 | function (_v3) { | ||
8204 | var properties = _v3.c; | ||
8205 | return $elm$core$List$isEmpty(properties); | ||
8206 | }, | ||
8207 | styleBlocks) ? _Utils_Tuple2(keyframesByName, declarations) : _Utils_Tuple2( | ||
8208 | keyframesByName, | ||
8209 | A2($elm$core$List$cons, declaration, declarations)); | ||
8210 | case 'SupportsRule': | ||
8211 | var otherDeclarations = declaration.b; | ||
8212 | return $elm$core$List$isEmpty(otherDeclarations) ? _Utils_Tuple2(keyframesByName, declarations) : _Utils_Tuple2( | ||
8213 | keyframesByName, | ||
8214 | A2($elm$core$List$cons, declaration, declarations)); | ||
8215 | case 'DocumentRule': | ||
8216 | return _Utils_Tuple2( | ||
8217 | keyframesByName, | ||
8218 | A2($elm$core$List$cons, declaration, declarations)); | ||
8219 | case 'PageRule': | ||
8220 | var properties = declaration.b; | ||
8221 | return $elm$core$List$isEmpty(properties) ? _Utils_Tuple2(keyframesByName, declarations) : _Utils_Tuple2( | ||
8222 | keyframesByName, | ||
8223 | A2($elm$core$List$cons, declaration, declarations)); | ||
8224 | case 'FontFace': | ||
8225 | var properties = declaration.a; | ||
8226 | return $elm$core$List$isEmpty(properties) ? _Utils_Tuple2(keyframesByName, declarations) : _Utils_Tuple2( | ||
8227 | keyframesByName, | ||
8228 | A2($elm$core$List$cons, declaration, declarations)); | ||
8229 | case 'Keyframes': | ||
8230 | var record = declaration.a; | ||
8231 | return $elm$core$String$isEmpty(record.declaration) ? _Utils_Tuple2(keyframesByName, declarations) : _Utils_Tuple2( | ||
8232 | A3($elm$core$Dict$insert, record.name, record.declaration, keyframesByName), | ||
8233 | declarations); | ||
8234 | case 'Viewport': | ||
8235 | var properties = declaration.a; | ||
8236 | return $elm$core$List$isEmpty(properties) ? _Utils_Tuple2(keyframesByName, declarations) : _Utils_Tuple2( | ||
8237 | keyframesByName, | ||
8238 | A2($elm$core$List$cons, declaration, declarations)); | ||
8239 | case 'CounterStyle': | ||
8240 | var properties = declaration.a; | ||
8241 | return $elm$core$List$isEmpty(properties) ? _Utils_Tuple2(keyframesByName, declarations) : _Utils_Tuple2( | ||
8242 | keyframesByName, | ||
8243 | A2($elm$core$List$cons, declaration, declarations)); | ||
8244 | default: | ||
8245 | var tuples = declaration.a; | ||
8246 | return A2( | ||
8247 | $elm$core$List$all, | ||
8248 | function (_v4) { | ||
8249 | var properties = _v4.b; | ||
8250 | return $elm$core$List$isEmpty(properties); | ||
8251 | }, | ||
8252 | tuples) ? _Utils_Tuple2(keyframesByName, declarations) : _Utils_Tuple2( | ||
8253 | keyframesByName, | ||
8254 | A2($elm$core$List$cons, declaration, declarations)); | ||
8255 | } | ||
8256 | }); | ||
8257 | var $rtfeldman$elm_css$Css$Structure$Keyframes = function (a) { | ||
8258 | return {$: 'Keyframes', a: a}; | ||
8259 | }; | ||
8260 | var $rtfeldman$elm_css$Css$Structure$withKeyframeDeclarations = F2( | ||
8261 | function (keyframesByName, compactedDeclarations) { | ||
8262 | return A2( | ||
8263 | $elm$core$List$append, | ||
8264 | A2( | ||
8265 | $elm$core$List$map, | ||
8266 | function (_v0) { | ||
8267 | var name = _v0.a; | ||
8268 | var decl = _v0.b; | ||
8269 | return $rtfeldman$elm_css$Css$Structure$Keyframes( | ||
8270 | {declaration: decl, name: name}); | ||
8271 | }, | ||
8272 | $elm$core$Dict$toList(keyframesByName)), | ||
8273 | compactedDeclarations); | ||
8274 | }); | ||
8275 | var $rtfeldman$elm_css$Css$Structure$compactStylesheet = function (_v0) { | ||
8276 | var charset = _v0.charset; | ||
8277 | var imports = _v0.imports; | ||
8278 | var namespaces = _v0.namespaces; | ||
8279 | var declarations = _v0.declarations; | ||
8280 | var _v1 = A3( | ||
8281 | $elm$core$List$foldr, | ||
8282 | $rtfeldman$elm_css$Css$Structure$compactHelp, | ||
8283 | _Utils_Tuple2($elm$core$Dict$empty, _List_Nil), | ||
8284 | declarations); | ||
8285 | var keyframesByName = _v1.a; | ||
8286 | var compactedDeclarations = _v1.b; | ||
8287 | var finalDeclarations = A2($rtfeldman$elm_css$Css$Structure$withKeyframeDeclarations, keyframesByName, compactedDeclarations); | ||
8288 | return {charset: charset, declarations: finalDeclarations, imports: imports, namespaces: namespaces}; | ||
8289 | }; | ||
8290 | var $elm$core$Maybe$map = F2( | ||
8291 | function (f, maybe) { | ||
8292 | if (maybe.$ === 'Just') { | ||
8293 | var value = maybe.a; | ||
8294 | return $elm$core$Maybe$Just( | ||
8295 | f(value)); | ||
8296 | } else { | ||
8297 | return $elm$core$Maybe$Nothing; | ||
8298 | } | ||
8299 | }); | ||
8300 | var $rtfeldman$elm_css$Css$Structure$Output$charsetToString = function (charset) { | ||
8301 | return A2( | ||
8302 | $elm$core$Maybe$withDefault, | ||
8303 | '', | ||
8304 | A2( | ||
8305 | $elm$core$Maybe$map, | ||
8306 | function (str) { | ||
8307 | return '@charset \"' + (str + '\"'); | ||
8308 | }, | ||
8309 | charset)); | ||
8310 | }; | ||
8311 | var $elm$core$List$filter = F2( | ||
8312 | function (isGood, list) { | ||
8313 | return A3( | ||
8314 | $elm$core$List$foldr, | ||
8315 | F2( | ||
8316 | function (x, xs) { | ||
8317 | return isGood(x) ? A2($elm$core$List$cons, x, xs) : xs; | ||
8318 | }), | ||
8319 | _List_Nil, | ||
8320 | list); | ||
8321 | }); | ||
8322 | var $rtfeldman$elm_css$Css$Structure$Output$mediaExpressionToString = function (expression) { | ||
8323 | return '(' + (expression.feature + (A2( | ||
8324 | $elm$core$Maybe$withDefault, | ||
8325 | '', | ||
8326 | A2( | ||
8327 | $elm$core$Maybe$map, | ||
8328 | $elm$core$Basics$append(': '), | ||
8329 | expression.value)) + ')')); | ||
8330 | }; | ||
8331 | var $rtfeldman$elm_css$Css$Structure$Output$mediaTypeToString = function (mediaType) { | ||
8332 | switch (mediaType.$) { | ||
8333 | case 'Print': | ||
8334 | return 'print'; | ||
8335 | case 'Screen': | ||
8336 | return 'screen'; | ||
8337 | default: | ||
8338 | return 'speech'; | ||
8339 | } | ||
8340 | }; | ||
8341 | var $rtfeldman$elm_css$Css$Structure$Output$mediaQueryToString = function (mediaQuery) { | ||
8342 | var prefixWith = F3( | ||
8343 | function (str, mediaType, expressions) { | ||
8344 | return str + (' ' + A2( | ||
8345 | $elm$core$String$join, | ||
8346 | ' and ', | ||
8347 | A2( | ||
8348 | $elm$core$List$cons, | ||
8349 | $rtfeldman$elm_css$Css$Structure$Output$mediaTypeToString(mediaType), | ||
8350 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$mediaExpressionToString, expressions)))); | ||
8351 | }); | ||
8352 | switch (mediaQuery.$) { | ||
8353 | case 'AllQuery': | ||
8354 | var expressions = mediaQuery.a; | ||
8355 | return A2( | ||
8356 | $elm$core$String$join, | ||
8357 | ' and ', | ||
8358 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$mediaExpressionToString, expressions)); | ||
8359 | case 'OnlyQuery': | ||
8360 | var mediaType = mediaQuery.a; | ||
8361 | var expressions = mediaQuery.b; | ||
8362 | return A3(prefixWith, 'only', mediaType, expressions); | ||
8363 | case 'NotQuery': | ||
8364 | var mediaType = mediaQuery.a; | ||
8365 | var expressions = mediaQuery.b; | ||
8366 | return A3(prefixWith, 'not', mediaType, expressions); | ||
8367 | default: | ||
8368 | var str = mediaQuery.a; | ||
8369 | return str; | ||
8370 | } | ||
8371 | }; | ||
8372 | var $rtfeldman$elm_css$Css$Structure$Output$importMediaQueryToString = F2( | ||
8373 | function (name, mediaQuery) { | ||
8374 | return '@import \"' + (name + ($rtfeldman$elm_css$Css$Structure$Output$mediaQueryToString(mediaQuery) + '\"')); | ||
8375 | }); | ||
8376 | var $rtfeldman$elm_css$Css$Structure$Output$importToString = function (_v0) { | ||
8377 | var name = _v0.a; | ||
8378 | var mediaQueries = _v0.b; | ||
8379 | return A2( | ||
8380 | $elm$core$String$join, | ||
8381 | '\n', | ||
8382 | A2( | ||
8383 | $elm$core$List$map, | ||
8384 | $rtfeldman$elm_css$Css$Structure$Output$importMediaQueryToString(name), | ||
8385 | mediaQueries)); | ||
8386 | }; | ||
8387 | var $rtfeldman$elm_css$Css$Structure$Output$namespaceToString = function (_v0) { | ||
8388 | var prefix = _v0.a; | ||
8389 | var str = _v0.b; | ||
8390 | return '@namespace ' + (prefix + ('\"' + (str + '\"'))); | ||
8391 | }; | ||
8392 | var $rtfeldman$elm_css$Css$Structure$Output$spaceIndent = ' '; | ||
8393 | var $rtfeldman$elm_css$Css$Structure$Output$indent = function (str) { | ||
8394 | return _Utils_ap($rtfeldman$elm_css$Css$Structure$Output$spaceIndent, str); | ||
8395 | }; | ||
8396 | var $rtfeldman$elm_css$Css$Structure$Output$noIndent = ''; | ||
8397 | var $rtfeldman$elm_css$Css$Structure$Output$emitProperty = function (str) { | ||
8398 | return str + ';'; | ||
8399 | }; | ||
8400 | var $rtfeldman$elm_css$Css$Structure$Output$emitProperties = function (properties) { | ||
8401 | return A2( | ||
8402 | $elm$core$String$join, | ||
8403 | '\n', | ||
8404 | A2( | ||
8405 | $elm$core$List$map, | ||
8406 | A2($elm$core$Basics$composeL, $rtfeldman$elm_css$Css$Structure$Output$indent, $rtfeldman$elm_css$Css$Structure$Output$emitProperty), | ||
8407 | properties)); | ||
8408 | }; | ||
8409 | var $elm$core$String$append = _String_append; | ||
8410 | var $rtfeldman$elm_css$Css$Structure$Output$pseudoElementToString = function (_v0) { | ||
8411 | var str = _v0.a; | ||
8412 | return '::' + str; | ||
8413 | }; | ||
8414 | var $rtfeldman$elm_css$Css$Structure$Output$combinatorToString = function (combinator) { | ||
8415 | switch (combinator.$) { | ||
8416 | case 'AdjacentSibling': | ||
8417 | return '+'; | ||
8418 | case 'GeneralSibling': | ||
8419 | return '~'; | ||
8420 | case 'Child': | ||
8421 | return '>'; | ||
8422 | default: | ||
8423 | return ''; | ||
8424 | } | ||
8425 | }; | ||
8426 | var $rtfeldman$elm_css$Css$Structure$Output$repeatableSimpleSelectorToString = function (repeatableSimpleSelector) { | ||
8427 | switch (repeatableSimpleSelector.$) { | ||
8428 | case 'ClassSelector': | ||
8429 | var str = repeatableSimpleSelector.a; | ||
8430 | return '.' + str; | ||
8431 | case 'IdSelector': | ||
8432 | var str = repeatableSimpleSelector.a; | ||
8433 | return '#' + str; | ||
8434 | case 'PseudoClassSelector': | ||
8435 | var str = repeatableSimpleSelector.a; | ||
8436 | return ':' + str; | ||
8437 | default: | ||
8438 | var str = repeatableSimpleSelector.a; | ||
8439 | return '[' + (str + ']'); | ||
8440 | } | ||
8441 | }; | ||
8442 | var $rtfeldman$elm_css$Css$Structure$Output$simpleSelectorSequenceToString = function (simpleSelectorSequence) { | ||
8443 | switch (simpleSelectorSequence.$) { | ||
8444 | case 'TypeSelectorSequence': | ||
8445 | var str = simpleSelectorSequence.a.a; | ||
8446 | var repeatableSimpleSelectors = simpleSelectorSequence.b; | ||
8447 | return A2( | ||
8448 | $elm$core$String$join, | ||
8449 | '', | ||
8450 | A2( | ||
8451 | $elm$core$List$cons, | ||
8452 | str, | ||
8453 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$repeatableSimpleSelectorToString, repeatableSimpleSelectors))); | ||
8454 | case 'UniversalSelectorSequence': | ||
8455 | var repeatableSimpleSelectors = simpleSelectorSequence.a; | ||
8456 | return $elm$core$List$isEmpty(repeatableSimpleSelectors) ? '*' : A2( | ||
8457 | $elm$core$String$join, | ||
8458 | '', | ||
8459 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$repeatableSimpleSelectorToString, repeatableSimpleSelectors)); | ||
8460 | default: | ||
8461 | var str = simpleSelectorSequence.a; | ||
8462 | var repeatableSimpleSelectors = simpleSelectorSequence.b; | ||
8463 | return A2( | ||
8464 | $elm$core$String$join, | ||
8465 | '', | ||
8466 | A2( | ||
8467 | $elm$core$List$cons, | ||
8468 | str, | ||
8469 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$repeatableSimpleSelectorToString, repeatableSimpleSelectors))); | ||
8470 | } | ||
8471 | }; | ||
8472 | var $rtfeldman$elm_css$Css$Structure$Output$selectorChainToString = function (_v0) { | ||
8473 | var combinator = _v0.a; | ||
8474 | var sequence = _v0.b; | ||
8475 | return A2( | ||
8476 | $elm$core$String$join, | ||
8477 | ' ', | ||
8478 | _List_fromArray( | ||
8479 | [ | ||
8480 | $rtfeldman$elm_css$Css$Structure$Output$combinatorToString(combinator), | ||
8481 | $rtfeldman$elm_css$Css$Structure$Output$simpleSelectorSequenceToString(sequence) | ||
8482 | ])); | ||
8483 | }; | ||
8484 | var $rtfeldman$elm_css$Css$Structure$Output$selectorToString = function (_v0) { | ||
8485 | var simpleSelectorSequence = _v0.a; | ||
8486 | var chain = _v0.b; | ||
8487 | var pseudoElement = _v0.c; | ||
8488 | var segments = A2( | ||
8489 | $elm$core$List$cons, | ||
8490 | $rtfeldman$elm_css$Css$Structure$Output$simpleSelectorSequenceToString(simpleSelectorSequence), | ||
8491 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$selectorChainToString, chain)); | ||
8492 | var pseudoElementsString = A2( | ||
8493 | $elm$core$String$join, | ||
8494 | '', | ||
8495 | _List_fromArray( | ||
8496 | [ | ||
8497 | A2( | ||
8498 | $elm$core$Maybe$withDefault, | ||
8499 | '', | ||
8500 | A2($elm$core$Maybe$map, $rtfeldman$elm_css$Css$Structure$Output$pseudoElementToString, pseudoElement)) | ||
8501 | ])); | ||
8502 | return A2( | ||
8503 | $elm$core$String$append, | ||
8504 | A2( | ||
8505 | $elm$core$String$join, | ||
8506 | ' ', | ||
8507 | A2( | ||
8508 | $elm$core$List$filter, | ||
8509 | A2($elm$core$Basics$composeL, $elm$core$Basics$not, $elm$core$String$isEmpty), | ||
8510 | segments)), | ||
8511 | pseudoElementsString); | ||
8512 | }; | ||
8513 | var $rtfeldman$elm_css$Css$Structure$Output$prettyPrintStyleBlock = F2( | ||
8514 | function (indentLevel, _v0) { | ||
8515 | var firstSelector = _v0.a; | ||
8516 | var otherSelectors = _v0.b; | ||
8517 | var properties = _v0.c; | ||
8518 | var selectorStr = A2( | ||
8519 | $elm$core$String$join, | ||
8520 | ', ', | ||
8521 | A2( | ||
8522 | $elm$core$List$map, | ||
8523 | $rtfeldman$elm_css$Css$Structure$Output$selectorToString, | ||
8524 | A2($elm$core$List$cons, firstSelector, otherSelectors))); | ||
8525 | return A2( | ||
8526 | $elm$core$String$join, | ||
8527 | '', | ||
8528 | _List_fromArray( | ||
8529 | [ | ||
8530 | selectorStr, | ||
8531 | ' {\n', | ||
8532 | indentLevel, | ||
8533 | $rtfeldman$elm_css$Css$Structure$Output$emitProperties(properties), | ||
8534 | '\n', | ||
8535 | indentLevel, | ||
8536 | '}' | ||
8537 | ])); | ||
8538 | }); | ||
8539 | var $rtfeldman$elm_css$Css$Structure$Output$prettyPrintDeclaration = function (decl) { | ||
8540 | switch (decl.$) { | ||
8541 | case 'StyleBlockDeclaration': | ||
8542 | var styleBlock = decl.a; | ||
8543 | return A2($rtfeldman$elm_css$Css$Structure$Output$prettyPrintStyleBlock, $rtfeldman$elm_css$Css$Structure$Output$noIndent, styleBlock); | ||
8544 | case 'MediaRule': | ||
8545 | var mediaQueries = decl.a; | ||
8546 | var styleBlocks = decl.b; | ||
8547 | var query = A2( | ||
8548 | $elm$core$String$join, | ||
8549 | ',\n', | ||
8550 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$mediaQueryToString, mediaQueries)); | ||
8551 | var blocks = A2( | ||
8552 | $elm$core$String$join, | ||
8553 | '\n\n', | ||
8554 | A2( | ||
8555 | $elm$core$List$map, | ||
8556 | A2( | ||
8557 | $elm$core$Basics$composeL, | ||
8558 | $rtfeldman$elm_css$Css$Structure$Output$indent, | ||
8559 | $rtfeldman$elm_css$Css$Structure$Output$prettyPrintStyleBlock($rtfeldman$elm_css$Css$Structure$Output$spaceIndent)), | ||
8560 | styleBlocks)); | ||
8561 | return '@media ' + (query + (' {\n' + (blocks + '\n}'))); | ||
8562 | case 'SupportsRule': | ||
8563 | return 'TODO'; | ||
8564 | case 'DocumentRule': | ||
8565 | return 'TODO'; | ||
8566 | case 'PageRule': | ||
8567 | return 'TODO'; | ||
8568 | case 'FontFace': | ||
8569 | return 'TODO'; | ||
8570 | case 'Keyframes': | ||
8571 | var name = decl.a.name; | ||
8572 | var declaration = decl.a.declaration; | ||
8573 | return '@keyframes ' + (name + (' {\n' + (declaration + '\n}'))); | ||
8574 | case 'Viewport': | ||
8575 | return 'TODO'; | ||
8576 | case 'CounterStyle': | ||
8577 | return 'TODO'; | ||
8578 | default: | ||
8579 | return 'TODO'; | ||
8580 | } | ||
8581 | }; | ||
8582 | var $rtfeldman$elm_css$Css$Structure$Output$prettyPrint = function (_v0) { | ||
8583 | var charset = _v0.charset; | ||
8584 | var imports = _v0.imports; | ||
8585 | var namespaces = _v0.namespaces; | ||
8586 | var declarations = _v0.declarations; | ||
8587 | return A2( | ||
8588 | $elm$core$String$join, | ||
8589 | '\n\n', | ||
8590 | A2( | ||
8591 | $elm$core$List$filter, | ||
8592 | A2($elm$core$Basics$composeL, $elm$core$Basics$not, $elm$core$String$isEmpty), | ||
8593 | _List_fromArray( | ||
8594 | [ | ||
8595 | $rtfeldman$elm_css$Css$Structure$Output$charsetToString(charset), | ||
8596 | A2( | ||
8597 | $elm$core$String$join, | ||
8598 | '\n', | ||
8599 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$importToString, imports)), | ||
8600 | A2( | ||
8601 | $elm$core$String$join, | ||
8602 | '\n', | ||
8603 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$namespaceToString, namespaces)), | ||
8604 | A2( | ||
8605 | $elm$core$String$join, | ||
8606 | '\n\n', | ||
8607 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Structure$Output$prettyPrintDeclaration, declarations)) | ||
8608 | ]))); | ||
8609 | }; | ||
8610 | var $rtfeldman$elm_css$Css$Structure$CounterStyle = function (a) { | ||
8611 | return {$: 'CounterStyle', a: a}; | ||
8612 | }; | ||
8613 | var $rtfeldman$elm_css$Css$Structure$FontFace = function (a) { | ||
8614 | return {$: 'FontFace', a: a}; | ||
8615 | }; | ||
8616 | var $rtfeldman$elm_css$Css$Structure$PageRule = F2( | ||
8617 | function (a, b) { | ||
8618 | return {$: 'PageRule', a: a, b: b}; | ||
8619 | }); | ||
8620 | var $rtfeldman$elm_css$Css$Structure$Selector = F3( | ||
8621 | function (a, b, c) { | ||
8622 | return {$: 'Selector', a: a, b: b, c: c}; | ||
8623 | }); | ||
8624 | var $rtfeldman$elm_css$Css$Structure$StyleBlock = F3( | ||
8625 | function (a, b, c) { | ||
8626 | return {$: 'StyleBlock', a: a, b: b, c: c}; | ||
8627 | }); | ||
8628 | var $rtfeldman$elm_css$Css$Structure$StyleBlockDeclaration = function (a) { | ||
8629 | return {$: 'StyleBlockDeclaration', a: a}; | ||
8630 | }; | ||
8631 | var $rtfeldman$elm_css$Css$Structure$SupportsRule = F2( | ||
8632 | function (a, b) { | ||
8633 | return {$: 'SupportsRule', a: a, b: b}; | ||
8634 | }); | ||
8635 | var $rtfeldman$elm_css$Css$Structure$Viewport = function (a) { | ||
8636 | return {$: 'Viewport', a: a}; | ||
8637 | }; | ||
8638 | var $rtfeldman$elm_css$Css$Structure$MediaRule = F2( | ||
8639 | function (a, b) { | ||
8640 | return {$: 'MediaRule', a: a, b: b}; | ||
8641 | }); | ||
8642 | var $rtfeldman$elm_css$Css$Structure$mapLast = F2( | ||
8643 | function (update, list) { | ||
8644 | if (!list.b) { | ||
8645 | return list; | ||
8646 | } else { | ||
8647 | if (!list.b.b) { | ||
8648 | var only = list.a; | ||
8649 | return _List_fromArray( | ||
8650 | [ | ||
8651 | update(only) | ||
8652 | ]); | ||
8653 | } else { | ||
8654 | var first = list.a; | ||
8655 | var rest = list.b; | ||
8656 | return A2( | ||
8657 | $elm$core$List$cons, | ||
8658 | first, | ||
8659 | A2($rtfeldman$elm_css$Css$Structure$mapLast, update, rest)); | ||
8660 | } | ||
8661 | } | ||
8662 | }); | ||
8663 | var $rtfeldman$elm_css$Css$Structure$withPropertyAppended = F2( | ||
8664 | function (property, _v0) { | ||
8665 | var firstSelector = _v0.a; | ||
8666 | var otherSelectors = _v0.b; | ||
8667 | var properties = _v0.c; | ||
8668 | return A3( | ||
8669 | $rtfeldman$elm_css$Css$Structure$StyleBlock, | ||
8670 | firstSelector, | ||
8671 | otherSelectors, | ||
8672 | _Utils_ap( | ||
8673 | properties, | ||
8674 | _List_fromArray( | ||
8675 | [property]))); | ||
8676 | }); | ||
8677 | var $rtfeldman$elm_css$Css$Structure$appendProperty = F2( | ||
8678 | function (property, declarations) { | ||
8679 | if (!declarations.b) { | ||
8680 | return declarations; | ||
8681 | } else { | ||
8682 | if (!declarations.b.b) { | ||
8683 | switch (declarations.a.$) { | ||
8684 | case 'StyleBlockDeclaration': | ||
8685 | var styleBlock = declarations.a.a; | ||
8686 | return _List_fromArray( | ||
8687 | [ | ||
8688 | $rtfeldman$elm_css$Css$Structure$StyleBlockDeclaration( | ||
8689 | A2($rtfeldman$elm_css$Css$Structure$withPropertyAppended, property, styleBlock)) | ||
8690 | ]); | ||
8691 | case 'MediaRule': | ||
8692 | var _v1 = declarations.a; | ||
8693 | var mediaQueries = _v1.a; | ||
8694 | var styleBlocks = _v1.b; | ||
8695 | return _List_fromArray( | ||
8696 | [ | ||
8697 | A2( | ||
8698 | $rtfeldman$elm_css$Css$Structure$MediaRule, | ||
8699 | mediaQueries, | ||
8700 | A2( | ||
8701 | $rtfeldman$elm_css$Css$Structure$mapLast, | ||
8702 | $rtfeldman$elm_css$Css$Structure$withPropertyAppended(property), | ||
8703 | styleBlocks)) | ||
8704 | ]); | ||
8705 | default: | ||
8706 | return declarations; | ||
8707 | } | ||
8708 | } else { | ||
8709 | var first = declarations.a; | ||
8710 | var rest = declarations.b; | ||
8711 | return A2( | ||
8712 | $elm$core$List$cons, | ||
8713 | first, | ||
8714 | A2($rtfeldman$elm_css$Css$Structure$appendProperty, property, rest)); | ||
8715 | } | ||
8716 | } | ||
8717 | }); | ||
8718 | var $rtfeldman$elm_css$Css$Structure$appendToLastSelector = F2( | ||
8719 | function (f, styleBlock) { | ||
8720 | if (!styleBlock.b.b) { | ||
8721 | var only = styleBlock.a; | ||
8722 | var properties = styleBlock.c; | ||
8723 | return _List_fromArray( | ||
8724 | [ | ||
8725 | A3($rtfeldman$elm_css$Css$Structure$StyleBlock, only, _List_Nil, properties), | ||
8726 | A3( | ||
8727 | $rtfeldman$elm_css$Css$Structure$StyleBlock, | ||
8728 | f(only), | ||
8729 | _List_Nil, | ||
8730 | _List_Nil) | ||
8731 | ]); | ||
8732 | } else { | ||
8733 | var first = styleBlock.a; | ||
8734 | var rest = styleBlock.b; | ||
8735 | var properties = styleBlock.c; | ||
8736 | var newRest = A2($elm$core$List$map, f, rest); | ||
8737 | var newFirst = f(first); | ||
8738 | return _List_fromArray( | ||
8739 | [ | ||
8740 | A3($rtfeldman$elm_css$Css$Structure$StyleBlock, first, rest, properties), | ||
8741 | A3($rtfeldman$elm_css$Css$Structure$StyleBlock, newFirst, newRest, _List_Nil) | ||
8742 | ]); | ||
8743 | } | ||
8744 | }); | ||
8745 | var $rtfeldman$elm_css$Css$Structure$applyPseudoElement = F2( | ||
8746 | function (pseudo, _v0) { | ||
8747 | var sequence = _v0.a; | ||
8748 | var selectors = _v0.b; | ||
8749 | return A3( | ||
8750 | $rtfeldman$elm_css$Css$Structure$Selector, | ||
8751 | sequence, | ||
8752 | selectors, | ||
8753 | $elm$core$Maybe$Just(pseudo)); | ||
8754 | }); | ||
8755 | var $rtfeldman$elm_css$Css$Structure$appendPseudoElementToLastSelector = F2( | ||
8756 | function (pseudo, styleBlock) { | ||
8757 | return A2( | ||
8758 | $rtfeldman$elm_css$Css$Structure$appendToLastSelector, | ||
8759 | $rtfeldman$elm_css$Css$Structure$applyPseudoElement(pseudo), | ||
8760 | styleBlock); | ||
8761 | }); | ||
8762 | var $rtfeldman$elm_css$Css$Structure$CustomSelector = F2( | ||
8763 | function (a, b) { | ||
8764 | return {$: 'CustomSelector', a: a, b: b}; | ||
8765 | }); | ||
8766 | var $rtfeldman$elm_css$Css$Structure$TypeSelectorSequence = F2( | ||
8767 | function (a, b) { | ||
8768 | return {$: 'TypeSelectorSequence', a: a, b: b}; | ||
8769 | }); | ||
8770 | var $rtfeldman$elm_css$Css$Structure$UniversalSelectorSequence = function (a) { | ||
8771 | return {$: 'UniversalSelectorSequence', a: a}; | ||
8772 | }; | ||
8773 | var $rtfeldman$elm_css$Css$Structure$appendRepeatable = F2( | ||
8774 | function (selector, sequence) { | ||
8775 | switch (sequence.$) { | ||
8776 | case 'TypeSelectorSequence': | ||
8777 | var typeSelector = sequence.a; | ||
8778 | var list = sequence.b; | ||
8779 | return A2( | ||
8780 | $rtfeldman$elm_css$Css$Structure$TypeSelectorSequence, | ||
8781 | typeSelector, | ||
8782 | _Utils_ap( | ||
8783 | list, | ||
8784 | _List_fromArray( | ||
8785 | [selector]))); | ||
8786 | case 'UniversalSelectorSequence': | ||
8787 | var list = sequence.a; | ||
8788 | return $rtfeldman$elm_css$Css$Structure$UniversalSelectorSequence( | ||
8789 | _Utils_ap( | ||
8790 | list, | ||
8791 | _List_fromArray( | ||
8792 | [selector]))); | ||
8793 | default: | ||
8794 | var str = sequence.a; | ||
8795 | var list = sequence.b; | ||
8796 | return A2( | ||
8797 | $rtfeldman$elm_css$Css$Structure$CustomSelector, | ||
8798 | str, | ||
8799 | _Utils_ap( | ||
8800 | list, | ||
8801 | _List_fromArray( | ||
8802 | [selector]))); | ||
8803 | } | ||
8804 | }); | ||
8805 | var $rtfeldman$elm_css$Css$Structure$appendRepeatableWithCombinator = F2( | ||
8806 | function (selector, list) { | ||
8807 | if (!list.b) { | ||
8808 | return _List_Nil; | ||
8809 | } else { | ||
8810 | if (!list.b.b) { | ||
8811 | var _v1 = list.a; | ||
8812 | var combinator = _v1.a; | ||
8813 | var sequence = _v1.b; | ||
8814 | return _List_fromArray( | ||
8815 | [ | ||
8816 | _Utils_Tuple2( | ||
8817 | combinator, | ||
8818 | A2($rtfeldman$elm_css$Css$Structure$appendRepeatable, selector, sequence)) | ||
8819 | ]); | ||
8820 | } else { | ||
8821 | var first = list.a; | ||
8822 | var rest = list.b; | ||
8823 | return A2( | ||
8824 | $elm$core$List$cons, | ||
8825 | first, | ||
8826 | A2($rtfeldman$elm_css$Css$Structure$appendRepeatableWithCombinator, selector, rest)); | ||
8827 | } | ||
8828 | } | ||
8829 | }); | ||
8830 | var $rtfeldman$elm_css$Css$Structure$appendRepeatableSelector = F2( | ||
8831 | function (repeatableSimpleSelector, selector) { | ||
8832 | if (!selector.b.b) { | ||
8833 | var sequence = selector.a; | ||
8834 | var pseudoElement = selector.c; | ||
8835 | return A3( | ||
8836 | $rtfeldman$elm_css$Css$Structure$Selector, | ||
8837 | A2($rtfeldman$elm_css$Css$Structure$appendRepeatable, repeatableSimpleSelector, sequence), | ||
8838 | _List_Nil, | ||
8839 | pseudoElement); | ||
8840 | } else { | ||
8841 | var firstSelector = selector.a; | ||
8842 | var tuples = selector.b; | ||
8843 | var pseudoElement = selector.c; | ||
8844 | return A3( | ||
8845 | $rtfeldman$elm_css$Css$Structure$Selector, | ||
8846 | firstSelector, | ||
8847 | A2($rtfeldman$elm_css$Css$Structure$appendRepeatableWithCombinator, repeatableSimpleSelector, tuples), | ||
8848 | pseudoElement); | ||
8849 | } | ||
8850 | }); | ||
8851 | var $rtfeldman$elm_css$Css$Structure$appendRepeatableToLastSelector = F2( | ||
8852 | function (selector, styleBlock) { | ||
8853 | return A2( | ||
8854 | $rtfeldman$elm_css$Css$Structure$appendToLastSelector, | ||
8855 | $rtfeldman$elm_css$Css$Structure$appendRepeatableSelector(selector), | ||
8856 | styleBlock); | ||
8857 | }); | ||
8858 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$collectSelectors = function (declarations) { | ||
8859 | collectSelectors: | ||
8860 | while (true) { | ||
8861 | if (!declarations.b) { | ||
8862 | return _List_Nil; | ||
8863 | } else { | ||
8864 | if (declarations.a.$ === 'StyleBlockDeclaration') { | ||
8865 | var _v1 = declarations.a.a; | ||
8866 | var firstSelector = _v1.a; | ||
8867 | var otherSelectors = _v1.b; | ||
8868 | var rest = declarations.b; | ||
8869 | return _Utils_ap( | ||
8870 | A2($elm$core$List$cons, firstSelector, otherSelectors), | ||
8871 | $rtfeldman$elm_css$Css$Preprocess$Resolve$collectSelectors(rest)); | ||
8872 | } else { | ||
8873 | var rest = declarations.b; | ||
8874 | var $temp$declarations = rest; | ||
8875 | declarations = $temp$declarations; | ||
8876 | continue collectSelectors; | ||
8877 | } | ||
8878 | } | ||
8879 | } | ||
8880 | }; | ||
8881 | var $rtfeldman$elm_css$Css$Structure$DocumentRule = F5( | ||
8882 | function (a, b, c, d, e) { | ||
8883 | return {$: 'DocumentRule', a: a, b: b, c: c, d: d, e: e}; | ||
8884 | }); | ||
8885 | var $rtfeldman$elm_css$Css$Structure$concatMapLastStyleBlock = F2( | ||
8886 | function (update, declarations) { | ||
8887 | _v0$12: | ||
8888 | while (true) { | ||
8889 | if (!declarations.b) { | ||
8890 | return declarations; | ||
8891 | } else { | ||
8892 | if (!declarations.b.b) { | ||
8893 | switch (declarations.a.$) { | ||
8894 | case 'StyleBlockDeclaration': | ||
8895 | var styleBlock = declarations.a.a; | ||
8896 | return A2( | ||
8897 | $elm$core$List$map, | ||
8898 | $rtfeldman$elm_css$Css$Structure$StyleBlockDeclaration, | ||
8899 | update(styleBlock)); | ||
8900 | case 'MediaRule': | ||
8901 | if (declarations.a.b.b) { | ||
8902 | if (!declarations.a.b.b.b) { | ||
8903 | var _v1 = declarations.a; | ||
8904 | var mediaQueries = _v1.a; | ||
8905 | var _v2 = _v1.b; | ||
8906 | var styleBlock = _v2.a; | ||
8907 | return _List_fromArray( | ||
8908 | [ | ||
8909 | A2( | ||
8910 | $rtfeldman$elm_css$Css$Structure$MediaRule, | ||
8911 | mediaQueries, | ||
8912 | update(styleBlock)) | ||
8913 | ]); | ||
8914 | } else { | ||
8915 | var _v3 = declarations.a; | ||
8916 | var mediaQueries = _v3.a; | ||
8917 | var _v4 = _v3.b; | ||
8918 | var first = _v4.a; | ||
8919 | var rest = _v4.b; | ||
8920 | var _v5 = A2( | ||
8921 | $rtfeldman$elm_css$Css$Structure$concatMapLastStyleBlock, | ||
8922 | update, | ||
8923 | _List_fromArray( | ||
8924 | [ | ||
8925 | A2($rtfeldman$elm_css$Css$Structure$MediaRule, mediaQueries, rest) | ||
8926 | ])); | ||
8927 | if ((_v5.b && (_v5.a.$ === 'MediaRule')) && (!_v5.b.b)) { | ||
8928 | var _v6 = _v5.a; | ||
8929 | var newMediaQueries = _v6.a; | ||
8930 | var newStyleBlocks = _v6.b; | ||
8931 | return _List_fromArray( | ||
8932 | [ | ||
8933 | A2( | ||
8934 | $rtfeldman$elm_css$Css$Structure$MediaRule, | ||
8935 | newMediaQueries, | ||
8936 | A2($elm$core$List$cons, first, newStyleBlocks)) | ||
8937 | ]); | ||
8938 | } else { | ||
8939 | var newDeclarations = _v5; | ||
8940 | return newDeclarations; | ||
8941 | } | ||
8942 | } | ||
8943 | } else { | ||
8944 | break _v0$12; | ||
8945 | } | ||
8946 | case 'SupportsRule': | ||
8947 | var _v7 = declarations.a; | ||
8948 | var str = _v7.a; | ||
8949 | var nestedDeclarations = _v7.b; | ||
8950 | return _List_fromArray( | ||
8951 | [ | ||
8952 | A2( | ||
8953 | $rtfeldman$elm_css$Css$Structure$SupportsRule, | ||
8954 | str, | ||
8955 | A2($rtfeldman$elm_css$Css$Structure$concatMapLastStyleBlock, update, nestedDeclarations)) | ||
8956 | ]); | ||
8957 | case 'DocumentRule': | ||
8958 | var _v8 = declarations.a; | ||
8959 | var str1 = _v8.a; | ||
8960 | var str2 = _v8.b; | ||
8961 | var str3 = _v8.c; | ||
8962 | var str4 = _v8.d; | ||
8963 | var styleBlock = _v8.e; | ||
8964 | return A2( | ||
8965 | $elm$core$List$map, | ||
8966 | A4($rtfeldman$elm_css$Css$Structure$DocumentRule, str1, str2, str3, str4), | ||
8967 | update(styleBlock)); | ||
8968 | case 'PageRule': | ||
8969 | var _v9 = declarations.a; | ||
8970 | return declarations; | ||
8971 | case 'FontFace': | ||
8972 | return declarations; | ||
8973 | case 'Keyframes': | ||
8974 | return declarations; | ||
8975 | case 'Viewport': | ||
8976 | return declarations; | ||
8977 | case 'CounterStyle': | ||
8978 | return declarations; | ||
8979 | default: | ||
8980 | return declarations; | ||
8981 | } | ||
8982 | } else { | ||
8983 | break _v0$12; | ||
8984 | } | ||
8985 | } | ||
8986 | } | ||
8987 | var first = declarations.a; | ||
8988 | var rest = declarations.b; | ||
8989 | return A2( | ||
8990 | $elm$core$List$cons, | ||
8991 | first, | ||
8992 | A2($rtfeldman$elm_css$Css$Structure$concatMapLastStyleBlock, update, rest)); | ||
8993 | }); | ||
8994 | var $elm$core$String$cons = _String_cons; | ||
8995 | var $rtfeldman$elm_css$ElmCssVendor$Murmur3$HashData = F4( | ||
8996 | function (shift, seed, hash, charsProcessed) { | ||
8997 | return {charsProcessed: charsProcessed, hash: hash, seed: seed, shift: shift}; | ||
8998 | }); | ||
8999 | var $rtfeldman$elm_css$ElmCssVendor$Murmur3$c1 = 3432918353; | ||
9000 | var $rtfeldman$elm_css$ElmCssVendor$Murmur3$c2 = 461845907; | ||
9001 | var $elm$core$Bitwise$and = _Bitwise_and; | ||
9002 | var $elm$core$Bitwise$shiftLeftBy = _Bitwise_shiftLeftBy; | ||
9003 | var $elm$core$Bitwise$shiftRightZfBy = _Bitwise_shiftRightZfBy; | ||
9004 | var $rtfeldman$elm_css$ElmCssVendor$Murmur3$multiplyBy = F2( | ||
9005 | function (b, a) { | ||
9006 | return ((a & 65535) * b) + ((((a >>> 16) * b) & 65535) << 16); | ||
9007 | }); | ||
9008 | var $elm$core$Bitwise$or = _Bitwise_or; | ||
9009 | var $rtfeldman$elm_css$ElmCssVendor$Murmur3$rotlBy = F2( | ||
9010 | function (b, a) { | ||
9011 | return (a << b) | (a >>> (32 - b)); | ||
9012 | }); | ||
9013 | var $elm$core$Bitwise$xor = _Bitwise_xor; | ||
9014 | var $rtfeldman$elm_css$ElmCssVendor$Murmur3$finalize = function (data) { | ||
9015 | var acc = (!(!data.hash)) ? (data.seed ^ A2( | ||
9016 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$multiplyBy, | ||
9017 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$c2, | ||
9018 | A2( | ||
9019 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$rotlBy, | ||
9020 | 15, | ||
9021 | A2($rtfeldman$elm_css$ElmCssVendor$Murmur3$multiplyBy, $rtfeldman$elm_css$ElmCssVendor$Murmur3$c1, data.hash)))) : data.seed; | ||
9022 | var h0 = acc ^ data.charsProcessed; | ||
9023 | var h1 = A2($rtfeldman$elm_css$ElmCssVendor$Murmur3$multiplyBy, 2246822507, h0 ^ (h0 >>> 16)); | ||
9024 | var h2 = A2($rtfeldman$elm_css$ElmCssVendor$Murmur3$multiplyBy, 3266489909, h1 ^ (h1 >>> 13)); | ||
9025 | return (h2 ^ (h2 >>> 16)) >>> 0; | ||
9026 | }; | ||
9027 | var $elm$core$String$foldl = _String_foldl; | ||
9028 | var $rtfeldman$elm_css$ElmCssVendor$Murmur3$mix = F2( | ||
9029 | function (h1, k1) { | ||
9030 | return A2( | ||
9031 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$multiplyBy, | ||
9032 | 5, | ||
9033 | A2( | ||
9034 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$rotlBy, | ||
9035 | 13, | ||
9036 | h1 ^ A2( | ||
9037 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$multiplyBy, | ||
9038 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$c2, | ||
9039 | A2( | ||
9040 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$rotlBy, | ||
9041 | 15, | ||
9042 | A2($rtfeldman$elm_css$ElmCssVendor$Murmur3$multiplyBy, $rtfeldman$elm_css$ElmCssVendor$Murmur3$c1, k1))))) + 3864292196; | ||
9043 | }); | ||
9044 | var $rtfeldman$elm_css$ElmCssVendor$Murmur3$hashFold = F2( | ||
9045 | function (c, data) { | ||
9046 | var res = data.hash | ((255 & $elm$core$Char$toCode(c)) << data.shift); | ||
9047 | var _v0 = data.shift; | ||
9048 | if (_v0 === 24) { | ||
9049 | return { | ||
9050 | charsProcessed: data.charsProcessed + 1, | ||
9051 | hash: 0, | ||
9052 | seed: A2($rtfeldman$elm_css$ElmCssVendor$Murmur3$mix, data.seed, res), | ||
9053 | shift: 0 | ||
9054 | }; | ||
9055 | } else { | ||
9056 | return {charsProcessed: data.charsProcessed + 1, hash: res, seed: data.seed, shift: data.shift + 8}; | ||
9057 | } | ||
9058 | }); | ||
9059 | var $rtfeldman$elm_css$ElmCssVendor$Murmur3$hashString = F2( | ||
9060 | function (seed, str) { | ||
9061 | return $rtfeldman$elm_css$ElmCssVendor$Murmur3$finalize( | ||
9062 | A3( | ||
9063 | $elm$core$String$foldl, | ||
9064 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$hashFold, | ||
9065 | A4($rtfeldman$elm_css$ElmCssVendor$Murmur3$HashData, 0, seed, 0, 0), | ||
9066 | str)); | ||
9067 | }); | ||
9068 | var $rtfeldman$elm_css$Hash$murmurSeed = 15739; | ||
9069 | var $elm$core$String$fromList = _String_fromList; | ||
9070 | var $elm$core$Basics$modBy = _Basics_modBy; | ||
9071 | var $rtfeldman$elm_hex$Hex$unsafeToDigit = function (num) { | ||
9072 | unsafeToDigit: | ||
9073 | while (true) { | ||
9074 | switch (num) { | ||
9075 | case 0: | ||
9076 | return _Utils_chr('0'); | ||
9077 | case 1: | ||
9078 | return _Utils_chr('1'); | ||
9079 | case 2: | ||
9080 | return _Utils_chr('2'); | ||
9081 | case 3: | ||
9082 | return _Utils_chr('3'); | ||
9083 | case 4: | ||
9084 | return _Utils_chr('4'); | ||
9085 | case 5: | ||
9086 | return _Utils_chr('5'); | ||
9087 | case 6: | ||
9088 | return _Utils_chr('6'); | ||
9089 | case 7: | ||
9090 | return _Utils_chr('7'); | ||
9091 | case 8: | ||
9092 | return _Utils_chr('8'); | ||
9093 | case 9: | ||
9094 | return _Utils_chr('9'); | ||
9095 | case 10: | ||
9096 | return _Utils_chr('a'); | ||
9097 | case 11: | ||
9098 | return _Utils_chr('b'); | ||
9099 | case 12: | ||
9100 | return _Utils_chr('c'); | ||
9101 | case 13: | ||
9102 | return _Utils_chr('d'); | ||
9103 | case 14: | ||
9104 | return _Utils_chr('e'); | ||
9105 | case 15: | ||
9106 | return _Utils_chr('f'); | ||
9107 | default: | ||
9108 | var $temp$num = num; | ||
9109 | num = $temp$num; | ||
9110 | continue unsafeToDigit; | ||
9111 | } | ||
9112 | } | ||
9113 | }; | ||
9114 | var $rtfeldman$elm_hex$Hex$unsafePositiveToDigits = F2( | ||
9115 | function (digits, num) { | ||
9116 | unsafePositiveToDigits: | ||
9117 | while (true) { | ||
9118 | if (num < 16) { | ||
9119 | return A2( | ||
9120 | $elm$core$List$cons, | ||
9121 | $rtfeldman$elm_hex$Hex$unsafeToDigit(num), | ||
9122 | digits); | ||
9123 | } else { | ||
9124 | var $temp$digits = A2( | ||
9125 | $elm$core$List$cons, | ||
9126 | $rtfeldman$elm_hex$Hex$unsafeToDigit( | ||
9127 | A2($elm$core$Basics$modBy, 16, num)), | ||
9128 | digits), | ||
9129 | $temp$num = (num / 16) | 0; | ||
9130 | digits = $temp$digits; | ||
9131 | num = $temp$num; | ||
9132 | continue unsafePositiveToDigits; | ||
9133 | } | ||
9134 | } | ||
9135 | }); | ||
9136 | var $rtfeldman$elm_hex$Hex$toString = function (num) { | ||
9137 | return $elm$core$String$fromList( | ||
9138 | (num < 0) ? A2( | ||
9139 | $elm$core$List$cons, | ||
9140 | _Utils_chr('-'), | ||
9141 | A2($rtfeldman$elm_hex$Hex$unsafePositiveToDigits, _List_Nil, -num)) : A2($rtfeldman$elm_hex$Hex$unsafePositiveToDigits, _List_Nil, num)); | ||
9142 | }; | ||
9143 | var $rtfeldman$elm_css$Hash$fromString = function (str) { | ||
9144 | return A2( | ||
9145 | $elm$core$String$cons, | ||
9146 | _Utils_chr('_'), | ||
9147 | $rtfeldman$elm_hex$Hex$toString( | ||
9148 | A2($rtfeldman$elm_css$ElmCssVendor$Murmur3$hashString, $rtfeldman$elm_css$Hash$murmurSeed, str))); | ||
9149 | }; | ||
9150 | var $elm$core$List$head = function (list) { | ||
9151 | if (list.b) { | ||
9152 | var x = list.a; | ||
9153 | var xs = list.b; | ||
9154 | return $elm$core$Maybe$Just(x); | ||
9155 | } else { | ||
9156 | return $elm$core$Maybe$Nothing; | ||
9157 | } | ||
9158 | }; | ||
9159 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$last = function (list) { | ||
9160 | last: | ||
9161 | while (true) { | ||
9162 | if (!list.b) { | ||
9163 | return $elm$core$Maybe$Nothing; | ||
9164 | } else { | ||
9165 | if (!list.b.b) { | ||
9166 | var singleton = list.a; | ||
9167 | return $elm$core$Maybe$Just(singleton); | ||
9168 | } else { | ||
9169 | var rest = list.b; | ||
9170 | var $temp$list = rest; | ||
9171 | list = $temp$list; | ||
9172 | continue last; | ||
9173 | } | ||
9174 | } | ||
9175 | } | ||
9176 | }; | ||
9177 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$lastDeclaration = function (declarations) { | ||
9178 | lastDeclaration: | ||
9179 | while (true) { | ||
9180 | if (!declarations.b) { | ||
9181 | return $elm$core$Maybe$Nothing; | ||
9182 | } else { | ||
9183 | if (!declarations.b.b) { | ||
9184 | var x = declarations.a; | ||
9185 | return $elm$core$Maybe$Just( | ||
9186 | _List_fromArray( | ||
9187 | [x])); | ||
9188 | } else { | ||
9189 | var xs = declarations.b; | ||
9190 | var $temp$declarations = xs; | ||
9191 | declarations = $temp$declarations; | ||
9192 | continue lastDeclaration; | ||
9193 | } | ||
9194 | } | ||
9195 | } | ||
9196 | }; | ||
9197 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$oneOf = function (maybes) { | ||
9198 | oneOf: | ||
9199 | while (true) { | ||
9200 | if (!maybes.b) { | ||
9201 | return $elm$core$Maybe$Nothing; | ||
9202 | } else { | ||
9203 | var maybe = maybes.a; | ||
9204 | var rest = maybes.b; | ||
9205 | if (maybe.$ === 'Nothing') { | ||
9206 | var $temp$maybes = rest; | ||
9207 | maybes = $temp$maybes; | ||
9208 | continue oneOf; | ||
9209 | } else { | ||
9210 | return maybe; | ||
9211 | } | ||
9212 | } | ||
9213 | } | ||
9214 | }; | ||
9215 | var $rtfeldman$elm_css$Css$Structure$FontFeatureValues = function (a) { | ||
9216 | return {$: 'FontFeatureValues', a: a}; | ||
9217 | }; | ||
9218 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$resolveFontFeatureValues = function (tuples) { | ||
9219 | var expandTuples = function (tuplesToExpand) { | ||
9220 | if (!tuplesToExpand.b) { | ||
9221 | return _List_Nil; | ||
9222 | } else { | ||
9223 | var properties = tuplesToExpand.a; | ||
9224 | var rest = tuplesToExpand.b; | ||
9225 | return A2( | ||
9226 | $elm$core$List$cons, | ||
9227 | properties, | ||
9228 | expandTuples(rest)); | ||
9229 | } | ||
9230 | }; | ||
9231 | var newTuples = expandTuples(tuples); | ||
9232 | return _List_fromArray( | ||
9233 | [ | ||
9234 | $rtfeldman$elm_css$Css$Structure$FontFeatureValues(newTuples) | ||
9235 | ]); | ||
9236 | }; | ||
9237 | var $rtfeldman$elm_css$Css$Structure$styleBlockToMediaRule = F2( | ||
9238 | function (mediaQueries, declaration) { | ||
9239 | if (declaration.$ === 'StyleBlockDeclaration') { | ||
9240 | var styleBlock = declaration.a; | ||
9241 | return A2( | ||
9242 | $rtfeldman$elm_css$Css$Structure$MediaRule, | ||
9243 | mediaQueries, | ||
9244 | _List_fromArray( | ||
9245 | [styleBlock])); | ||
9246 | } else { | ||
9247 | return declaration; | ||
9248 | } | ||
9249 | }); | ||
9250 | var $elm$core$List$tail = function (list) { | ||
9251 | if (list.b) { | ||
9252 | var x = list.a; | ||
9253 | var xs = list.b; | ||
9254 | return $elm$core$Maybe$Just(xs); | ||
9255 | } else { | ||
9256 | return $elm$core$Maybe$Nothing; | ||
9257 | } | ||
9258 | }; | ||
9259 | var $elm$core$List$takeReverse = F3( | ||
9260 | function (n, list, kept) { | ||
9261 | takeReverse: | ||
9262 | while (true) { | ||
9263 | if (n <= 0) { | ||
9264 | return kept; | ||
9265 | } else { | ||
9266 | if (!list.b) { | ||
9267 | return kept; | ||
9268 | } else { | ||
9269 | var x = list.a; | ||
9270 | var xs = list.b; | ||
9271 | var $temp$n = n - 1, | ||
9272 | $temp$list = xs, | ||
9273 | $temp$kept = A2($elm$core$List$cons, x, kept); | ||
9274 | n = $temp$n; | ||
9275 | list = $temp$list; | ||
9276 | kept = $temp$kept; | ||
9277 | continue takeReverse; | ||
9278 | } | ||
9279 | } | ||
9280 | } | ||
9281 | }); | ||
9282 | var $elm$core$List$takeTailRec = F2( | ||
9283 | function (n, list) { | ||
9284 | return $elm$core$List$reverse( | ||
9285 | A3($elm$core$List$takeReverse, n, list, _List_Nil)); | ||
9286 | }); | ||
9287 | var $elm$core$List$takeFast = F3( | ||
9288 | function (ctr, n, list) { | ||
9289 | if (n <= 0) { | ||
9290 | return _List_Nil; | ||
9291 | } else { | ||
9292 | var _v0 = _Utils_Tuple2(n, list); | ||
9293 | _v0$1: | ||
9294 | while (true) { | ||
9295 | _v0$5: | ||
9296 | while (true) { | ||
9297 | if (!_v0.b.b) { | ||
9298 | return list; | ||
9299 | } else { | ||
9300 | if (_v0.b.b.b) { | ||
9301 | switch (_v0.a) { | ||
9302 | case 1: | ||
9303 | break _v0$1; | ||
9304 | case 2: | ||
9305 | var _v2 = _v0.b; | ||
9306 | var x = _v2.a; | ||
9307 | var _v3 = _v2.b; | ||
9308 | var y = _v3.a; | ||
9309 | return _List_fromArray( | ||
9310 | [x, y]); | ||
9311 | case 3: | ||
9312 | if (_v0.b.b.b.b) { | ||
9313 | var _v4 = _v0.b; | ||
9314 | var x = _v4.a; | ||
9315 | var _v5 = _v4.b; | ||
9316 | var y = _v5.a; | ||
9317 | var _v6 = _v5.b; | ||
9318 | var z = _v6.a; | ||
9319 | return _List_fromArray( | ||
9320 | [x, y, z]); | ||
9321 | } else { | ||
9322 | break _v0$5; | ||
9323 | } | ||
9324 | default: | ||
9325 | if (_v0.b.b.b.b && _v0.b.b.b.b.b) { | ||
9326 | var _v7 = _v0.b; | ||
9327 | var x = _v7.a; | ||
9328 | var _v8 = _v7.b; | ||
9329 | var y = _v8.a; | ||
9330 | var _v9 = _v8.b; | ||
9331 | var z = _v9.a; | ||
9332 | var _v10 = _v9.b; | ||
9333 | var w = _v10.a; | ||
9334 | var tl = _v10.b; | ||
9335 | return (ctr > 1000) ? A2( | ||
9336 | $elm$core$List$cons, | ||
9337 | x, | ||
9338 | A2( | ||
9339 | $elm$core$List$cons, | ||
9340 | y, | ||
9341 | A2( | ||
9342 | $elm$core$List$cons, | ||
9343 | z, | ||
9344 | A2( | ||
9345 | $elm$core$List$cons, | ||
9346 | w, | ||
9347 | A2($elm$core$List$takeTailRec, n - 4, tl))))) : A2( | ||
9348 | $elm$core$List$cons, | ||
9349 | x, | ||
9350 | A2( | ||
9351 | $elm$core$List$cons, | ||
9352 | y, | ||
9353 | A2( | ||
9354 | $elm$core$List$cons, | ||
9355 | z, | ||
9356 | A2( | ||
9357 | $elm$core$List$cons, | ||
9358 | w, | ||
9359 | A3($elm$core$List$takeFast, ctr + 1, n - 4, tl))))); | ||
9360 | } else { | ||
9361 | break _v0$5; | ||
9362 | } | ||
9363 | } | ||
9364 | } else { | ||
9365 | if (_v0.a === 1) { | ||
9366 | break _v0$1; | ||
9367 | } else { | ||
9368 | break _v0$5; | ||
9369 | } | ||
9370 | } | ||
9371 | } | ||
9372 | } | ||
9373 | return list; | ||
9374 | } | ||
9375 | var _v1 = _v0.b; | ||
9376 | var x = _v1.a; | ||
9377 | return _List_fromArray( | ||
9378 | [x]); | ||
9379 | } | ||
9380 | }); | ||
9381 | var $elm$core$List$take = F2( | ||
9382 | function (n, list) { | ||
9383 | return A3($elm$core$List$takeFast, 0, n, list); | ||
9384 | }); | ||
9385 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$toDocumentRule = F5( | ||
9386 | function (str1, str2, str3, str4, declaration) { | ||
9387 | if (declaration.$ === 'StyleBlockDeclaration') { | ||
9388 | var structureStyleBlock = declaration.a; | ||
9389 | return A5($rtfeldman$elm_css$Css$Structure$DocumentRule, str1, str2, str3, str4, structureStyleBlock); | ||
9390 | } else { | ||
9391 | return declaration; | ||
9392 | } | ||
9393 | }); | ||
9394 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$toMediaRule = F2( | ||
9395 | function (mediaQueries, declaration) { | ||
9396 | switch (declaration.$) { | ||
9397 | case 'StyleBlockDeclaration': | ||
9398 | var structureStyleBlock = declaration.a; | ||
9399 | return A2( | ||
9400 | $rtfeldman$elm_css$Css$Structure$MediaRule, | ||
9401 | mediaQueries, | ||
9402 | _List_fromArray( | ||
9403 | [structureStyleBlock])); | ||
9404 | case 'MediaRule': | ||
9405 | var newMediaQueries = declaration.a; | ||
9406 | var structureStyleBlocks = declaration.b; | ||
9407 | return A2( | ||
9408 | $rtfeldman$elm_css$Css$Structure$MediaRule, | ||
9409 | _Utils_ap(mediaQueries, newMediaQueries), | ||
9410 | structureStyleBlocks); | ||
9411 | case 'SupportsRule': | ||
9412 | var str = declaration.a; | ||
9413 | var declarations = declaration.b; | ||
9414 | return A2( | ||
9415 | $rtfeldman$elm_css$Css$Structure$SupportsRule, | ||
9416 | str, | ||
9417 | A2( | ||
9418 | $elm$core$List$map, | ||
9419 | $rtfeldman$elm_css$Css$Preprocess$Resolve$toMediaRule(mediaQueries), | ||
9420 | declarations)); | ||
9421 | case 'DocumentRule': | ||
9422 | var str1 = declaration.a; | ||
9423 | var str2 = declaration.b; | ||
9424 | var str3 = declaration.c; | ||
9425 | var str4 = declaration.d; | ||
9426 | var structureStyleBlock = declaration.e; | ||
9427 | return A5($rtfeldman$elm_css$Css$Structure$DocumentRule, str1, str2, str3, str4, structureStyleBlock); | ||
9428 | case 'PageRule': | ||
9429 | return declaration; | ||
9430 | case 'FontFace': | ||
9431 | return declaration; | ||
9432 | case 'Keyframes': | ||
9433 | return declaration; | ||
9434 | case 'Viewport': | ||
9435 | return declaration; | ||
9436 | case 'CounterStyle': | ||
9437 | return declaration; | ||
9438 | default: | ||
9439 | return declaration; | ||
9440 | } | ||
9441 | }); | ||
9442 | var $rtfeldman$elm_css$Css$Preprocess$unwrapSnippet = function (_v0) { | ||
9443 | var declarations = _v0.a; | ||
9444 | return declarations; | ||
9445 | }; | ||
9446 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$applyNestedStylesToLast = F4( | ||
9447 | function (nestedStyles, rest, f, declarations) { | ||
9448 | var withoutParent = function (decls) { | ||
9449 | return A2( | ||
9450 | $elm$core$Maybe$withDefault, | ||
9451 | _List_Nil, | ||
9452 | $elm$core$List$tail(decls)); | ||
9453 | }; | ||
9454 | var nextResult = A2( | ||
9455 | $rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles, | ||
9456 | rest, | ||
9457 | A2( | ||
9458 | $elm$core$Maybe$withDefault, | ||
9459 | _List_Nil, | ||
9460 | $rtfeldman$elm_css$Css$Preprocess$Resolve$lastDeclaration(declarations))); | ||
9461 | var newDeclarations = function () { | ||
9462 | var _v14 = _Utils_Tuple2( | ||
9463 | $elm$core$List$head(nextResult), | ||
9464 | $rtfeldman$elm_css$Css$Preprocess$Resolve$last(declarations)); | ||
9465 | if ((_v14.a.$ === 'Just') && (_v14.b.$ === 'Just')) { | ||
9466 | var nextResultParent = _v14.a.a; | ||
9467 | var originalParent = _v14.b.a; | ||
9468 | return _Utils_ap( | ||
9469 | A2( | ||
9470 | $elm$core$List$take, | ||
9471 | $elm$core$List$length(declarations) - 1, | ||
9472 | declarations), | ||
9473 | _List_fromArray( | ||
9474 | [ | ||
9475 | (!_Utils_eq(originalParent, nextResultParent)) ? nextResultParent : originalParent | ||
9476 | ])); | ||
9477 | } else { | ||
9478 | return declarations; | ||
9479 | } | ||
9480 | }(); | ||
9481 | var insertStylesToNestedDecl = function (lastDecl) { | ||
9482 | return $elm$core$List$concat( | ||
9483 | A2( | ||
9484 | $rtfeldman$elm_css$Css$Structure$mapLast, | ||
9485 | $rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles(nestedStyles), | ||
9486 | A2( | ||
9487 | $elm$core$List$map, | ||
9488 | $elm$core$List$singleton, | ||
9489 | A2($rtfeldman$elm_css$Css$Structure$concatMapLastStyleBlock, f, lastDecl)))); | ||
9490 | }; | ||
9491 | var initialResult = A2( | ||
9492 | $elm$core$Maybe$withDefault, | ||
9493 | _List_Nil, | ||
9494 | A2( | ||
9495 | $elm$core$Maybe$map, | ||
9496 | insertStylesToNestedDecl, | ||
9497 | $rtfeldman$elm_css$Css$Preprocess$Resolve$lastDeclaration(declarations))); | ||
9498 | return _Utils_ap( | ||
9499 | newDeclarations, | ||
9500 | _Utils_ap( | ||
9501 | withoutParent(initialResult), | ||
9502 | withoutParent(nextResult))); | ||
9503 | }); | ||
9504 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles = F2( | ||
9505 | function (styles, declarations) { | ||
9506 | if (!styles.b) { | ||
9507 | return declarations; | ||
9508 | } else { | ||
9509 | switch (styles.a.$) { | ||
9510 | case 'AppendProperty': | ||
9511 | var property = styles.a.a; | ||
9512 | var rest = styles.b; | ||
9513 | return A2( | ||
9514 | $rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles, | ||
9515 | rest, | ||
9516 | A2($rtfeldman$elm_css$Css$Structure$appendProperty, property, declarations)); | ||
9517 | case 'ExtendSelector': | ||
9518 | var _v4 = styles.a; | ||
9519 | var selector = _v4.a; | ||
9520 | var nestedStyles = _v4.b; | ||
9521 | var rest = styles.b; | ||
9522 | return A4( | ||
9523 | $rtfeldman$elm_css$Css$Preprocess$Resolve$applyNestedStylesToLast, | ||
9524 | nestedStyles, | ||
9525 | rest, | ||
9526 | $rtfeldman$elm_css$Css$Structure$appendRepeatableToLastSelector(selector), | ||
9527 | declarations); | ||
9528 | case 'NestSnippet': | ||
9529 | var _v5 = styles.a; | ||
9530 | var selectorCombinator = _v5.a; | ||
9531 | var snippets = _v5.b; | ||
9532 | var rest = styles.b; | ||
9533 | var chain = F2( | ||
9534 | function (_v9, _v10) { | ||
9535 | var originalSequence = _v9.a; | ||
9536 | var originalTuples = _v9.b; | ||
9537 | var originalPseudoElement = _v9.c; | ||
9538 | var newSequence = _v10.a; | ||
9539 | var newTuples = _v10.b; | ||
9540 | var newPseudoElement = _v10.c; | ||
9541 | return A3( | ||
9542 | $rtfeldman$elm_css$Css$Structure$Selector, | ||
9543 | originalSequence, | ||
9544 | _Utils_ap( | ||
9545 | originalTuples, | ||
9546 | A2( | ||
9547 | $elm$core$List$cons, | ||
9548 | _Utils_Tuple2(selectorCombinator, newSequence), | ||
9549 | newTuples)), | ||
9550 | $rtfeldman$elm_css$Css$Preprocess$Resolve$oneOf( | ||
9551 | _List_fromArray( | ||
9552 | [newPseudoElement, originalPseudoElement]))); | ||
9553 | }); | ||
9554 | var expandDeclaration = function (declaration) { | ||
9555 | switch (declaration.$) { | ||
9556 | case 'StyleBlockDeclaration': | ||
9557 | var _v7 = declaration.a; | ||
9558 | var firstSelector = _v7.a; | ||
9559 | var otherSelectors = _v7.b; | ||
9560 | var nestedStyles = _v7.c; | ||
9561 | var newSelectors = A2( | ||
9562 | $elm$core$List$concatMap, | ||
9563 | function (originalSelector) { | ||
9564 | return A2( | ||
9565 | $elm$core$List$map, | ||
9566 | chain(originalSelector), | ||
9567 | A2($elm$core$List$cons, firstSelector, otherSelectors)); | ||
9568 | }, | ||
9569 | $rtfeldman$elm_css$Css$Preprocess$Resolve$collectSelectors(declarations)); | ||
9570 | var newDeclarations = function () { | ||
9571 | if (!newSelectors.b) { | ||
9572 | return _List_Nil; | ||
9573 | } else { | ||
9574 | var first = newSelectors.a; | ||
9575 | var remainder = newSelectors.b; | ||
9576 | return _List_fromArray( | ||
9577 | [ | ||
9578 | $rtfeldman$elm_css$Css$Structure$StyleBlockDeclaration( | ||
9579 | A3($rtfeldman$elm_css$Css$Structure$StyleBlock, first, remainder, _List_Nil)) | ||
9580 | ]); | ||
9581 | } | ||
9582 | }(); | ||
9583 | return A2($rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles, nestedStyles, newDeclarations); | ||
9584 | case 'MediaRule': | ||
9585 | var mediaQueries = declaration.a; | ||
9586 | var styleBlocks = declaration.b; | ||
9587 | return A2($rtfeldman$elm_css$Css$Preprocess$Resolve$resolveMediaRule, mediaQueries, styleBlocks); | ||
9588 | case 'SupportsRule': | ||
9589 | var str = declaration.a; | ||
9590 | var otherSnippets = declaration.b; | ||
9591 | return A2($rtfeldman$elm_css$Css$Preprocess$Resolve$resolveSupportsRule, str, otherSnippets); | ||
9592 | case 'DocumentRule': | ||
9593 | var str1 = declaration.a; | ||
9594 | var str2 = declaration.b; | ||
9595 | var str3 = declaration.c; | ||
9596 | var str4 = declaration.d; | ||
9597 | var styleBlock = declaration.e; | ||
9598 | return A2( | ||
9599 | $elm$core$List$map, | ||
9600 | A4($rtfeldman$elm_css$Css$Preprocess$Resolve$toDocumentRule, str1, str2, str3, str4), | ||
9601 | $rtfeldman$elm_css$Css$Preprocess$Resolve$expandStyleBlock(styleBlock)); | ||
9602 | case 'PageRule': | ||
9603 | var str = declaration.a; | ||
9604 | var properties = declaration.b; | ||
9605 | return _List_fromArray( | ||
9606 | [ | ||
9607 | A2($rtfeldman$elm_css$Css$Structure$PageRule, str, properties) | ||
9608 | ]); | ||
9609 | case 'FontFace': | ||
9610 | var properties = declaration.a; | ||
9611 | return _List_fromArray( | ||
9612 | [ | ||
9613 | $rtfeldman$elm_css$Css$Structure$FontFace(properties) | ||
9614 | ]); | ||
9615 | case 'Viewport': | ||
9616 | var properties = declaration.a; | ||
9617 | return _List_fromArray( | ||
9618 | [ | ||
9619 | $rtfeldman$elm_css$Css$Structure$Viewport(properties) | ||
9620 | ]); | ||
9621 | case 'CounterStyle': | ||
9622 | var properties = declaration.a; | ||
9623 | return _List_fromArray( | ||
9624 | [ | ||
9625 | $rtfeldman$elm_css$Css$Structure$CounterStyle(properties) | ||
9626 | ]); | ||
9627 | default: | ||
9628 | var tuples = declaration.a; | ||
9629 | return $rtfeldman$elm_css$Css$Preprocess$Resolve$resolveFontFeatureValues(tuples); | ||
9630 | } | ||
9631 | }; | ||
9632 | return $elm$core$List$concat( | ||
9633 | _Utils_ap( | ||
9634 | _List_fromArray( | ||
9635 | [ | ||
9636 | A2($rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles, rest, declarations) | ||
9637 | ]), | ||
9638 | A2( | ||
9639 | $elm$core$List$map, | ||
9640 | expandDeclaration, | ||
9641 | A2($elm$core$List$concatMap, $rtfeldman$elm_css$Css$Preprocess$unwrapSnippet, snippets)))); | ||
9642 | case 'WithPseudoElement': | ||
9643 | var _v11 = styles.a; | ||
9644 | var pseudoElement = _v11.a; | ||
9645 | var nestedStyles = _v11.b; | ||
9646 | var rest = styles.b; | ||
9647 | return A4( | ||
9648 | $rtfeldman$elm_css$Css$Preprocess$Resolve$applyNestedStylesToLast, | ||
9649 | nestedStyles, | ||
9650 | rest, | ||
9651 | $rtfeldman$elm_css$Css$Structure$appendPseudoElementToLastSelector(pseudoElement), | ||
9652 | declarations); | ||
9653 | case 'WithKeyframes': | ||
9654 | var str = styles.a.a; | ||
9655 | var rest = styles.b; | ||
9656 | var name = $rtfeldman$elm_css$Hash$fromString(str); | ||
9657 | var newProperty = 'animation-name:' + name; | ||
9658 | var newDeclarations = A2( | ||
9659 | $rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles, | ||
9660 | rest, | ||
9661 | A2($rtfeldman$elm_css$Css$Structure$appendProperty, newProperty, declarations)); | ||
9662 | return A2( | ||
9663 | $elm$core$List$append, | ||
9664 | newDeclarations, | ||
9665 | _List_fromArray( | ||
9666 | [ | ||
9667 | $rtfeldman$elm_css$Css$Structure$Keyframes( | ||
9668 | {declaration: str, name: name}) | ||
9669 | ])); | ||
9670 | case 'WithMedia': | ||
9671 | var _v12 = styles.a; | ||
9672 | var mediaQueries = _v12.a; | ||
9673 | var nestedStyles = _v12.b; | ||
9674 | var rest = styles.b; | ||
9675 | var extraDeclarations = function () { | ||
9676 | var _v13 = $rtfeldman$elm_css$Css$Preprocess$Resolve$collectSelectors(declarations); | ||
9677 | if (!_v13.b) { | ||
9678 | return _List_Nil; | ||
9679 | } else { | ||
9680 | var firstSelector = _v13.a; | ||
9681 | var otherSelectors = _v13.b; | ||
9682 | return A2( | ||
9683 | $elm$core$List$map, | ||
9684 | $rtfeldman$elm_css$Css$Structure$styleBlockToMediaRule(mediaQueries), | ||
9685 | A2( | ||
9686 | $rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles, | ||
9687 | nestedStyles, | ||
9688 | $elm$core$List$singleton( | ||
9689 | $rtfeldman$elm_css$Css$Structure$StyleBlockDeclaration( | ||
9690 | A3($rtfeldman$elm_css$Css$Structure$StyleBlock, firstSelector, otherSelectors, _List_Nil))))); | ||
9691 | } | ||
9692 | }(); | ||
9693 | return _Utils_ap( | ||
9694 | A2($rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles, rest, declarations), | ||
9695 | extraDeclarations); | ||
9696 | default: | ||
9697 | var otherStyles = styles.a.a; | ||
9698 | var rest = styles.b; | ||
9699 | return A2( | ||
9700 | $rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles, | ||
9701 | _Utils_ap(otherStyles, rest), | ||
9702 | declarations); | ||
9703 | } | ||
9704 | } | ||
9705 | }); | ||
9706 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$expandStyleBlock = function (_v2) { | ||
9707 | var firstSelector = _v2.a; | ||
9708 | var otherSelectors = _v2.b; | ||
9709 | var styles = _v2.c; | ||
9710 | return A2( | ||
9711 | $rtfeldman$elm_css$Css$Preprocess$Resolve$applyStyles, | ||
9712 | styles, | ||
9713 | _List_fromArray( | ||
9714 | [ | ||
9715 | $rtfeldman$elm_css$Css$Structure$StyleBlockDeclaration( | ||
9716 | A3($rtfeldman$elm_css$Css$Structure$StyleBlock, firstSelector, otherSelectors, _List_Nil)) | ||
9717 | ])); | ||
9718 | }; | ||
9719 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$extract = function (snippetDeclarations) { | ||
9720 | if (!snippetDeclarations.b) { | ||
9721 | return _List_Nil; | ||
9722 | } else { | ||
9723 | var first = snippetDeclarations.a; | ||
9724 | var rest = snippetDeclarations.b; | ||
9725 | return _Utils_ap( | ||
9726 | $rtfeldman$elm_css$Css$Preprocess$Resolve$toDeclarations(first), | ||
9727 | $rtfeldman$elm_css$Css$Preprocess$Resolve$extract(rest)); | ||
9728 | } | ||
9729 | }; | ||
9730 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$resolveMediaRule = F2( | ||
9731 | function (mediaQueries, styleBlocks) { | ||
9732 | var handleStyleBlock = function (styleBlock) { | ||
9733 | return A2( | ||
9734 | $elm$core$List$map, | ||
9735 | $rtfeldman$elm_css$Css$Preprocess$Resolve$toMediaRule(mediaQueries), | ||
9736 | $rtfeldman$elm_css$Css$Preprocess$Resolve$expandStyleBlock(styleBlock)); | ||
9737 | }; | ||
9738 | return A2($elm$core$List$concatMap, handleStyleBlock, styleBlocks); | ||
9739 | }); | ||
9740 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$resolveSupportsRule = F2( | ||
9741 | function (str, snippets) { | ||
9742 | var declarations = $rtfeldman$elm_css$Css$Preprocess$Resolve$extract( | ||
9743 | A2($elm$core$List$concatMap, $rtfeldman$elm_css$Css$Preprocess$unwrapSnippet, snippets)); | ||
9744 | return _List_fromArray( | ||
9745 | [ | ||
9746 | A2($rtfeldman$elm_css$Css$Structure$SupportsRule, str, declarations) | ||
9747 | ]); | ||
9748 | }); | ||
9749 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$toDeclarations = function (snippetDeclaration) { | ||
9750 | switch (snippetDeclaration.$) { | ||
9751 | case 'StyleBlockDeclaration': | ||
9752 | var styleBlock = snippetDeclaration.a; | ||
9753 | return $rtfeldman$elm_css$Css$Preprocess$Resolve$expandStyleBlock(styleBlock); | ||
9754 | case 'MediaRule': | ||
9755 | var mediaQueries = snippetDeclaration.a; | ||
9756 | var styleBlocks = snippetDeclaration.b; | ||
9757 | return A2($rtfeldman$elm_css$Css$Preprocess$Resolve$resolveMediaRule, mediaQueries, styleBlocks); | ||
9758 | case 'SupportsRule': | ||
9759 | var str = snippetDeclaration.a; | ||
9760 | var snippets = snippetDeclaration.b; | ||
9761 | return A2($rtfeldman$elm_css$Css$Preprocess$Resolve$resolveSupportsRule, str, snippets); | ||
9762 | case 'DocumentRule': | ||
9763 | var str1 = snippetDeclaration.a; | ||
9764 | var str2 = snippetDeclaration.b; | ||
9765 | var str3 = snippetDeclaration.c; | ||
9766 | var str4 = snippetDeclaration.d; | ||
9767 | var styleBlock = snippetDeclaration.e; | ||
9768 | return A2( | ||
9769 | $elm$core$List$map, | ||
9770 | A4($rtfeldman$elm_css$Css$Preprocess$Resolve$toDocumentRule, str1, str2, str3, str4), | ||
9771 | $rtfeldman$elm_css$Css$Preprocess$Resolve$expandStyleBlock(styleBlock)); | ||
9772 | case 'PageRule': | ||
9773 | var str = snippetDeclaration.a; | ||
9774 | var properties = snippetDeclaration.b; | ||
9775 | return _List_fromArray( | ||
9776 | [ | ||
9777 | A2($rtfeldman$elm_css$Css$Structure$PageRule, str, properties) | ||
9778 | ]); | ||
9779 | case 'FontFace': | ||
9780 | var properties = snippetDeclaration.a; | ||
9781 | return _List_fromArray( | ||
9782 | [ | ||
9783 | $rtfeldman$elm_css$Css$Structure$FontFace(properties) | ||
9784 | ]); | ||
9785 | case 'Viewport': | ||
9786 | var properties = snippetDeclaration.a; | ||
9787 | return _List_fromArray( | ||
9788 | [ | ||
9789 | $rtfeldman$elm_css$Css$Structure$Viewport(properties) | ||
9790 | ]); | ||
9791 | case 'CounterStyle': | ||
9792 | var properties = snippetDeclaration.a; | ||
9793 | return _List_fromArray( | ||
9794 | [ | ||
9795 | $rtfeldman$elm_css$Css$Structure$CounterStyle(properties) | ||
9796 | ]); | ||
9797 | default: | ||
9798 | var tuples = snippetDeclaration.a; | ||
9799 | return $rtfeldman$elm_css$Css$Preprocess$Resolve$resolveFontFeatureValues(tuples); | ||
9800 | } | ||
9801 | }; | ||
9802 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$toStructure = function (_v0) { | ||
9803 | var charset = _v0.charset; | ||
9804 | var imports = _v0.imports; | ||
9805 | var namespaces = _v0.namespaces; | ||
9806 | var snippets = _v0.snippets; | ||
9807 | var declarations = $rtfeldman$elm_css$Css$Preprocess$Resolve$extract( | ||
9808 | A2($elm$core$List$concatMap, $rtfeldman$elm_css$Css$Preprocess$unwrapSnippet, snippets)); | ||
9809 | return {charset: charset, declarations: declarations, imports: imports, namespaces: namespaces}; | ||
9810 | }; | ||
9811 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$compileHelp = function (sheet) { | ||
9812 | return $rtfeldman$elm_css$Css$Structure$Output$prettyPrint( | ||
9813 | $rtfeldman$elm_css$Css$Structure$compactStylesheet( | ||
9814 | $rtfeldman$elm_css$Css$Preprocess$Resolve$toStructure(sheet))); | ||
9815 | }; | ||
9816 | var $rtfeldman$elm_css$Css$Preprocess$Resolve$compile = function (styles) { | ||
9817 | return A2( | ||
9818 | $elm$core$String$join, | ||
9819 | '\n\n', | ||
9820 | A2($elm$core$List$map, $rtfeldman$elm_css$Css$Preprocess$Resolve$compileHelp, styles)); | ||
9821 | }; | ||
9822 | var $rtfeldman$elm_css$Css$Structure$ClassSelector = function (a) { | ||
9823 | return {$: 'ClassSelector', a: a}; | ||
9824 | }; | ||
9825 | var $rtfeldman$elm_css$Css$Preprocess$Snippet = function (a) { | ||
9826 | return {$: 'Snippet', a: a}; | ||
9827 | }; | ||
9828 | var $rtfeldman$elm_css$Css$Preprocess$StyleBlock = F3( | ||
9829 | function (a, b, c) { | ||
9830 | return {$: 'StyleBlock', a: a, b: b, c: c}; | ||
9831 | }); | ||
9832 | var $rtfeldman$elm_css$Css$Preprocess$StyleBlockDeclaration = function (a) { | ||
9833 | return {$: 'StyleBlockDeclaration', a: a}; | ||
9834 | }; | ||
9835 | var $rtfeldman$elm_css$VirtualDom$Styled$makeSnippet = F2( | ||
9836 | function (styles, sequence) { | ||
9837 | var selector = A3($rtfeldman$elm_css$Css$Structure$Selector, sequence, _List_Nil, $elm$core$Maybe$Nothing); | ||
9838 | return $rtfeldman$elm_css$Css$Preprocess$Snippet( | ||
9839 | _List_fromArray( | ||
9840 | [ | ||
9841 | $rtfeldman$elm_css$Css$Preprocess$StyleBlockDeclaration( | ||
9842 | A3($rtfeldman$elm_css$Css$Preprocess$StyleBlock, selector, _List_Nil, styles)) | ||
9843 | ])); | ||
9844 | }); | ||
9845 | var $rtfeldman$elm_css$VirtualDom$Styled$snippetFromPair = function (_v0) { | ||
9846 | var classname = _v0.a; | ||
9847 | var styles = _v0.b; | ||
9848 | return A2( | ||
9849 | $rtfeldman$elm_css$VirtualDom$Styled$makeSnippet, | ||
9850 | styles, | ||
9851 | $rtfeldman$elm_css$Css$Structure$UniversalSelectorSequence( | ||
9852 | _List_fromArray( | ||
9853 | [ | ||
9854 | $rtfeldman$elm_css$Css$Structure$ClassSelector(classname) | ||
9855 | ]))); | ||
9856 | }; | ||
9857 | var $rtfeldman$elm_css$Css$Preprocess$stylesheet = function (snippets) { | ||
9858 | return {charset: $elm$core$Maybe$Nothing, imports: _List_Nil, namespaces: _List_Nil, snippets: snippets}; | ||
9859 | }; | ||
9860 | var $rtfeldman$elm_css$VirtualDom$Styled$toDeclaration = function (dict) { | ||
9861 | return $rtfeldman$elm_css$Css$Preprocess$Resolve$compile( | ||
9862 | $elm$core$List$singleton( | ||
9863 | $rtfeldman$elm_css$Css$Preprocess$stylesheet( | ||
9864 | A2( | ||
9865 | $elm$core$List$map, | ||
9866 | $rtfeldman$elm_css$VirtualDom$Styled$snippetFromPair, | ||
9867 | $elm$core$Dict$toList(dict))))); | ||
9868 | }; | ||
9869 | var $rtfeldman$elm_css$VirtualDom$Styled$toStyleNode = function (styles) { | ||
9870 | return A3( | ||
9871 | $elm$virtual_dom$VirtualDom$node, | ||
9872 | 'style', | ||
9873 | _List_Nil, | ||
9874 | $elm$core$List$singleton( | ||
9875 | $elm$virtual_dom$VirtualDom$text( | ||
9876 | $rtfeldman$elm_css$VirtualDom$Styled$toDeclaration(styles)))); | ||
9877 | }; | ||
9878 | var $rtfeldman$elm_css$VirtualDom$Styled$unstyle = F3( | ||
9879 | function (elemType, properties, children) { | ||
9880 | var unstyledProperties = A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties); | ||
9881 | var initialStyles = $rtfeldman$elm_css$VirtualDom$Styled$stylesFromProperties(properties); | ||
9882 | var _v0 = A3( | ||
9883 | $elm$core$List$foldl, | ||
9884 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyledHtml, | ||
9885 | _Utils_Tuple2(_List_Nil, initialStyles), | ||
9886 | children); | ||
9887 | var childNodes = _v0.a; | ||
9888 | var styles = _v0.b; | ||
9889 | var styleNode = $rtfeldman$elm_css$VirtualDom$Styled$toStyleNode(styles); | ||
9890 | return A3( | ||
9891 | $elm$virtual_dom$VirtualDom$node, | ||
9892 | elemType, | ||
9893 | unstyledProperties, | ||
9894 | A2( | ||
9895 | $elm$core$List$cons, | ||
9896 | styleNode, | ||
9897 | $elm$core$List$reverse(childNodes))); | ||
9898 | }); | ||
9899 | var $rtfeldman$elm_css$VirtualDom$Styled$containsKey = F2( | ||
9900 | function (key, pairs) { | ||
9901 | containsKey: | ||
9902 | while (true) { | ||
9903 | if (!pairs.b) { | ||
9904 | return false; | ||
9905 | } else { | ||
9906 | var _v1 = pairs.a; | ||
9907 | var str = _v1.a; | ||
9908 | var rest = pairs.b; | ||
9909 | if (_Utils_eq(key, str)) { | ||
9910 | return true; | ||
9911 | } else { | ||
9912 | var $temp$key = key, | ||
9913 | $temp$pairs = rest; | ||
9914 | key = $temp$key; | ||
9915 | pairs = $temp$pairs; | ||
9916 | continue containsKey; | ||
9917 | } | ||
9918 | } | ||
9919 | } | ||
9920 | }); | ||
9921 | var $rtfeldman$elm_css$VirtualDom$Styled$getUnusedKey = F2( | ||
9922 | function (_default, pairs) { | ||
9923 | getUnusedKey: | ||
9924 | while (true) { | ||
9925 | if (!pairs.b) { | ||
9926 | return _default; | ||
9927 | } else { | ||
9928 | var _v1 = pairs.a; | ||
9929 | var firstKey = _v1.a; | ||
9930 | var rest = pairs.b; | ||
9931 | var newKey = '_' + firstKey; | ||
9932 | if (A2($rtfeldman$elm_css$VirtualDom$Styled$containsKey, newKey, rest)) { | ||
9933 | var $temp$default = newKey, | ||
9934 | $temp$pairs = rest; | ||
9935 | _default = $temp$default; | ||
9936 | pairs = $temp$pairs; | ||
9937 | continue getUnusedKey; | ||
9938 | } else { | ||
9939 | return newKey; | ||
9940 | } | ||
9941 | } | ||
9942 | } | ||
9943 | }); | ||
9944 | var $rtfeldman$elm_css$VirtualDom$Styled$toKeyedStyleNode = F2( | ||
9945 | function (allStyles, keyedChildNodes) { | ||
9946 | var styleNodeKey = A2($rtfeldman$elm_css$VirtualDom$Styled$getUnusedKey, '_', keyedChildNodes); | ||
9947 | var finalNode = $rtfeldman$elm_css$VirtualDom$Styled$toStyleNode(allStyles); | ||
9948 | return _Utils_Tuple2(styleNodeKey, finalNode); | ||
9949 | }); | ||
9950 | var $rtfeldman$elm_css$VirtualDom$Styled$unstyleKeyed = F3( | ||
9951 | function (elemType, properties, keyedChildren) { | ||
9952 | var unstyledProperties = A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties); | ||
9953 | var initialStyles = $rtfeldman$elm_css$VirtualDom$Styled$stylesFromProperties(properties); | ||
9954 | var _v0 = A3( | ||
9955 | $elm$core$List$foldl, | ||
9956 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateKeyedStyledHtml, | ||
9957 | _Utils_Tuple2(_List_Nil, initialStyles), | ||
9958 | keyedChildren); | ||
9959 | var keyedChildNodes = _v0.a; | ||
9960 | var styles = _v0.b; | ||
9961 | var keyedStyleNode = A2($rtfeldman$elm_css$VirtualDom$Styled$toKeyedStyleNode, styles, keyedChildNodes); | ||
9962 | return A3( | ||
9963 | $elm$virtual_dom$VirtualDom$keyedNode, | ||
9964 | elemType, | ||
9965 | unstyledProperties, | ||
9966 | A2( | ||
9967 | $elm$core$List$cons, | ||
9968 | keyedStyleNode, | ||
9969 | $elm$core$List$reverse(keyedChildNodes))); | ||
9970 | }); | ||
9971 | var $rtfeldman$elm_css$VirtualDom$Styled$unstyleKeyedNS = F4( | ||
9972 | function (ns, elemType, properties, keyedChildren) { | ||
9973 | var unstyledProperties = A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties); | ||
9974 | var initialStyles = $rtfeldman$elm_css$VirtualDom$Styled$stylesFromProperties(properties); | ||
9975 | var _v0 = A3( | ||
9976 | $elm$core$List$foldl, | ||
9977 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateKeyedStyledHtml, | ||
9978 | _Utils_Tuple2(_List_Nil, initialStyles), | ||
9979 | keyedChildren); | ||
9980 | var keyedChildNodes = _v0.a; | ||
9981 | var styles = _v0.b; | ||
9982 | var keyedStyleNode = A2($rtfeldman$elm_css$VirtualDom$Styled$toKeyedStyleNode, styles, keyedChildNodes); | ||
9983 | return A4( | ||
9984 | $elm$virtual_dom$VirtualDom$keyedNodeNS, | ||
9985 | ns, | ||
9986 | elemType, | ||
9987 | unstyledProperties, | ||
9988 | A2( | ||
9989 | $elm$core$List$cons, | ||
9990 | keyedStyleNode, | ||
9991 | $elm$core$List$reverse(keyedChildNodes))); | ||
9992 | }); | ||
9993 | var $rtfeldman$elm_css$VirtualDom$Styled$unstyleNS = F4( | ||
9994 | function (ns, elemType, properties, children) { | ||
9995 | var unstyledProperties = A2($elm$core$List$map, $rtfeldman$elm_css$VirtualDom$Styled$extractUnstyledAttribute, properties); | ||
9996 | var initialStyles = $rtfeldman$elm_css$VirtualDom$Styled$stylesFromProperties(properties); | ||
9997 | var _v0 = A3( | ||
9998 | $elm$core$List$foldl, | ||
9999 | $rtfeldman$elm_css$VirtualDom$Styled$accumulateStyledHtml, | ||
10000 | _Utils_Tuple2(_List_Nil, initialStyles), | ||
10001 | children); | ||
10002 | var childNodes = _v0.a; | ||
10003 | var styles = _v0.b; | ||
10004 | var styleNode = $rtfeldman$elm_css$VirtualDom$Styled$toStyleNode(styles); | ||
10005 | return A4( | ||
10006 | $elm$virtual_dom$VirtualDom$nodeNS, | ||
10007 | ns, | ||
10008 | elemType, | ||
10009 | unstyledProperties, | ||
10010 | A2( | ||
10011 | $elm$core$List$cons, | ||
10012 | styleNode, | ||
10013 | $elm$core$List$reverse(childNodes))); | ||
10014 | }); | ||
10015 | var $rtfeldman$elm_css$VirtualDom$Styled$toUnstyled = function (vdom) { | ||
10016 | switch (vdom.$) { | ||
10017 | case 'Unstyled': | ||
10018 | var plainNode = vdom.a; | ||
10019 | return plainNode; | ||
10020 | case 'Node': | ||
10021 | var elemType = vdom.a; | ||
10022 | var properties = vdom.b; | ||
10023 | var children = vdom.c; | ||
10024 | return A3($rtfeldman$elm_css$VirtualDom$Styled$unstyle, elemType, properties, children); | ||
10025 | case 'NodeNS': | ||
10026 | var ns = vdom.a; | ||
10027 | var elemType = vdom.b; | ||
10028 | var properties = vdom.c; | ||
10029 | var children = vdom.d; | ||
10030 | return A4($rtfeldman$elm_css$VirtualDom$Styled$unstyleNS, ns, elemType, properties, children); | ||
10031 | case 'KeyedNode': | ||
10032 | var elemType = vdom.a; | ||
10033 | var properties = vdom.b; | ||
10034 | var children = vdom.c; | ||
10035 | return A3($rtfeldman$elm_css$VirtualDom$Styled$unstyleKeyed, elemType, properties, children); | ||
10036 | default: | ||
10037 | var ns = vdom.a; | ||
10038 | var elemType = vdom.b; | ||
10039 | var properties = vdom.c; | ||
10040 | var children = vdom.d; | ||
10041 | return A4($rtfeldman$elm_css$VirtualDom$Styled$unstyleKeyedNS, ns, elemType, properties, children); | ||
10042 | } | ||
10043 | }; | ||
10044 | var $rtfeldman$elm_css$Html$Styled$toUnstyled = $rtfeldman$elm_css$VirtualDom$Styled$toUnstyled; | ||
7474 | var $author$project$Main$LogoutPressed = {$: 'LogoutPressed'}; | 10045 | var $author$project$Main$LogoutPressed = {$: 'LogoutPressed'}; |
7475 | var $elm$html$Html$button = _VirtualDom_node('button'); | 10046 | var $rtfeldman$elm_css$Css$Preprocess$AppendProperty = function (a) { |
7476 | var $elm$html$Html$li = _VirtualDom_node('li'); | 10047 | return {$: 'AppendProperty', a: a}; |
10048 | }; | ||
10049 | var $rtfeldman$elm_css$Css$property = F2( | ||
10050 | function (key, value) { | ||
10051 | return $rtfeldman$elm_css$Css$Preprocess$AppendProperty(key + (':' + value)); | ||
10052 | }); | ||
10053 | var $rtfeldman$elm_css$Css$backgroundColor = function (c) { | ||
10054 | return A2($rtfeldman$elm_css$Css$property, 'background-color', c.value); | ||
10055 | }; | ||
10056 | var $rtfeldman$elm_css$VirtualDom$Styled$murmurSeed = 15739; | ||
10057 | var $rtfeldman$elm_css$VirtualDom$Styled$getClassname = function (styles) { | ||
10058 | return $elm$core$List$isEmpty(styles) ? 'unstyled' : A2( | ||
10059 | $elm$core$String$cons, | ||
10060 | _Utils_chr('_'), | ||
10061 | $rtfeldman$elm_hex$Hex$toString( | ||
10062 | A2( | ||
10063 | $rtfeldman$elm_css$ElmCssVendor$Murmur3$hashString, | ||
10064 | $rtfeldman$elm_css$VirtualDom$Styled$murmurSeed, | ||
10065 | $rtfeldman$elm_css$Css$Preprocess$Resolve$compile( | ||
10066 | $elm$core$List$singleton( | ||
10067 | $rtfeldman$elm_css$Css$Preprocess$stylesheet( | ||
10068 | $elm$core$List$singleton( | ||
10069 | A2( | ||
10070 | $rtfeldman$elm_css$VirtualDom$Styled$makeSnippet, | ||
10071 | styles, | ||
10072 | $rtfeldman$elm_css$Css$Structure$UniversalSelectorSequence(_List_Nil))))))))); | ||
10073 | }; | ||
10074 | var $rtfeldman$elm_css$Html$Styled$Internal$css = function (styles) { | ||
10075 | var classname = $rtfeldman$elm_css$VirtualDom$Styled$getClassname(styles); | ||
10076 | var classProperty = A2( | ||
10077 | $elm$virtual_dom$VirtualDom$property, | ||
10078 | 'className', | ||
10079 | $elm$json$Json$Encode$string(classname)); | ||
10080 | return A3($rtfeldman$elm_css$VirtualDom$Styled$Attribute, classProperty, styles, classname); | ||
10081 | }; | ||
10082 | var $rtfeldman$elm_css$Html$Styled$Attributes$css = $rtfeldman$elm_css$Html$Styled$Internal$css; | ||
10083 | var $rtfeldman$elm_css$Css$prop1 = F2( | ||
10084 | function (key, arg) { | ||
10085 | return A2($rtfeldman$elm_css$Css$property, key, arg.value); | ||
10086 | }); | ||
10087 | var $rtfeldman$elm_css$Css$display = $rtfeldman$elm_css$Css$prop1('display'); | ||
10088 | var $rtfeldman$elm_css$Css$border = $rtfeldman$elm_css$Css$prop1('border'); | ||
10089 | var $rtfeldman$elm_css$Html$Styled$button = $rtfeldman$elm_css$Html$Styled$node('button'); | ||
10090 | var $rtfeldman$elm_css$Css$color = function (c) { | ||
10091 | return A2($rtfeldman$elm_css$Css$property, 'color', c.value); | ||
10092 | }; | ||
10093 | var $rtfeldman$elm_css$Css$height = $rtfeldman$elm_css$Css$prop1('height'); | ||
10094 | var $rtfeldman$elm_css$Css$Preprocess$ExtendSelector = F2( | ||
10095 | function (a, b) { | ||
10096 | return {$: 'ExtendSelector', a: a, b: b}; | ||
10097 | }); | ||
10098 | var $rtfeldman$elm_css$Css$Structure$PseudoClassSelector = function (a) { | ||
10099 | return {$: 'PseudoClassSelector', a: a}; | ||
10100 | }; | ||
10101 | var $rtfeldman$elm_css$Css$pseudoClass = function (_class) { | ||
10102 | return $rtfeldman$elm_css$Css$Preprocess$ExtendSelector( | ||
10103 | $rtfeldman$elm_css$Css$Structure$PseudoClassSelector(_class)); | ||
10104 | }; | ||
10105 | var $rtfeldman$elm_css$Css$hover = $rtfeldman$elm_css$Css$pseudoClass('hover'); | ||
10106 | var $rtfeldman$elm_css$Css$margin = $rtfeldman$elm_css$Css$prop1('margin'); | ||
10107 | var $rtfeldman$elm_css$Css$prop2 = F3( | ||
10108 | function (key, argA, argB) { | ||
10109 | return A2( | ||
10110 | $rtfeldman$elm_css$Css$property, | ||
10111 | key, | ||
10112 | A2( | ||
10113 | $elm$core$String$join, | ||
10114 | ' ', | ||
10115 | _List_fromArray( | ||
10116 | [argA.value, argB.value]))); | ||
10117 | }); | ||
10118 | var $rtfeldman$elm_css$Css$padding2 = $rtfeldman$elm_css$Css$prop2('padding'); | ||
10119 | var $rtfeldman$elm_css$Css$PxUnits = {$: 'PxUnits'}; | ||
10120 | var $rtfeldman$elm_css$Css$Structure$Compatible = {$: 'Compatible'}; | ||
10121 | var $elm$core$String$fromFloat = _String_fromNumber; | ||
10122 | var $rtfeldman$elm_css$Css$Internal$lengthConverter = F3( | ||
10123 | function (units, unitLabel, numericValue) { | ||
10124 | return { | ||
10125 | absoluteLength: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10126 | calc: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10127 | flexBasis: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10128 | fontSize: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10129 | length: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10130 | lengthOrAuto: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10131 | lengthOrAutoOrCoverOrContain: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10132 | lengthOrMinMaxDimension: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10133 | lengthOrNone: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10134 | lengthOrNoneOrMinMaxDimension: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10135 | lengthOrNumber: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10136 | lengthOrNumberOrAutoOrNoneOrContent: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10137 | numericValue: numericValue, | ||
10138 | textIndent: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10139 | unitLabel: unitLabel, | ||
10140 | units: units, | ||
10141 | value: _Utils_ap( | ||
10142 | $elm$core$String$fromFloat(numericValue), | ||
10143 | unitLabel) | ||
10144 | }; | ||
10145 | }); | ||
10146 | var $rtfeldman$elm_css$Css$px = A2($rtfeldman$elm_css$Css$Internal$lengthConverter, $rtfeldman$elm_css$Css$PxUnits, 'px'); | ||
10147 | var $rtfeldman$elm_css$Html$Styled$styled = F4( | ||
10148 | function (fn, styles, attrs, children) { | ||
10149 | return A2( | ||
10150 | fn, | ||
10151 | A2( | ||
10152 | $elm$core$List$cons, | ||
10153 | $rtfeldman$elm_css$Html$Styled$Internal$css(styles), | ||
10154 | attrs), | ||
10155 | children); | ||
10156 | }); | ||
10157 | var $author$project$Styles$Theme = F7( | ||
10158 | function (primary, secondary, bad, fg, bg, fgLight, bgLight) { | ||
10159 | return {bad: bad, bg: bg, bgLight: bgLight, fg: fg, fgLight: fgLight, primary: primary, secondary: secondary}; | ||
10160 | }); | ||
10161 | var $rtfeldman$elm_css$Css$withPrecedingHash = function (str) { | ||
10162 | return A2($elm$core$String$startsWith, '#', str) ? str : A2( | ||
10163 | $elm$core$String$cons, | ||
10164 | _Utils_chr('#'), | ||
10165 | str); | ||
10166 | }; | ||
10167 | var $rtfeldman$elm_css$Css$erroneousHex = function (str) { | ||
10168 | return { | ||
10169 | alpha: 1, | ||
10170 | blue: 0, | ||
10171 | color: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10172 | green: 0, | ||
10173 | red: 0, | ||
10174 | value: $rtfeldman$elm_css$Css$withPrecedingHash(str) | ||
10175 | }; | ||
10176 | }; | ||
10177 | var $elm$core$String$fromChar = function (_char) { | ||
10178 | return A2($elm$core$String$cons, _char, ''); | ||
10179 | }; | ||
10180 | var $elm$core$Basics$pow = _Basics_pow; | ||
10181 | var $rtfeldman$elm_hex$Hex$fromStringHelp = F3( | ||
10182 | function (position, chars, accumulated) { | ||
10183 | fromStringHelp: | ||
10184 | while (true) { | ||
10185 | if (!chars.b) { | ||
10186 | return $elm$core$Result$Ok(accumulated); | ||
10187 | } else { | ||
10188 | var _char = chars.a; | ||
10189 | var rest = chars.b; | ||
10190 | switch (_char.valueOf()) { | ||
10191 | case '0': | ||
10192 | var $temp$position = position - 1, | ||
10193 | $temp$chars = rest, | ||
10194 | $temp$accumulated = accumulated; | ||
10195 | position = $temp$position; | ||
10196 | chars = $temp$chars; | ||
10197 | accumulated = $temp$accumulated; | ||
10198 | continue fromStringHelp; | ||
10199 | case '1': | ||
10200 | var $temp$position = position - 1, | ||
10201 | $temp$chars = rest, | ||
10202 | $temp$accumulated = accumulated + A2($elm$core$Basics$pow, 16, position); | ||
10203 | position = $temp$position; | ||
10204 | chars = $temp$chars; | ||
10205 | accumulated = $temp$accumulated; | ||
10206 | continue fromStringHelp; | ||
10207 | case '2': | ||
10208 | var $temp$position = position - 1, | ||
10209 | $temp$chars = rest, | ||
10210 | $temp$accumulated = accumulated + (2 * A2($elm$core$Basics$pow, 16, position)); | ||
10211 | position = $temp$position; | ||
10212 | chars = $temp$chars; | ||
10213 | accumulated = $temp$accumulated; | ||
10214 | continue fromStringHelp; | ||
10215 | case '3': | ||
10216 | var $temp$position = position - 1, | ||
10217 | $temp$chars = rest, | ||
10218 | $temp$accumulated = accumulated + (3 * A2($elm$core$Basics$pow, 16, position)); | ||
10219 | position = $temp$position; | ||
10220 | chars = $temp$chars; | ||
10221 | accumulated = $temp$accumulated; | ||
10222 | continue fromStringHelp; | ||
10223 | case '4': | ||
10224 | var $temp$position = position - 1, | ||
10225 | $temp$chars = rest, | ||
10226 | $temp$accumulated = accumulated + (4 * A2($elm$core$Basics$pow, 16, position)); | ||
10227 | position = $temp$position; | ||
10228 | chars = $temp$chars; | ||
10229 | accumulated = $temp$accumulated; | ||
10230 | continue fromStringHelp; | ||
10231 | case '5': | ||
10232 | var $temp$position = position - 1, | ||
10233 | $temp$chars = rest, | ||
10234 | $temp$accumulated = accumulated + (5 * A2($elm$core$Basics$pow, 16, position)); | ||
10235 | position = $temp$position; | ||
10236 | chars = $temp$chars; | ||
10237 | accumulated = $temp$accumulated; | ||
10238 | continue fromStringHelp; | ||
10239 | case '6': | ||
10240 | var $temp$position = position - 1, | ||
10241 | $temp$chars = rest, | ||
10242 | $temp$accumulated = accumulated + (6 * A2($elm$core$Basics$pow, 16, position)); | ||
10243 | position = $temp$position; | ||
10244 | chars = $temp$chars; | ||
10245 | accumulated = $temp$accumulated; | ||
10246 | continue fromStringHelp; | ||
10247 | case '7': | ||
10248 | var $temp$position = position - 1, | ||
10249 | $temp$chars = rest, | ||
10250 | $temp$accumulated = accumulated + (7 * A2($elm$core$Basics$pow, 16, position)); | ||
10251 | position = $temp$position; | ||
10252 | chars = $temp$chars; | ||
10253 | accumulated = $temp$accumulated; | ||
10254 | continue fromStringHelp; | ||
10255 | case '8': | ||
10256 | var $temp$position = position - 1, | ||
10257 | $temp$chars = rest, | ||
10258 | $temp$accumulated = accumulated + (8 * A2($elm$core$Basics$pow, 16, position)); | ||
10259 | position = $temp$position; | ||
10260 | chars = $temp$chars; | ||
10261 | accumulated = $temp$accumulated; | ||
10262 | continue fromStringHelp; | ||
10263 | case '9': | ||
10264 | var $temp$position = position - 1, | ||
10265 | $temp$chars = rest, | ||
10266 | $temp$accumulated = accumulated + (9 * A2($elm$core$Basics$pow, 16, position)); | ||
10267 | position = $temp$position; | ||
10268 | chars = $temp$chars; | ||
10269 | accumulated = $temp$accumulated; | ||
10270 | continue fromStringHelp; | ||
10271 | case 'a': | ||
10272 | var $temp$position = position - 1, | ||
10273 | $temp$chars = rest, | ||
10274 | $temp$accumulated = accumulated + (10 * A2($elm$core$Basics$pow, 16, position)); | ||
10275 | position = $temp$position; | ||
10276 | chars = $temp$chars; | ||
10277 | accumulated = $temp$accumulated; | ||
10278 | continue fromStringHelp; | ||
10279 | case 'b': | ||
10280 | var $temp$position = position - 1, | ||
10281 | $temp$chars = rest, | ||
10282 | $temp$accumulated = accumulated + (11 * A2($elm$core$Basics$pow, 16, position)); | ||
10283 | position = $temp$position; | ||
10284 | chars = $temp$chars; | ||
10285 | accumulated = $temp$accumulated; | ||
10286 | continue fromStringHelp; | ||
10287 | case 'c': | ||
10288 | var $temp$position = position - 1, | ||
10289 | $temp$chars = rest, | ||
10290 | $temp$accumulated = accumulated + (12 * A2($elm$core$Basics$pow, 16, position)); | ||
10291 | position = $temp$position; | ||
10292 | chars = $temp$chars; | ||
10293 | accumulated = $temp$accumulated; | ||
10294 | continue fromStringHelp; | ||
10295 | case 'd': | ||
10296 | var $temp$position = position - 1, | ||
10297 | $temp$chars = rest, | ||
10298 | $temp$accumulated = accumulated + (13 * A2($elm$core$Basics$pow, 16, position)); | ||
10299 | position = $temp$position; | ||
10300 | chars = $temp$chars; | ||
10301 | accumulated = $temp$accumulated; | ||
10302 | continue fromStringHelp; | ||
10303 | case 'e': | ||
10304 | var $temp$position = position - 1, | ||
10305 | $temp$chars = rest, | ||
10306 | $temp$accumulated = accumulated + (14 * A2($elm$core$Basics$pow, 16, position)); | ||
10307 | position = $temp$position; | ||
10308 | chars = $temp$chars; | ||
10309 | accumulated = $temp$accumulated; | ||
10310 | continue fromStringHelp; | ||
10311 | case 'f': | ||
10312 | var $temp$position = position - 1, | ||
10313 | $temp$chars = rest, | ||
10314 | $temp$accumulated = accumulated + (15 * A2($elm$core$Basics$pow, 16, position)); | ||
10315 | position = $temp$position; | ||
10316 | chars = $temp$chars; | ||
10317 | accumulated = $temp$accumulated; | ||
10318 | continue fromStringHelp; | ||
10319 | default: | ||
10320 | var nonHex = _char; | ||
10321 | return $elm$core$Result$Err( | ||
10322 | $elm$core$String$fromChar(nonHex) + ' is not a valid hexadecimal character.'); | ||
10323 | } | ||
10324 | } | ||
10325 | } | ||
10326 | }); | ||
10327 | var $elm$core$Result$map = F2( | ||
10328 | function (func, ra) { | ||
10329 | if (ra.$ === 'Ok') { | ||
10330 | var a = ra.a; | ||
10331 | return $elm$core$Result$Ok( | ||
10332 | func(a)); | ||
10333 | } else { | ||
10334 | var e = ra.a; | ||
10335 | return $elm$core$Result$Err(e); | ||
10336 | } | ||
10337 | }); | ||
10338 | var $rtfeldman$elm_hex$Hex$fromString = function (str) { | ||
10339 | if ($elm$core$String$isEmpty(str)) { | ||
10340 | return $elm$core$Result$Err('Empty strings are not valid hexadecimal strings.'); | ||
10341 | } else { | ||
10342 | var result = function () { | ||
10343 | if (A2($elm$core$String$startsWith, '-', str)) { | ||
10344 | var list = A2( | ||
10345 | $elm$core$Maybe$withDefault, | ||
10346 | _List_Nil, | ||
10347 | $elm$core$List$tail( | ||
10348 | $elm$core$String$toList(str))); | ||
10349 | return A2( | ||
10350 | $elm$core$Result$map, | ||
10351 | $elm$core$Basics$negate, | ||
10352 | A3( | ||
10353 | $rtfeldman$elm_hex$Hex$fromStringHelp, | ||
10354 | $elm$core$List$length(list) - 1, | ||
10355 | list, | ||
10356 | 0)); | ||
10357 | } else { | ||
10358 | return A3( | ||
10359 | $rtfeldman$elm_hex$Hex$fromStringHelp, | ||
10360 | $elm$core$String$length(str) - 1, | ||
10361 | $elm$core$String$toList(str), | ||
10362 | 0); | ||
10363 | } | ||
10364 | }(); | ||
10365 | var formatError = function (err) { | ||
10366 | return A2( | ||
10367 | $elm$core$String$join, | ||
10368 | ' ', | ||
10369 | _List_fromArray( | ||
10370 | ['\"' + (str + '\"'), 'is not a valid hexadecimal string because', err])); | ||
10371 | }; | ||
10372 | return A2($elm$core$Result$mapError, formatError, result); | ||
10373 | } | ||
10374 | }; | ||
10375 | var $elm$core$String$toLower = _String_toLower; | ||
10376 | var $rtfeldman$elm_css$Css$validHex = F5( | ||
10377 | function (str, _v0, _v1, _v2, _v3) { | ||
10378 | var r1 = _v0.a; | ||
10379 | var r2 = _v0.b; | ||
10380 | var g1 = _v1.a; | ||
10381 | var g2 = _v1.b; | ||
10382 | var b1 = _v2.a; | ||
10383 | var b2 = _v2.b; | ||
10384 | var a1 = _v3.a; | ||
10385 | var a2 = _v3.b; | ||
10386 | var toResult = A2( | ||
10387 | $elm$core$Basics$composeR, | ||
10388 | $elm$core$String$fromList, | ||
10389 | A2($elm$core$Basics$composeR, $elm$core$String$toLower, $rtfeldman$elm_hex$Hex$fromString)); | ||
10390 | var results = _Utils_Tuple2( | ||
10391 | _Utils_Tuple2( | ||
10392 | toResult( | ||
10393 | _List_fromArray( | ||
10394 | [r1, r2])), | ||
10395 | toResult( | ||
10396 | _List_fromArray( | ||
10397 | [g1, g2]))), | ||
10398 | _Utils_Tuple2( | ||
10399 | toResult( | ||
10400 | _List_fromArray( | ||
10401 | [b1, b2])), | ||
10402 | toResult( | ||
10403 | _List_fromArray( | ||
10404 | [a1, a2])))); | ||
10405 | if ((((results.a.a.$ === 'Ok') && (results.a.b.$ === 'Ok')) && (results.b.a.$ === 'Ok')) && (results.b.b.$ === 'Ok')) { | ||
10406 | var _v5 = results.a; | ||
10407 | var red = _v5.a.a; | ||
10408 | var green = _v5.b.a; | ||
10409 | var _v6 = results.b; | ||
10410 | var blue = _v6.a.a; | ||
10411 | var alpha = _v6.b.a; | ||
10412 | return { | ||
10413 | alpha: alpha / 255, | ||
10414 | blue: blue, | ||
10415 | color: $rtfeldman$elm_css$Css$Structure$Compatible, | ||
10416 | green: green, | ||
10417 | red: red, | ||
10418 | value: $rtfeldman$elm_css$Css$withPrecedingHash(str) | ||
10419 | }; | ||
10420 | } else { | ||
10421 | return $rtfeldman$elm_css$Css$erroneousHex(str); | ||
10422 | } | ||
10423 | }); | ||
10424 | var $rtfeldman$elm_css$Css$hex = function (str) { | ||
10425 | var withoutHash = A2($elm$core$String$startsWith, '#', str) ? A2($elm$core$String$dropLeft, 1, str) : str; | ||
10426 | var _v0 = $elm$core$String$toList(withoutHash); | ||
10427 | _v0$4: | ||
10428 | while (true) { | ||
10429 | if ((_v0.b && _v0.b.b) && _v0.b.b.b) { | ||
10430 | if (!_v0.b.b.b.b) { | ||
10431 | var r = _v0.a; | ||
10432 | var _v1 = _v0.b; | ||
10433 | var g = _v1.a; | ||
10434 | var _v2 = _v1.b; | ||
10435 | var b = _v2.a; | ||
10436 | return A5( | ||
10437 | $rtfeldman$elm_css$Css$validHex, | ||
10438 | str, | ||
10439 | _Utils_Tuple2(r, r), | ||
10440 | _Utils_Tuple2(g, g), | ||
10441 | _Utils_Tuple2(b, b), | ||
10442 | _Utils_Tuple2( | ||
10443 | _Utils_chr('f'), | ||
10444 | _Utils_chr('f'))); | ||
10445 | } else { | ||
10446 | if (!_v0.b.b.b.b.b) { | ||
10447 | var r = _v0.a; | ||
10448 | var _v3 = _v0.b; | ||
10449 | var g = _v3.a; | ||
10450 | var _v4 = _v3.b; | ||
10451 | var b = _v4.a; | ||
10452 | var _v5 = _v4.b; | ||
10453 | var a = _v5.a; | ||
10454 | return A5( | ||
10455 | $rtfeldman$elm_css$Css$validHex, | ||
10456 | str, | ||
10457 | _Utils_Tuple2(r, r), | ||
10458 | _Utils_Tuple2(g, g), | ||
10459 | _Utils_Tuple2(b, b), | ||
10460 | _Utils_Tuple2(a, a)); | ||
10461 | } else { | ||
10462 | if (_v0.b.b.b.b.b.b) { | ||
10463 | if (!_v0.b.b.b.b.b.b.b) { | ||
10464 | var r1 = _v0.a; | ||
10465 | var _v6 = _v0.b; | ||
10466 | var r2 = _v6.a; | ||
10467 | var _v7 = _v6.b; | ||
10468 | var g1 = _v7.a; | ||
10469 | var _v8 = _v7.b; | ||
10470 | var g2 = _v8.a; | ||
10471 | var _v9 = _v8.b; | ||
10472 | var b1 = _v9.a; | ||
10473 | var _v10 = _v9.b; | ||
10474 | var b2 = _v10.a; | ||
10475 | return A5( | ||
10476 | $rtfeldman$elm_css$Css$validHex, | ||
10477 | str, | ||
10478 | _Utils_Tuple2(r1, r2), | ||
10479 | _Utils_Tuple2(g1, g2), | ||
10480 | _Utils_Tuple2(b1, b2), | ||
10481 | _Utils_Tuple2( | ||
10482 | _Utils_chr('f'), | ||
10483 | _Utils_chr('f'))); | ||
10484 | } else { | ||
10485 | if (_v0.b.b.b.b.b.b.b.b && (!_v0.b.b.b.b.b.b.b.b.b)) { | ||
10486 | var r1 = _v0.a; | ||
10487 | var _v11 = _v0.b; | ||
10488 | var r2 = _v11.a; | ||
10489 | var _v12 = _v11.b; | ||
10490 | var g1 = _v12.a; | ||
10491 | var _v13 = _v12.b; | ||
10492 | var g2 = _v13.a; | ||
10493 | var _v14 = _v13.b; | ||
10494 | var b1 = _v14.a; | ||
10495 | var _v15 = _v14.b; | ||
10496 | var b2 = _v15.a; | ||
10497 | var _v16 = _v15.b; | ||
10498 | var a1 = _v16.a; | ||
10499 | var _v17 = _v16.b; | ||
10500 | var a2 = _v17.a; | ||
10501 | return A5( | ||
10502 | $rtfeldman$elm_css$Css$validHex, | ||
10503 | str, | ||
10504 | _Utils_Tuple2(r1, r2), | ||
10505 | _Utils_Tuple2(g1, g2), | ||
10506 | _Utils_Tuple2(b1, b2), | ||
10507 | _Utils_Tuple2(a1, a2)); | ||
10508 | } else { | ||
10509 | break _v0$4; | ||
10510 | } | ||
10511 | } | ||
10512 | } else { | ||
10513 | break _v0$4; | ||
10514 | } | ||
10515 | } | ||
10516 | } | ||
10517 | } else { | ||
10518 | break _v0$4; | ||
10519 | } | ||
10520 | } | ||
10521 | return $rtfeldman$elm_css$Css$erroneousHex(str); | ||
10522 | }; | ||
10523 | var $author$project$Styles$theme = A7( | ||
10524 | $author$project$Styles$Theme, | ||
10525 | $rtfeldman$elm_css$Css$hex('fedbd0'), | ||
10526 | $rtfeldman$elm_css$Css$hex('feeae6'), | ||
10527 | $rtfeldman$elm_css$Css$hex('ff0000'), | ||
10528 | $rtfeldman$elm_css$Css$hex('442c2e'), | ||
10529 | $rtfeldman$elm_css$Css$hex('ffffff'), | ||
10530 | $rtfeldman$elm_css$Css$hex('442c2e'), | ||
10531 | $rtfeldman$elm_css$Css$hex('feeae6')); | ||
10532 | var $author$project$Styles$furbyButton = A2( | ||
10533 | $rtfeldman$elm_css$Html$Styled$styled, | ||
10534 | $rtfeldman$elm_css$Html$Styled$button, | ||
10535 | _List_fromArray( | ||
10536 | [ | ||
10537 | $rtfeldman$elm_css$Css$margin( | ||
10538 | $rtfeldman$elm_css$Css$px(12)), | ||
10539 | $rtfeldman$elm_css$Css$color($author$project$Styles$theme.fg), | ||
10540 | $rtfeldman$elm_css$Css$height( | ||
10541 | $rtfeldman$elm_css$Css$px(40)), | ||
10542 | $rtfeldman$elm_css$Css$border( | ||
10543 | $rtfeldman$elm_css$Css$px(0)), | ||
10544 | A2( | ||
10545 | $rtfeldman$elm_css$Css$padding2, | ||
10546 | $rtfeldman$elm_css$Css$px(6), | ||
10547 | $rtfeldman$elm_css$Css$px(12)), | ||
10548 | $rtfeldman$elm_css$Css$backgroundColor($author$project$Styles$theme.primary), | ||
10549 | $rtfeldman$elm_css$Css$hover( | ||
10550 | _List_fromArray( | ||
10551 | [ | ||
10552 | $rtfeldman$elm_css$Css$backgroundColor($author$project$Styles$theme.secondary), | ||
10553 | $rtfeldman$elm_css$Css$color($author$project$Styles$theme.fg), | ||
10554 | $rtfeldman$elm_css$Css$margin( | ||
10555 | $rtfeldman$elm_css$Css$px(12)) | ||
10556 | ])) | ||
10557 | ])); | ||
10558 | var $rtfeldman$elm_css$Css$none = {backgroundImage: $rtfeldman$elm_css$Css$Structure$Compatible, blockAxisOverflow: $rtfeldman$elm_css$Css$Structure$Compatible, borderStyle: $rtfeldman$elm_css$Css$Structure$Compatible, cursor: $rtfeldman$elm_css$Css$Structure$Compatible, display: $rtfeldman$elm_css$Css$Structure$Compatible, hoverCapability: $rtfeldman$elm_css$Css$Structure$Compatible, inlineAxisOverflow: $rtfeldman$elm_css$Css$Structure$Compatible, keyframes: $rtfeldman$elm_css$Css$Structure$Compatible, lengthOrNone: $rtfeldman$elm_css$Css$Structure$Compatible, lengthOrNoneOrMinMaxDimension: $rtfeldman$elm_css$Css$Structure$Compatible, lengthOrNumberOrAutoOrNoneOrContent: $rtfeldman$elm_css$Css$Structure$Compatible, listStyleType: $rtfeldman$elm_css$Css$Structure$Compatible, listStyleTypeOrPositionOrImage: $rtfeldman$elm_css$Css$Structure$Compatible, none: $rtfeldman$elm_css$Css$Structure$Compatible, outline: $rtfeldman$elm_css$Css$Structure$Compatible, pointerDevice: $rtfeldman$elm_css$Css$Structure$Compatible, pointerEvents: $rtfeldman$elm_css$Css$Structure$Compatible, resize: $rtfeldman$elm_css$Css$Structure$Compatible, scriptingSupport: $rtfeldman$elm_css$Css$Structure$Compatible, textDecorationLine: $rtfeldman$elm_css$Css$Structure$Compatible, textTransform: $rtfeldman$elm_css$Css$Structure$Compatible, touchAction: $rtfeldman$elm_css$Css$Structure$Compatible, transform: $rtfeldman$elm_css$Css$Structure$Compatible, updateFrequency: $rtfeldman$elm_css$Css$Structure$Compatible, value: 'none'}; | ||
10559 | var $rtfeldman$elm_css$Css$padding = $rtfeldman$elm_css$Css$prop1('padding'); | ||
10560 | var $rtfeldman$elm_css$Css$textDecoration = $rtfeldman$elm_css$Css$prop1('text-decoration'); | ||
10561 | var $rtfeldman$elm_css$Css$underline = {textDecorationLine: $rtfeldman$elm_css$Css$Structure$Compatible, value: 'underline'}; | ||
10562 | var $author$project$Styles$headerLink = A2( | ||
10563 | $rtfeldman$elm_css$Html$Styled$styled, | ||
10564 | $rtfeldman$elm_css$Html$Styled$a, | ||
10565 | _List_fromArray( | ||
10566 | [ | ||
10567 | $rtfeldman$elm_css$Css$color($author$project$Styles$theme.fgLight), | ||
10568 | $rtfeldman$elm_css$Css$padding( | ||
10569 | $rtfeldman$elm_css$Css$px(12)), | ||
10570 | $rtfeldman$elm_css$Css$textDecoration($rtfeldman$elm_css$Css$none), | ||
10571 | $rtfeldman$elm_css$Css$hover( | ||
10572 | _List_fromArray( | ||
10573 | [ | ||
10574 | $rtfeldman$elm_css$Css$backgroundColor($author$project$Styles$theme.secondary), | ||
10575 | $rtfeldman$elm_css$Css$textDecoration($rtfeldman$elm_css$Css$underline) | ||
10576 | ])) | ||
10577 | ])); | ||
10578 | var $rtfeldman$elm_css$Css$inline = {display: $rtfeldman$elm_css$Css$Structure$Compatible, value: 'inline'}; | ||
10579 | var $rtfeldman$elm_css$Css$left = $rtfeldman$elm_css$Css$prop1('left'); | ||
10580 | var $rtfeldman$elm_css$Css$listStyle = $rtfeldman$elm_css$Css$prop1('list-style'); | ||
7477 | var $elm$virtual_dom$VirtualDom$Normal = function (a) { | 10581 | var $elm$virtual_dom$VirtualDom$Normal = function (a) { |
7478 | return {$: 'Normal', a: a}; | 10582 | return {$: 'Normal', a: a}; |
7479 | }; | 10583 | }; |
7480 | var $elm$virtual_dom$VirtualDom$on = _VirtualDom_on; | 10584 | var $elm$virtual_dom$VirtualDom$on = _VirtualDom_on; |
7481 | var $elm$html$Html$Events$on = F2( | 10585 | var $rtfeldman$elm_css$VirtualDom$Styled$on = F2( |
10586 | function (eventName, handler) { | ||
10587 | return A3( | ||
10588 | $rtfeldman$elm_css$VirtualDom$Styled$Attribute, | ||
10589 | A2($elm$virtual_dom$VirtualDom$on, eventName, handler), | ||
10590 | _List_Nil, | ||
10591 | ''); | ||
10592 | }); | ||
10593 | var $rtfeldman$elm_css$Html$Styled$Events$on = F2( | ||
7482 | function (event, decoder) { | 10594 | function (event, decoder) { |
7483 | return A2( | 10595 | return A2( |
7484 | $elm$virtual_dom$VirtualDom$on, | 10596 | $rtfeldman$elm_css$VirtualDom$Styled$on, |
7485 | event, | 10597 | event, |
7486 | $elm$virtual_dom$VirtualDom$Normal(decoder)); | 10598 | $elm$virtual_dom$VirtualDom$Normal(decoder)); |
7487 | }); | 10599 | }); |
7488 | var $elm$html$Html$Events$onClick = function (msg) { | 10600 | var $rtfeldman$elm_css$Html$Styled$Events$onClick = function (msg) { |
7489 | return A2( | 10601 | return A2( |
7490 | $elm$html$Html$Events$on, | 10602 | $rtfeldman$elm_css$Html$Styled$Events$on, |
7491 | 'click', | 10603 | 'click', |
7492 | $elm$json$Json$Decode$succeed(msg)); | 10604 | $elm$json$Json$Decode$succeed(msg)); |
7493 | }; | 10605 | }; |
7494 | var $elm$virtual_dom$VirtualDom$text = _VirtualDom_text; | 10606 | var $rtfeldman$elm_css$Css$paddingBottom = $rtfeldman$elm_css$Css$prop1('padding-bottom'); |
7495 | var $elm$html$Html$text = $elm$virtual_dom$VirtualDom$text; | 10607 | var $rtfeldman$elm_css$Css$paddingTop = $rtfeldman$elm_css$Css$prop1('padding-top'); |
7496 | var $elm$html$Html$ul = _VirtualDom_node('ul'); | 10608 | var $rtfeldman$elm_css$VirtualDom$Styled$text = function (str) { |
10609 | return $rtfeldman$elm_css$VirtualDom$Styled$Unstyled( | ||
10610 | $elm$virtual_dom$VirtualDom$text(str)); | ||
10611 | }; | ||
10612 | var $rtfeldman$elm_css$Html$Styled$text = $rtfeldman$elm_css$VirtualDom$Styled$text; | ||
10613 | var $rtfeldman$elm_css$Css$Preprocess$ApplyStyles = function (a) { | ||
10614 | return {$: 'ApplyStyles', a: a}; | ||
10615 | }; | ||
10616 | var $rtfeldman$elm_css$Css$Internal$property = F2( | ||
10617 | function (key, value) { | ||
10618 | return $rtfeldman$elm_css$Css$Preprocess$AppendProperty(key + (':' + value)); | ||
10619 | }); | ||
10620 | var $rtfeldman$elm_css$Css$Internal$getOverloadedProperty = F3( | ||
10621 | function (functionName, desiredKey, style) { | ||
10622 | getOverloadedProperty: | ||
10623 | while (true) { | ||
10624 | switch (style.$) { | ||
10625 | case 'AppendProperty': | ||
10626 | var str = style.a; | ||
10627 | var key = A2( | ||
10628 | $elm$core$Maybe$withDefault, | ||
10629 | '', | ||
10630 | $elm$core$List$head( | ||
10631 | A2($elm$core$String$split, ':', str))); | ||
10632 | return A2($rtfeldman$elm_css$Css$Internal$property, desiredKey, key); | ||
10633 | case 'ExtendSelector': | ||
10634 | var selector = style.a; | ||
10635 | return A2($rtfeldman$elm_css$Css$Internal$property, desiredKey, 'elm-css-error-cannot-apply-' + (functionName + '-with-inapplicable-Style-for-selector')); | ||
10636 | case 'NestSnippet': | ||
10637 | var combinator = style.a; | ||
10638 | return A2($rtfeldman$elm_css$Css$Internal$property, desiredKey, 'elm-css-error-cannot-apply-' + (functionName + '-with-inapplicable-Style-for-combinator')); | ||
10639 | case 'WithPseudoElement': | ||
10640 | var pseudoElement = style.a; | ||
10641 | return A2($rtfeldman$elm_css$Css$Internal$property, desiredKey, 'elm-css-error-cannot-apply-' + (functionName + '-with-inapplicable-Style-for-pseudo-element setter')); | ||
10642 | case 'WithMedia': | ||
10643 | return A2($rtfeldman$elm_css$Css$Internal$property, desiredKey, 'elm-css-error-cannot-apply-' + (functionName + '-with-inapplicable-Style-for-media-query')); | ||
10644 | case 'WithKeyframes': | ||
10645 | return A2($rtfeldman$elm_css$Css$Internal$property, desiredKey, 'elm-css-error-cannot-apply-' + (functionName + '-with-inapplicable-Style-for-keyframes')); | ||
10646 | default: | ||
10647 | if (!style.a.b) { | ||
10648 | return A2($rtfeldman$elm_css$Css$Internal$property, desiredKey, 'elm-css-error-cannot-apply-' + (functionName + '-with-empty-Style')); | ||
10649 | } else { | ||
10650 | if (!style.a.b.b) { | ||
10651 | var _v1 = style.a; | ||
10652 | var only = _v1.a; | ||
10653 | var $temp$functionName = functionName, | ||
10654 | $temp$desiredKey = desiredKey, | ||
10655 | $temp$style = only; | ||
10656 | functionName = $temp$functionName; | ||
10657 | desiredKey = $temp$desiredKey; | ||
10658 | style = $temp$style; | ||
10659 | continue getOverloadedProperty; | ||
10660 | } else { | ||
10661 | var _v2 = style.a; | ||
10662 | var first = _v2.a; | ||
10663 | var rest = _v2.b; | ||
10664 | var $temp$functionName = functionName, | ||
10665 | $temp$desiredKey = desiredKey, | ||
10666 | $temp$style = $rtfeldman$elm_css$Css$Preprocess$ApplyStyles(rest); | ||
10667 | functionName = $temp$functionName; | ||
10668 | desiredKey = $temp$desiredKey; | ||
10669 | style = $temp$style; | ||
10670 | continue getOverloadedProperty; | ||
10671 | } | ||
10672 | } | ||
10673 | } | ||
10674 | } | ||
10675 | }); | ||
10676 | var $rtfeldman$elm_css$Css$Internal$IncompatibleUnits = {$: 'IncompatibleUnits'}; | ||
10677 | var $rtfeldman$elm_css$Css$Internal$lengthForOverloadedProperty = A3($rtfeldman$elm_css$Css$Internal$lengthConverter, $rtfeldman$elm_css$Css$Internal$IncompatibleUnits, '', 0); | ||
10678 | var $rtfeldman$elm_css$Css$textAlign = function (fn) { | ||
10679 | return A3( | ||
10680 | $rtfeldman$elm_css$Css$Internal$getOverloadedProperty, | ||
10681 | 'textAlign', | ||
10682 | 'text-align', | ||
10683 | fn($rtfeldman$elm_css$Css$Internal$lengthForOverloadedProperty)); | ||
10684 | }; | ||
10685 | var $rtfeldman$elm_css$Html$Styled$ul = $rtfeldman$elm_css$Html$Styled$node('ul'); | ||
7497 | var $author$project$Main$viewHeader = function (model) { | 10686 | var $author$project$Main$viewHeader = function (model) { |
7498 | var links = _List_fromArray( | 10687 | var links = _List_fromArray( |
7499 | [ | 10688 | [ |
7500 | _Utils_Tuple2('Home', '/'), | ||
7501 | _Utils_Tuple2('Catalog', '/catalog'), | 10689 | _Utils_Tuple2('Catalog', '/catalog'), |
7502 | _Utils_Tuple2('Cart', '/cart') | 10690 | _Utils_Tuple2('Cart', '/cart') |
7503 | ]); | 10691 | ]); |
7504 | return A2( | 10692 | return A2( |
7505 | $elm$html$Html$div, | 10693 | $rtfeldman$elm_css$Html$Styled$div, |
7506 | _List_Nil, | 10694 | _List_fromArray( |
10695 | [ | ||
10696 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
10697 | _List_fromArray( | ||
10698 | [ | ||
10699 | $rtfeldman$elm_css$Css$padding( | ||
10700 | $rtfeldman$elm_css$Css$px(40)), | ||
10701 | $rtfeldman$elm_css$Css$paddingTop( | ||
10702 | $rtfeldman$elm_css$Css$px(3)), | ||
10703 | $rtfeldman$elm_css$Css$paddingBottom( | ||
10704 | $rtfeldman$elm_css$Css$px(3)), | ||
10705 | $rtfeldman$elm_css$Css$textAlign($rtfeldman$elm_css$Css$left), | ||
10706 | $rtfeldman$elm_css$Css$backgroundColor($author$project$Styles$theme.secondary) | ||
10707 | ])) | ||
10708 | ]), | ||
7507 | _List_fromArray( | 10709 | _List_fromArray( |
7508 | [ | 10710 | [ |
7509 | A2( | 10711 | A2( |
7510 | $elm$html$Html$ul, | 10712 | $rtfeldman$elm_css$Html$Styled$ul, |
7511 | _List_Nil, | 10713 | _List_fromArray( |
10714 | [ | ||
10715 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
10716 | _List_fromArray( | ||
10717 | [ | ||
10718 | $rtfeldman$elm_css$Css$listStyle($rtfeldman$elm_css$Css$none), | ||
10719 | $rtfeldman$elm_css$Css$padding( | ||
10720 | $rtfeldman$elm_css$Css$px(0)) | ||
10721 | ])) | ||
10722 | ]), | ||
7512 | _Utils_ap( | 10723 | _Utils_ap( |
7513 | A2( | 10724 | A2( |
7514 | $elm$core$List$map, | 10725 | $elm$core$List$map, |
@@ -7516,19 +10727,26 @@ var $author$project$Main$viewHeader = function (model) { | |||
7516 | var name = _v0.a; | 10727 | var name = _v0.a; |
7517 | var loc = _v0.b; | 10728 | var loc = _v0.b; |
7518 | return A2( | 10729 | return A2( |
7519 | $elm$html$Html$li, | 10730 | $rtfeldman$elm_css$Html$Styled$li, |
7520 | _List_Nil, | 10731 | _List_fromArray( |
10732 | [ | ||
10733 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
10734 | _List_fromArray( | ||
10735 | [ | ||
10736 | $rtfeldman$elm_css$Css$display($rtfeldman$elm_css$Css$inline) | ||
10737 | ])) | ||
10738 | ]), | ||
7521 | _List_fromArray( | 10739 | _List_fromArray( |
7522 | [ | 10740 | [ |
7523 | A2( | 10741 | A2( |
7524 | $elm$html$Html$a, | 10742 | $author$project$Styles$headerLink, |
7525 | _List_fromArray( | 10743 | _List_fromArray( |
7526 | [ | 10744 | [ |
7527 | $elm$html$Html$Attributes$href(loc) | 10745 | $rtfeldman$elm_css$Html$Styled$Attributes$href(loc) |
7528 | ]), | 10746 | ]), |
7529 | _List_fromArray( | 10747 | _List_fromArray( |
7530 | [ | 10748 | [ |
7531 | $elm$html$Html$text(name) | 10749 | $rtfeldman$elm_css$Html$Styled$text(name) |
7532 | ])) | 10750 | ])) |
7533 | ])); | 10751 | ])); |
7534 | }, | 10752 | }, |
@@ -7536,121 +10754,160 @@ var $author$project$Main$viewHeader = function (model) { | |||
7536 | _List_fromArray( | 10754 | _List_fromArray( |
7537 | [ | 10755 | [ |
7538 | (!_Utils_eq(model.loginModel.loginStatus, $author$project$Login$LoggedIn)) ? A2( | 10756 | (!_Utils_eq(model.loginModel.loginStatus, $author$project$Login$LoggedIn)) ? A2( |
7539 | $elm$html$Html$li, | 10757 | $rtfeldman$elm_css$Html$Styled$li, |
7540 | _List_Nil, | 10758 | _List_fromArray( |
10759 | [ | ||
10760 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
10761 | _List_fromArray( | ||
10762 | [ | ||
10763 | $rtfeldman$elm_css$Css$display($rtfeldman$elm_css$Css$inline) | ||
10764 | ])) | ||
10765 | ]), | ||
7541 | _List_fromArray( | 10766 | _List_fromArray( |
7542 | [ | 10767 | [ |
7543 | A2( | 10768 | A2( |
7544 | $elm$html$Html$a, | 10769 | $author$project$Styles$headerLink, |
7545 | _List_fromArray( | 10770 | _List_fromArray( |
7546 | [ | 10771 | [ |
7547 | $elm$html$Html$Attributes$href('/login') | 10772 | $rtfeldman$elm_css$Html$Styled$Attributes$href('/login') |
7548 | ]), | 10773 | ]), |
7549 | _List_fromArray( | 10774 | _List_fromArray( |
7550 | [ | 10775 | [ |
7551 | $elm$html$Html$text('Login') | 10776 | $rtfeldman$elm_css$Html$Styled$text('Login') |
7552 | ])) | 10777 | ])) |
7553 | ])) : A2( | 10778 | ])) : A2( |
7554 | $elm$html$Html$button, | 10779 | $author$project$Styles$furbyButton, |
7555 | _List_fromArray( | 10780 | _List_fromArray( |
7556 | [ | 10781 | [ |
7557 | $elm$html$Html$Events$onClick($author$project$Main$LogoutPressed) | 10782 | $rtfeldman$elm_css$Html$Styled$Events$onClick($author$project$Main$LogoutPressed) |
7558 | ]), | 10783 | ]), |
7559 | _List_fromArray( | 10784 | _List_fromArray( |
7560 | [ | 10785 | [ |
7561 | $elm$html$Html$text('Logout') | 10786 | $rtfeldman$elm_css$Html$Styled$text('Logout') |
7562 | ])) | 10787 | ])) |
7563 | ]))) | 10788 | ]))) |
7564 | ])); | 10789 | ])); |
7565 | }; | 10790 | }; |
7566 | var $author$project$Main$pageWrap = F2( | 10791 | var $author$project$Main$pageWrap = F2( |
7567 | function (model, page) { | 10792 | function (model, page) { |
7568 | return _List_fromArray( | 10793 | return $elm$core$List$singleton( |
7569 | [ | 10794 | $rtfeldman$elm_css$Html$Styled$toUnstyled( |
7570 | A2( | 10795 | A2( |
7571 | $elm$html$Html$div, | 10796 | $rtfeldman$elm_css$Html$Styled$div, |
7572 | _List_Nil, | 10797 | _List_Nil, |
7573 | _List_fromArray( | 10798 | _List_fromArray( |
7574 | [ | 10799 | [ |
7575 | $author$project$Main$viewHeader(model), | 10800 | $author$project$Main$viewHeader(model), |
7576 | page | 10801 | page |
7577 | ])) | 10802 | ])))); |
7578 | ]); | ||
7579 | }); | 10803 | }); |
7580 | var $elm$core$List$isEmpty = function (xs) { | 10804 | var $author$project$Cart$calculateTotal = function (model) { |
7581 | if (!xs.b) { | 10805 | var items = model.products; |
7582 | return true; | 10806 | return A3( |
7583 | } else { | 10807 | $elm$core$List$foldl, |
7584 | return false; | 10808 | $elm$core$Basics$add, |
7585 | } | 10809 | 0, |
10810 | A2( | ||
10811 | $elm$core$List$map, | ||
10812 | function (i) { | ||
10813 | return i.quantity * i.productItem.price; | ||
10814 | }, | ||
10815 | items)); | ||
10816 | }; | ||
10817 | var $author$project$Cart$AddToCartPressed = function (a) { | ||
10818 | return {$: 'AddToCartPressed', a: a}; | ||
7586 | }; | 10819 | }; |
7587 | var $author$project$Cart$RemoveFromCart = function (a) { | 10820 | var $author$project$Cart$RemoveFromCart = function (a) { |
7588 | return {$: 'RemoveFromCart', a: a}; | 10821 | return {$: 'RemoveFromCart', a: a}; |
7589 | }; | 10822 | }; |
7590 | var $elm$core$String$fromFloat = _String_fromNumber; | 10823 | var $author$project$Cart$viewCartItemListing = function (listing) { |
7591 | var $author$project$Cart$viewProduct = function (p) { | ||
7592 | return A2( | 10824 | return A2( |
7593 | $elm$html$Html$div, | 10825 | $rtfeldman$elm_css$Html$Styled$div, |
7594 | _List_Nil, | 10826 | _List_Nil, |
7595 | _List_fromArray( | 10827 | _List_fromArray( |
7596 | [ | 10828 | [ |
7597 | $elm$html$Html$text(p.name), | 10829 | $rtfeldman$elm_css$Html$Styled$text(listing.productItem.name), |
7598 | A2( | 10830 | A2( |
7599 | $elm$html$Html$div, | 10831 | $rtfeldman$elm_css$Html$Styled$div, |
7600 | _List_Nil, | 10832 | _List_Nil, |
7601 | _List_fromArray( | 10833 | _List_fromArray( |
7602 | [ | 10834 | [ |
7603 | $elm$html$Html$text( | 10835 | $rtfeldman$elm_css$Html$Styled$text( |
7604 | A2($elm$core$Maybe$withDefault, '', p.kind)) | 10836 | A2($elm$core$Maybe$withDefault, '', listing.productItem.kind)) |
7605 | ])), | 10837 | ])), |
7606 | A2( | 10838 | A2( |
7607 | $elm$html$Html$div, | 10839 | $rtfeldman$elm_css$Html$Styled$div, |
7608 | _List_Nil, | 10840 | _List_Nil, |
7609 | _List_fromArray( | 10841 | _List_fromArray( |
7610 | [ | 10842 | [ |
7611 | $elm$html$Html$text( | 10843 | $rtfeldman$elm_css$Html$Styled$text( |
7612 | A2($elm$core$Maybe$withDefault, '', p.description)) | 10844 | A2($elm$core$Maybe$withDefault, '', listing.productItem.description)) |
7613 | ])), | 10845 | ])), |
7614 | A2( | 10846 | A2( |
7615 | $elm$html$Html$div, | 10847 | $rtfeldman$elm_css$Html$Styled$div, |
7616 | _List_Nil, | 10848 | _List_Nil, |
7617 | _List_fromArray( | 10849 | _List_fromArray( |
7618 | [ | 10850 | [ |
7619 | $elm$html$Html$text( | 10851 | $rtfeldman$elm_css$Html$Styled$text( |
7620 | $elm$core$String$fromFloat(p.price)) | 10852 | $elm$core$String$fromFloat(listing.productItem.price)) |
10853 | ])), | ||
10854 | A2( | ||
10855 | $rtfeldman$elm_css$Html$Styled$div, | ||
10856 | _List_Nil, | ||
10857 | _List_fromArray( | ||
10858 | [ | ||
10859 | $rtfeldman$elm_css$Html$Styled$text( | ||
10860 | $elm$core$String$fromInt(listing.quantity)) | ||
7621 | ])), | 10861 | ])), |
7622 | A2( | 10862 | A2( |
7623 | $elm$html$Html$div, | 10863 | $rtfeldman$elm_css$Html$Styled$div, |
7624 | _List_Nil, | 10864 | _List_Nil, |
7625 | _List_fromArray( | 10865 | _List_fromArray( |
7626 | [ | 10866 | [ |
7627 | A2( | 10867 | A2( |
7628 | $elm$html$Html$button, | 10868 | $rtfeldman$elm_css$Html$Styled$button, |
7629 | _List_fromArray( | 10869 | _List_fromArray( |
7630 | [ | 10870 | [ |
7631 | $elm$html$Html$Events$onClick( | 10871 | $rtfeldman$elm_css$Html$Styled$Events$onClick( |
7632 | $author$project$Cart$RemoveFromCart(p.id)) | 10872 | $author$project$Cart$AddToCartPressed(listing.productItem.id)) |
7633 | ]), | 10873 | ]), |
7634 | _List_fromArray( | 10874 | _List_fromArray( |
7635 | [ | 10875 | [ |
7636 | $elm$html$Html$text('Remove') | 10876 | $rtfeldman$elm_css$Html$Styled$text('Add') |
7637 | ])) | 10877 | ])) |
7638 | ])), | 10878 | ])), |
7639 | A2( | 10879 | A2( |
7640 | $elm$html$Html$div, | 10880 | $rtfeldman$elm_css$Html$Styled$div, |
7641 | _List_Nil, | 10881 | _List_Nil, |
7642 | _List_fromArray( | 10882 | _List_fromArray( |
7643 | [ | 10883 | [ |
7644 | A2( | 10884 | A2( |
7645 | $elm$html$Html$a, | 10885 | $rtfeldman$elm_css$Html$Styled$button, |
7646 | _List_fromArray( | 10886 | _List_fromArray( |
7647 | [ | 10887 | [ |
7648 | $elm$html$Html$Attributes$href( | 10888 | $rtfeldman$elm_css$Html$Styled$Events$onClick( |
7649 | '/product/' + $elm$core$String$fromInt(p.id)) | 10889 | $author$project$Cart$RemoveFromCart(listing.productItem.id)) |
7650 | ]), | 10890 | ]), |
7651 | _List_fromArray( | 10891 | _List_fromArray( |
7652 | [ | 10892 | [ |
7653 | $elm$html$Html$text('View Product') | 10893 | $rtfeldman$elm_css$Html$Styled$text('Remove') |
10894 | ])) | ||
10895 | ])), | ||
10896 | A2( | ||
10897 | $rtfeldman$elm_css$Html$Styled$div, | ||
10898 | _List_Nil, | ||
10899 | _List_fromArray( | ||
10900 | [ | ||
10901 | A2( | ||
10902 | $rtfeldman$elm_css$Html$Styled$a, | ||
10903 | _List_fromArray( | ||
10904 | [ | ||
10905 | $rtfeldman$elm_css$Html$Styled$Attributes$href( | ||
10906 | '/product/' + $elm$core$String$fromInt(listing.productItem.id)) | ||
10907 | ]), | ||
10908 | _List_fromArray( | ||
10909 | [ | ||
10910 | $rtfeldman$elm_css$Html$Styled$text('View Product') | ||
7654 | ])) | 10911 | ])) |
7655 | ])) | 10912 | ])) |
7656 | ])); | 10913 | ])); |
@@ -7669,49 +10926,371 @@ var $author$project$Cart$view = function (model) { | |||
7669 | var _v0 = model.pageStatus; | 10926 | var _v0 = model.pageStatus; |
7670 | if (_v0.$ === 'Loading') { | 10927 | if (_v0.$ === 'Loading') { |
7671 | return A2( | 10928 | return A2( |
7672 | $elm$html$Html$div, | 10929 | $rtfeldman$elm_css$Html$Styled$div, |
7673 | _List_Nil, | 10930 | _List_Nil, |
7674 | _List_fromArray( | 10931 | _List_fromArray( |
7675 | [ | 10932 | [ |
7676 | $elm$html$Html$text( | 10933 | $rtfeldman$elm_css$Html$Styled$text( |
7677 | $author$project$Cart$viewStatus($author$project$Cart$Loading)) | 10934 | $author$project$Cart$viewStatus($author$project$Cart$Loading)) |
7678 | ])); | 10935 | ])); |
7679 | } else { | 10936 | } else { |
7680 | return A2( | 10937 | return A2( |
7681 | $elm$html$Html$div, | 10938 | $rtfeldman$elm_css$Html$Styled$div, |
7682 | _List_Nil, | 10939 | _List_Nil, |
7683 | _List_fromArray( | 10940 | _List_fromArray( |
7684 | [ | 10941 | [ |
7685 | function () { | 10942 | function () { |
7686 | var cart = A2($elm$core$List$map, $author$project$Cart$viewProduct, model.products); | 10943 | var cart = A2($elm$core$List$map, $author$project$Cart$viewCartItemListing, model.products); |
7687 | return $elm$core$List$isEmpty(cart) ? $elm$html$Html$text('No items in cart') : A2($elm$html$Html$ul, _List_Nil, cart); | 10944 | return $elm$core$List$isEmpty(cart) ? $rtfeldman$elm_css$Html$Styled$text('No items in cart') : A2($rtfeldman$elm_css$Html$Styled$ul, _List_Nil, cart); |
7688 | }() | 10945 | }(), |
10946 | $rtfeldman$elm_css$Html$Styled$text( | ||
10947 | $elm$core$String$fromFloat( | ||
10948 | $author$project$Cart$calculateTotal(model))), | ||
10949 | A2( | ||
10950 | $rtfeldman$elm_css$Html$Styled$a, | ||
10951 | _List_fromArray( | ||
10952 | [ | ||
10953 | $rtfeldman$elm_css$Html$Styled$Attributes$href('/checkout') | ||
10954 | ]), | ||
10955 | _List_fromArray( | ||
10956 | [ | ||
10957 | $rtfeldman$elm_css$Html$Styled$text('Checkout') | ||
10958 | ])) | ||
7689 | ])); | 10959 | ])); |
7690 | } | 10960 | } |
7691 | }; | 10961 | }; |
7692 | var $author$project$Catalog$viewProduct = function (p) { | 10962 | var $rtfeldman$elm_css$Css$fontSize = $rtfeldman$elm_css$Css$prop1('font-size'); |
10963 | var $author$project$Styles$bigHeading = $rtfeldman$elm_css$Css$fontSize( | ||
10964 | $rtfeldman$elm_css$Css$px(24)); | ||
10965 | var $elm$core$Basics$ge = _Utils_ge; | ||
10966 | var $author$project$Utils$between = F2( | ||
10967 | function (_v0, v) { | ||
10968 | var l = _v0.a; | ||
10969 | var u = _v0.b; | ||
10970 | return (_Utils_cmp(v, l) > -1) && (_Utils_cmp(v, u) < 1); | ||
10971 | }); | ||
10972 | var $author$project$Catalog$filterProducts = function (model) { | ||
10973 | return A2( | ||
10974 | $elm$core$List$filter, | ||
10975 | function (p) { | ||
10976 | return A2( | ||
10977 | $author$project$Utils$between, | ||
10978 | model.filters.rating, | ||
10979 | A2($elm$core$Maybe$withDefault, 5.0, p.averageRating)); | ||
10980 | }, | ||
10981 | A2( | ||
10982 | $elm$core$List$filter, | ||
10983 | A2( | ||
10984 | $elm$core$Basics$composeL, | ||
10985 | $author$project$Utils$between(model.filters.price), | ||
10986 | function ($) { | ||
10987 | return $.price; | ||
10988 | }), | ||
10989 | model.products)); | ||
10990 | }; | ||
10991 | var $rtfeldman$elm_css$Css$float = function (fn) { | ||
10992 | return A3( | ||
10993 | $rtfeldman$elm_css$Css$Internal$getOverloadedProperty, | ||
10994 | 'float', | ||
10995 | 'float', | ||
10996 | fn($rtfeldman$elm_css$Css$Internal$lengthForOverloadedProperty)); | ||
10997 | }; | ||
10998 | var $rtfeldman$elm_css$Css$PercentageUnits = {$: 'PercentageUnits'}; | ||
10999 | var $rtfeldman$elm_css$Css$pct = A2($rtfeldman$elm_css$Css$Internal$lengthConverter, $rtfeldman$elm_css$Css$PercentageUnits, '%'); | ||
11000 | var $author$project$Catalog$ChangePriceLower = function (a) { | ||
11001 | return {$: 'ChangePriceLower', a: a}; | ||
11002 | }; | ||
11003 | var $author$project$Catalog$ChangePriceUpper = function (a) { | ||
11004 | return {$: 'ChangePriceUpper', a: a}; | ||
11005 | }; | ||
11006 | var $author$project$Catalog$ChangeRatingLower = function (a) { | ||
11007 | return {$: 'ChangeRatingLower', a: a}; | ||
11008 | }; | ||
11009 | var $author$project$Catalog$ChangeRatingUpper = function (a) { | ||
11010 | return {$: 'ChangeRatingUpper', a: a}; | ||
11011 | }; | ||
11012 | var $rtfeldman$elm_css$Css$prop3 = F4( | ||
11013 | function (key, argA, argB, argC) { | ||
11014 | return A2( | ||
11015 | $rtfeldman$elm_css$Css$property, | ||
11016 | key, | ||
11017 | A2( | ||
11018 | $elm$core$String$join, | ||
11019 | ' ', | ||
11020 | _List_fromArray( | ||
11021 | [argA.value, argB.value, argC.value]))); | ||
11022 | }); | ||
11023 | var $rtfeldman$elm_css$Css$borderBottom3 = $rtfeldman$elm_css$Css$prop3('border-bottom'); | ||
11024 | var $rtfeldman$elm_css$Css$right = $rtfeldman$elm_css$Css$prop1('right'); | ||
11025 | var $rtfeldman$elm_css$Html$Styled$select = $rtfeldman$elm_css$Html$Styled$node('select'); | ||
11026 | var $rtfeldman$elm_css$Css$solid = {borderStyle: $rtfeldman$elm_css$Css$Structure$Compatible, textDecorationStyle: $rtfeldman$elm_css$Css$Structure$Compatible, value: 'solid'}; | ||
11027 | var $author$project$Styles$furbySelect = A2( | ||
11028 | $rtfeldman$elm_css$Html$Styled$styled, | ||
11029 | $rtfeldman$elm_css$Html$Styled$select, | ||
11030 | _List_fromArray( | ||
11031 | [ | ||
11032 | $rtfeldman$elm_css$Css$margin( | ||
11033 | $rtfeldman$elm_css$Css$px(6)), | ||
11034 | $rtfeldman$elm_css$Css$color($author$project$Styles$theme.fg), | ||
11035 | $rtfeldman$elm_css$Css$border( | ||
11036 | $rtfeldman$elm_css$Css$px(0)), | ||
11037 | A3( | ||
11038 | $rtfeldman$elm_css$Css$borderBottom3, | ||
11039 | $rtfeldman$elm_css$Css$px(2), | ||
11040 | $rtfeldman$elm_css$Css$solid, | ||
11041 | $author$project$Styles$theme.bgLight), | ||
11042 | $rtfeldman$elm_css$Css$textAlign($rtfeldman$elm_css$Css$right), | ||
11043 | A2( | ||
11044 | $rtfeldman$elm_css$Css$padding2, | ||
11045 | $rtfeldman$elm_css$Css$px(3), | ||
11046 | $rtfeldman$elm_css$Css$px(3)), | ||
11047 | $rtfeldman$elm_css$Css$backgroundColor($author$project$Styles$theme.bg), | ||
11048 | $rtfeldman$elm_css$Css$hover( | ||
11049 | _List_fromArray( | ||
11050 | [ | ||
11051 | A3( | ||
11052 | $rtfeldman$elm_css$Css$borderBottom3, | ||
11053 | $rtfeldman$elm_css$Css$px(2), | ||
11054 | $rtfeldman$elm_css$Css$solid, | ||
11055 | $author$project$Styles$theme.fg) | ||
11056 | ])) | ||
11057 | ])); | ||
11058 | var $rtfeldman$elm_css$Html$Styled$Events$alwaysStop = function (x) { | ||
11059 | return _Utils_Tuple2(x, true); | ||
11060 | }; | ||
11061 | var $elm$virtual_dom$VirtualDom$MayStopPropagation = function (a) { | ||
11062 | return {$: 'MayStopPropagation', a: a}; | ||
11063 | }; | ||
11064 | var $rtfeldman$elm_css$Html$Styled$Events$stopPropagationOn = F2( | ||
11065 | function (event, decoder) { | ||
11066 | return A2( | ||
11067 | $rtfeldman$elm_css$VirtualDom$Styled$on, | ||
11068 | event, | ||
11069 | $elm$virtual_dom$VirtualDom$MayStopPropagation(decoder)); | ||
11070 | }); | ||
11071 | var $elm$json$Json$Decode$at = F2( | ||
11072 | function (fields, decoder) { | ||
11073 | return A3($elm$core$List$foldr, $elm$json$Json$Decode$field, decoder, fields); | ||
11074 | }); | ||
11075 | var $rtfeldman$elm_css$Html$Styled$Events$targetValue = A2( | ||
11076 | $elm$json$Json$Decode$at, | ||
11077 | _List_fromArray( | ||
11078 | ['target', 'value']), | ||
11079 | $elm$json$Json$Decode$string); | ||
11080 | var $rtfeldman$elm_css$Html$Styled$Events$onInput = function (tagger) { | ||
7693 | return A2( | 11081 | return A2( |
7694 | $elm$html$Html$div, | 11082 | $rtfeldman$elm_css$Html$Styled$Events$stopPropagationOn, |
11083 | 'input', | ||
11084 | A2( | ||
11085 | $elm$json$Json$Decode$map, | ||
11086 | $rtfeldman$elm_css$Html$Styled$Events$alwaysStop, | ||
11087 | A2($elm$json$Json$Decode$map, tagger, $rtfeldman$elm_css$Html$Styled$Events$targetValue))); | ||
11088 | }; | ||
11089 | var $rtfeldman$elm_css$Html$Styled$option = $rtfeldman$elm_css$Html$Styled$node('option'); | ||
11090 | var $author$project$Utils$range = F3( | ||
11091 | function (start, stop, step) { | ||
11092 | return (_Utils_cmp(start, stop) > -1) ? _List_Nil : A2( | ||
11093 | $elm$core$List$cons, | ||
11094 | start, | ||
11095 | A3($author$project$Utils$range, start + step, stop, step)); | ||
11096 | }); | ||
11097 | var $elm$json$Json$Encode$bool = _Json_wrap; | ||
11098 | var $rtfeldman$elm_css$Html$Styled$Attributes$boolProperty = F2( | ||
11099 | function (key, bool) { | ||
11100 | return A2( | ||
11101 | $rtfeldman$elm_css$VirtualDom$Styled$property, | ||
11102 | key, | ||
11103 | $elm$json$Json$Encode$bool(bool)); | ||
11104 | }); | ||
11105 | var $rtfeldman$elm_css$Html$Styled$Attributes$selected = $rtfeldman$elm_css$Html$Styled$Attributes$boolProperty('selected'); | ||
11106 | var $elm$virtual_dom$VirtualDom$style = _VirtualDom_style; | ||
11107 | var $rtfeldman$elm_css$VirtualDom$Styled$style = F2( | ||
11108 | function (key, val) { | ||
11109 | return A3( | ||
11110 | $rtfeldman$elm_css$VirtualDom$Styled$Attribute, | ||
11111 | A2($elm$virtual_dom$VirtualDom$style, key, val), | ||
11112 | _List_Nil, | ||
11113 | ''); | ||
11114 | }); | ||
11115 | var $rtfeldman$elm_css$Html$Styled$Attributes$style = $rtfeldman$elm_css$VirtualDom$Styled$style; | ||
11116 | var $elm$core$String$toFloat = _String_toFloat; | ||
11117 | var $author$project$Catalog$viewFilters = function (model) { | ||
11118 | var viewRange = F2( | ||
11119 | function (_default, scale) { | ||
11120 | return A2( | ||
11121 | $elm$core$List$map, | ||
11122 | function (i) { | ||
11123 | return A2( | ||
11124 | $rtfeldman$elm_css$Html$Styled$option, | ||
11125 | _List_fromArray( | ||
11126 | [ | ||
11127 | $rtfeldman$elm_css$Html$Styled$Attributes$selected( | ||
11128 | _Utils_eq(i, _default)) | ||
11129 | ]), | ||
11130 | _List_fromArray( | ||
11131 | [ | ||
11132 | $rtfeldman$elm_css$Html$Styled$text( | ||
11133 | $elm$core$String$fromInt(i)) | ||
11134 | ])); | ||
11135 | }, | ||
11136 | scale); | ||
11137 | }); | ||
11138 | var ratingRange = A3($author$project$Utils$range, 1, 6, 1); | ||
11139 | var priceRange = A3($author$project$Utils$range, 0, 55000, 5000); | ||
11140 | var inp = A2( | ||
11141 | $elm$core$Basics$composeL, | ||
11142 | $elm$core$Maybe$withDefault(0), | ||
11143 | $elm$core$String$toFloat); | ||
11144 | return A2( | ||
11145 | $rtfeldman$elm_css$Html$Styled$div, | ||
7695 | _List_Nil, | 11146 | _List_Nil, |
7696 | _List_fromArray( | 11147 | _List_fromArray( |
7697 | [ | 11148 | [ |
7698 | $elm$html$Html$text(p.name), | ||
7699 | $elm$html$Html$text( | ||
7700 | A2($elm$core$Maybe$withDefault, '', p.kind)), | ||
7701 | $elm$html$Html$text( | ||
7702 | A2($elm$core$Maybe$withDefault, '', p.description)), | ||
7703 | $elm$html$Html$text( | ||
7704 | $elm$core$String$fromFloat(p.price)), | ||
7705 | A2( | 11149 | A2( |
7706 | $elm$html$Html$a, | 11150 | $rtfeldman$elm_css$Html$Styled$div, |
7707 | _List_fromArray( | 11151 | _List_fromArray( |
7708 | [ | 11152 | [ |
7709 | $elm$html$Html$Attributes$href( | 11153 | $rtfeldman$elm_css$Html$Styled$Attributes$css( |
7710 | '/product/' + $elm$core$String$fromInt(p.id)) | 11154 | _List_fromArray( |
11155 | [ | ||
11156 | $author$project$Styles$bigHeading, | ||
11157 | $rtfeldman$elm_css$Css$paddingBottom( | ||
11158 | $rtfeldman$elm_css$Css$px(12)) | ||
11159 | ])) | ||
7711 | ]), | 11160 | ]), |
7712 | _List_fromArray( | 11161 | _List_fromArray( |
7713 | [ | 11162 | [ |
7714 | $elm$html$Html$text('View Product') | 11163 | $rtfeldman$elm_css$Html$Styled$text('Filters') |
11164 | ])), | ||
11165 | A2( | ||
11166 | $rtfeldman$elm_css$Html$Styled$div, | ||
11167 | _List_Nil, | ||
11168 | _List_fromArray( | ||
11169 | [ | ||
11170 | A2( | ||
11171 | $rtfeldman$elm_css$Html$Styled$div, | ||
11172 | _List_Nil, | ||
11173 | _List_fromArray( | ||
11174 | [ | ||
11175 | $rtfeldman$elm_css$Html$Styled$text('Price') | ||
11176 | ])), | ||
11177 | A2( | ||
11178 | $author$project$Styles$furbySelect, | ||
11179 | _List_fromArray( | ||
11180 | [ | ||
11181 | $rtfeldman$elm_css$Html$Styled$Events$onInput( | ||
11182 | A2($elm$core$Basics$composeL, $author$project$Catalog$ChangePriceLower, inp)), | ||
11183 | A2($rtfeldman$elm_css$Html$Styled$Attributes$style, 'appearance', 'none') | ||
11184 | ]), | ||
11185 | A2(viewRange, 0, priceRange)), | ||
11186 | $rtfeldman$elm_css$Html$Styled$text('to'), | ||
11187 | A2( | ||
11188 | $author$project$Styles$furbySelect, | ||
11189 | _List_fromArray( | ||
11190 | [ | ||
11191 | $rtfeldman$elm_css$Html$Styled$Events$onInput( | ||
11192 | A2($elm$core$Basics$composeL, $author$project$Catalog$ChangePriceUpper, inp)), | ||
11193 | A2($rtfeldman$elm_css$Html$Styled$Attributes$style, 'appearance', 'none') | ||
11194 | ]), | ||
11195 | A2(viewRange, 50000, priceRange)) | ||
11196 | ])), | ||
11197 | A2( | ||
11198 | $rtfeldman$elm_css$Html$Styled$div, | ||
11199 | _List_Nil, | ||
11200 | _List_fromArray( | ||
11201 | [ | ||
11202 | A2( | ||
11203 | $rtfeldman$elm_css$Html$Styled$div, | ||
11204 | _List_Nil, | ||
11205 | _List_fromArray( | ||
11206 | [ | ||
11207 | $rtfeldman$elm_css$Html$Styled$text('Rating') | ||
11208 | ])), | ||
11209 | A2( | ||
11210 | $author$project$Styles$furbySelect, | ||
11211 | _List_fromArray( | ||
11212 | [ | ||
11213 | $rtfeldman$elm_css$Html$Styled$Events$onInput( | ||
11214 | A2($elm$core$Basics$composeL, $author$project$Catalog$ChangeRatingLower, inp)), | ||
11215 | A2($rtfeldman$elm_css$Html$Styled$Attributes$style, 'appearance', 'none') | ||
11216 | ]), | ||
11217 | A2(viewRange, 1, ratingRange)), | ||
11218 | $rtfeldman$elm_css$Html$Styled$text('to'), | ||
11219 | A2( | ||
11220 | $author$project$Styles$furbySelect, | ||
11221 | _List_fromArray( | ||
11222 | [ | ||
11223 | $rtfeldman$elm_css$Html$Styled$Events$onInput( | ||
11224 | A2($elm$core$Basics$composeL, $author$project$Catalog$ChangeRatingUpper, inp)), | ||
11225 | A2($rtfeldman$elm_css$Html$Styled$Attributes$style, 'appearance', 'none') | ||
11226 | ]), | ||
11227 | A2(viewRange, 5, ratingRange)) | ||
11228 | ])) | ||
11229 | ])); | ||
11230 | }; | ||
11231 | var $author$project$Catalog$viewProduct = function (p) { | ||
11232 | return A2( | ||
11233 | $rtfeldman$elm_css$Html$Styled$div, | ||
11234 | _List_Nil, | ||
11235 | _List_fromArray( | ||
11236 | [ | ||
11237 | A2( | ||
11238 | $rtfeldman$elm_css$Html$Styled$div, | ||
11239 | _List_Nil, | ||
11240 | _List_fromArray( | ||
11241 | [ | ||
11242 | $rtfeldman$elm_css$Html$Styled$text(p.name) | ||
11243 | ])), | ||
11244 | A2( | ||
11245 | $rtfeldman$elm_css$Html$Styled$div, | ||
11246 | _List_Nil, | ||
11247 | _List_fromArray( | ||
11248 | [ | ||
11249 | $rtfeldman$elm_css$Html$Styled$text( | ||
11250 | A2($elm$core$Maybe$withDefault, '', p.kind)) | ||
11251 | ])), | ||
11252 | A2( | ||
11253 | $rtfeldman$elm_css$Html$Styled$div, | ||
11254 | _List_Nil, | ||
11255 | _List_fromArray( | ||
11256 | [ | ||
11257 | $rtfeldman$elm_css$Html$Styled$text( | ||
11258 | A2($elm$core$Maybe$withDefault, '', p.description)) | ||
11259 | ])), | ||
11260 | A2( | ||
11261 | $rtfeldman$elm_css$Html$Styled$div, | ||
11262 | _List_Nil, | ||
11263 | _List_fromArray( | ||
11264 | [ | ||
11265 | $rtfeldman$elm_css$Html$Styled$text( | ||
11266 | $elm$core$String$fromFloat(p.price)) | ||
11267 | ])), | ||
11268 | function () { | ||
11269 | var _v0 = p.averageRating; | ||
11270 | if (_v0.$ === 'Just') { | ||
11271 | var v = _v0.a; | ||
11272 | return $rtfeldman$elm_css$Html$Styled$text( | ||
11273 | 'Avg Rating: ' + $elm$core$String$fromFloat(v)); | ||
11274 | } else { | ||
11275 | return $rtfeldman$elm_css$Html$Styled$text('No Ratings'); | ||
11276 | } | ||
11277 | }(), | ||
11278 | A2( | ||
11279 | $rtfeldman$elm_css$Html$Styled$div, | ||
11280 | _List_Nil, | ||
11281 | _List_fromArray( | ||
11282 | [ | ||
11283 | A2( | ||
11284 | $rtfeldman$elm_css$Html$Styled$a, | ||
11285 | _List_fromArray( | ||
11286 | [ | ||
11287 | $rtfeldman$elm_css$Html$Styled$Attributes$href( | ||
11288 | '/product/' + $elm$core$String$fromInt(p.id)) | ||
11289 | ]), | ||
11290 | _List_fromArray( | ||
11291 | [ | ||
11292 | $rtfeldman$elm_css$Html$Styled$text('View Product') | ||
11293 | ])) | ||
7715 | ])) | 11294 | ])) |
7716 | ])); | 11295 | ])); |
7717 | }; | 11296 | }; |
@@ -7725,27 +11304,200 @@ var $author$project$Catalog$viewStatus = function (s) { | |||
7725 | return 'Not loaded ...'; | 11304 | return 'Not loaded ...'; |
7726 | } | 11305 | } |
7727 | }; | 11306 | }; |
11307 | var $rtfeldman$elm_css$Css$width = $rtfeldman$elm_css$Css$prop1('width'); | ||
7728 | var $author$project$Catalog$view = function (model) { | 11308 | var $author$project$Catalog$view = function (model) { |
7729 | var _v0 = model.pageStatus; | 11309 | var _v0 = model.pageStatus; |
7730 | if (_v0.$ === 'Loading') { | 11310 | if (_v0.$ === 'Loading') { |
7731 | return A2( | 11311 | return A2( |
7732 | $elm$html$Html$div, | 11312 | $rtfeldman$elm_css$Html$Styled$div, |
7733 | _List_Nil, | 11313 | _List_Nil, |
7734 | _List_fromArray( | 11314 | _List_fromArray( |
7735 | [ | 11315 | [ |
7736 | $elm$html$Html$text( | 11316 | $rtfeldman$elm_css$Html$Styled$text( |
7737 | $author$project$Catalog$viewStatus($author$project$Catalog$Loading)) | 11317 | $author$project$Catalog$viewStatus($author$project$Catalog$Loading)) |
7738 | ])); | 11318 | ])); |
7739 | } else { | 11319 | } else { |
7740 | return A2( | 11320 | return A2( |
7741 | $elm$html$Html$div, | 11321 | $rtfeldman$elm_css$Html$Styled$div, |
11322 | _List_fromArray( | ||
11323 | [ | ||
11324 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11325 | _List_fromArray( | ||
11326 | [ | ||
11327 | $rtfeldman$elm_css$Css$padding( | ||
11328 | $rtfeldman$elm_css$Css$px(40)) | ||
11329 | ])) | ||
11330 | ]), | ||
11331 | _List_fromArray( | ||
11332 | [ | ||
11333 | A2( | ||
11334 | $rtfeldman$elm_css$Html$Styled$div, | ||
11335 | _List_fromArray( | ||
11336 | [ | ||
11337 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11338 | _List_fromArray( | ||
11339 | [ | ||
11340 | $rtfeldman$elm_css$Css$float($rtfeldman$elm_css$Css$left), | ||
11341 | $rtfeldman$elm_css$Css$width( | ||
11342 | $rtfeldman$elm_css$Css$pct(20)) | ||
11343 | ])) | ||
11344 | ]), | ||
11345 | _List_fromArray( | ||
11346 | [ | ||
11347 | $author$project$Catalog$viewFilters(model) | ||
11348 | ])), | ||
11349 | A2( | ||
11350 | $rtfeldman$elm_css$Html$Styled$div, | ||
11351 | _List_fromArray( | ||
11352 | [ | ||
11353 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11354 | _List_fromArray( | ||
11355 | [ | ||
11356 | $rtfeldman$elm_css$Css$float($rtfeldman$elm_css$Css$left), | ||
11357 | $rtfeldman$elm_css$Css$width( | ||
11358 | $rtfeldman$elm_css$Css$pct(80)) | ||
11359 | ])) | ||
11360 | ]), | ||
11361 | _List_fromArray( | ||
11362 | [ | ||
11363 | A2( | ||
11364 | $rtfeldman$elm_css$Html$Styled$div, | ||
11365 | _List_fromArray( | ||
11366 | [ | ||
11367 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11368 | _List_fromArray( | ||
11369 | [$author$project$Styles$bigHeading])) | ||
11370 | ]), | ||
11371 | _List_fromArray( | ||
11372 | [ | ||
11373 | $rtfeldman$elm_css$Html$Styled$text('Products') | ||
11374 | ])), | ||
11375 | A2( | ||
11376 | $rtfeldman$elm_css$Html$Styled$ul, | ||
11377 | _List_fromArray( | ||
11378 | [ | ||
11379 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11380 | _List_fromArray( | ||
11381 | [ | ||
11382 | $rtfeldman$elm_css$Css$padding( | ||
11383 | $rtfeldman$elm_css$Css$px(0)) | ||
11384 | ])) | ||
11385 | ]), | ||
11386 | A2( | ||
11387 | $elm$core$List$map, | ||
11388 | $author$project$Catalog$viewProduct, | ||
11389 | $author$project$Catalog$filterProducts(model))) | ||
11390 | ])) | ||
11391 | ])); | ||
11392 | } | ||
11393 | }; | ||
11394 | var $author$project$Checkout$CheckoutPressed = {$: 'CheckoutPressed'}; | ||
11395 | var $author$project$Checkout$PaymentModeSelected = function (a) { | ||
11396 | return {$: 'PaymentModeSelected', a: a}; | ||
11397 | }; | ||
11398 | var $author$project$Checkout$viewStatus = function (s) { | ||
11399 | switch (s.$) { | ||
11400 | case 'Loading': | ||
11401 | return 'Loading'; | ||
11402 | case 'Loaded': | ||
11403 | return 'Ready!'; | ||
11404 | default: | ||
11405 | return 'Not loaded ...'; | ||
11406 | } | ||
11407 | }; | ||
11408 | var $author$project$Checkout$view = function (model) { | ||
11409 | var _v0 = model.pageStatus; | ||
11410 | if (_v0.$ === 'Loading') { | ||
11411 | return A2( | ||
11412 | $rtfeldman$elm_css$Html$Styled$div, | ||
7742 | _List_Nil, | 11413 | _List_Nil, |
7743 | _List_fromArray( | 11414 | _List_fromArray( |
7744 | [ | 11415 | [ |
11416 | $rtfeldman$elm_css$Html$Styled$text( | ||
11417 | $author$project$Checkout$viewStatus($author$project$Checkout$Loading)) | ||
11418 | ])); | ||
11419 | } else { | ||
11420 | return A2( | ||
11421 | $rtfeldman$elm_css$Html$Styled$div, | ||
11422 | _List_Nil, | ||
11423 | _List_fromArray( | ||
11424 | [ | ||
11425 | A2( | ||
11426 | $rtfeldman$elm_css$Html$Styled$div, | ||
11427 | _List_Nil, | ||
11428 | _List_fromArray( | ||
11429 | [ | ||
11430 | $rtfeldman$elm_css$Html$Styled$text( | ||
11431 | $elm$core$String$fromFloat(model.cartTotal)) | ||
11432 | ])), | ||
11433 | A2( | ||
11434 | $rtfeldman$elm_css$Html$Styled$select, | ||
11435 | _List_Nil, | ||
11436 | _List_fromArray( | ||
11437 | [ | ||
11438 | A2( | ||
11439 | $rtfeldman$elm_css$Html$Styled$option, | ||
11440 | _List_fromArray( | ||
11441 | [ | ||
11442 | $rtfeldman$elm_css$Html$Styled$Events$onInput($author$project$Checkout$PaymentModeSelected) | ||
11443 | ]), | ||
11444 | _List_fromArray( | ||
11445 | [ | ||
11446 | $rtfeldman$elm_css$Html$Styled$text('Cash') | ||
11447 | ])), | ||
11448 | A2( | ||
11449 | $rtfeldman$elm_css$Html$Styled$option, | ||
11450 | _List_fromArray( | ||
11451 | [ | ||
11452 | $rtfeldman$elm_css$Html$Styled$Events$onInput($author$project$Checkout$PaymentModeSelected) | ||
11453 | ]), | ||
11454 | _List_fromArray( | ||
11455 | [ | ||
11456 | $rtfeldman$elm_css$Html$Styled$text('Debit Card') | ||
11457 | ])), | ||
11458 | A2( | ||
11459 | $rtfeldman$elm_css$Html$Styled$option, | ||
11460 | _List_fromArray( | ||
11461 | [ | ||
11462 | $rtfeldman$elm_css$Html$Styled$Events$onInput($author$project$Checkout$PaymentModeSelected) | ||
11463 | ]), | ||
11464 | _List_fromArray( | ||
11465 | [ | ||
11466 | $rtfeldman$elm_css$Html$Styled$text('Credit Card') | ||
11467 | ])) | ||
11468 | ])), | ||
7745 | A2( | 11469 | A2( |
7746 | $elm$html$Html$ul, | 11470 | $rtfeldman$elm_css$Html$Styled$div, |
7747 | _List_Nil, | 11471 | _List_Nil, |
7748 | A2($elm$core$List$map, $author$project$Catalog$viewProduct, model.products)) | 11472 | _List_fromArray( |
11473 | [ | ||
11474 | A2( | ||
11475 | $rtfeldman$elm_css$Html$Styled$a, | ||
11476 | _List_fromArray( | ||
11477 | [ | ||
11478 | $rtfeldman$elm_css$Html$Styled$Attributes$href('/cart') | ||
11479 | ]), | ||
11480 | _List_fromArray( | ||
11481 | [ | ||
11482 | $rtfeldman$elm_css$Html$Styled$text('Cancel') | ||
11483 | ])) | ||
11484 | ])), | ||
11485 | A2( | ||
11486 | $rtfeldman$elm_css$Html$Styled$div, | ||
11487 | _List_Nil, | ||
11488 | _List_fromArray( | ||
11489 | [ | ||
11490 | A2( | ||
11491 | $rtfeldman$elm_css$Html$Styled$button, | ||
11492 | _List_fromArray( | ||
11493 | [ | ||
11494 | $rtfeldman$elm_css$Html$Styled$Events$onClick($author$project$Checkout$CheckoutPressed) | ||
11495 | ]), | ||
11496 | _List_fromArray( | ||
11497 | [ | ||
11498 | $rtfeldman$elm_css$Html$Styled$text('Confirm and Pay') | ||
11499 | ])) | ||
11500 | ])) | ||
7749 | ])); | 11501 | ])); |
7750 | } | 11502 | } |
7751 | }; | 11503 | }; |
@@ -7756,58 +11508,64 @@ var $author$project$Login$PassEntered = function (a) { | |||
7756 | var $author$project$Login$UserEntered = function (a) { | 11508 | var $author$project$Login$UserEntered = function (a) { |
7757 | return {$: 'UserEntered', a: a}; | 11509 | return {$: 'UserEntered', a: a}; |
7758 | }; | 11510 | }; |
7759 | var $elm$html$Html$input = _VirtualDom_node('input'); | 11511 | var $rtfeldman$elm_css$Css$auto = {alignItemsOrAuto: $rtfeldman$elm_css$Css$Structure$Compatible, cursor: $rtfeldman$elm_css$Css$Structure$Compatible, flexBasis: $rtfeldman$elm_css$Css$Structure$Compatible, intOrAuto: $rtfeldman$elm_css$Css$Structure$Compatible, justifyContentOrAuto: $rtfeldman$elm_css$Css$Structure$Compatible, lengthOrAuto: $rtfeldman$elm_css$Css$Structure$Compatible, lengthOrAutoOrCoverOrContain: $rtfeldman$elm_css$Css$Structure$Compatible, lengthOrNumberOrAutoOrNoneOrContent: $rtfeldman$elm_css$Css$Structure$Compatible, overflow: $rtfeldman$elm_css$Css$Structure$Compatible, pointerEvents: $rtfeldman$elm_css$Css$Structure$Compatible, tableLayout: $rtfeldman$elm_css$Css$Structure$Compatible, textRendering: $rtfeldman$elm_css$Css$Structure$Compatible, touchAction: $rtfeldman$elm_css$Css$Structure$Compatible, value: 'auto'}; |
7760 | var $elm$html$Html$Events$alwaysStop = function (x) { | 11512 | var $rtfeldman$elm_css$Css$center = $rtfeldman$elm_css$Css$prop1('center'); |
7761 | return _Utils_Tuple2(x, true); | 11513 | var $author$project$Login$fieldPadding = $rtfeldman$elm_css$Html$Styled$Attributes$css( |
7762 | }; | ||
7763 | var $elm$virtual_dom$VirtualDom$MayStopPropagation = function (a) { | ||
7764 | return {$: 'MayStopPropagation', a: a}; | ||
7765 | }; | ||
7766 | var $elm$html$Html$Events$stopPropagationOn = F2( | ||
7767 | function (event, decoder) { | ||
7768 | return A2( | ||
7769 | $elm$virtual_dom$VirtualDom$on, | ||
7770 | event, | ||
7771 | $elm$virtual_dom$VirtualDom$MayStopPropagation(decoder)); | ||
7772 | }); | ||
7773 | var $elm$json$Json$Decode$at = F2( | ||
7774 | function (fields, decoder) { | ||
7775 | return A3($elm$core$List$foldr, $elm$json$Json$Decode$field, decoder, fields); | ||
7776 | }); | ||
7777 | var $elm$html$Html$Events$targetValue = A2( | ||
7778 | $elm$json$Json$Decode$at, | ||
7779 | _List_fromArray( | 11514 | _List_fromArray( |
7780 | ['target', 'value']), | 11515 | [ |
7781 | $elm$json$Json$Decode$string); | 11516 | $rtfeldman$elm_css$Css$paddingTop( |
7782 | var $elm$html$Html$Events$onInput = function (tagger) { | 11517 | $rtfeldman$elm_css$Css$px(10)), |
7783 | return A2( | 11518 | $rtfeldman$elm_css$Css$paddingBottom( |
7784 | $elm$html$Html$Events$stopPropagationOn, | 11519 | $rtfeldman$elm_css$Css$px(10)) |
7785 | 'input', | 11520 | ])); |
7786 | A2( | 11521 | var $rtfeldman$elm_css$Css$marginTop = $rtfeldman$elm_css$Css$prop1('margin-top'); |
7787 | $elm$json$Json$Decode$map, | 11522 | var $rtfeldman$elm_css$Css$focus = $rtfeldman$elm_css$Css$pseudoClass('focus'); |
7788 | $elm$html$Html$Events$alwaysStop, | 11523 | var $rtfeldman$elm_css$Html$Styled$input = $rtfeldman$elm_css$Html$Styled$node('input'); |
7789 | A2($elm$json$Json$Decode$map, tagger, $elm$html$Html$Events$targetValue))); | 11524 | var $author$project$Styles$loginInputField = A2( |
7790 | }; | 11525 | $rtfeldman$elm_css$Html$Styled$styled, |
7791 | var $elm$html$Html$Attributes$placeholder = $elm$html$Html$Attributes$stringProperty('placeholder'); | 11526 | $rtfeldman$elm_css$Html$Styled$input, |
7792 | var $elm$html$Html$Attributes$type_ = $elm$html$Html$Attributes$stringProperty('type'); | 11527 | _List_fromArray( |
7793 | var $elm$html$Html$Attributes$value = $elm$html$Html$Attributes$stringProperty('value'); | 11528 | [ |
11529 | $rtfeldman$elm_css$Css$width( | ||
11530 | $rtfeldman$elm_css$Css$pct(100)), | ||
11531 | $rtfeldman$elm_css$Css$color($author$project$Styles$theme.fg), | ||
11532 | $rtfeldman$elm_css$Css$border( | ||
11533 | $rtfeldman$elm_css$Css$px(0)), | ||
11534 | A3( | ||
11535 | $rtfeldman$elm_css$Css$borderBottom3, | ||
11536 | $rtfeldman$elm_css$Css$px(1), | ||
11537 | $rtfeldman$elm_css$Css$solid, | ||
11538 | $author$project$Styles$theme.bgLight), | ||
11539 | $rtfeldman$elm_css$Css$focus( | ||
11540 | _List_fromArray( | ||
11541 | [ | ||
11542 | A3( | ||
11543 | $rtfeldman$elm_css$Css$borderBottom3, | ||
11544 | $rtfeldman$elm_css$Css$px(2), | ||
11545 | $rtfeldman$elm_css$Css$solid, | ||
11546 | $author$project$Styles$theme.fg) | ||
11547 | ])) | ||
11548 | ])); | ||
11549 | var $rtfeldman$elm_css$Html$Styled$Attributes$placeholder = $rtfeldman$elm_css$Html$Styled$Attributes$stringProperty('placeholder'); | ||
11550 | var $rtfeldman$elm_css$Html$Styled$Attributes$type_ = $rtfeldman$elm_css$Html$Styled$Attributes$stringProperty('type'); | ||
11551 | var $rtfeldman$elm_css$Html$Styled$Attributes$value = $rtfeldman$elm_css$Html$Styled$Attributes$stringProperty('value'); | ||
7794 | var $author$project$Login$viewInput = F4( | 11552 | var $author$project$Login$viewInput = F4( |
7795 | function (t, p, v, toMsg) { | 11553 | function (t, p, v, toMsg) { |
7796 | return A2( | 11554 | return A2( |
7797 | $elm$html$Html$input, | 11555 | $author$project$Styles$loginInputField, |
7798 | _List_fromArray( | 11556 | _List_fromArray( |
7799 | [ | 11557 | [ |
7800 | $elm$html$Html$Attributes$type_(t), | 11558 | $rtfeldman$elm_css$Html$Styled$Attributes$type_(t), |
7801 | $elm$html$Html$Attributes$placeholder(p), | 11559 | $rtfeldman$elm_css$Html$Styled$Attributes$placeholder(p), |
7802 | $elm$html$Html$Attributes$value(v), | 11560 | $rtfeldman$elm_css$Html$Styled$Attributes$value(v), |
7803 | $elm$html$Html$Events$onInput(toMsg) | 11561 | $rtfeldman$elm_css$Html$Styled$Events$onInput(toMsg) |
7804 | ]), | 11562 | ]), |
7805 | _List_Nil); | 11563 | _List_Nil); |
7806 | }); | 11564 | }); |
7807 | var $author$project$Login$viewStatus = function (ls) { | 11565 | var $author$project$Login$viewStatus = function (ls) { |
7808 | switch (ls.$) { | 11566 | switch (ls.$) { |
7809 | case 'NotLoggedIn': | 11567 | case 'NotLoggedIn': |
7810 | return 'Not Logged In'; | 11568 | return ''; |
7811 | case 'InvalidLogin': | 11569 | case 'InvalidLogin': |
7812 | return 'Invalid Login'; | 11570 | return 'Invalid Login'; |
7813 | case 'LoggedIn': | 11571 | case 'LoggedIn': |
@@ -7818,63 +11576,107 @@ var $author$project$Login$viewStatus = function (ls) { | |||
7818 | }; | 11576 | }; |
7819 | var $author$project$Login$view = function (model) { | 11577 | var $author$project$Login$view = function (model) { |
7820 | return A2( | 11578 | return A2( |
7821 | $elm$html$Html$div, | 11579 | $rtfeldman$elm_css$Html$Styled$div, |
7822 | _List_Nil, | 11580 | _List_fromArray( |
11581 | [ | ||
11582 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11583 | _List_fromArray( | ||
11584 | [ | ||
11585 | $rtfeldman$elm_css$Css$margin($rtfeldman$elm_css$Css$auto), | ||
11586 | $rtfeldman$elm_css$Css$marginTop( | ||
11587 | $rtfeldman$elm_css$Css$pct(10)), | ||
11588 | $rtfeldman$elm_css$Css$padding( | ||
11589 | $rtfeldman$elm_css$Css$px(20)), | ||
11590 | $rtfeldman$elm_css$Css$width( | ||
11591 | $rtfeldman$elm_css$Css$pct(30)) | ||
11592 | ])) | ||
11593 | ]), | ||
7823 | _List_fromArray( | 11594 | _List_fromArray( |
7824 | [ | 11595 | [ |
7825 | A2( | 11596 | A2( |
7826 | $elm$html$Html$div, | 11597 | $rtfeldman$elm_css$Html$Styled$div, |
7827 | _List_Nil, | 11598 | _List_fromArray( |
11599 | [ | ||
11600 | $author$project$Login$fieldPadding, | ||
11601 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11602 | _List_fromArray( | ||
11603 | [$author$project$Styles$bigHeading])) | ||
11604 | ]), | ||
11605 | _List_fromArray( | ||
11606 | [ | ||
11607 | $rtfeldman$elm_css$Html$Styled$text('Login') | ||
11608 | ])), | ||
11609 | A2( | ||
11610 | $rtfeldman$elm_css$Html$Styled$div, | ||
11611 | _List_fromArray( | ||
11612 | [$author$project$Login$fieldPadding]), | ||
7828 | _List_fromArray( | 11613 | _List_fromArray( |
7829 | [ | 11614 | [ |
7830 | A4($author$project$Login$viewInput, 'text', 'Enter name here', model.username, $author$project$Login$UserEntered) | 11615 | A4($author$project$Login$viewInput, 'text', 'Enter name here', model.username, $author$project$Login$UserEntered) |
7831 | ])), | 11616 | ])), |
7832 | A2( | 11617 | A2( |
7833 | $elm$html$Html$div, | 11618 | $rtfeldman$elm_css$Html$Styled$div, |
7834 | _List_Nil, | 11619 | _List_fromArray( |
11620 | [$author$project$Login$fieldPadding]), | ||
7835 | _List_fromArray( | 11621 | _List_fromArray( |
7836 | [ | 11622 | [ |
7837 | A4($author$project$Login$viewInput, 'password', 'Password', model.password, $author$project$Login$PassEntered) | 11623 | A4($author$project$Login$viewInput, 'password', 'Password', model.password, $author$project$Login$PassEntered) |
7838 | ])), | 11624 | ])), |
7839 | A2( | 11625 | A2( |
7840 | $elm$html$Html$div, | 11626 | $rtfeldman$elm_css$Html$Styled$div, |
7841 | _List_Nil, | 11627 | _List_fromArray( |
11628 | [ | ||
11629 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11630 | _List_fromArray( | ||
11631 | [ | ||
11632 | $rtfeldman$elm_css$Css$textAlign($rtfeldman$elm_css$Css$center) | ||
11633 | ])), | ||
11634 | $author$project$Login$fieldPadding | ||
11635 | ]), | ||
7842 | _List_fromArray( | 11636 | _List_fromArray( |
7843 | [ | 11637 | [ |
7844 | A2( | 11638 | A2( |
7845 | $elm$html$Html$button, | 11639 | $author$project$Styles$furbyButton, |
7846 | _List_fromArray( | 11640 | _List_fromArray( |
7847 | [ | 11641 | [ |
7848 | $elm$html$Html$Events$onClick($author$project$Login$LoginPressed) | 11642 | $rtfeldman$elm_css$Html$Styled$Events$onClick($author$project$Login$LoginPressed) |
7849 | ]), | 11643 | ]), |
7850 | _List_fromArray( | 11644 | _List_fromArray( |
7851 | [ | 11645 | [ |
7852 | $elm$html$Html$text('Login') | 11646 | $rtfeldman$elm_css$Html$Styled$text('Login') |
7853 | ])) | 11647 | ])) |
7854 | ])), | 11648 | ])), |
7855 | A2( | 11649 | A2( |
7856 | $elm$html$Html$div, | 11650 | $rtfeldman$elm_css$Html$Styled$div, |
7857 | _List_Nil, | 11651 | _List_fromArray( |
11652 | [ | ||
11653 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11654 | _List_fromArray( | ||
11655 | [ | ||
11656 | $rtfeldman$elm_css$Css$textAlign($rtfeldman$elm_css$Css$center) | ||
11657 | ])) | ||
11658 | ]), | ||
7858 | _List_fromArray( | 11659 | _List_fromArray( |
7859 | [ | 11660 | [ |
7860 | $elm$html$Html$text( | 11661 | $rtfeldman$elm_css$Html$Styled$text( |
7861 | $author$project$Login$viewStatus(model.loginStatus)) | 11662 | $author$project$Login$viewStatus(model.loginStatus)) |
7862 | ])), | 11663 | ])), |
7863 | A2( | 11664 | A2( |
7864 | $elm$html$Html$div, | 11665 | $rtfeldman$elm_css$Html$Styled$div, |
7865 | _List_Nil, | 11666 | _List_fromArray( |
11667 | [$author$project$Login$fieldPadding]), | ||
7866 | _List_fromArray( | 11668 | _List_fromArray( |
7867 | [ | 11669 | [ |
7868 | $elm$html$Html$text('Don\'t have an account? '), | 11670 | $rtfeldman$elm_css$Html$Styled$text('Don\'t have an account? '), |
7869 | A2( | 11671 | A2( |
7870 | $elm$html$Html$a, | 11672 | $rtfeldman$elm_css$Html$Styled$a, |
7871 | _List_fromArray( | 11673 | _List_fromArray( |
7872 | [ | 11674 | [ |
7873 | $elm$html$Html$Attributes$href('/signup') | 11675 | $rtfeldman$elm_css$Html$Styled$Attributes$href('/signup') |
7874 | ]), | 11676 | ]), |
7875 | _List_fromArray( | 11677 | _List_fromArray( |
7876 | [ | 11678 | [ |
7877 | $elm$html$Html$text('Register now!') | 11679 | $rtfeldman$elm_css$Html$Styled$text('Register now!') |
7878 | ])) | 11680 | ])) |
7879 | ])) | 11681 | ])) |
7880 | ])); | 11682 | ])); |
@@ -7887,42 +11689,118 @@ var $author$project$Product$AddToCartPressed = {$: 'AddToCartPressed'}; | |||
7887 | var $author$project$Product$viewInput = F4( | 11689 | var $author$project$Product$viewInput = F4( |
7888 | function (t, p, v, toMsg) { | 11690 | function (t, p, v, toMsg) { |
7889 | return A2( | 11691 | return A2( |
7890 | $elm$html$Html$input, | 11692 | $rtfeldman$elm_css$Html$Styled$input, |
7891 | _List_fromArray( | 11693 | _List_fromArray( |
7892 | [ | 11694 | [ |
7893 | $elm$html$Html$Attributes$type_(t), | 11695 | $rtfeldman$elm_css$Html$Styled$Attributes$type_(t), |
7894 | $elm$html$Html$Attributes$placeholder(p), | 11696 | $rtfeldman$elm_css$Html$Styled$Attributes$placeholder(p), |
7895 | $elm$html$Html$Attributes$value(v), | 11697 | $rtfeldman$elm_css$Html$Styled$Attributes$value(v), |
7896 | $elm$html$Html$Events$onInput(toMsg) | 11698 | $rtfeldman$elm_css$Html$Styled$Events$onInput(toMsg) |
7897 | ]), | 11699 | ]), |
7898 | _List_Nil); | 11700 | _List_Nil); |
7899 | }); | 11701 | }); |
11702 | var $elm$virtual_dom$VirtualDom$attribute = F2( | ||
11703 | function (key, value) { | ||
11704 | return A2( | ||
11705 | _VirtualDom_attribute, | ||
11706 | _VirtualDom_noOnOrFormAction(key), | ||
11707 | _VirtualDom_noJavaScriptOrHtmlUri(value)); | ||
11708 | }); | ||
11709 | var $rtfeldman$elm_css$VirtualDom$Styled$attribute = F2( | ||
11710 | function (key, value) { | ||
11711 | return A3( | ||
11712 | $rtfeldman$elm_css$VirtualDom$Styled$Attribute, | ||
11713 | A2($elm$virtual_dom$VirtualDom$attribute, key, value), | ||
11714 | _List_Nil, | ||
11715 | ''); | ||
11716 | }); | ||
11717 | var $rtfeldman$elm_css$Html$Styled$Attributes$attribute = $rtfeldman$elm_css$VirtualDom$Styled$attribute; | ||
11718 | var $author$project$Utils$arIosSrc = function (src) { | ||
11719 | return A2($rtfeldman$elm_css$Html$Styled$Attributes$attribute, 'ios-src', src); | ||
11720 | }; | ||
11721 | var $author$project$Utils$arModes = function (mode) { | ||
11722 | return A2($rtfeldman$elm_css$Html$Styled$Attributes$attribute, 'ar-modes', mode); | ||
11723 | }; | ||
11724 | var $author$project$Utils$arSrc = function (src) { | ||
11725 | return A2($rtfeldman$elm_css$Html$Styled$Attributes$attribute, 'src', src); | ||
11726 | }; | ||
11727 | var $author$project$Utils$autoRotate = A2($rtfeldman$elm_css$Html$Styled$Attributes$attribute, 'auto-rotate', ''); | ||
11728 | var $author$project$Utils$cameraControls = A2($rtfeldman$elm_css$Html$Styled$Attributes$attribute, 'camera-controls', ''); | ||
11729 | var $author$project$Utils$loading = function (mode) { | ||
11730 | return A2($rtfeldman$elm_css$Html$Styled$Attributes$attribute, 'loading', mode); | ||
11731 | }; | ||
11732 | var $author$project$Utils$modelViewer = F2( | ||
11733 | function (attributes, children) { | ||
11734 | return A3($rtfeldman$elm_css$Html$Styled$node, 'model-viewer', attributes, children); | ||
11735 | }); | ||
7900 | var $author$project$Product$viewProduct = function (p) { | 11736 | var $author$project$Product$viewProduct = function (p) { |
7901 | return A2( | 11737 | return A2( |
7902 | $elm$html$Html$div, | 11738 | $rtfeldman$elm_css$Html$Styled$div, |
7903 | _List_Nil, | 11739 | _List_Nil, |
7904 | _List_fromArray( | 11740 | _List_fromArray( |
7905 | [ | 11741 | [ |
7906 | $elm$html$Html$text(p.name), | 11742 | A2( |
7907 | $elm$html$Html$text( | 11743 | $rtfeldman$elm_css$Html$Styled$div, |
7908 | A2($elm$core$Maybe$withDefault, '', p.kind)), | 11744 | _List_Nil, |
7909 | $elm$html$Html$text( | 11745 | _List_fromArray( |
7910 | A2($elm$core$Maybe$withDefault, '', p.description)), | 11746 | [ |
7911 | $elm$html$Html$text( | 11747 | $rtfeldman$elm_css$Html$Styled$text(p.name) |
7912 | $elm$core$String$fromFloat(p.price)) | 11748 | ])), |
11749 | A2( | ||
11750 | $rtfeldman$elm_css$Html$Styled$div, | ||
11751 | _List_Nil, | ||
11752 | _List_fromArray( | ||
11753 | [ | ||
11754 | $rtfeldman$elm_css$Html$Styled$text( | ||
11755 | A2($elm$core$Maybe$withDefault, '', p.kind)) | ||
11756 | ])), | ||
11757 | A2( | ||
11758 | $rtfeldman$elm_css$Html$Styled$div, | ||
11759 | _List_Nil, | ||
11760 | _List_fromArray( | ||
11761 | [ | ||
11762 | $rtfeldman$elm_css$Html$Styled$text( | ||
11763 | A2($elm$core$Maybe$withDefault, '', p.description)) | ||
11764 | ])), | ||
11765 | A2( | ||
11766 | $rtfeldman$elm_css$Html$Styled$div, | ||
11767 | _List_Nil, | ||
11768 | _List_fromArray( | ||
11769 | [ | ||
11770 | $rtfeldman$elm_css$Html$Styled$text( | ||
11771 | $elm$core$String$fromFloat(p.price)) | ||
11772 | ])), | ||
11773 | A2( | ||
11774 | $rtfeldman$elm_css$Html$Styled$div, | ||
11775 | _List_Nil, | ||
11776 | _List_fromArray( | ||
11777 | [ | ||
11778 | A2( | ||
11779 | $author$project$Utils$modelViewer, | ||
11780 | _List_fromArray( | ||
11781 | [ | ||
11782 | $author$project$Utils$cameraControls, | ||
11783 | $author$project$Utils$autoRotate, | ||
11784 | $author$project$Utils$arSrc(p.src), | ||
11785 | $author$project$Utils$arIosSrc(p.iosSrc), | ||
11786 | $author$project$Utils$loading('eager'), | ||
11787 | $author$project$Utils$arModes('webxr') | ||
11788 | ]), | ||
11789 | _List_Nil) | ||
11790 | ])) | ||
7913 | ])); | 11791 | ])); |
7914 | }; | 11792 | }; |
7915 | var $author$project$Product$viewRating = function (r) { | 11793 | var $author$project$Product$viewRating = function (r) { |
7916 | return A2( | 11794 | return A2( |
7917 | $elm$html$Html$div, | 11795 | $rtfeldman$elm_css$Html$Styled$div, |
7918 | _List_Nil, | 11796 | _List_Nil, |
7919 | _List_fromArray( | 11797 | _List_fromArray( |
7920 | [ | 11798 | [ |
7921 | $elm$html$Html$text(r.customerName + ' posted on '), | 11799 | $rtfeldman$elm_css$Html$Styled$text(r.customerName + ' posted on '), |
7922 | $elm$html$Html$text(r.commentDate + ' '), | 11800 | $rtfeldman$elm_css$Html$Styled$text(r.commentDate + ' '), |
7923 | $elm$html$Html$text( | 11801 | $rtfeldman$elm_css$Html$Styled$text( |
7924 | A2($elm$core$Maybe$withDefault, '', r.commentText)), | 11802 | A2($elm$core$Maybe$withDefault, '', r.commentText)), |
7925 | $elm$html$Html$text( | 11803 | $rtfeldman$elm_css$Html$Styled$text( |
7926 | ' Stars: ' + $elm$core$String$fromInt(r.stars)) | 11804 | ' Stars: ' + $elm$core$String$fromInt(r.stars)) |
7927 | ])); | 11805 | ])); |
7928 | }; | 11806 | }; |
@@ -7930,21 +11808,21 @@ var $author$project$Product$AddRatingStars = function (a) { | |||
7930 | return {$: 'AddRatingStars', a: a}; | 11808 | return {$: 'AddRatingStars', a: a}; |
7931 | }; | 11809 | }; |
7932 | var $author$project$Product$viewStars = A2( | 11810 | var $author$project$Product$viewStars = A2( |
7933 | $elm$html$Html$ul, | 11811 | $rtfeldman$elm_css$Html$Styled$ul, |
7934 | _List_Nil, | 11812 | _List_Nil, |
7935 | A2( | 11813 | A2( |
7936 | $elm$core$List$map, | 11814 | $elm$core$List$map, |
7937 | function (i) { | 11815 | function (i) { |
7938 | return A2( | 11816 | return A2( |
7939 | $elm$html$Html$button, | 11817 | $rtfeldman$elm_css$Html$Styled$button, |
7940 | _List_fromArray( | 11818 | _List_fromArray( |
7941 | [ | 11819 | [ |
7942 | $elm$html$Html$Events$onClick( | 11820 | $rtfeldman$elm_css$Html$Styled$Events$onClick( |
7943 | $author$project$Product$AddRatingStars(i)) | 11821 | $author$project$Product$AddRatingStars(i)) |
7944 | ]), | 11822 | ]), |
7945 | _List_fromArray( | 11823 | _List_fromArray( |
7946 | [ | 11824 | [ |
7947 | $elm$html$Html$text( | 11825 | $rtfeldman$elm_css$Html$Styled$text( |
7948 | $elm$core$String$fromInt(i)) | 11826 | $elm$core$String$fromInt(i)) |
7949 | ])); | 11827 | ])); |
7950 | }, | 11828 | }, |
@@ -7964,85 +11842,85 @@ var $author$project$Product$view = function (model) { | |||
7964 | var _v0 = model.pageStatus; | 11842 | var _v0 = model.pageStatus; |
7965 | if (_v0.$ === 'Loading') { | 11843 | if (_v0.$ === 'Loading') { |
7966 | return A2( | 11844 | return A2( |
7967 | $elm$html$Html$div, | 11845 | $rtfeldman$elm_css$Html$Styled$div, |
7968 | _List_Nil, | 11846 | _List_Nil, |
7969 | _List_fromArray( | 11847 | _List_fromArray( |
7970 | [ | 11848 | [ |
7971 | $elm$html$Html$text( | 11849 | $rtfeldman$elm_css$Html$Styled$text( |
7972 | $author$project$Product$viewStatus($author$project$Product$Loading)) | 11850 | $author$project$Product$viewStatus($author$project$Product$Loading)) |
7973 | ])); | 11851 | ])); |
7974 | } else { | 11852 | } else { |
7975 | return A2( | 11853 | return A2( |
7976 | $elm$html$Html$div, | 11854 | $rtfeldman$elm_css$Html$Styled$div, |
7977 | _List_Nil, | 11855 | _List_Nil, |
7978 | _List_fromArray( | 11856 | _List_fromArray( |
7979 | [ | 11857 | [ |
7980 | A2( | 11858 | A2( |
7981 | $elm$html$Html$div, | 11859 | $rtfeldman$elm_css$Html$Styled$div, |
7982 | _List_Nil, | 11860 | _List_Nil, |
7983 | _List_fromArray( | 11861 | _List_fromArray( |
7984 | [ | 11862 | [ |
7985 | $author$project$Product$viewProduct(model.listing) | 11863 | $author$project$Product$viewProduct(model.listing) |
7986 | ])), | 11864 | ])), |
7987 | A2( | 11865 | A2( |
7988 | $elm$html$Html$ul, | 11866 | $rtfeldman$elm_css$Html$Styled$ul, |
7989 | _List_Nil, | 11867 | _List_Nil, |
7990 | A2($elm$core$List$map, $author$project$Product$viewRating, model.ratings)), | 11868 | A2($elm$core$List$map, $author$project$Product$viewRating, model.ratings)), |
7991 | A2( | 11869 | A2( |
7992 | $elm$html$Html$div, | 11870 | $rtfeldman$elm_css$Html$Styled$div, |
7993 | _List_Nil, | 11871 | _List_Nil, |
7994 | _List_fromArray( | 11872 | _List_fromArray( |
7995 | [ | 11873 | [ |
7996 | $elm$html$Html$text('Add Rating: ') | 11874 | $rtfeldman$elm_css$Html$Styled$text('Add Rating: ') |
7997 | ])), | 11875 | ])), |
7998 | A2( | 11876 | A2( |
7999 | $elm$html$Html$div, | 11877 | $rtfeldman$elm_css$Html$Styled$div, |
8000 | _List_Nil, | 11878 | _List_Nil, |
8001 | _List_fromArray( | 11879 | _List_fromArray( |
8002 | [ | 11880 | [ |
8003 | $author$project$Product$viewStars, | 11881 | $author$project$Product$viewStars, |
8004 | A4($author$project$Product$viewInput, 'text', 'Enter Comment Text', model.ratingText, $author$project$Product$AddRatingComment), | 11882 | A4($author$project$Product$viewInput, 'text', 'Enter Comment Text', model.ratingText, $author$project$Product$AddRatingComment), |
8005 | A2( | 11883 | A2( |
8006 | $elm$html$Html$button, | 11884 | $rtfeldman$elm_css$Html$Styled$button, |
8007 | _List_fromArray( | 11885 | _List_fromArray( |
8008 | [ | 11886 | [ |
8009 | $elm$html$Html$Events$onClick($author$project$Product$AddRatingPressed) | 11887 | $rtfeldman$elm_css$Html$Styled$Events$onClick($author$project$Product$AddRatingPressed) |
8010 | ]), | 11888 | ]), |
8011 | _List_fromArray( | 11889 | _List_fromArray( |
8012 | [ | 11890 | [ |
8013 | $elm$html$Html$text('Submit Rating') | 11891 | $rtfeldman$elm_css$Html$Styled$text('Submit Rating') |
8014 | ])) | 11892 | ])) |
8015 | ])), | 11893 | ])), |
8016 | A2( | 11894 | A2( |
8017 | $elm$html$Html$div, | 11895 | $rtfeldman$elm_css$Html$Styled$div, |
8018 | _List_Nil, | 11896 | _List_Nil, |
8019 | _List_fromArray( | 11897 | _List_fromArray( |
8020 | [ | 11898 | [ |
8021 | A2( | 11899 | A2( |
8022 | $elm$html$Html$button, | 11900 | $rtfeldman$elm_css$Html$Styled$button, |
8023 | _List_fromArray( | 11901 | _List_fromArray( |
8024 | [ | 11902 | [ |
8025 | $elm$html$Html$Events$onClick($author$project$Product$AddToCartPressed) | 11903 | $rtfeldman$elm_css$Html$Styled$Events$onClick($author$project$Product$AddToCartPressed) |
8026 | ]), | 11904 | ]), |
8027 | _List_fromArray( | 11905 | _List_fromArray( |
8028 | [ | 11906 | [ |
8029 | $elm$html$Html$text('Add To Cart') | 11907 | $rtfeldman$elm_css$Html$Styled$text('Add To Cart') |
8030 | ])) | 11908 | ])) |
8031 | ])), | 11909 | ])), |
8032 | A2( | 11910 | A2( |
8033 | $elm$html$Html$div, | 11911 | $rtfeldman$elm_css$Html$Styled$div, |
8034 | _List_Nil, | 11912 | _List_Nil, |
8035 | _List_fromArray( | 11913 | _List_fromArray( |
8036 | [ | 11914 | [ |
8037 | A2( | 11915 | A2( |
8038 | $elm$html$Html$a, | 11916 | $rtfeldman$elm_css$Html$Styled$a, |
8039 | _List_fromArray( | 11917 | _List_fromArray( |
8040 | [ | 11918 | [ |
8041 | $elm$html$Html$Attributes$href('/catalog') | 11919 | $rtfeldman$elm_css$Html$Styled$Attributes$href('/catalog') |
8042 | ]), | 11920 | ]), |
8043 | _List_fromArray( | 11921 | _List_fromArray( |
8044 | [ | 11922 | [ |
8045 | $elm$html$Html$text('Back to catalog') | 11923 | $rtfeldman$elm_css$Html$Styled$text('Back to catalog') |
8046 | ])) | 11924 | ])) |
8047 | ])) | 11925 | ])) |
8048 | ])); | 11926 | ])); |
@@ -8064,16 +11942,24 @@ var $author$project$Signup$PhoneEntered = function (a) { | |||
8064 | var $author$project$Signup$UserEntered = function (a) { | 11942 | var $author$project$Signup$UserEntered = function (a) { |
8065 | return {$: 'UserEntered', a: a}; | 11943 | return {$: 'UserEntered', a: a}; |
8066 | }; | 11944 | }; |
11945 | var $author$project$Signup$fieldPadding = $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11946 | _List_fromArray( | ||
11947 | [ | ||
11948 | $rtfeldman$elm_css$Css$paddingTop( | ||
11949 | $rtfeldman$elm_css$Css$px(10)), | ||
11950 | $rtfeldman$elm_css$Css$paddingBottom( | ||
11951 | $rtfeldman$elm_css$Css$px(10)) | ||
11952 | ])); | ||
8067 | var $author$project$Signup$viewInput = F4( | 11953 | var $author$project$Signup$viewInput = F4( |
8068 | function (t, p, v, toMsg) { | 11954 | function (t, p, v, toMsg) { |
8069 | return A2( | 11955 | return A2( |
8070 | $elm$html$Html$input, | 11956 | $author$project$Styles$loginInputField, |
8071 | _List_fromArray( | 11957 | _List_fromArray( |
8072 | [ | 11958 | [ |
8073 | $elm$html$Html$Attributes$type_(t), | 11959 | $rtfeldman$elm_css$Html$Styled$Attributes$type_(t), |
8074 | $elm$html$Html$Attributes$placeholder(p), | 11960 | $rtfeldman$elm_css$Html$Styled$Attributes$placeholder(p), |
8075 | $elm$html$Html$Attributes$value(v), | 11961 | $rtfeldman$elm_css$Html$Styled$Attributes$value(v), |
8076 | $elm$html$Html$Events$onInput(toMsg) | 11962 | $rtfeldman$elm_css$Html$Styled$Events$onInput(toMsg) |
8077 | ]), | 11963 | ]), |
8078 | _List_Nil); | 11964 | _List_Nil); |
8079 | }); | 11965 | }); |
@@ -8095,172 +11981,208 @@ var $author$project$Signup$viewStatus = function (s) { | |||
8095 | }; | 11981 | }; |
8096 | var $author$project$Signup$view = function (model) { | 11982 | var $author$project$Signup$view = function (model) { |
8097 | return A2( | 11983 | return A2( |
8098 | $elm$html$Html$div, | 11984 | $rtfeldman$elm_css$Html$Styled$div, |
8099 | _List_Nil, | 11985 | _List_fromArray( |
11986 | [ | ||
11987 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
11988 | _List_fromArray( | ||
11989 | [ | ||
11990 | $rtfeldman$elm_css$Css$margin($rtfeldman$elm_css$Css$auto), | ||
11991 | $rtfeldman$elm_css$Css$marginTop( | ||
11992 | $rtfeldman$elm_css$Css$pct(10)), | ||
11993 | $rtfeldman$elm_css$Css$padding( | ||
11994 | $rtfeldman$elm_css$Css$px(20)), | ||
11995 | $rtfeldman$elm_css$Css$width( | ||
11996 | $rtfeldman$elm_css$Css$pct(30)) | ||
11997 | ])) | ||
11998 | ]), | ||
8100 | _List_fromArray( | 11999 | _List_fromArray( |
8101 | [ | 12000 | [ |
8102 | A2( | 12001 | A2( |
8103 | $elm$html$Html$div, | 12002 | $rtfeldman$elm_css$Html$Styled$div, |
8104 | _List_Nil, | 12003 | _List_fromArray( |
12004 | [ | ||
12005 | $author$project$Signup$fieldPadding, | ||
12006 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
12007 | _List_fromArray( | ||
12008 | [$author$project$Styles$bigHeading])) | ||
12009 | ]), | ||
8105 | _List_fromArray( | 12010 | _List_fromArray( |
8106 | [ | 12011 | [ |
8107 | A4($author$project$Signup$viewInput, 'text', 'Enter Username', model.username, $author$project$Signup$UserEntered) | 12012 | $rtfeldman$elm_css$Html$Styled$text('Signup') |
8108 | ])), | 12013 | ])), |
8109 | A2( | 12014 | A2( |
8110 | $elm$html$Html$div, | 12015 | $rtfeldman$elm_css$Html$Styled$div, |
8111 | _List_Nil, | 12016 | _List_fromArray( |
12017 | [$author$project$Signup$fieldPadding]), | ||
12018 | _List_fromArray( | ||
12019 | [ | ||
12020 | A4($author$project$Signup$viewInput, 'text', 'Username', model.username, $author$project$Signup$UserEntered) | ||
12021 | ])), | ||
12022 | A2( | ||
12023 | $rtfeldman$elm_css$Html$Styled$div, | ||
12024 | _List_fromArray( | ||
12025 | [$author$project$Signup$fieldPadding]), | ||
8112 | _List_fromArray( | 12026 | _List_fromArray( |
8113 | [ | 12027 | [ |
8114 | A4($author$project$Signup$viewInput, 'password', 'Password', model.password, $author$project$Signup$PassEntered) | 12028 | A4($author$project$Signup$viewInput, 'password', 'Password', model.password, $author$project$Signup$PassEntered) |
8115 | ])), | 12029 | ])), |
8116 | A2( | 12030 | A2( |
8117 | $elm$html$Html$div, | 12031 | $rtfeldman$elm_css$Html$Styled$div, |
8118 | _List_Nil, | 12032 | _List_fromArray( |
12033 | [$author$project$Signup$fieldPadding]), | ||
8119 | _List_fromArray( | 12034 | _List_fromArray( |
8120 | [ | 12035 | [ |
8121 | A4($author$project$Signup$viewInput, 'text', 'Email', model.emailId, $author$project$Signup$EmailEntered) | 12036 | A4($author$project$Signup$viewInput, 'text', 'Email', model.emailId, $author$project$Signup$EmailEntered) |
8122 | ])), | 12037 | ])), |
8123 | A2( | 12038 | A2( |
8124 | $elm$html$Html$div, | 12039 | $rtfeldman$elm_css$Html$Styled$div, |
8125 | _List_Nil, | 12040 | _List_fromArray( |
12041 | [$author$project$Signup$fieldPadding]), | ||
8126 | _List_fromArray( | 12042 | _List_fromArray( |
8127 | [ | 12043 | [ |
8128 | A4($author$project$Signup$viewInput, 'text', 'Enter your Phone number', model.phoneNumber, $author$project$Signup$PhoneEntered) | 12044 | A4($author$project$Signup$viewInput, 'text', 'Phone Number', model.phoneNumber, $author$project$Signup$PhoneEntered) |
8129 | ])), | 12045 | ])), |
8130 | A2( | 12046 | A2( |
8131 | $elm$html$Html$div, | 12047 | $rtfeldman$elm_css$Html$Styled$div, |
8132 | _List_Nil, | 12048 | _List_fromArray( |
12049 | [$author$project$Signup$fieldPadding]), | ||
8133 | _List_fromArray( | 12050 | _List_fromArray( |
8134 | [ | 12051 | [ |
8135 | A4( | 12052 | A4( |
8136 | $author$project$Signup$viewInput, | 12053 | $author$project$Signup$viewInput, |
8137 | 'text', | 12054 | 'text', |
8138 | 'Enter Shipping address', | 12055 | 'Shipping Address', |
8139 | A2($elm$core$Maybe$withDefault, '', model.address), | 12056 | A2($elm$core$Maybe$withDefault, '', model.address), |
8140 | $author$project$Signup$AddressEntered) | 12057 | $author$project$Signup$AddressEntered) |
8141 | ])), | 12058 | ])), |
8142 | A2( | 12059 | A2( |
8143 | $elm$html$Html$div, | 12060 | $rtfeldman$elm_css$Html$Styled$div, |
8144 | _List_Nil, | 12061 | _List_fromArray( |
12062 | [ | ||
12063 | $author$project$Signup$fieldPadding, | ||
12064 | $rtfeldman$elm_css$Html$Styled$Attributes$css( | ||
12065 | _List_fromArray( | ||
12066 | [ | ||
12067 | $rtfeldman$elm_css$Css$textAlign($rtfeldman$elm_css$Css$center) | ||
12068 | ])) | ||
12069 | ]), | ||
8145 | _List_fromArray( | 12070 | _List_fromArray( |
8146 | [ | 12071 | [ |
8147 | A2( | 12072 | A2( |
8148 | $elm$html$Html$button, | 12073 | $author$project$Styles$furbyButton, |
8149 | _List_fromArray( | 12074 | _List_fromArray( |
8150 | [ | 12075 | [ |
8151 | $elm$html$Html$Events$onClick($author$project$Signup$CreatePressed) | 12076 | $rtfeldman$elm_css$Html$Styled$Events$onClick($author$project$Signup$CreatePressed) |
8152 | ]), | 12077 | ]), |
8153 | _List_fromArray( | 12078 | _List_fromArray( |
8154 | [ | 12079 | [ |
8155 | $elm$html$Html$text('Create') | 12080 | $rtfeldman$elm_css$Html$Styled$text('Create Account') |
8156 | ])) | 12081 | ])) |
8157 | ])), | 12082 | ])), |
8158 | A2( | 12083 | A2( |
8159 | $elm$html$Html$div, | 12084 | $rtfeldman$elm_css$Html$Styled$div, |
8160 | _List_Nil, | 12085 | _List_fromArray( |
12086 | [$author$project$Signup$fieldPadding]), | ||
8161 | _List_fromArray( | 12087 | _List_fromArray( |
8162 | [ | 12088 | [ |
8163 | $elm$html$Html$text('Already have a account? '), | 12089 | $rtfeldman$elm_css$Html$Styled$text('Already have a account? '), |
8164 | A2( | 12090 | A2( |
8165 | $elm$html$Html$a, | 12091 | $rtfeldman$elm_css$Html$Styled$a, |
8166 | _List_fromArray( | 12092 | _List_fromArray( |
8167 | [ | 12093 | [ |
8168 | $elm$html$Html$Attributes$href('/login') | 12094 | $rtfeldman$elm_css$Html$Styled$Attributes$href('/login') |
8169 | ]), | 12095 | ]), |
8170 | _List_fromArray( | 12096 | _List_fromArray( |
8171 | [ | 12097 | [ |
8172 | $elm$html$Html$text('Login >') | 12098 | $rtfeldman$elm_css$Html$Styled$text('Login >') |
8173 | ])) | 12099 | ])) |
8174 | ])), | 12100 | ])), |
8175 | $elm$html$Html$text( | 12101 | $rtfeldman$elm_css$Html$Styled$text( |
8176 | $author$project$Signup$viewStatus(model.status)) | 12102 | $author$project$Signup$viewStatus(model.status)) |
8177 | ])); | 12103 | ])); |
8178 | }; | 12104 | }; |
8179 | var $author$project$Main$viewLink = function (path) { | ||
8180 | return A2( | ||
8181 | $elm$html$Html$li, | ||
8182 | _List_Nil, | ||
8183 | _List_fromArray( | ||
8184 | [ | ||
8185 | A2( | ||
8186 | $elm$html$Html$a, | ||
8187 | _List_fromArray( | ||
8188 | [ | ||
8189 | $elm$html$Html$Attributes$href(path) | ||
8190 | ]), | ||
8191 | _List_fromArray( | ||
8192 | [ | ||
8193 | $elm$html$Html$text(path) | ||
8194 | ])) | ||
8195 | ])); | ||
8196 | }; | ||
8197 | var $author$project$Main$view = function (model) { | 12105 | var $author$project$Main$view = function (model) { |
8198 | var _v0 = model.location; | 12106 | var _v0 = model.location; |
8199 | switch (_v0.$) { | 12107 | switch (_v0.$) { |
8200 | case 'LoginPage': | 12108 | case 'HomePage': |
8201 | return { | 12109 | return { |
8202 | body: _List_fromArray( | 12110 | body: $elm$core$List$singleton( |
8203 | [ | 12111 | $rtfeldman$elm_css$Html$Styled$toUnstyled( |
8204 | A2( | 12112 | A2( |
8205 | $elm$html$Html$map, | 12113 | $rtfeldman$elm_css$Html$Styled$div, |
8206 | $author$project$Main$LoginMessage, | 12114 | _List_Nil, |
8207 | $author$project$Login$view(model.loginModel)) | 12115 | _List_fromArray( |
8208 | ]), | 12116 | [ |
12117 | A2( | ||
12118 | $rtfeldman$elm_css$Html$Styled$ul, | ||
12119 | _List_Nil, | ||
12120 | A2( | ||
12121 | $elm$core$List$map, | ||
12122 | function (l) { | ||
12123 | return A2( | ||
12124 | $rtfeldman$elm_css$Html$Styled$li, | ||
12125 | _List_Nil, | ||
12126 | _List_fromArray( | ||
12127 | [ | ||
12128 | A2( | ||
12129 | $rtfeldman$elm_css$Html$Styled$a, | ||
12130 | _List_fromArray( | ||
12131 | [ | ||
12132 | $rtfeldman$elm_css$Html$Styled$Attributes$href(l) | ||
12133 | ]), | ||
12134 | _List_fromArray( | ||
12135 | [ | ||
12136 | $rtfeldman$elm_css$Html$Styled$text(l) | ||
12137 | ])) | ||
12138 | ])); | ||
12139 | }, | ||
12140 | _List_fromArray( | ||
12141 | ['/login', '/catalog', '/cart']))) | ||
12142 | ])))), | ||
8209 | title: 'Login' | 12143 | title: 'Login' |
8210 | }; | 12144 | }; |
8211 | case 'SignupPage': | 12145 | case 'LoginPage': |
8212 | return { | 12146 | return { |
8213 | body: _List_fromArray( | 12147 | body: $elm$core$List$singleton( |
8214 | [ | 12148 | $rtfeldman$elm_css$Html$Styled$toUnstyled( |
8215 | A2( | 12149 | A2( |
8216 | $elm$html$Html$map, | 12150 | $rtfeldman$elm_css$Html$Styled$map, |
8217 | $author$project$Main$SignupMessage, | 12151 | $author$project$Main$LoginMessage, |
8218 | $author$project$Signup$view(model.signupModel)) | 12152 | $author$project$Login$view(model.loginModel)))), |
8219 | ]), | 12153 | title: 'Login' |
8220 | title: 'Signup' | ||
8221 | }; | 12154 | }; |
8222 | case 'HomePage': | 12155 | case 'SignupPage': |
8223 | return { | 12156 | return { |
8224 | body: _List_fromArray( | 12157 | body: $elm$core$List$singleton( |
8225 | [ | 12158 | $rtfeldman$elm_css$Html$Styled$toUnstyled( |
8226 | $elm$html$Html$text('The current URL is: '), | ||
8227 | A2( | 12159 | A2( |
8228 | $elm$html$Html$b, | 12160 | $rtfeldman$elm_css$Html$Styled$map, |
8229 | _List_Nil, | 12161 | $author$project$Main$SignupMessage, |
8230 | _List_fromArray( | 12162 | $author$project$Signup$view(model.signupModel)))), |
8231 | [ | 12163 | title: 'Signup' |
8232 | $elm$html$Html$text( | ||
8233 | $elm$url$Url$toString(model.url)) | ||
8234 | ])), | ||
8235 | A2( | ||
8236 | $elm$html$Html$ul, | ||
8237 | _List_Nil, | ||
8238 | _List_fromArray( | ||
8239 | [ | ||
8240 | $author$project$Main$viewLink('/login'), | ||
8241 | $author$project$Main$viewLink('/catalog'), | ||
8242 | $author$project$Main$viewLink('/cart'), | ||
8243 | $author$project$Main$viewLink('/signup') | ||
8244 | ])) | ||
8245 | ]), | ||
8246 | title: 'URL Interceptor' | ||
8247 | }; | 12164 | }; |
8248 | case 'NotFoundPage': | 12165 | case 'NotFoundPage': |
8249 | return { | 12166 | return { |
8250 | body: _List_fromArray( | 12167 | body: $elm$core$List$singleton( |
8251 | [ | 12168 | $rtfeldman$elm_css$Html$Styled$toUnstyled( |
8252 | $elm$html$Html$text('404 - Not Found'), | ||
8253 | A2( | 12169 | A2( |
8254 | $elm$html$Html$a, | 12170 | $rtfeldman$elm_css$Html$Styled$div, |
8255 | _List_fromArray( | 12171 | _List_Nil, |
8256 | [ | 12172 | _List_fromArray( |
8257 | $elm$html$Html$Attributes$href('/') | 12173 | [ |
8258 | ]), | 12174 | $rtfeldman$elm_css$Html$Styled$text('404 - Not Found'), |
8259 | _List_fromArray( | 12175 | A2( |
8260 | [ | 12176 | $rtfeldman$elm_css$Html$Styled$a, |
8261 | $elm$html$Html$text('Go back >') | 12177 | _List_fromArray( |
8262 | ])) | 12178 | [ |
8263 | ]), | 12179 | $rtfeldman$elm_css$Html$Styled$Attributes$href('/') |
12180 | ]), | ||
12181 | _List_fromArray( | ||
12182 | [ | ||
12183 | $rtfeldman$elm_css$Html$Styled$text('Go back >') | ||
12184 | ])) | ||
12185 | ])))), | ||
8264 | title: '404 - Not Found' | 12186 | title: '404 - Not Found' |
8265 | }; | 12187 | }; |
8266 | case 'CatalogPage': | 12188 | case 'CatalogPage': |
@@ -8269,7 +12191,7 @@ var $author$project$Main$view = function (model) { | |||
8269 | $author$project$Main$pageWrap, | 12191 | $author$project$Main$pageWrap, |
8270 | model, | 12192 | model, |
8271 | A2( | 12193 | A2( |
8272 | $elm$html$Html$map, | 12194 | $rtfeldman$elm_css$Html$Styled$map, |
8273 | $author$project$Main$CatalogMessage, | 12195 | $author$project$Main$CatalogMessage, |
8274 | $author$project$Catalog$view(model.catalogModel))), | 12196 | $author$project$Catalog$view(model.catalogModel))), |
8275 | title: 'Catalog' | 12197 | title: 'Catalog' |
@@ -8280,11 +12202,22 @@ var $author$project$Main$view = function (model) { | |||
8280 | $author$project$Main$pageWrap, | 12202 | $author$project$Main$pageWrap, |
8281 | model, | 12203 | model, |
8282 | A2( | 12204 | A2( |
8283 | $elm$html$Html$map, | 12205 | $rtfeldman$elm_css$Html$Styled$map, |
8284 | $author$project$Main$CartMessage, | 12206 | $author$project$Main$CartMessage, |
8285 | $author$project$Cart$view(model.cartModel))), | 12207 | $author$project$Cart$view(model.cartModel))), |
8286 | title: 'Cart' | 12208 | title: 'Cart' |
8287 | }; | 12209 | }; |
12210 | case 'CheckoutPage': | ||
12211 | return { | ||
12212 | body: A2( | ||
12213 | $author$project$Main$pageWrap, | ||
12214 | model, | ||
12215 | A2( | ||
12216 | $rtfeldman$elm_css$Html$Styled$map, | ||
12217 | $author$project$Main$CheckoutMessage, | ||
12218 | $author$project$Checkout$view(model.checkoutModel))), | ||
12219 | title: 'Checkout' | ||
12220 | }; | ||
8288 | default: | 12221 | default: |
8289 | var item = _v0.a; | 12222 | var item = _v0.a; |
8290 | return { | 12223 | return { |
@@ -8292,7 +12225,7 @@ var $author$project$Main$view = function (model) { | |||
8292 | $author$project$Main$pageWrap, | 12225 | $author$project$Main$pageWrap, |
8293 | model, | 12226 | model, |
8294 | A2( | 12227 | A2( |
8295 | $elm$html$Html$map, | 12228 | $rtfeldman$elm_css$Html$Styled$map, |
8296 | $author$project$Main$ProductMessage, | 12229 | $author$project$Main$ProductMessage, |
8297 | $author$project$Product$view(model.productModel))), | 12230 | $author$project$Product$view(model.productModel))), |
8298 | title: 'Product ' + $elm$core$String$fromInt(item) | 12231 | title: 'Product ' + $elm$core$String$fromInt(item) |
diff --git a/frontend/src/Cart.elm b/frontend/src/Cart.elm index 58fb72e..44d5a0d 100644 --- a/frontend/src/Cart.elm +++ b/frontend/src/Cart.elm | |||
@@ -2,9 +2,10 @@ module Cart exposing (..) | |||
2 | 2 | ||
3 | import Browser | 3 | import Browser |
4 | import Browser.Navigation as Nav | 4 | import Browser.Navigation as Nav |
5 | import Html exposing (..) | 5 | import Html |
6 | import Html.Attributes exposing (..) | 6 | import Html.Styled exposing (..) |
7 | import Html.Events exposing (..) | 7 | import Html.Styled.Attributes exposing (..) |
8 | import Html.Styled.Events exposing (..) | ||
8 | import Http | 9 | import Http |
9 | import Json.Decode as D | 10 | import Json.Decode as D |
10 | import Json.Encode as Encode | 11 | import Json.Encode as Encode |
diff --git a/frontend/src/Catalog.elm b/frontend/src/Catalog.elm index d00cb92..5b233f2 100644 --- a/frontend/src/Catalog.elm +++ b/frontend/src/Catalog.elm | |||
@@ -2,15 +2,16 @@ module Catalog exposing (..) | |||
2 | 2 | ||
3 | import Browser | 3 | import Browser |
4 | import Browser.Navigation as Nav | 4 | import Browser.Navigation as Nav |
5 | import Html exposing (..) | 5 | import Css exposing (..) |
6 | import Html.Attributes exposing (..) | 6 | import Html |
7 | import Html.Events exposing (..) | 7 | import Html.Styled exposing (..) |
8 | import Html.Styled.Attributes exposing (..) | ||
9 | import Html.Styled.Events exposing (..) | ||
8 | import Http | 10 | import Http |
9 | import Json.Decode as D | 11 | import Json.Decode as D |
10 | import Json.Encode as Encode | 12 | import Json.Encode as Encode |
13 | import Styles exposing (..) | ||
11 | import Tuple exposing (..) | 14 | import Tuple exposing (..) |
12 | import Url | ||
13 | import Url.Parser as P exposing ((</>), Parser, int, oneOf, s, string) | ||
14 | import Utils exposing (..) | 15 | import Utils exposing (..) |
15 | 16 | ||
16 | 17 | ||
@@ -37,7 +38,7 @@ type alias Filters = | |||
37 | 38 | ||
38 | defaultFilters : Filters | 39 | defaultFilters : Filters |
39 | defaultFilters = | 40 | defaultFilters = |
40 | Filters ( -1, 10000 ) ( 0, 5 ) | 41 | Filters ( -1, 100000 ) ( 0, 5 ) |
41 | 42 | ||
42 | 43 | ||
43 | type alias Model = | 44 | type alias Model = |
@@ -199,18 +200,26 @@ viewFilters model = | |||
199 | inp = | 200 | inp = |
200 | Maybe.withDefault 0 << String.toFloat | 201 | Maybe.withDefault 0 << String.toFloat |
201 | in | 202 | in |
202 | div [] | 203 | div |
203 | [ div [] | 204 | [] |
204 | [ text "Price" | 205 | [ div |
205 | , select [ onInput (ChangePriceLower << inp) ] (viewRange 0 priceRange) | 206 | [ css |
207 | [ bigHeading | ||
208 | , paddingBottom (px 12) | ||
209 | ] | ||
210 | ] | ||
211 | [ text "Filters" ] | ||
212 | , div [] | ||
213 | [ div [] [ text "Price" ] | ||
214 | , furbySelect [ onInput (ChangePriceLower << inp), style "appearance" "none" ] (viewRange 0 priceRange) | ||
206 | , text "to" | 215 | , text "to" |
207 | , select [ onInput (ChangePriceUpper << inp) ] (viewRange 50000 priceRange) | 216 | , furbySelect [ onInput (ChangePriceUpper << inp), style "appearance" "none" ] (viewRange 50000 priceRange) |
208 | ] | 217 | ] |
209 | , div [] | 218 | , div [] |
210 | [ text "Rating" | 219 | [ div [] [ text "Rating" ] |
211 | , select [ onInput (ChangeRatingLower << inp) ] (viewRange 1 ratingRange) | 220 | , furbySelect [ onInput (ChangeRatingLower << inp), style "appearance" "none" ] (viewRange 1 ratingRange) |
212 | , text "to" | 221 | , text "to" |
213 | , select [ onInput (ChangeRatingUpper << inp) ] (viewRange 5 ratingRange) | 222 | , furbySelect [ onInput (ChangeRatingUpper << inp), style "appearance" "none" ] (viewRange 5 ratingRange) |
214 | ] | 223 | ] |
215 | ] | 224 | ] |
216 | 225 | ||
@@ -234,8 +243,25 @@ view model = | |||
234 | div [] [ text <| viewStatus Loading ] | 243 | div [] [ text <| viewStatus Loading ] |
235 | 244 | ||
236 | _ -> | 245 | _ -> |
237 | div [] | 246 | div |
238 | [ div [] [ viewFilters model ] | 247 | [ css [ padding (px 40) ] ] |
239 | , ul [] | 248 | [ div |
240 | (filterProducts model |> List.map viewProduct) | 249 | [ css |
250 | [ float left | ||
251 | , Css.width (pct 20) | ||
252 | ] | ||
253 | ] | ||
254 | [ viewFilters model ] | ||
255 | , div | ||
256 | [ css | ||
257 | [ float left | ||
258 | , Css.width (pct 80) | ||
259 | ] | ||
260 | ] | ||
261 | [ div [ css [ bigHeading ] ] [ text "Products" ] | ||
262 | , ul | ||
263 | [ css [ padding (px 0) ] | ||
264 | ] | ||
265 | (filterProducts model |> List.map viewProduct) | ||
266 | ] | ||
241 | ] | 267 | ] |
diff --git a/frontend/src/Checkout.elm b/frontend/src/Checkout.elm index c60da0d..4df20d8 100644 --- a/frontend/src/Checkout.elm +++ b/frontend/src/Checkout.elm | |||
@@ -2,9 +2,10 @@ module Checkout exposing (..) | |||
2 | 2 | ||
3 | import Browser | 3 | import Browser |
4 | import Browser.Navigation as Nav | 4 | import Browser.Navigation as Nav |
5 | import Html exposing (..) | 5 | import Html |
6 | import Html.Attributes exposing (..) | 6 | import Html.Styled exposing (..) |
7 | import Html.Events exposing (..) | 7 | import Html.Styled.Attributes exposing (..) |
8 | import Html.Styled.Events exposing (..) | ||
8 | import Http | 9 | import Http |
9 | import Json.Decode as D | 10 | import Json.Decode as D |
10 | import Json.Encode as Encode | 11 | import Json.Encode as Encode |
diff --git a/frontend/src/Icons.elm b/frontend/src/Icons.elm new file mode 100644 index 0000000..d3b862f --- /dev/null +++ b/frontend/src/Icons.elm | |||
@@ -0,0 +1,15 @@ | |||
1 | module Icons exposing (..) | ||
2 | |||
3 | import FeatherIcons exposing (toHtml) | ||
4 | import Html | ||
5 | import Html.Styled exposing (..) | ||
6 | import Html.Styled.Attributes exposing (..) | ||
7 | import Html.Styled.Events exposing (..) | ||
8 | |||
9 | |||
10 | convert = | ||
11 | Html.Styled.fromUnstyled << toHtml [] | ||
12 | |||
13 | |||
14 | loginIcon = | ||
15 | convert FeatherIcons.logIn | ||
diff --git a/frontend/src/Login.elm b/frontend/src/Login.elm index dd168f0..87657bb 100644 --- a/frontend/src/Login.elm +++ b/frontend/src/Login.elm | |||
@@ -2,11 +2,15 @@ module Login exposing (..) | |||
2 | 2 | ||
3 | import Browser | 3 | import Browser |
4 | import Browser.Navigation as Nav | 4 | import Browser.Navigation as Nav |
5 | import Html exposing (..) | 5 | import Css exposing (..) |
6 | import Html.Attributes exposing (..) | 6 | import Html |
7 | import Html.Events exposing (..) | 7 | import Html.Styled exposing (..) |
8 | import Html.Styled.Attributes exposing (..) | ||
9 | import Html.Styled.Events exposing (..) | ||
8 | import Http | 10 | import Http |
11 | import Icons exposing (..) | ||
9 | import Json.Encode as Encode | 12 | import Json.Encode as Encode |
13 | import Styles exposing (..) | ||
10 | import Url | 14 | import Url |
11 | import Url.Parser as P exposing ((</>), Parser, int, oneOf, s, string) | 15 | import Url.Parser as P exposing ((</>), Parser, int, oneOf, s, string) |
12 | 16 | ||
@@ -91,7 +95,7 @@ viewStatus : LoginStatus -> String | |||
91 | viewStatus ls = | 95 | viewStatus ls = |
92 | case ls of | 96 | case ls of |
93 | NotLoggedIn -> | 97 | NotLoggedIn -> |
94 | "Not Logged In" | 98 | "" |
95 | 99 | ||
96 | InvalidLogin -> | 100 | InvalidLogin -> |
97 | "Invalid Login" | 101 | "Invalid Login" |
@@ -105,15 +109,30 @@ viewStatus ls = | |||
105 | 109 | ||
106 | viewInput : String -> String -> String -> (String -> msg) -> Html msg | 110 | viewInput : String -> String -> String -> (String -> msg) -> Html msg |
107 | viewInput t p v toMsg = | 111 | viewInput t p v toMsg = |
108 | input [ type_ t, placeholder p, value v, onInput toMsg ] [] | 112 | loginInputField [ type_ t, placeholder p, value v, onInput toMsg ] [] |
113 | |||
114 | |||
115 | fieldPadding = | ||
116 | css | ||
117 | [ paddingTop (px 10) | ||
118 | , paddingBottom (px 10) | ||
119 | ] | ||
109 | 120 | ||
110 | 121 | ||
111 | view : Model -> Html Msg | 122 | view : Model -> Html Msg |
112 | view model = | 123 | view model = |
113 | div [] | 124 | div |
114 | [ div [] [ viewInput "text" "Enter name here" model.username UserEntered ] | 125 | [ css |
115 | , div [] [ viewInput "password" "Password" model.password PassEntered ] | 126 | [ margin auto |
116 | , div [] [ button [ onClick LoginPressed ] [ text "Login" ] ] | 127 | , marginTop (pct 10) |
117 | , div [] [ text (viewStatus model.loginStatus) ] | 128 | , padding (px 20) |
118 | , div [] [ text "Don't have an account? ", a [ href "/signup" ] [ text "Register now!" ] ] | 129 | , Css.width (pct 30) |
130 | ] | ||
131 | ] | ||
132 | [ div [ fieldPadding, css [ bigHeading ] ] [ text "Login" ] | ||
133 | , div [ fieldPadding ] [ viewInput "text" "Enter name here" model.username UserEntered ] | ||
134 | , div [ fieldPadding ] [ viewInput "password" "Password" model.password PassEntered ] | ||
135 | , div [ css [ textAlign center ], fieldPadding ] [ furbyButton [ onClick LoginPressed ] [ text "Login" ] ] | ||
136 | , div [ css [ textAlign center ] ] [ text (viewStatus model.loginStatus) ] | ||
137 | , div [ fieldPadding ] [ text "Don't have an account? ", a [ href "/signup" ] [ text "Register now!" ] ] | ||
119 | ] | 138 | ] |
diff --git a/frontend/src/Main.elm b/frontend/src/Main.elm index f1883a1..ea80921 100644 --- a/frontend/src/Main.elm +++ b/frontend/src/Main.elm | |||
@@ -5,14 +5,17 @@ import Browser.Navigation as Nav | |||
5 | import Cart | 5 | import Cart |
6 | import Catalog | 6 | import Catalog |
7 | import Checkout | 7 | import Checkout |
8 | import Html exposing (..) | 8 | import Css exposing (..) |
9 | import Html.Attributes exposing (..) | 9 | import Html |
10 | import Html.Events exposing (..) | 10 | import Html.Styled exposing (..) |
11 | import Html.Styled.Attributes exposing (..) | ||
12 | import Html.Styled.Events exposing (..) | ||
11 | import Http | 13 | import Http |
12 | import Json.Encode as Encode | 14 | import Json.Encode as Encode |
13 | import Login | 15 | import Login |
14 | import Product | 16 | import Product |
15 | import Signup | 17 | import Signup |
18 | import Styles exposing (..) | ||
16 | import Url | 19 | import Url |
17 | import Url.Parser as P exposing ((</>), Parser, int, oneOf, s, string) | 20 | import Url.Parser as P exposing ((</>), Parser, int, oneOf, s, string) |
18 | 21 | ||
@@ -276,56 +279,93 @@ subscriptions _ = | |||
276 | view : Model -> Browser.Document Msg | 279 | view : Model -> Browser.Document Msg |
277 | view model = | 280 | view model = |
278 | case model.location of | 281 | case model.location of |
282 | HomePage -> | ||
283 | { title = "Login" | ||
284 | , body = | ||
285 | -- model.loginModel | ||
286 | -- |> Login.view | ||
287 | -- |> Html.Styled.map LoginMessage | ||
288 | -- |> toUnstyled | ||
289 | -- |> List.singleton | ||
290 | div [] | ||
291 | [ ul [] | ||
292 | (List.map | ||
293 | (\l -> | ||
294 | li [] | ||
295 | [ a [ href l ] [ text l ] ] | ||
296 | ) | ||
297 | [ "/login", "/catalog", "/cart" ] | ||
298 | ) | ||
299 | ] | ||
300 | |> toUnstyled | ||
301 | |> List.singleton | ||
302 | } | ||
303 | |||
279 | LoginPage -> | 304 | LoginPage -> |
280 | { title = "Login" | 305 | { title = "Login" |
281 | , body = [ Html.map LoginMessage (Login.view model.loginModel) ] | 306 | , body = |
307 | model.loginModel | ||
308 | |> Login.view | ||
309 | |> Html.Styled.map LoginMessage | ||
310 | |> toUnstyled | ||
311 | |> List.singleton | ||
282 | } | 312 | } |
283 | 313 | ||
284 | SignupPage -> | 314 | SignupPage -> |
285 | { title = "Signup" | 315 | { title = "Signup" |
286 | , body = [ Html.map SignupMessage (Signup.view model.signupModel) ] | ||
287 | } | ||
288 | |||
289 | HomePage -> | ||
290 | { title = "URL Interceptor" | ||
291 | , body = | 316 | , body = |
292 | [ text "The current URL is: " | 317 | model.signupModel |
293 | , b [] [ text (Url.toString model.url) ] | 318 | |> Signup.view |
294 | , ul [] | 319 | |> Html.Styled.map SignupMessage |
295 | [ viewLink "/login" | 320 | |> toUnstyled |
296 | , viewLink "/catalog" | 321 | |> List.singleton |
297 | , viewLink "/cart" | ||
298 | , viewLink "/signup" | ||
299 | ] | ||
300 | ] | ||
301 | } | 322 | } |
302 | 323 | ||
303 | NotFoundPage -> | 324 | NotFoundPage -> |
304 | { title = "404 - Not Found" | 325 | { title = "404 - Not Found" |
305 | , body = | 326 | , body = |
306 | [ text "404 - Not Found" | 327 | div [] |
307 | , a [ href "/" ] [ text "Go back >" ] | 328 | [ text "404 - Not Found" |
308 | ] | 329 | , a [ href "/" ] [ text "Go back >" ] |
330 | ] | ||
331 | |> toUnstyled | ||
332 | |> List.singleton | ||
309 | } | 333 | } |
310 | 334 | ||
311 | CatalogPage -> | 335 | CatalogPage -> |
312 | { title = "Catalog" | 336 | { title = "Catalog" |
313 | , body = pageWrap model (Html.map CatalogMessage (Catalog.view model.catalogModel)) | 337 | , body = |
338 | model.catalogModel | ||
339 | |> Catalog.view | ||
340 | |> Html.Styled.map CatalogMessage | ||
341 | |> pageWrap model | ||
314 | } | 342 | } |
315 | 343 | ||
316 | CartPage -> | 344 | CartPage -> |
317 | { title = "Cart" | 345 | { title = "Cart" |
318 | , body = pageWrap model (Html.map CartMessage (Cart.view model.cartModel)) | 346 | , body = |
347 | model.cartModel | ||
348 | |> Cart.view | ||
349 | |> Html.Styled.map CartMessage | ||
350 | |> pageWrap model | ||
319 | } | 351 | } |
320 | 352 | ||
321 | CheckoutPage -> | 353 | CheckoutPage -> |
322 | { title = "Checkout" | 354 | { title = "Checkout" |
323 | , body = pageWrap model (Html.map CheckoutMessage (Checkout.view model.checkoutModel)) | 355 | , body = |
356 | model.checkoutModel | ||
357 | |> Checkout.view | ||
358 | |> Html.Styled.map CheckoutMessage | ||
359 | |> pageWrap model | ||
324 | } | 360 | } |
325 | 361 | ||
326 | ProductPage item -> | 362 | ProductPage item -> |
327 | { title = "Product " ++ String.fromInt item | 363 | { title = "Product " ++ String.fromInt item |
328 | , body = pageWrap model (Html.map ProductMessage (Product.view model.productModel)) | 364 | , body = |
365 | model.productModel | ||
366 | |> Product.view | ||
367 | |> Html.Styled.map ProductMessage | ||
368 | |> pageWrap model | ||
329 | } | 369 | } |
330 | 370 | ||
331 | 371 | ||
@@ -333,36 +373,49 @@ viewHeader : Model -> Html Msg | |||
333 | viewHeader model = | 373 | viewHeader model = |
334 | let | 374 | let |
335 | links = | 375 | links = |
336 | [ ( "Home", "/" ) | 376 | [ ( "Catalog", "/catalog" ) |
337 | , ( "Catalog", "/catalog" ) | ||
338 | , ( "Cart", "/cart" ) | 377 | , ( "Cart", "/cart" ) |
339 | ] | 378 | ] |
340 | in | 379 | in |
341 | div [] | 380 | div |
381 | [ css | ||
382 | [ padding (px 40) | ||
383 | , paddingTop (px 3) | ||
384 | , paddingBottom (px 3) | ||
385 | , textAlign left | ||
386 | , backgroundColor theme.secondary | ||
387 | ] | ||
388 | ] | ||
342 | [ List.map | 389 | [ List.map |
343 | (\( name, loc ) -> | 390 | (\( name, loc ) -> |
344 | li [] | 391 | li [ css [ display inline ] ] |
345 | [ a [ href loc ] [ text name ] | 392 | [ headerLink [ href loc ] [ text name ] |
346 | ] | 393 | ] |
347 | ) | 394 | ) |
348 | links | 395 | links |
349 | ++ [ if model.loginModel.loginStatus /= Login.LoggedIn then | 396 | ++ [ if model.loginModel.loginStatus /= Login.LoggedIn then |
350 | li [] [ a [ href "/login" ] [ text "Login" ] ] | 397 | li [ css [ display inline ] ] [ headerLink [ href "/login" ] [ text "Login" ] ] |
351 | 398 | ||
352 | else | 399 | else |
353 | button [ onClick LogoutPressed ] [ text "Logout" ] | 400 | furbyButton [ onClick LogoutPressed ] [ text "Logout" ] |
354 | ] | 401 | ] |
355 | |> ul [] | 402 | |> ul |
403 | [ css | ||
404 | [ listStyle Css.none | ||
405 | , padding (px 0) | ||
406 | ] | ||
407 | ] | ||
356 | ] | 408 | ] |
357 | 409 | ||
358 | 410 | ||
359 | pageWrap : Model -> Html Msg -> List (Html Msg) | 411 | pageWrap : Model -> Html Msg -> List (Html.Html Msg) |
360 | pageWrap model page = | 412 | pageWrap model page = |
361 | [ div [] | 413 | div [] |
362 | [ viewHeader model | 414 | [ viewHeader model |
363 | , page | 415 | , page |
364 | ] | 416 | ] |
365 | ] | 417 | |> toUnstyled |
418 | |> List.singleton | ||
366 | 419 | ||
367 | 420 | ||
368 | viewLink : String -> Html msg | 421 | viewLink : String -> Html msg |
diff --git a/frontend/src/Product.elm b/frontend/src/Product.elm index 0ea0ce1..b97a847 100644 --- a/frontend/src/Product.elm +++ b/frontend/src/Product.elm | |||
@@ -2,14 +2,16 @@ module Product exposing (..) | |||
2 | 2 | ||
3 | import Browser | 3 | import Browser |
4 | import Browser.Navigation as Nav | 4 | import Browser.Navigation as Nav |
5 | import Html exposing (..) | 5 | import Html |
6 | import Html.Attributes exposing (..) | 6 | import Html.Styled exposing (..) |
7 | import Html.Events exposing (..) | 7 | import Html.Styled.Attributes exposing (..) |
8 | import Html.Styled.Events exposing (..) | ||
8 | import Http | 9 | import Http |
9 | import Json.Decode as D | 10 | import Json.Decode as D |
10 | import Json.Encode as Encode | 11 | import Json.Encode as Encode |
11 | import Url | 12 | import Url |
12 | import Url.Parser as P exposing ((</>), Parser, int, oneOf, s, string) | 13 | import Url.Parser as P exposing ((</>), Parser, int, oneOf, s, string) |
14 | import Utils exposing (..) | ||
13 | 15 | ||
14 | 16 | ||
15 | type SubmitStatus | 17 | type SubmitStatus |
@@ -25,11 +27,13 @@ type alias Product = | |||
25 | , kind : Maybe String | 27 | , kind : Maybe String |
26 | , price : Float | 28 | , price : Float |
27 | , description : Maybe String | 29 | , description : Maybe String |
30 | , src : String | ||
31 | , iosSrc : String | ||
28 | } | 32 | } |
29 | 33 | ||
30 | 34 | ||
31 | emptyProduct = | 35 | emptyProduct = |
32 | Product -1 "" Nothing 0 Nothing | 36 | Product -1 "" Nothing 0 Nothing "" "" |
33 | 37 | ||
34 | 38 | ||
35 | type alias Rating = | 39 | type alias Rating = |
@@ -140,12 +144,14 @@ update msg model = | |||
140 | 144 | ||
141 | decodeProduct : D.Decoder Product | 145 | decodeProduct : D.Decoder Product |
142 | decodeProduct = | 146 | decodeProduct = |
143 | D.map5 Product | 147 | D.map7 Product |
144 | (D.field "id" D.int) | 148 | (D.field "id" D.int) |
145 | (D.field "name" D.string) | 149 | (D.field "name" D.string) |
146 | (D.field "kind" (D.nullable D.string)) | 150 | (D.field "kind" (D.nullable D.string)) |
147 | (D.field "price" D.float) | 151 | (D.field "price" D.float) |
148 | (D.field "description" (D.nullable D.string)) | 152 | (D.field "description" (D.nullable D.string)) |
153 | (D.field "src" D.string) | ||
154 | (D.field "ios_src" D.string) | ||
149 | 155 | ||
150 | 156 | ||
151 | decodeRating : D.Decoder Rating | 157 | decodeRating : D.Decoder Rating |
@@ -246,10 +252,21 @@ viewStatus s = | |||
246 | viewProduct : Product -> Html Msg | 252 | viewProduct : Product -> Html Msg |
247 | viewProduct p = | 253 | viewProduct p = |
248 | div [] | 254 | div [] |
249 | [ text p.name | 255 | [ div [] [ text p.name ] |
250 | , text <| Maybe.withDefault "" p.kind | 256 | , div [] [ text <| Maybe.withDefault "" p.kind ] |
251 | , text <| Maybe.withDefault "" p.description | 257 | , div [] [ text <| Maybe.withDefault "" p.description ] |
252 | , text <| String.fromFloat p.price | 258 | , div [] [ text <| String.fromFloat p.price ] |
259 | , div [] | ||
260 | [ modelViewer | ||
261 | [ cameraControls | ||
262 | , autoRotate | ||
263 | , arSrc p.src | ||
264 | , arIosSrc p.iosSrc | ||
265 | , loading "eager" | ||
266 | , arModes "webxr" | ||
267 | ] | ||
268 | [] | ||
269 | ] | ||
253 | ] | 270 | ] |
254 | 271 | ||
255 | 272 | ||
diff --git a/frontend/src/Signup.elm b/frontend/src/Signup.elm index 30794e7..028af9c 100644 --- a/frontend/src/Signup.elm +++ b/frontend/src/Signup.elm | |||
@@ -2,11 +2,14 @@ module Signup exposing (..) | |||
2 | 2 | ||
3 | import Browser | 3 | import Browser |
4 | import Browser.Navigation as Nav | 4 | import Browser.Navigation as Nav |
5 | import Html exposing (..) | 5 | import Css exposing (..) |
6 | import Html.Attributes exposing (..) | 6 | import Html |
7 | import Html.Events exposing (..) | 7 | import Html.Styled exposing (..) |
8 | import Html.Styled.Attributes exposing (..) | ||
9 | import Html.Styled.Events exposing (..) | ||
8 | import Http | 10 | import Http |
9 | import Json.Encode as Encode | 11 | import Json.Encode as Encode |
12 | import Styles exposing (..) | ||
10 | import Url | 13 | import Url |
11 | import Url.Parser as P exposing ((</>), Parser, int, oneOf, s, string) | 14 | import Url.Parser as P exposing ((</>), Parser, int, oneOf, s, string) |
12 | 15 | ||
@@ -178,19 +181,41 @@ viewStatus s = | |||
178 | 181 | ||
179 | viewInput : String -> String -> String -> (String -> msg) -> Html msg | 182 | viewInput : String -> String -> String -> (String -> msg) -> Html msg |
180 | viewInput t p v toMsg = | 183 | viewInput t p v toMsg = |
181 | input [ type_ t, placeholder p, value v, onInput toMsg ] [] | 184 | loginInputField [ type_ t, placeholder p, value v, onInput toMsg ] [] |
185 | |||
186 | |||
187 | fieldPadding = | ||
188 | css | ||
189 | [ paddingTop (px 10) | ||
190 | , paddingBottom (px 10) | ||
191 | ] | ||
182 | 192 | ||
183 | 193 | ||
184 | view : Model -> Html Msg | 194 | view : Model -> Html Msg |
185 | view model = | 195 | view model = |
186 | div [] | 196 | div |
187 | [ div [] [ viewInput "text" "Enter Username" model.username UserEntered ] | 197 | [ css |
188 | , div [] [ viewInput "password" "Password" model.password PassEntered ] | 198 | [ margin auto |
189 | , div [] [ viewInput "text" "Email" model.emailId EmailEntered ] | 199 | , marginTop (pct 10) |
190 | , div [] [ viewInput "text" "Enter your Phone number" model.phoneNumber PhoneEntered ] | 200 | , padding (px 20) |
191 | , div [] [ viewInput "text" "Enter Shipping address" (Maybe.withDefault "" model.address) AddressEntered ] | 201 | , Css.width (pct 30) |
192 | , div [] [ button [ onClick CreatePressed ] [ text "Create" ] ] | 202 | ] |
193 | , div [] | 203 | ] |
204 | [ div [ fieldPadding, css [ bigHeading ] ] [ text "Signup" ] | ||
205 | , div [ fieldPadding ] [ viewInput "text" "Username" model.username UserEntered ] | ||
206 | , div [ fieldPadding ] [ viewInput "password" "Password" model.password PassEntered ] | ||
207 | , div [ fieldPadding ] [ viewInput "text" "Email" model.emailId EmailEntered ] | ||
208 | , div [ fieldPadding ] [ viewInput "text" "Phone Number" model.phoneNumber PhoneEntered ] | ||
209 | , div [ fieldPadding ] [ viewInput "text" "Shipping Address" (Maybe.withDefault "" model.address) AddressEntered ] | ||
210 | , div | ||
211 | [ fieldPadding | ||
212 | , css [ textAlign center ] | ||
213 | ] | ||
214 | [ furbyButton | ||
215 | [ onClick CreatePressed ] | ||
216 | [ text "Create Account" ] | ||
217 | ] | ||
218 | , div [ fieldPadding ] | ||
194 | [ text "Already have a account? " | 219 | [ text "Already have a account? " |
195 | , a [ href "/login" ] [ text "Login >" ] | 220 | , a [ href "/login" ] [ text "Login >" ] |
196 | ] | 221 | ] |
diff --git a/frontend/src/Styles.elm b/frontend/src/Styles.elm new file mode 100644 index 0000000..36f2a81 --- /dev/null +++ b/frontend/src/Styles.elm | |||
@@ -0,0 +1,104 @@ | |||
1 | module Styles exposing (..) | ||
2 | |||
3 | import Css exposing (..) | ||
4 | import Html | ||
5 | import Html.Styled exposing (..) | ||
6 | import Html.Styled.Attributes exposing (..) | ||
7 | import Html.Styled.Events exposing (..) | ||
8 | |||
9 | |||
10 | type alias Theme = | ||
11 | { primary : Color | ||
12 | , secondary : Color | ||
13 | , bad : Color | ||
14 | , fg : Color | ||
15 | , bg : Color | ||
16 | , fgLight : Color | ||
17 | , bgLight : Color | ||
18 | } | ||
19 | |||
20 | |||
21 | theme : Theme | ||
22 | theme = | ||
23 | Theme | ||
24 | (hex "fedbd0") | ||
25 | -- primary | ||
26 | (hex "feeae6") | ||
27 | -- secondary | ||
28 | (hex "ff0000") | ||
29 | -- bad | ||
30 | (hex "442c2e") | ||
31 | -- fg | ||
32 | (hex "ffffff") | ||
33 | -- bg | ||
34 | (hex "442c2e") | ||
35 | -- fgLight | ||
36 | (hex "feeae6") | ||
37 | |||
38 | |||
39 | |||
40 | -- bgLight | ||
41 | |||
42 | |||
43 | headerLink : List (Attribute msg) -> List (Html msg) -> Html msg | ||
44 | headerLink = | ||
45 | styled a | ||
46 | [ color theme.fgLight | ||
47 | , padding (px 12) | ||
48 | , textDecoration Css.none | ||
49 | , hover | ||
50 | [ backgroundColor theme.secondary | ||
51 | , textDecoration underline | ||
52 | ] | ||
53 | ] | ||
54 | |||
55 | |||
56 | furbyButton : List (Attribute msg) -> List (Html msg) -> Html msg | ||
57 | furbyButton = | ||
58 | styled button | ||
59 | [ margin (px 12) | ||
60 | , color theme.fg | ||
61 | , Css.height (px 40) | ||
62 | , border (px 0) | ||
63 | , padding2 (px 6) (px 12) | ||
64 | , backgroundColor theme.primary | ||
65 | , hover | ||
66 | [ backgroundColor theme.secondary | ||
67 | , color theme.fg | ||
68 | , margin (px 12) | ||
69 | ] | ||
70 | ] | ||
71 | |||
72 | |||
73 | furbySelect : List (Attribute msg) -> List (Html msg) -> Html msg | ||
74 | furbySelect = | ||
75 | styled select | ||
76 | [ margin (px 6) | ||
77 | , color theme.fg | ||
78 | , border (px 0) | ||
79 | , borderBottom3 (px 2) solid theme.bgLight | ||
80 | , textAlign right | ||
81 | , padding2 (px 3) (px 3) | ||
82 | , backgroundColor theme.bg | ||
83 | , hover | ||
84 | [ borderBottom3 (px 2) solid theme.fg | ||
85 | ] | ||
86 | ] | ||
87 | |||
88 | |||
89 | loginInputField : List (Attribute msg) -> List (Html msg) -> Html msg | ||
90 | loginInputField = | ||
91 | styled input | ||
92 | [ Css.width (pct 100) | ||
93 | , color theme.fg | ||
94 | , border (px 0) | ||
95 | , borderBottom3 (px 1) solid theme.bgLight | ||
96 | , focus | ||
97 | [ borderBottom3 (px 2) solid theme.fg | ||
98 | ] | ||
99 | ] | ||
100 | |||
101 | |||
102 | bigHeading : Style | ||
103 | bigHeading = | ||
104 | fontSize (px 24) | ||
diff --git a/frontend/src/Utils.elm b/frontend/src/Utils.elm index 825e4b7..b6c4bd5 100644 --- a/frontend/src/Utils.elm +++ b/frontend/src/Utils.elm | |||
@@ -1,5 +1,10 @@ | |||
1 | module Utils exposing (..) | 1 | module Utils exposing (..) |
2 | 2 | ||
3 | import Html | ||
4 | import Html.Styled exposing (..) | ||
5 | import Html.Styled.Attributes exposing (..) | ||
6 | import Html.Styled.Events exposing (..) | ||
7 | |||
3 | 8 | ||
4 | between : ( Float, Float ) -> Float -> Bool | 9 | between : ( Float, Float ) -> Float -> Bool |
5 | between ( l, u ) v = | 10 | between ( l, u ) v = |
@@ -13,3 +18,43 @@ range start stop step = | |||
13 | 18 | ||
14 | else | 19 | else |
15 | start :: range (start + step) stop step | 20 | start :: range (start + step) stop step |
21 | |||
22 | |||
23 | modelViewer : List (Attribute msg) -> List (Html msg) -> Html msg | ||
24 | modelViewer attributes children = | ||
25 | node "model-viewer" attributes children | ||
26 | |||
27 | |||
28 | cameraControls : Attribute msg | ||
29 | cameraControls = | ||
30 | attribute "camera-controls" "" | ||
31 | |||
32 | |||
33 | autoRotate : Attribute msg | ||
34 | autoRotate = | ||
35 | attribute "auto-rotate" "" | ||
36 | |||
37 | |||
38 | ar : Attribute msg | ||
39 | ar = | ||
40 | attribute "ar" "" | ||
41 | |||
42 | |||
43 | arSrc : String -> Attribute msg | ||
44 | arSrc src = | ||
45 | attribute "src" src | ||
46 | |||
47 | |||
48 | arIosSrc : String -> Attribute msg | ||
49 | arIosSrc src = | ||
50 | attribute "ios-src" src | ||
51 | |||
52 | |||
53 | arModes : String -> Attribute msg | ||
54 | arModes mode = | ||
55 | attribute "ar-modes" mode | ||
56 | |||
57 | |||
58 | loading : String -> Attribute msg | ||
59 | loading mode = | ||
60 | attribute "loading" mode | ||