diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..8ee8d20 --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +node_modules +/node_modules \ No newline at end of file diff --git a/css/main.css b/css/main.css new file mode 100644 index 0000000..2071dca --- /dev/null +++ b/css/main.css @@ -0,0 +1,514 @@ +section form input { + padding: 1rem; + outline: 0; + font-family: inherit; + font-size: 0.95em; +} + +section form, section #showData { + padding: 0.5rem; + margin: 10px auto; + border-radius: 1px; +} + +* { + box-sizing: border-box; + margin: 0; + padding: 0; +} + +body { + font-family: 'Open Sans', sans-serif; + text-rendering: optimizeSpeed; + image-rendering: pixelated; +} + +h2 { + color: #747a8a; + font-kerning: auto; + font-weight: 800; +} + +section form { + font-size: 16px; +} + +@media (min-width: 300px) and (max-width: 599px) { + section form { + width: 95%; + } +} + +@media (min-width: 600px) and (max-width: 767px) { + section form { + width: 95%; + } +} + +@media (min-width: 768px) and (max-width: 1110px) { + section form { + width: 95%; + } +} + +@media (min-width: 1111px) and (max-width: 1600px) { + section form { + width: 80%; + } +} + +@media (min-width: 1601px) { + section form { + width: 80%; + } +} + +section form input[type="submit"] { + background: #d5041f; + border-color: transparent; + color: #FFF; + cursor: pointer; +} + +section form input[type="submit"] :focus { + border: 0.1em solid #bdbdbd; +} + +@media (min-width: 300px) and (max-width: 599px) { + section form #searchBook { + width: 68%; + } +} + +@media (min-width: 600px) and (max-width: 767px) { + section form #searchBook { + width: 68%; + } +} + +@media (min-width: 768px) and (max-width: 1110px) { + section form #searchBook { + width: 68%; + } +} + +@media (min-width: 1111px) and (max-width: 1600px) { + section form #searchBook { + width: 70%; + } +} + +@media (min-width: 1601px) { + section form #searchBook { + width: 70%; + } +} + +section form #submit { + width: 28%; + margin-left: 0.6rem; +} + +section form input { + border: 1px solid #ea8300; + color: #ea8300; + font-family: inherit; + width: 100%; +} + +section form input[type="placeholder"] { + color: #fe6103; +} + +section form #submit { + background: #ea8300; + color: #FFF; + border: 0; + border-radius: 2px; + transition: .6s; + overflow: hidden; + text-decoration: none; +} + +section form #submit:focus { + outline: 0; +} + +section form #submit:before { + font-family: 'iconfont'; + content: "\ea2d"; + display: block; + position: absolute; + height: 100%; + left: 0; + top: 0; + opacity: .5; + filter: blur(30px); + transform: translateX(-100px) skewX(-15deg); +} + +section form #submit:after { + content: ''; + display: block; + position: absolute; + width: 30px; + height: 100%; + left: 30px; + top: 0; + opacity: 0; + filter: blur(5px); + transform: translateX(-100px) skewX(-15deg); +} + +section form #submit:hover { + background: #d5041f; + cursor: pointer; +} + +section #showData { + display: -webkit-box; + display: -moz-box; + display: -ms-flexbox; + display: -webkit-flex; + display: flex; + -webkit-flex-wrap: wrap; + -moz-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; + background: #bababa; + width: 65rem; + font-size: 12px; +} + +section #showData > :nth-of-type(1) { + padding: 2rem; + width: 100%; +} + +section #showData > :nth-of-type(1) a { + color: #FFF; + text-decoration: none; +} + +@media (min-width: 300px) and (max-width: 599px) { + section #showData { + width: 95%; + } +} + +@media (min-width: 600px) and (max-width: 767px) { + section #showData { + width: 95%; + } +} + +@media (min-width: 768px) and (max-width: 1110px) { + section #showData { + width: 95%; + } +} + +@media (min-width: 1111px) and (max-width: 1600px) { + section #showData { + width: 80%; + } +} + +@media (min-width: 1601px) { + section #showData { + width: 80%; + } +} + +section #showData .book { + background: #f7f7f7; + padding: 1rem; + margin: 1px; + width: 33.1%; + -webkit-transition: all 0.3s; + -moz-transition: all 0.3s; + transition: all 0.3s; + display: -webkit-box; + display: -moz-box; + display: -ms-flexbox; + display: -webkit-flex; + display: flex; + -webkit-flex-direction: column; + -moz-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + -webkit-flex-flow: wrap; + -moz-flex-flow: wrap; + -ms-flex-flow: wrap; + flex-flow: wrap; +} + +section #showData .book:hover { + background-color: #FFF; + top: 0; + transform: translateY(-5px); + box-shadow: 0 2px 5px rgba(0, 0, 0, 0.5); +} + +@media (min-width: 768px) and (max-width: 1110px) { + section #showData .book { + width: 49%; + } +} + +@media (min-width: 300px) and (max-width: 599px) { + section #showData .book { + width: 100%; + } +} + +@media (min-width: 600px) and (max-width: 767px) { + section #showData .book { + width: 49%; + } +} + +@media (min-width: 1111px) and (max-width: 1600px) { + section #showData .book { + width: 33.1%; + } +} + +@media (min-width: 1601px) { + section #showData .book { + width: 24.7%; + } +} + +section #showData .book > :nth-of-type(3) { + margin-top: 1rem; +} + +section #showData .book .bookContent { + width: 100%; +} + +section #showData .book .bookContent .author { + padding-top: 1rem; +} + +section #showData .book .bookContent .title { + padding-bottom: 1rem; + border-bottom: 0.3rem solid #747a8a; +} + +section #showData .book .bookContent .title ul { + list-style-type: none; +} + +section #showData .book .bookContent .title ul :nth-of-type(1) { + font-size: 25px; + font-weight: 800; + color: #747a8a; +} + +section #showData .book .bookContent .title ul :nth-of-type(2) { + font-size: 18px; +} + +section #showData .book .bookContent .bookInfo { + width: 100%; + padding: 16px 12px 16px 16px; +} + +section #showData .book .bookContent .bookInfo > div { + color: #bababa; +} + +section #showData .book .bookContent .bookImage { + width: 100%; + padding: 1rem; + height: 15rem; + background: #FFF; +} + +section #showData .book .bookContent .bookImage img { + height: 13rem; +} + +section #showData div.btnDiv { + display: -webkit-box; + display: -moz-box; + display: -ms-flexbox; + display: -webkit-flex; + display: flex; + -webkit-align-self: flex-end; + -moz-align-self: flex-end; + -ms-align-self: flex-end; + align-self: flex-end; + width: 100%; +} + +section #showData div.btnDiv .btnBook { + display: block; + width: 100%; + margin-top: 1rem; + padding: 1rem 2rem; + font-size: 14px; + font-weight: 400; + line-height: 1.42857143; + text-align: center; + white-space: nowrap; + vertical-align: middle; + -ms-touch-action: manipulation; + touch-action: manipulation; + cursor: pointer; + -webkit-transition: all 0.3s; + -moz-transition: all 0.3s; + transition: all 0.3s; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + background-image: none; + border: 1px solid transparent; + border-radius: 1px; + text-decoration: none; + color: #FFF; + background-color: #ea8300; +} + +section #showData div.btnDiv .btnBook:hover { + background-color: #d5041f; + cursor: pointer; + box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); +} + +section #showData .note { + font-weight: 800; + color: #d5041f; +} + +footer .full-of-color { + display: -webkit-box; + display: -moz-box; + display: -ms-flexbox; + display: -webkit-flex; + display: flex; + -webkit-flex-direction: row; + -moz-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; + margin: 0 auto; +} + +@media (min-width: 300px) and (max-width: 599px) { + footer .full-of-color { + width: 95%; + } +} + +@media (min-width: 600px) and (max-width: 767px) { + footer .full-of-color { + width: 95%; + } +} + +@media (min-width: 768px) and (max-width: 1110px) { + footer .full-of-color { + width: 95%; + } +} + +@media (min-width: 1111px) and (max-width: 1600px) { + footer .full-of-color { + width: 80%; + } +} + +@media (min-width: 1601px) { + footer .full-of-color { + width: 80%; + } +} + +footer .full-of-color :nth-child(5n+1) { + background: #d5041f; +} + +footer .full-of-color :nth-child(5n+2) { + background: #ea8300; +} + +footer .full-of-color :nth-child(5n+3) { + background: #f5bf00; +} + +footer .full-of-color :nth-child(5n+4) { + background: #FFF; +} + +footer .full-of-color :nth-child(5n+5) { + background: #747a8a; +} + +footer .full-of-color div { + padding: 0.2rem; + width: 30%; +} + +footer .main-width { + display: -webkit-box; + display: -moz-box; + display: -ms-flexbox; + display: -webkit-flex; + display: flex; + -webkit-flex-direction: row-reverse; + -moz-flex-direction: row-reverse; + -ms-flex-direction: row-reverse; + flex-direction: row-reverse; + color: #FFF; + background: #d5041f; + margin: 0 auto; + font-size: 10px; +} + +@media (min-width: 300px) and (max-width: 599px) { + footer .main-width { + width: 95%; + } +} + +@media (min-width: 600px) and (max-width: 767px) { + footer .main-width { + width: 95%; + } +} + +@media (min-width: 768px) and (max-width: 1110px) { + footer .main-width { + width: 95%; + } +} + +@media (min-width: 1111px) and (max-width: 1600px) { + footer .main-width { + width: 80%; + } +} + +@media (min-width: 1601px) { + footer .main-width { + width: 80%; + } +} + +footer .main-width a { + display: -webkit-box; + display: -moz-box; + display: -ms-flexbox; + display: -webkit-flex; + display: flex; + background: #d5041f; + text-decoration: none; + color: #FFF; + padding: 2rem; + width: 100%; +} + +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"main.css","sources":["main.scss","modules/_colors.scss","modules/_all.scss","modules/_flex.scss","modules/_media.scss","partials/_footer.scss","partials/_base.scss"],"sourcesContent":["@import \"modules/_colors\";\n@import \"modules/_all\";\n@import \"modules/_flex\";\n@import \"modules/_media\";\n@import \"partials/_footer\";\n@import \"partials/_base\";\n\n// $mapOfPrimarColors:\n// (redGwo:#d5041f,\n// orangeGwo: #ea8300,\n// yellowGwo: #f5bf00,\n// whiteGwo: #FFF);\n// fontMain: color\n//\n// $mapOfColors:\n// (backgoundColor:#FFF,\n// ColorBG: #f7f7f7,\n// footerColor: #fe6103,\n// linkCoror: #00c6ff,\n// hoverColor: #9600ff,\n// fontAdditional: #bababa);\n\n\n\n////////////////////////////\n// search / wyszukiwarka //\n//////////////////////////\n\nsection {\n\n  form {\n    @include phone(95%);\n    @include smPhone(95%);\n    @include tablet(95%);\n    @include desktop(80%);\n    @include maxDesktop(80%);\n    @extend %form;\n    // @extend %clearfix;\n    @include inputSubmit(map-get($mapOfPrimarColors, redGwo), map-get($mapOfPrimarColors, whiteGwo));\n    // background: map-get($mapOfColors, ColorBG);\n\n    font-size: 16px;\n\n    #searchBook {\n      @include phone(68%);\n      @include smPhone(68%);\n      @include tablet(68%);\n      @include desktop(70%);\n      @include maxDesktop(70%);\n    }\n    #submit {\n      width: 28%;\n      margin-left: 0.6rem;\n    }\n    input {\n      @extend %input;\n      border: 1px solid map-get($mapOfPrimarColors, orangeGwo);\n      color: map-get($mapOfPrimarColors, orangeGwo);\n      font-family: inherit;\n      width: 100%;\n    }\n\n    input[type=\"placeholder\"] {\n      color: map-get($mapOfColors, footerColor);\n    }\n\n    #submit {\n      @include button(map-get($mapOfPrimarColors, orangeGwo), map-get($mapOfPrimarColors, redGwo), map-get($mapOfPrimarColors, whiteGwo), map-get($mapOfPrimarColors, whiteGwo));\n    }\n  }\n\n  /////////////////////\n  //// render book////\n  ///////////////////\n\n  #showData {\n    @include flexbox();\n    @include flex-wrap(wrap);\n    background: map-get($mapOfColors, fontAdditional);\n\n    > :nth-of-type(1) {\n      padding: 2rem;\n      width: 100%;\n      a {\n        color: map-get($mapOfPrimarColors, whiteGwo);\n        text-decoration: none;\n      }\n    }\n\n    width: 65rem;\n    font-size: 12px;\n\n    @include phone(95%);\n    @include smPhone(95%);\n    @include tablet(95%);\n    @include desktop(80%);\n    @include maxDesktop(80%);\n    @extend %form;\n\n    .book {\n      background: map-get($mapOfColors, ColorBG);\n      padding: 1rem;\n      margin: 1px;\n      width: 33.1%;\n\n      @include bookHover(red, map-get($mapOfColors, backgoundColor), green, yellow) ;\n\n\n      @include flexbox();\n      @include flex-direction(column);\n      @include flex-flow(wrap);\n\n      @include tablet(49%);\n      @include phone(100%);\n      @include smPhone(49%);\n      @include desktop(33.1%);\n      @include maxDesktop(24.7%);\n\n      > :nth-of-type(3) {\n        margin-top: 1rem;\n      }\n      .bookContent {\n        width: 100%;\n        .author {\n          padding-top: 1rem;\n        }\n        .title {\n\n          ul {\n            list-style-type: none;\n            :nth-of-type(1) {\n              font-size: 25px;\n              font-weight: 800;\n              color: map-get($mapOfPrimarColors, fontMain);\n            }\n            :nth-of-type(2) {\n              font-size: 18px;\n            }\n          }\n          padding-bottom: 1rem;\n          border-bottom: 0.3rem solid map-get($mapOfPrimarColors, fontMain);\n        }\n        .bookInfo {\n          width: 100%;\n          // background: map-get($mapOfColors, ColorBG);\n          padding: 16px 12px 16px 16px;\n        }\n        .bookInfo > div {\n          color: map-get($mapOfColors, fontAdditional);\n        }\n        .bookImage {\n          width: 100%;\n          padding: 1rem;\n          height: 15rem;\n          background: map-get($mapOfPrimarColors, whiteGwo);\n\n          img {\n            // box-shadow: 0 2px 2px 0 rgba(0,0,0,0.16), 0 0 0 1px rgba(0,0,0,0.08);\n            height: 13rem;\n          }\n        }\n      }\n    }\n\n    //////////////////////////////////////////////////////\n    /////////// button \"Przejdź do księgarni\" ///////////\n    ////////////////////////////////////////////////////\n\n    div.btnDiv {\n      @include flexbox();\n      @include align-self(flex-end);\n      width: 100%;\n\n      .btnBook {\n        @include buttonStore(map-get($mapOfPrimarColors, orangeGwo), map-get($mapOfPrimarColors, redGwo), map-get($mapOfPrimarColors, whiteGwo), map-get($mapOfPrimarColors, whiteGwo));\n      }\n    }\n    .note {\n      font-weight: 800;\n      color: map-get($mapOfPrimarColors, redGwo);\n    }\n  }\n}\n\n///////////////////////////////\n/////////// footer ///////////\n/////////////////////////////\n\nfooter {\n  .full-of-color {\n    @include flexbox();\n    @include flex-direction(row);\n\n    @include phone(95%);\n    @include smPhone(95%);\n    @include tablet(95%);\n    @include desktop(80%);\n    @include maxDesktop(80%);\n\n    @include fullOfMainColors;\n    margin: 0 auto;\n\n    div {\n      padding: 0.2rem;\n      width: 30%;\n    }\n  }\n  .main-width {\n    @include flexbox();\n    @include flex-direction(row-reverse );\n\n    // @include justify-content(space-between)\n\n    @include phone(95%);\n    @include smPhone(95%);\n    @include tablet(95%);\n    @include desktop(80%);\n    @include maxDesktop(80%);\n    color: map-get($mapOfPrimarColors, whiteGwo);\n    background: map-get($mapOfPrimarColors, redGwo);\n\n    margin: 0 auto;\n    font-size: 10px;\n\n    a {\n      @include flexbox();\n      background: map-get($mapOfPrimarColors, redGwo);\n      text-decoration: none;\n      color: map-get($mapOfPrimarColors, whiteGwo);\n      padding: 2rem;\n      width: 100%;\n    }\n  }\n}\n","$primary-color: #ea8300;\n$additional-color: #d5041f;\n$complementary-color: #f5bf00;\n$neutralColor: #FFF;\n\n$mapOfPrimarColors:\n(redGwo:#d5041f,\norangeGwo: #ea8300,\nyellowGwo: #f5bf00,\nwhiteGwo: #FFF,\nfontMain: #747a8a);\n\n$mapOfColors:\n(backgoundColor:#FFF,\nColorBG: #f7f7f7,\nfooterColor: #fe6103,\nlinkCoror: #00c6ff,\nhoverColor: #9600ff,\nfontAdditional: #bababa);\n","@import \"modules/_colors\";\n\n%clearfix {\n  &:after,\n  &:before {\n    content: \"\";\n    display: block;\n    clear: both;\n  }\n}\n\n%float {\n  float: left;\n  display: block;\n}\n\n%input {\n  // box-sizing: border-box;\n  padding: 1rem;\n  outline: 0;\n  font-family: inherit;\n  font-size: 0.95em;\n}\n\n%form {\n  padding: 0.5rem;\n  margin: 10px auto;\n  border-radius: 1px;\n}\n\n@mixin inputSubmit($colorBackground, $color ) {\n  input[type=\"submit\"] {\n    background: $colorBackground;\n    border-color: transparent;\n    color: $color;\n    cursor: pointer;\n\n    :focus {\n      border: 0.1em solid darken(#ccc, 6%);\n    }\n  }\n}\n\n@mixin button($colorBasic, $colorHover, $colorText, $colortextHover) {\n\n  background: $colorBasic;\n  color: $colorText;\n  border: 0;\n  border-radius: 2px;\n  transition: .6s;\n  overflow: hidden;\n  text-decoration: none;\n\n  &:focus{\n    outline: 0;\n  }\n  &:before{\n    font-family: 'iconfont';\n    content: \"\\ea2d\";\n    display: block;\n    position: absolute;\n    height: 100%;\n    left: 0;\n    top: 0;\n    opacity: .5;\n    filter: blur(30px);\n    transform: translateX(-100px)  skewX(-15deg);\n  }\n  &:after{\n    content: '';\n    display: block;\n    position: absolute;\n    width: 30px;\n    height: 100%;\n    left: 30px;\n    top: 0;\n    opacity: 0;\n    filter: blur(5px);\n    transform: translateX(-100px) skewX(-15deg);\n  }\n  &:hover{\n    background: $colorHover;\n    cursor: pointer;\n  }\n}\n\n$button-color: #2D3142;\n\n@mixin buttonStore($colorBasic, $colorHover, $colorText, $colortextHover) {\n\n  display: block;\n  width: 100%;\n  margin-top: 1rem;\n  padding: 1rem 2rem;\n  font-size: 14px;\n  font-weight: 400;\n  line-height: 1.42857143;\n  text-align: center;\n  white-space: nowrap;\n\n  vertical-align: middle;\n  -ms-touch-action: manipulation;\n  touch-action: manipulation;\n\n  cursor: pointer;\n\n  -webkit-transition: all 0.3s;\n  -moz-transition: all 0.3s;\n  transition: all 0.3s;\n\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  user-select: none;\n  background-image: none;\n  border: 1px solid transparent;\n  border-radius: 1px;\n  text-decoration: none;\n  color: $colorText;\n  background-color: $colorBasic;\n\n  &:hover {\n    background-color: $colorHover;\n    cursor: pointer;\n    box-shadow: 0 2px 5px rgba(0,0,0,0.1);\n  }\n  &:focus {\n  }\n  &:active {\n  }\n}\n\n@mixin bookHover($colorBasic, $colorHover, $colorText, $colortextHover) {\n  -webkit-transition: all 0.3s;\n  -moz-transition: all 0.3s;\n  transition: all 0.3s;\n\n  &:hover {\n    background-color: $colorHover;\n    top: 0;\n    // opacity: 0;\n    // filter: blur(5px);\n    // transform: translateX(-5px);\n    transform: translateY(-5px);\n\n    box-shadow: 0 2px 5px rgba(0,0,0,0.5);\n\n  }\n  &:focus {\n  }\n  &:active {\n  }\n}\n\n\n$total: 5;\n$step: 90deg / $total;\n\n@mixin fullOfColors {\n  @for $i from 1 through $total {\n    :nth-child(#{$i}) {\n      background: adjust-hue(blue, $i * $step);\n    }\n  }\n}\n\n@mixin fullOfMainColors {\n\n  $primarColors: (#d5041f, #ea8300, #f5bf00, #FFF, #747a8a);\n\n  @for $i from 1 through length($primarColors) {\n    :nth-child(#{length($primarColors)}n+#{$i}) {\n      background: nth($primarColors, $i)\n    }\n  }\n}\n","// Flexbox display\n  @mixin flexbox() {\n    display: -webkit-box;\n    display: -moz-box;\n    display: -ms-flexbox;\n    display: -webkit-flex;\n    display: flex;\n  }\n\n  // The 'flex' shorthand\n  // - applies to: flex items\n  // <positive-number>, initial, auto, or none\n  @mixin flex($values) {\n    -webkit-box-flex: $values;\n       -moz-box-flex: $values;\n        -webkit-flex: $values;\n    \t  -ms-flex: $values;\n    \t      flex: $values;\n  }\n\n  // Flex Flow Direction\n  // - applies to: flex containers\n  // row | row-reverse | column | column-reverse\n  @mixin flex-direction($direction) {\n    -webkit-flex-direction: $direction;\n       -moz-flex-direction: $direction;\n        -ms-flex-direction: $direction;\n            flex-direction: $direction;\n  }\n\n  // Flex Line Wrapping\n  // umieszcza elementy w kolejnym anonimowym bloku\n  // - applies to: flex containers\n  // nowrap | wrap | wrap-reverse\n  @mixin flex-wrap($wrap) {\n    -webkit-flex-wrap: $wrap;\n       -moz-flex-wrap: $wrap;\n        -ms-flex-wrap: $wrap;\n            flex-wrap: $wrap;\n  }\n\n  // Flex Direction and Wrap\n  // - applies to: flex containers\n  // <flex-direction> || <flex-wrap>\n  @mixin flex-flow($flow) {\n    -webkit-flex-flow: $flow;\n       -moz-flex-flow: $flow;\n        -ms-flex-flow: $flow;\n            flex-flow: $flow;\n  }\n\n  // Display Order\n  // - applies to: flex items\n  // <integer>\n  @mixin order($val) {\n    -webkit-box-ordinal-group: $val;\n       -moz-box-ordinal-group: $val;\n    \t     -ms-flex-order: $val;\n    \t      -webkit-order: $val;\n    \t\t      order: $val;\n  }\n\n  // Flex grow factor\n  // - applies to: flex items\n  // <number>\n  @mixin flex-grow($grow) {\n    -webkit-flex-grow: $grow;\n       -moz-flex-grow: $grow;\n        -ms-flex-grow: $grow;\n            flex-grow: $grow;\n  }\n\n  // Flex shrink\n  // - applies to: flex item shrink factor\n  // <number>\n  @mixin flex-shrink($shrink) {\n    -webkit-flex-shrink: $shrink;\n       -moz-flex-shrink: $shrink;\n        -ms-flex-shrink: $shrink;\n            flex-shrink: $shrink;\n  }\n\n  // Flex basis\n  // - the initial main size of the flex item\n  // - applies to: flex itemsnitial main size of the flex item\n  // <width>\n  @mixin flex-basis($width) {\n    -webkit-flex-basis: $width;\n       -moz-flex-basis: $width;\n        -ms-flex-basis: $width;\n            flex-basis: $width;\n  }\n\n  // Axis Alignment\n  // - applies to: flex containers\n  // flex-start | flex-end | center | space-between | space-around\n  @mixin justify-content($justify) {\n    -webkit-justify-content: $justify;\n       -moz-justify-content: $justify;\n        -ms-justify-content: $justify;\n            justify-content: $justify;\n              -ms-flex-pack: $justify;\n  }\n\n  // Packing Flex Lines\n  // - applies to: multi-line flex containers\n  // flex-start | flex-end | center | space-between | space-around | stretch\n  @mixin align-content($align) {\n    -webkit-align-content: $align;\n       -moz-align-content: $align;\n        -ms-align-content: $align;\n            align-content: $align;\n  }\n\n  // Cross-axis Alignment\n  // - applies to: flex containers\n  // flex-start | flex-end | center | baseline | stretch\n  @mixin align-items($align) {\n    -webkit-align-items: $align;\n       -moz-align-items: $align;\n        -ms-align-items: $align;\n            align-items: $align;\n  }\n\n  // Cross-axis Alignment\n  // - applies to: flex items\n  // auto | flex-start | flex-end | center | baseline | stretch\n  @mixin align-self($align) {\n    -webkit-align-self: $align;\n       -moz-align-self: $align;\n        -ms-align-self: $align;\n            align-self: $align;\n  }\n","@import \"modules/_colors\";\n\n$phone2: \"(min-width: 100px) and (max-width: 299px)\";\n$phone: \"(min-width: 300px) and (max-width: 599px)\";\n$smPhone: \"(min-width: 600px) and (max-width: 767px)\";\n$tablet: \"(min-width: 768px) and (max-width: 1110px)\";\n$desktop: \"(min-width: 1111px) and (max-width: 1600px)\";\n$maxDesktop: \"(min-width: 1601px)\";\n\n@mixin phone2($width) {\n  @media #{$phone} {\n    @content;\n    width: $width;\n  }\n}\n\n@mixin phone($width)  {\n  @media #{$phone} {\n    @content;\n    width: $width;\n  }\n}\n\n@mixin smPhone($width) {\n  @media #{$smPhone} {\n    @content;\n    width: $width;\n  }\n}\n\n@mixin tablet($width) {\n  @media #{$tablet} {\n    @content;\n    width: $width;\n  }\n}\n\n@mixin desktop($width) {\n  @media #{$desktop} {\n    @content;\n    width: $width;\n  }\n}\n\n@mixin maxDesktop($width) {\n  @media #{$maxDesktop} {\n    @content;\n    width: $width;\n  }\n}\n","footer {\n}\n","@import \"modules/_colors\";\n\n* {\n  box-sizing: border-box;\n  margin: 0;\n  padding: 0;\n}\n\nbody {\n  // background: map-get($mapOfColors, fontAdditional);\n  font-family: 'Open Sans', sans-serif;\n  text-rendering: optimizeSpeed;\n  image-rendering: pixelated;\n}\n\nh2 {\n  color: map-get($mapOfPrimarColors, fontMain);\n  font-kerning: auto;\n  font-weight: 800;\n}\n"],"names":[],"mappings":"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"} */ diff --git a/dist/bundle.js b/dist/bundle.js new file mode 100644 index 0000000..08d1652 --- /dev/null +++ b/dist/bundle.js @@ -0,0 +1,100 @@ +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { +/******/ configurable: false, +/******/ enumerable: true, +/******/ get: getter +/******/ }); +/******/ } +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 0); +/******/ }) +/************************************************************************/ +/******/ ([ +/* 0 */ +/*!*******************!*\ + !*** ./js/app.js ***! + \*******************/ +/*! dynamic exports provided */ +/*! all exports used */ +/***/ (function(module, exports, __webpack_require__) { + +eval("__webpack_require__(/*! ./data.js */ 1);\n__webpack_require__(/*! ./component.js */ 2);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL2pzL2FwcC5qcz9jOTllIl0sInNvdXJjZXNDb250ZW50IjpbInJlcXVpcmUoXCIuL2RhdGEuanNcIik7XG5yZXF1aXJlKFwiLi9jb21wb25lbnQuanNcIik7XG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL2pzL2FwcC5qc1xuLy8gbW9kdWxlIGlkID0gMFxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7Iiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///0\n"); + +/***/ }), +/* 1 */ +/*!********************!*\ + !*** ./js/data.js ***! + \********************/ +/*! dynamic exports provided */ +/*! all exports used */ +/***/ (function(module, exports) { + +eval("document.addEventListener(\"DOMContentLoaded\", function() {\n console.log(\"DOM fully loaded and parsed\"); // test - załadowanie drzewa DOM\n\n var apiPath = \"https://gwo.pl/booksApi/v1/search?query=\";\n var submitButton = document.getElementById(\"submit\"); // Wyszukiwanie przycisku submit w DOM-ie\n var userInput = document.getElementById(\"searchBook\");\n var userInput2 = document.querySelector('#searchBook')\n\n var bookContainer = document.getElementById(\"showData\");\n console.log(bookContainer);\n var pageCounter = 1;\n\n submitButton.addEventListener(\"click\", function(event) { // dodanie eventu na przycisk submit\n this.url = apiPath + encodeURI(userInput.value);\n\n console.log(this.url); // sprawdzam w konsoli czy link jest dynamicznie zmieniany\n\n var ourRequest = new XMLHttpRequest();\n\n ourRequest.open(\"GET\", this.url); // używam metody \"GET\" aby pobrać dane\n ourRequest.onload = function() {\n\n if (ourRequest.status >= 200 && ourRequest.status < 400) {\n var ourData = JSON.parse(ourRequest.responseText);\n renderHTML(ourData); // przekazuję zmienną zawierającą parsowane dane do funkcji renderHTML().\n\n if (ourData.length === 0) {\n var ourData = \"
Brak pozycji, spróbuj ponownie.
\";\n document.getElementById(\"showData\").innerHTML = ourData;\n }\n\n } else {\n console.log(\"We connected to the server, but it returned an error.\");\n }\n\n };\n\n ourRequest.onerror = function() {\n console.log(\"Connection error\");\n var webConnection = \"
Brak połączenia z serwerem
\";\n document.getElementById(\"showData\").innerHTML = webConnection;\n\n };\n ourRequest.send();\n\n function renderHTML(data) { // funkcja wrapująca div-y zawierające dane API do bookContainer\n pageCounter++;\n var htmlString = \"\";\n\n var line = document.createElement(\"div\");\n for (i = 0; i < data.length; i++) {\n\n console.log((data[i].title));\n\n htmlString +=\n \"
\" +\n \"
\" +\n \"
\" + '' + \"
\" +\n \"
\" +\n \"
\" + \"
    \" + \"
  • \" + (data[i].title).replace(/\\./g, '
  • ') + \"
  • \" + \"
\" + \"
\" +\n \"
\" + \"autorzy: \" + (data[i].author) + \"
\" +\n \"
\" + \"ISBN: \" + data[i].isbn + \"
\" +\n \"
\" + \"numer dopuszczenia MEN: \" + data[i].men + \"
\" +\n \"
\" + \"liczba stron: \" + data[i].pages_count + \"
\" +\n \"
\" + \"poziomy nauczania: \" + JSON.stringify(data[i].levels).replace(/:|\"|school|class|}|{|]|[[]/g, ' ') + \"
\" + // JSON.stringify zwraca mi ciąg zawierający tekst\n \"
\" + \"przedmiot: \" + data[i].subject + \"
\" +\n \"
\" + \"rodzaj publikacji: \" + data[i].type + \"
\" + \"
\" + \"
\"\n + \"
\" + '' + \"Przejdź do księgarni\" + \"\" + \"
\" + \"
\";\n }\n document.getElementById(\"showData\").innerHTML = htmlString; // wykorzystałem atrybut innerHTML który zwraca kod HTML.\n }\n });\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL2pzL2RhdGEuanM/OWFjNyJdLCJzb3VyY2VzQ29udGVudCI6WyJkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKFwiRE9NQ29udGVudExvYWRlZFwiLCBmdW5jdGlvbigpIHtcbiAgY29uc29sZS5sb2coXCJET00gZnVsbHkgbG9hZGVkIGFuZCBwYXJzZWRcIik7IC8vIHRlc3QgLSB6YcWCYWRvd2FuaWUgZHJ6ZXdhIERPTVxuXG4gIHZhciBhcGlQYXRoID0gXCJodHRwczovL2d3by5wbC9ib29rc0FwaS92MS9zZWFyY2g/cXVlcnk9XCI7XG4gIHZhciBzdWJtaXRCdXR0b24gPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcInN1Ym1pdFwiKTsgLy8gV3lzenVraXdhbmllIHByenljaXNrdSBzdWJtaXQgdyBET00taWVcbiAgdmFyIHVzZXJJbnB1dCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKFwic2VhcmNoQm9va1wiKTtcbiAgdmFyIHVzZXJJbnB1dDIgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKCcjc2VhcmNoQm9vaycpXG5cbiAgdmFyIGJvb2tDb250YWluZXIgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcInNob3dEYXRhXCIpO1xuICBjb25zb2xlLmxvZyhib29rQ29udGFpbmVyKTtcbiAgdmFyIHBhZ2VDb3VudGVyID0gMTtcblxuICBzdWJtaXRCdXR0b24uYWRkRXZlbnRMaXN0ZW5lcihcImNsaWNrXCIsIGZ1bmN0aW9uKGV2ZW50KSB7IC8vIGRvZGFuaWUgZXZlbnR1IG5hIHByenljaXNrIHN1Ym1pdFxuICAgIHRoaXMudXJsID0gYXBpUGF0aCArIGVuY29kZVVSSSh1c2VySW5wdXQudmFsdWUpO1xuXG4gICAgY29uc29sZS5sb2codGhpcy51cmwpOyAvLyBzcHJhd2R6YW0gdyBrb25zb2xpIGN6eSBsaW5rIGplc3QgZHluYW1pY3puaWUgem1pZW5pYW55XG5cbiAgICB2YXIgb3VyUmVxdWVzdCA9IG5ldyBYTUxIdHRwUmVxdWVzdCgpO1xuXG4gICAgb3VyUmVxdWVzdC5vcGVuKFwiR0VUXCIsIHRoaXMudXJsKTsgLy8gdcW8eXdhbSBtZXRvZHkgXCJHRVRcIiBhYnkgcG9icmFjzIEgZGFuZVxuICAgIG91clJlcXVlc3Qub25sb2FkID0gZnVuY3Rpb24oKSB7XG5cbiAgICAgIGlmIChvdXJSZXF1ZXN0LnN0YXR1cyA+PSAyMDAgJiYgb3VyUmVxdWVzdC5zdGF0dXMgPCA0MDApIHtcbiAgICAgICAgdmFyIG91ckRhdGEgPSBKU09OLnBhcnNlKG91clJlcXVlc3QucmVzcG9uc2VUZXh0KTtcbiAgICAgICAgcmVuZGVySFRNTChvdXJEYXRhKTsgLy8gcHJ6ZWthenVqxJkgem1pZW5uxIUgemF3aWVyYWrEhWPEhSBwYXJzb3dhbmUgZGFuZSBkbyBmdW5rY2ppIHJlbmRlckhUTUwoKS5cblxuICAgICAgICBpZiAob3VyRGF0YS5sZW5ndGggPT09IDApIHtcbiAgICAgICAgICB2YXIgb3VyRGF0YSA9IFwiPGRpdiBjbGFzcz0nbm90ZSc+QnJhayBwb3p5Y2ppLCBzcHLDs2J1aiBwb25vd25pZS48L2Rpdj5cIjtcbiAgICAgICAgICBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcInNob3dEYXRhXCIpLmlubmVySFRNTCA9IG91ckRhdGE7XG4gICAgICAgIH1cblxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY29uc29sZS5sb2coXCJXZSBjb25uZWN0ZWQgdG8gdGhlIHNlcnZlciwgYnV0IGl0IHJldHVybmVkIGFuIGVycm9yLlwiKTtcbiAgICAgIH1cblxuICAgIH07XG5cbiAgICBvdXJSZXF1ZXN0Lm9uZXJyb3IgPSBmdW5jdGlvbigpIHtcbiAgICAgIGNvbnNvbGUubG9nKFwiQ29ubmVjdGlvbiBlcnJvclwiKTtcbiAgICAgIHZhciB3ZWJDb25uZWN0aW9uID0gXCI8ZGl2IGNsYXNzPSdub3RlJz5CcmFrIHBvxYLEhWN6ZW5pYSB6IHNlcndlcmVtPC9kaXY+XCI7XG4gICAgICBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcInNob3dEYXRhXCIpLmlubmVySFRNTCA9IHdlYkNvbm5lY3Rpb247XG5cbiAgICB9O1xuICAgIG91clJlcXVlc3Quc2VuZCgpO1xuXG4gICAgZnVuY3Rpb24gcmVuZGVySFRNTChkYXRhKSB7IC8vIGZ1bmtjamEgd3JhcHVqxIVjYSBkaXYteSB6YXdpZXJhasSFY2UgZGFuZSBBUEkgZG8gYm9va0NvbnRhaW5lclxuICAgICAgcGFnZUNvdW50ZXIrKztcbiAgICAgIHZhciBodG1sU3RyaW5nID0gXCJcIjtcblxuICAgICAgdmFyIGxpbmUgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiZGl2XCIpO1xuICAgICAgZm9yIChpID0gMDsgaSA8IGRhdGEubGVuZ3RoOyBpKyspIHtcblxuICAgICAgICBjb25zb2xlLmxvZygoZGF0YVtpXS50aXRsZSkpO1xuXG4gICAgICAgIGh0bWxTdHJpbmcgKz1cbiAgICAgICAgICBcIjxkaXYgY2xhc3M9J2Jvb2snPlwiICtcbiAgICAgICAgICBcIjxkaXYgY2xhc3M9J2Jvb2tDb250ZW50Jz5cIiArXG4gICAgICAgICAgXCI8ZGl2IGNsYXNzPSdib29rSW1hZ2UnPlwiICsgJzxpbWcgc3JjPScgKyBkYXRhW2ldLmNvdmVyICsgJyArIGhlaWdodD1cIjI1MFwiPicgKyBcIjwvZGl2PlwiICtcbiAgICAgICAgICBcIjxkaXYgY2xhc3M9J2Jvb2tJbmZvJz5cIiArXG4gICAgICAgICAgXCI8ZGl2IGNsYXNzPSd0aXRsZSc+XCIgKyBcIjx1bD5cIiArIFwiPGxpPlwiICsgKGRhdGFbaV0udGl0bGUpLnJlcGxhY2UoL1xcLi9nLCAnPC9saT48bGk+JykgKyBcIjwvbGk+XCIgKyBcIjwvdWw+XCIgKyBcIjwvZGl2PlwiICtcbiAgICAgICAgICBcIjxkaXYgY2xhc3M9J2F1dGhvcic+XCIgKyBcImF1dG9yenk6IFwiICsgKGRhdGFbaV0uYXV0aG9yKSArIFwiPC9kaXY+XCIgK1xuICAgICAgICAgIFwiPGRpdiBjbGFzcz0naXNibic+XCIgKyBcIklTQk46IFwiICsgZGF0YVtpXS5pc2JuICsgXCI8L2Rpdj5cIiArXG4gICAgICAgICAgXCI8ZGl2IGNsYXNzPSdtZW4nPlwiICsgXCJudW1lciBkb3B1c3pjemVuaWEgTUVOOiBcIiArIGRhdGFbaV0ubWVuICsgXCI8L2Rpdj5cIiArXG4gICAgICAgICAgXCI8ZGl2IGNsYXNzPSdwYWdlc19jb3VudCc+XCIgKyBcImxpY3piYSBzdHJvbjogXCIgKyBkYXRhW2ldLnBhZ2VzX2NvdW50ICsgXCI8L2Rpdj5cIiArXG4gICAgICAgICAgXCI8ZGl2IGNsYXNzPSdsZXZlbHMnPlwiICsgXCJwb3ppb215IG5hdWN6YW5pYTogXCIgKyBKU09OLnN0cmluZ2lmeShkYXRhW2ldLmxldmVscykucmVwbGFjZSgvOnxcInxzY2hvb2x8Y2xhc3N8fXx7fF18W1tdL2csICcgJykgKyBcIjwvZGl2PlwiICsgLy8gSlNPTi5zdHJpbmdpZnkgendyYWNhIG1pIGNpxIVnIHphd2llcmFqxIVjeSB0ZWtzdFxuICAgICAgICAgIFwiPGRpdiBjbGFzcz0nc3ViamVjdCc+XCIgKyBcInByemVkbWlvdDogXCIgKyBkYXRhW2ldLnN1YmplY3QgKyBcIjwvZGl2PlwiICtcbiAgICAgICAgICBcIjxkaXYgY2xhc3M9J3R5cGUnPlwiICsgXCJyb2R6YWogcHVibGlrYWNqaTogXCIgKyBkYXRhW2ldLnR5cGUgKyBcIjwvZGl2PlwiICsgXCI8L2Rpdj5cIiArIFwiPC9kaXY+XCJcbiAgICAgICAgICArIFwiPGRpdiBjbGFzcz0nYnRuRGl2Jz5cIiArICc8YSBocmVmPScgKyBkYXRhW2ldLnVybCArICcgY2xhc3M9XCJidG5Cb29rXCIgPicgKyBcIlByemVqZMW6IGRvIGtzacSZZ2FybmlcIiArIFwiPC9hPlwiICsgXCI8L2Rpdj5cIiArIFwiPC9kaXY+XCI7XG4gICAgICB9XG4gICAgICBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcInNob3dEYXRhXCIpLmlubmVySFRNTCA9IGh0bWxTdHJpbmc7IC8vIHd5a29yenlzdGHFgmVtIGF0cnlidXQgaW5uZXJIVE1MIGt0w7NyeSB6d3JhY2Ega29kIEhUTUwuXG4gICAgfVxuICB9KTtcbn0pO1xuXG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9qcy9kYXRhLmpzXG4vLyBtb2R1bGUgaWQgPSAxXG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Iiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///1\n"); + +/***/ }), +/* 2 */ +/*!*************************!*\ + !*** ./js/component.js ***! + \*************************/ +/*! dynamic exports provided */ +/*! all exports used */ +/***/ (function(module, exports) { + +eval("console.log(' world!');\n\ndocument.addEventListener(\"DOMContentLoaded\", function() {\n console.log(\"DOM fully loaded and parsed\");\n\n var formattedBody = \"Witam, \\n\\n Tereść wiadomości...\";\n\n var gitHub = document.createElement('a');\n var portfolio = document.createElement('a');\n var contactToMail = document.createElement('a');\n\n document.getElementById(\"linkGitHubId\").appendChild(gitHub);\n document.getElementById(\"linkPortfolioId\").appendChild(portfolio);\n document.getElementById(\"contactMailId\").appendChild(contactToMail);\n\n var footerTextFirst = document.createTextNode(\"GitHub\");\n var footerTextSecond = document.createTextNode(\"Portfolio\");\n var emailText = document.createTextNode(\"Kontakt\");\n\n var footerLinkFirst = \"https://github.com/Vongriffe\";\n var footerLinkSecond = \"http://capalgerie.org/portfolio/\";\n var mailToLink = \"mailto:kamelboukoffa.mac@gmail.com?\";\n\n function mailConcat(link, tag) {\n\n var content = \"Subject=Zadanie rekrutacyjne frontend&\";\n\n link+= \"\";\n\n if (link.indexOf(\"@\") >=0 ) {\n content += \"body=\" + encodeURIComponent(formattedBody);\n tag.appendChild(emailText);\n tag.title = \"napisz maila\";\n tag.href = link + content;\n return tag;\n\n } else if (link.indexOf(\"github\") >=0 ) {\n tag.appendChild(footerTextFirst);\n tag.href = link;\n tag.target = '_blank';\n return tag;\n\n } else if (link.indexOf(\"portfolio\") >=0 ) {\n tag.appendChild(footerTextSecond);\n tag.href = link;\n tag.target = '_blank';\n return tag;\n }\n }\n mailConcat(mailToLink, contactToMail);\n mailConcat(footerLinkFirst, gitHub);\n mailConcat(footerLinkSecond, portfolio);\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL2pzL2NvbXBvbmVudC5qcz9hMDZhIl0sInNvdXJjZXNDb250ZW50IjpbImNvbnNvbGUubG9nKCcgd29ybGQhJyk7XG5cbmRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoXCJET01Db250ZW50TG9hZGVkXCIsIGZ1bmN0aW9uKCkge1xuICBjb25zb2xlLmxvZyhcIkRPTSBmdWxseSBsb2FkZWQgYW5kIHBhcnNlZFwiKTtcblxuICB2YXIgZm9ybWF0dGVkQm9keSA9IFwiV2l0YW0sIFxcblxcbiBUZXJlxZvEhyB3aWFkb21vxZtjaS4uLlwiO1xuXG4gIHZhciBnaXRIdWIgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdhJyk7XG4gIHZhciBwb3J0Zm9saW8gPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdhJyk7XG4gIHZhciBjb250YWN0VG9NYWlsID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnYScpO1xuXG4gIGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKFwibGlua0dpdEh1YklkXCIpLmFwcGVuZENoaWxkKGdpdEh1Yik7XG4gIGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKFwibGlua1BvcnRmb2xpb0lkXCIpLmFwcGVuZENoaWxkKHBvcnRmb2xpbyk7XG4gIGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKFwiY29udGFjdE1haWxJZFwiKS5hcHBlbmRDaGlsZChjb250YWN0VG9NYWlsKTtcblxuICB2YXIgZm9vdGVyVGV4dEZpcnN0ID0gZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoXCJHaXRIdWJcIik7XG4gIHZhciBmb290ZXJUZXh0U2Vjb25kID0gZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoXCJQb3J0Zm9saW9cIik7XG4gIHZhciBlbWFpbFRleHQgPSBkb2N1bWVudC5jcmVhdGVUZXh0Tm9kZShcIktvbnRha3RcIik7XG5cbiAgdmFyIGZvb3RlckxpbmtGaXJzdCA9IFwiaHR0cHM6Ly9naXRodWIuY29tL1ZvbmdyaWZmZVwiO1xuICB2YXIgZm9vdGVyTGlua1NlY29uZCA9IFwiaHR0cDovL2NhcGFsZ2VyaWUub3JnL3BvcnRmb2xpby9cIjtcbiAgdmFyIG1haWxUb0xpbmsgPSBcIm1haWx0bzprYW1lbGJvdWtvZmZhLm1hY0BnbWFpbC5jb20/XCI7XG5cbiAgZnVuY3Rpb24gbWFpbENvbmNhdChsaW5rLCB0YWcpIHtcblxuICAgIHZhciBjb250ZW50ID0gXCJTdWJqZWN0PVphZGFuaWUgcmVrcnV0YWN5am5lIGZyb250ZW5kJlwiO1xuXG4gICAgbGluays9IFwiXCI7XG5cbiAgICBpZiAobGluay5pbmRleE9mKFwiQFwiKSA+PTAgKSB7XG4gICAgICBjb250ZW50ICs9IFwiYm9keT1cIiArIGVuY29kZVVSSUNvbXBvbmVudChmb3JtYXR0ZWRCb2R5KTtcbiAgICAgIHRhZy5hcHBlbmRDaGlsZChlbWFpbFRleHQpO1xuICAgICAgdGFnLnRpdGxlID0gXCJuYXBpc3ogbWFpbGFcIjtcbiAgICAgIHRhZy5ocmVmID0gbGluayArIGNvbnRlbnQ7XG4gICAgICByZXR1cm4gdGFnO1xuXG4gICAgfSBlbHNlIGlmIChsaW5rLmluZGV4T2YoXCJnaXRodWJcIikgPj0wICkge1xuICAgICAgdGFnLmFwcGVuZENoaWxkKGZvb3RlclRleHRGaXJzdCk7XG4gICAgICB0YWcuaHJlZiA9IGxpbms7XG4gICAgICB0YWcudGFyZ2V0ID0gJ19ibGFuayc7XG4gICAgICByZXR1cm4gdGFnO1xuXG4gICAgfSBlbHNlIGlmIChsaW5rLmluZGV4T2YoXCJwb3J0Zm9saW9cIikgPj0wICkge1xuICAgICAgdGFnLmFwcGVuZENoaWxkKGZvb3RlclRleHRTZWNvbmQpO1xuICAgICAgdGFnLmhyZWYgPSBsaW5rO1xuICAgICAgdGFnLnRhcmdldCA9ICdfYmxhbmsnO1xuICAgICAgcmV0dXJuIHRhZztcbiAgICB9XG4gIH1cbiAgbWFpbENvbmNhdChtYWlsVG9MaW5rLCBjb250YWN0VG9NYWlsKTtcbiAgbWFpbENvbmNhdChmb290ZXJMaW5rRmlyc3QsIGdpdEh1Yik7XG4gIG1haWxDb25jYXQoZm9vdGVyTGlua1NlY29uZCwgcG9ydGZvbGlvKTtcbn0pO1xuXG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9qcy9jb21wb25lbnQuanNcbi8vIG1vZHVsZSBpZCA9IDJcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOyIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///2\n"); + +/***/ }) +/******/ ]); \ No newline at end of file diff --git a/gulpfile.js b/gulpfile.js new file mode 100644 index 0000000..455546e --- /dev/null +++ b/gulpfile.js @@ -0,0 +1,54 @@ +var gulp = require('gulp'); +var sass = require('gulp-sass'); +var sourcemaps = require('gulp-sourcemaps'); +var browserSync = require('browser-sync').create(); +var watch = require('gulp-watch'); +var jslint = require('gulp-jslint'); +var plumber = require('gulp-plumber'); +var imagemin = require('gulp-imagemin'); + + +var Files = { + html: './index.html', + css_dest: './css', + scss_all: './sass/**/*.scss', + scss_main: './sass/*.scss', + image_max: './image/*', + image_min:'./dist/images' +} + + +gulp.task('image', function(){ + + return gulp.src(Files.image_min) + + .pipe(imagemin({interlaced: true, + progressive: true, + optimizationLevel: 5, + svgoPlugins: [{removeViewBox: true}] })) + .pipe(gulp.dest(Files.image_min)) +}); + +gulp.task('sass', function(){ + + return gulp.src(Files.scss_main) + .pipe(sourcemaps.init()) + .pipe(sass({outputStyle: 'expanded'})) + .on('error', sass.logError) + .pipe(sourcemaps.write()) + .pipe(gulp.dest(Files.css_dest)) + .pipe(browserSync.stream()) +}); + +gulp.task('default', ['sass'], function(){ + + browserSync.init({ + server: { + baseDir: './' + } + }); + + gulp.watch(Files.scss_all, ['sass']); + gulp.watch(Files.html, browserSync.reload); + +}); diff --git a/index.html b/index.html new file mode 100644 index 0000000..d6d668f --- /dev/null +++ b/index.html @@ -0,0 +1,65 @@ + + + + + + + + + Zadanie rekrutacyjne + + + + +
+ +
+
+ +
+ +
+ +
+ + + + + +
+ +
+
+ + Specyfikacja zadania "README" + +
+
+ +
+ + + + + + diff --git a/js/app.js b/js/app.js new file mode 100644 index 0000000..324684e --- /dev/null +++ b/js/app.js @@ -0,0 +1,2 @@ +require("./data.js"); +require("./component.js"); diff --git a/js/component.js b/js/component.js new file mode 100644 index 0000000..f3ce759 --- /dev/null +++ b/js/component.js @@ -0,0 +1,53 @@ +console.log(' world!'); + +document.addEventListener("DOMContentLoaded", function() { + console.log("DOM fully loaded and parsed"); + + var formattedBody = "Witam, \n\n Tereść wiadomości..."; + + var gitHub = document.createElement('a'); + var portfolio = document.createElement('a'); + var contactToMail = document.createElement('a'); + + document.getElementById("linkGitHubId").appendChild(gitHub); + document.getElementById("linkPortfolioId").appendChild(portfolio); + document.getElementById("contactMailId").appendChild(contactToMail); + + var footerTextFirst = document.createTextNode("GitHub"); + var footerTextSecond = document.createTextNode("Portfolio"); + var emailText = document.createTextNode("Kontakt"); + + var footerLinkFirst = "https://github.com/Vongriffe"; + var footerLinkSecond = "http://capalgerie.org/portfolio/"; + var mailToLink = "mailto:kamelboukoffa.mac@gmail.com?"; + + function mailConcat(link, tag) { + + var content = "Subject=Zadanie rekrutacyjne frontend&"; + + link+= ""; + + if (link.indexOf("@") >=0 ) { + content += "body=" + encodeURIComponent(formattedBody); + tag.appendChild(emailText); + tag.title = "napisz maila"; + tag.href = link + content; + return tag; + + } else if (link.indexOf("github") >=0 ) { + tag.appendChild(footerTextFirst); + tag.href = link; + tag.target = '_blank'; + return tag; + + } else if (link.indexOf("portfolio") >=0 ) { + tag.appendChild(footerTextSecond); + tag.href = link; + tag.target = '_blank'; + return tag; + } + } + mailConcat(mailToLink, contactToMail); + mailConcat(footerLinkFirst, gitHub); + mailConcat(footerLinkSecond, portfolio); +}); diff --git a/js/data.js b/js/data.js new file mode 100644 index 0000000..94af25e --- /dev/null +++ b/js/data.js @@ -0,0 +1,73 @@ +document.addEventListener("DOMContentLoaded", function() { + console.log("DOM fully loaded and parsed"); // test - załadowanie drzewa DOM + + var apiPath = "https://gwo.pl/booksApi/v1/search?query="; + var submitButton = document.getElementById("submit"); // Wyszukiwanie przycisku submit w DOM-ie + var userInput = document.getElementById("searchBook"); + var userInput2 = document.querySelector('#searchBook') + + var bookContainer = document.getElementById("showData"); + console.log(bookContainer); + var pageCounter = 1; + + submitButton.addEventListener("click", function(event) { // dodanie eventu na przycisk submit + this.url = apiPath + encodeURI(userInput.value); + + console.log(this.url); // sprawdzam w konsoli czy link jest dynamicznie zmieniany + + var ourRequest = new XMLHttpRequest(); + + ourRequest.open("GET", this.url); // używam metody "GET" aby pobrać dane + ourRequest.onload = function() { + + if (ourRequest.status >= 200 && ourRequest.status < 400) { + var ourData = JSON.parse(ourRequest.responseText); + renderHTML(ourData); // przekazuję zmienną zawierającą parsowane dane do funkcji renderHTML(). + + if (ourData.length === 0) { + var ourData = "
Brak pozycji, spróbuj ponownie.
"; + document.getElementById("showData").innerHTML = ourData; + } + + } else { + console.log("We connected to the server, but it returned an error."); + } + + }; + + ourRequest.onerror = function() { + console.log("Connection error"); + var webConnection = "
Brak połączenia z serwerem
"; + document.getElementById("showData").innerHTML = webConnection; + + }; + ourRequest.send(); + + function renderHTML(data) { // funkcja wrapująca div-y zawierające dane API do bookContainer + pageCounter++; + var htmlString = ""; + + var line = document.createElement("div"); + for (i = 0; i < data.length; i++) { + + console.log((data[i].title)); + + htmlString += + "
" + + "
" + + "
" + '' + "
" + + "
" + + "
" + "
    " + "
  • " + (data[i].title).replace(/\./g, '
  • ') + "
  • " + "
" + "
" + + "
" + "autorzy: " + (data[i].author) + "
" + + "
" + "ISBN: " + data[i].isbn + "
" + + "
" + "numer dopuszczenia MEN: " + data[i].men + "
" + + "
" + "liczba stron: " + data[i].pages_count + "
" + + "
" + "poziomy nauczania: " + JSON.stringify(data[i].levels).replace(/:|"|school|class|}|{|]|[[]/g, ' ') + "
" + // JSON.stringify zwraca mi ciąg zawierający tekst + "
" + "przedmiot: " + data[i].subject + "
" + + "
" + "rodzaj publikacji: " + data[i].type + "
" + "
" + "
" + + "
" + '' + "Przejdź do księgarni" + "" + "
" + "
"; + } + document.getElementById("showData").innerHTML = htmlString; // wykorzystałem atrybut innerHTML który zwraca kod HTML. + } + }); +}); diff --git a/my-index.html b/my-index.html new file mode 100644 index 0000000..5b28448 --- /dev/null +++ b/my-index.html @@ -0,0 +1,59 @@ + + + + + + + + + Zadanie rekrutacyjne + + + + +
+ +
+
+ +
+ +
+ +
+ + + + + +
+ +
+
+ + Specyfikacja zadania "README" + +
+
+ +
+ + + + + + diff --git a/package.json b/package.json new file mode 100644 index 0000000..d12702f --- /dev/null +++ b/package.json @@ -0,0 +1,36 @@ +{ + "name": "frontend_recruitment", + "version": "1.0.0", + "description": "Zadanie rekrutacyjne", + "main": "index.js", + "scripts": { + "server": "webpack --config webpack.config.js", + "dev": "webpack -d --watch", + "prod": "webpack -p", + "install": "npm install gulp --save-dev" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/Vongriffe/frontend_recruitment.git" + }, + "author": "Kamel Boukoffa - Vongriffe", + "license": "ISC", + "bugs": { + "url": "https://github.com/Vongriffe/frontend_recruitment/issues" + }, + "homepage": "https://github.com/Vongriffe/frontend_recruitment#readme", + "devDependencies": { + "browser-sync": "^2.18.13", + "fast-json": "^1.1.0", + "gulp": "^3.9.1", + "gulp-debug": "^3.1.0", + "gulp-imagemin": "^3.4.0", + "gulp-jslint": "^1.0.10", + "gulp-plumber": "^1.1.0", + "gulp-sass": "^3.1.0", + "gulp-sourcemaps": "^2.6.1", + "gulp-watch": "^4.3.11", + "html-webpack-plugin": "^2.30.1", + "webpack": "^3.8.1" + } +} diff --git a/sass/main.scss b/sass/main.scss new file mode 100644 index 0000000..3d12438 --- /dev/null +++ b/sass/main.scss @@ -0,0 +1,234 @@ +@import "modules/_colors"; +@import "modules/_all"; +@import "modules/_flex"; +@import "modules/_media"; +@import "partials/_footer"; +@import "partials/_base"; + +// $mapOfPrimarColors: +// (redGwo:#d5041f, +// orangeGwo: #ea8300, +// yellowGwo: #f5bf00, +// whiteGwo: #FFF); +// fontMain: color +// +// $mapOfColors: +// (backgoundColor:#FFF, +// ColorBG: #f7f7f7, +// footerColor: #fe6103, +// linkCoror: #00c6ff, +// hoverColor: #9600ff, +// fontAdditional: #bababa); + + + +//////////////////////////// +// search / wyszukiwarka // +////////////////////////// + +section { + + form { + @include phone(95%); + @include smPhone(95%); + @include tablet(95%); + @include desktop(80%); + @include maxDesktop(80%); + @extend %form; + // @extend %clearfix; + @include inputSubmit(map-get($mapOfPrimarColors, redGwo), map-get($mapOfPrimarColors, whiteGwo)); + // background: map-get($mapOfColors, ColorBG); + + font-size: 16px; + + #searchBook { + @include phone(68%); + @include smPhone(68%); + @include tablet(68%); + @include desktop(70%); + @include maxDesktop(70%); + } + #submit { + width: 28%; + margin-left: 0.6rem; + } + input { + @extend %input; + border: 1px solid map-get($mapOfPrimarColors, orangeGwo); + color: map-get($mapOfPrimarColors, orangeGwo); + font-family: inherit; + width: 100%; + } + + input[type="placeholder"] { + color: map-get($mapOfColors, footerColor); + } + + #submit { + @include button(map-get($mapOfPrimarColors, orangeGwo), map-get($mapOfPrimarColors, redGwo), map-get($mapOfPrimarColors, whiteGwo), map-get($mapOfPrimarColors, whiteGwo)); + } + } + + ///////////////////// + //// render book//// + /////////////////// + + #showData { + @include flexbox(); + @include flex-wrap(wrap); + background: map-get($mapOfColors, fontAdditional); + + > :nth-of-type(1) { + padding: 2rem; + width: 100%; + a { + color: map-get($mapOfPrimarColors, whiteGwo); + text-decoration: none; + } + } + + width: 65rem; + font-size: 12px; + + @include phone(95%); + @include smPhone(95%); + @include tablet(95%); + @include desktop(80%); + @include maxDesktop(80%); + @extend %form; + + .book { + background: map-get($mapOfColors, ColorBG); + padding: 1rem; + margin: 1px; + width: 33.1%; + + @include bookHover(red, map-get($mapOfColors, backgoundColor), green, yellow) ; + + + @include flexbox(); + @include flex-direction(column); + @include flex-flow(wrap); + + @include tablet(49%); + @include phone(100%); + @include smPhone(49%); + @include desktop(33.1%); + @include maxDesktop(24.7%); + + > :nth-of-type(3) { + margin-top: 1rem; + } + .bookContent { + width: 100%; + .author { + padding-top: 1rem; + } + .title { + + ul { + list-style-type: none; + :nth-of-type(1) { + font-size: 25px; + font-weight: 800; + color: map-get($mapOfPrimarColors, fontMain); + } + :nth-of-type(2) { + font-size: 18px; + } + } + padding-bottom: 1rem; + border-bottom: 0.3rem solid map-get($mapOfPrimarColors, fontMain); + } + .bookInfo { + width: 100%; + // background: map-get($mapOfColors, ColorBG); + padding: 16px 12px 16px 16px; + } + .bookInfo > div { + color: map-get($mapOfColors, fontAdditional); + } + .bookImage { + width: 100%; + padding: 1rem; + height: 15rem; + background: map-get($mapOfPrimarColors, whiteGwo); + + img { + // box-shadow: 0 2px 2px 0 rgba(0,0,0,0.16), 0 0 0 1px rgba(0,0,0,0.08); + height: 13rem; + } + } + } + } + + ////////////////////////////////////////////////////// + /////////// button "Przejdź do księgarni" /////////// + //////////////////////////////////////////////////// + + div.btnDiv { + @include flexbox(); + @include align-self(flex-end); + width: 100%; + + .btnBook { + @include buttonStore(map-get($mapOfPrimarColors, orangeGwo), map-get($mapOfPrimarColors, redGwo), map-get($mapOfPrimarColors, whiteGwo), map-get($mapOfPrimarColors, whiteGwo)); + } + } + .note { + font-weight: 800; + color: map-get($mapOfPrimarColors, redGwo); + } + } +} + +/////////////////////////////// +/////////// footer /////////// +///////////////////////////// + +footer { + .full-of-color { + @include flexbox(); + @include flex-direction(row); + + @include phone(95%); + @include smPhone(95%); + @include tablet(95%); + @include desktop(80%); + @include maxDesktop(80%); + + @include fullOfMainColors; + margin: 0 auto; + + div { + padding: 0.2rem; + width: 30%; + } + } + .main-width { + @include flexbox(); + @include flex-direction(row-reverse ); + + // @include justify-content(space-between) + + @include phone(95%); + @include smPhone(95%); + @include tablet(95%); + @include desktop(80%); + @include maxDesktop(80%); + color: map-get($mapOfPrimarColors, whiteGwo); + background: map-get($mapOfPrimarColors, redGwo); + + margin: 0 auto; + font-size: 10px; + + a { + @include flexbox(); + background: map-get($mapOfPrimarColors, redGwo); + text-decoration: none; + color: map-get($mapOfPrimarColors, whiteGwo); + padding: 2rem; + width: 100%; + } + } +} diff --git a/sass/modules/_all.scss b/sass/modules/_all.scss new file mode 100644 index 0000000..7a36d44 --- /dev/null +++ b/sass/modules/_all.scss @@ -0,0 +1,176 @@ +@import "modules/_colors"; + +%clearfix { + &:after, + &:before { + content: ""; + display: block; + clear: both; + } +} + +%float { + float: left; + display: block; +} + +%input { + // box-sizing: border-box; + padding: 1rem; + outline: 0; + font-family: inherit; + font-size: 0.95em; +} + +%form { + padding: 0.5rem; + margin: 10px auto; + border-radius: 1px; +} + +@mixin inputSubmit($colorBackground, $color ) { + input[type="submit"] { + background: $colorBackground; + border-color: transparent; + color: $color; + cursor: pointer; + + :focus { + border: 0.1em solid darken(#ccc, 6%); + } + } +} + +@mixin button($colorBasic, $colorHover, $colorText, $colortextHover) { + + background: $colorBasic; + color: $colorText; + border: 0; + border-radius: 2px; + transition: .6s; + overflow: hidden; + text-decoration: none; + + &:focus{ + outline: 0; + } + &:before{ + font-family: 'iconfont'; + content: "\ea2d"; + display: block; + position: absolute; + height: 100%; + left: 0; + top: 0; + opacity: .5; + filter: blur(30px); + transform: translateX(-100px) skewX(-15deg); + } + &:after{ + content: ''; + display: block; + position: absolute; + width: 30px; + height: 100%; + left: 30px; + top: 0; + opacity: 0; + filter: blur(5px); + transform: translateX(-100px) skewX(-15deg); + } + &:hover{ + background: $colorHover; + cursor: pointer; + } +} + +$button-color: #2D3142; + +@mixin buttonStore($colorBasic, $colorHover, $colorText, $colortextHover) { + + display: block; + width: 100%; + margin-top: 1rem; + padding: 1rem 2rem; + font-size: 14px; + font-weight: 400; + line-height: 1.42857143; + text-align: center; + white-space: nowrap; + + vertical-align: middle; + -ms-touch-action: manipulation; + touch-action: manipulation; + + cursor: pointer; + + -webkit-transition: all 0.3s; + -moz-transition: all 0.3s; + transition: all 0.3s; + + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + background-image: none; + border: 1px solid transparent; + border-radius: 1px; + text-decoration: none; + color: $colorText; + background-color: $colorBasic; + + &:hover { + background-color: $colorHover; + cursor: pointer; + box-shadow: 0 2px 5px rgba(0,0,0,0.1); + } + &:focus { + } + &:active { + } +} + +@mixin bookHover($colorBasic, $colorHover, $colorText, $colortextHover) { + -webkit-transition: all 0.3s; + -moz-transition: all 0.3s; + transition: all 0.3s; + + &:hover { + background-color: $colorHover; + top: 0; + // opacity: 0; + // filter: blur(5px); + // transform: translateX(-5px); + transform: translateY(-5px); + + box-shadow: 0 2px 5px rgba(0,0,0,0.5); + + } + &:focus { + } + &:active { + } +} + + +$total: 5; +$step: 90deg / $total; + +@mixin fullOfColors { + @for $i from 1 through $total { + :nth-child(#{$i}) { + background: adjust-hue(blue, $i * $step); + } + } +} + +@mixin fullOfMainColors { + + $primarColors: (#d5041f, #ea8300, #f5bf00, #FFF, #747a8a); + + @for $i from 1 through length($primarColors) { + :nth-child(#{length($primarColors)}n+#{$i}) { + background: nth($primarColors, $i) + } + } +} diff --git a/sass/modules/_colors.scss b/sass/modules/_colors.scss new file mode 100644 index 0000000..09eafe3 --- /dev/null +++ b/sass/modules/_colors.scss @@ -0,0 +1,19 @@ +$primary-color: #ea8300; +$additional-color: #d5041f; +$complementary-color: #f5bf00; +$neutralColor: #FFF; + +$mapOfPrimarColors: +(redGwo:#d5041f, +orangeGwo: #ea8300, +yellowGwo: #f5bf00, +whiteGwo: #FFF, +fontMain: #747a8a); + +$mapOfColors: +(backgoundColor:#FFF, +ColorBG: #f7f7f7, +footerColor: #fe6103, +linkCoror: #00c6ff, +hoverColor: #9600ff, +fontAdditional: #bababa); diff --git a/sass/modules/_flex.scss b/sass/modules/_flex.scss new file mode 100644 index 0000000..ef623da --- /dev/null +++ b/sass/modules/_flex.scss @@ -0,0 +1,133 @@ +// Flexbox display + @mixin flexbox() { + display: -webkit-box; + display: -moz-box; + display: -ms-flexbox; + display: -webkit-flex; + display: flex; + } + + // The 'flex' shorthand + // - applies to: flex items + // , initial, auto, or none + @mixin flex($values) { + -webkit-box-flex: $values; + -moz-box-flex: $values; + -webkit-flex: $values; + -ms-flex: $values; + flex: $values; + } + + // Flex Flow Direction + // - applies to: flex containers + // row | row-reverse | column | column-reverse + @mixin flex-direction($direction) { + -webkit-flex-direction: $direction; + -moz-flex-direction: $direction; + -ms-flex-direction: $direction; + flex-direction: $direction; + } + + // Flex Line Wrapping + // umieszcza elementy w kolejnym anonimowym bloku + // - applies to: flex containers + // nowrap | wrap | wrap-reverse + @mixin flex-wrap($wrap) { + -webkit-flex-wrap: $wrap; + -moz-flex-wrap: $wrap; + -ms-flex-wrap: $wrap; + flex-wrap: $wrap; + } + + // Flex Direction and Wrap + // - applies to: flex containers + // || + @mixin flex-flow($flow) { + -webkit-flex-flow: $flow; + -moz-flex-flow: $flow; + -ms-flex-flow: $flow; + flex-flow: $flow; + } + + // Display Order + // - applies to: flex items + // + @mixin order($val) { + -webkit-box-ordinal-group: $val; + -moz-box-ordinal-group: $val; + -ms-flex-order: $val; + -webkit-order: $val; + order: $val; + } + + // Flex grow factor + // - applies to: flex items + // + @mixin flex-grow($grow) { + -webkit-flex-grow: $grow; + -moz-flex-grow: $grow; + -ms-flex-grow: $grow; + flex-grow: $grow; + } + + // Flex shrink + // - applies to: flex item shrink factor + // + @mixin flex-shrink($shrink) { + -webkit-flex-shrink: $shrink; + -moz-flex-shrink: $shrink; + -ms-flex-shrink: $shrink; + flex-shrink: $shrink; + } + + // Flex basis + // - the initial main size of the flex item + // - applies to: flex itemsnitial main size of the flex item + // + @mixin flex-basis($width) { + -webkit-flex-basis: $width; + -moz-flex-basis: $width; + -ms-flex-basis: $width; + flex-basis: $width; + } + + // Axis Alignment + // - applies to: flex containers + // flex-start | flex-end | center | space-between | space-around + @mixin justify-content($justify) { + -webkit-justify-content: $justify; + -moz-justify-content: $justify; + -ms-justify-content: $justify; + justify-content: $justify; + -ms-flex-pack: $justify; + } + + // Packing Flex Lines + // - applies to: multi-line flex containers + // flex-start | flex-end | center | space-between | space-around | stretch + @mixin align-content($align) { + -webkit-align-content: $align; + -moz-align-content: $align; + -ms-align-content: $align; + align-content: $align; + } + + // Cross-axis Alignment + // - applies to: flex containers + // flex-start | flex-end | center | baseline | stretch + @mixin align-items($align) { + -webkit-align-items: $align; + -moz-align-items: $align; + -ms-align-items: $align; + align-items: $align; + } + + // Cross-axis Alignment + // - applies to: flex items + // auto | flex-start | flex-end | center | baseline | stretch + @mixin align-self($align) { + -webkit-align-self: $align; + -moz-align-self: $align; + -ms-align-self: $align; + align-self: $align; + } diff --git a/sass/modules/_icon.scss b/sass/modules/_icon.scss new file mode 100644 index 0000000..e69de29 diff --git a/sass/modules/_media.scss b/sass/modules/_media.scss new file mode 100644 index 0000000..f539fc3 --- /dev/null +++ b/sass/modules/_media.scss @@ -0,0 +1,50 @@ +@import "modules/_colors"; + +$phone2: "(min-width: 100px) and (max-width: 299px)"; +$phone: "(min-width: 300px) and (max-width: 599px)"; +$smPhone: "(min-width: 600px) and (max-width: 767px)"; +$tablet: "(min-width: 768px) and (max-width: 1110px)"; +$desktop: "(min-width: 1111px) and (max-width: 1600px)"; +$maxDesktop: "(min-width: 1601px)"; + +@mixin phone2($width) { + @media #{$phone} { + @content; + width: $width; + } +} + +@mixin phone($width) { + @media #{$phone} { + @content; + width: $width; + } +} + +@mixin smPhone($width) { + @media #{$smPhone} { + @content; + width: $width; + } +} + +@mixin tablet($width) { + @media #{$tablet} { + @content; + width: $width; + } +} + +@mixin desktop($width) { + @media #{$desktop} { + @content; + width: $width; + } +} + +@mixin maxDesktop($width) { + @media #{$maxDesktop} { + @content; + width: $width; + } +} diff --git a/sass/partials/_base.scss b/sass/partials/_base.scss new file mode 100644 index 0000000..c0ce261 --- /dev/null +++ b/sass/partials/_base.scss @@ -0,0 +1,20 @@ +@import "modules/_colors"; + +* { + box-sizing: border-box; + margin: 0; + padding: 0; +} + +body { + // background: map-get($mapOfColors, fontAdditional); + font-family: 'Open Sans', sans-serif; + text-rendering: optimizeSpeed; + image-rendering: pixelated; +} + +h2 { + color: map-get($mapOfPrimarColors, fontMain); + font-kerning: auto; + font-weight: 800; +} diff --git a/sass/partials/_footer.scss b/sass/partials/_footer.scss new file mode 100644 index 0000000..9186584 --- /dev/null +++ b/sass/partials/_footer.scss @@ -0,0 +1,2 @@ +footer { +} diff --git a/sass/partials/_header.scss b/sass/partials/_header.scss new file mode 100644 index 0000000..e69de29 diff --git a/webpack.config.js b/webpack.config.js new file mode 100644 index 0000000..405335d --- /dev/null +++ b/webpack.config.js @@ -0,0 +1,15 @@ +var HtmlWebpackPlugin = require('html-webpack-plugin'); + +module.exports = { + entry: './js/app.js', + output: { + // path: 'dist' + filename: './dist/bundle.js' + }, + plugins: [ + new HtmlWebpackPlugin({ + title: 'fronted_recruitment', + template: 'my-index.html', //load + }) + ] +};