czwartek, 3 września 2015

ES6 - arrows

The biggest difference between arrow and function is this value. Function uses its own this value, but arrow uses this value of the enclosing context.

Arrows are always anonymous functions!

Their syntax is slightly different than function expression:
(args) => { statements }


There could be few variations from this main version:
(arg1, arg2, argN) => { statements }
arg1 => { statements }
() => { statements }

(arg1, arg2, argN) => { statements }
(arg1, arg2, argN) => expression
(arg1, arg2, argN) => ({ prop: val })


It means - prentheses are optional. Mostly if there is only one argument, or only one value to return, this could be simplified.
But there is a catch:
(arg1, arg2, argN) => expression

but
(arg1, arg2, argN) => { return expression }


Example:
(arg1, arg2) => arg1 * arg2

(arg1, arg2) => { return arg1 * arg2 }


Both return the same, but we can write it in different way.

czwartek, 6 sierpnia 2015

CSS - setting elements inline - part 1

I bet that every frontend developer met the problem with setting many elements in line. As lately I had to solve this problem during recruitment processes I decided to share some thoughts and solution.

Example structure:
<div class="container">
    <div class="color green"></div>
    <div class="color yellow"></div>
    <div class="color blue"></div>
    <div class="color red"></div>
</div>


Let's color elements to see them clearly:
.color {
    width: 25%;
    display: inline-block;
    height: 100px;
    padding: 0;
    margin: 0;
} .green {
    background-color: green;
}
.yellow {
    background-color: yellow;
}
.blue {
    background-color: blue;
}
.red {
    background-color: red;
}


So we have a container, which contains few elements, and looks like on this image:



So this is definitely not the goal. The inner elements should be in line and without gaps between. Why are there those gaps? The answer is display: inline-block;. Displaying inline takes all white spaces as a spaces... and spaces have width, so last element is going down, as there is no space for it. So how to remove gaps between elements?

change boxing-size:
div {
    boxing-size: border-box;
}

środa, 5 sierpnia 2015

Magento beginner - set up category and product

After installation of Magento I faced a new problem. The menu in the beginning wasn't much helpful. So I'm creating short post about first steps with Magento

After logging in to admin area Dashbord is first visible page. If shop is live and people are buying stuff there are many useful information.

Before you start changing anything and ONLY if your shop is not live (online) go to System -> Cache Management. Click "Select All", from Action choose "Disable" and click "Submit". This will disable cache on your Magento. So all changes should be visible immediately. If you are working on live system, remember to refresh proper cache (NOT ALL) after making changes.

To manage categories choose Catalog -> Categories -> Manage Categories. In the left column you can see already existing categories. "Default category" is crested by default. For your needs create new Root Category by clicking button "Add Root Category". This root category would be a container for all category tree. It won't be displayed. In the first tab - "General information" fill name, set "Is Active" and "Include in Navigation Menu" to "Yes" and add all information you know would be needed. Click "Save Category" to save category record.

Then, click in the name your just created root category in the left column, to set a context, and then click button "Add Subcategory". It will show you the same form. Just be sure that on "General information" tab you filled "Name" and set "Is Active" and "Include in Navigation Menu" to "Yes".

So you should now to see our new subcategory in the menu. But if you click it it shows the page with information: "There are no products matching the selection.". So let's add some products then. In admin choose Catalog -> Manage Products. Click button "Add Product" and set product attributes (or use defaults). Click "Continue". Now you can see first tab. Obligatory information are mark with asterisk. Remember to set "Status" to "Enabled". Fill information in "General" and "Prices" tabs. Then click to "Inventory" tab. There set "Qty" to any number greater than 0 and "Stock Availability" to "In Stock". Next click to "Categories" tab to bound product with category.

Now you have to bound your shop name with category. In admin click System -> Manage Stores and for your Store Name (default is "Main Website Store") choose root category you just created.

Still in admin click in System -> Index Management and reindex whatever needs it. From now all your changes should be visible.

poniedziałek, 6 lipca 2015

Codility Lesson 1 - JavaScript solutions

Some time ago I started to play with Codility challenges. As JavaScript solutions are not so popular I decided to create a GitHub repository with my solutions.

Lesson 1 - Time complexity is already merged to the repo. It contains all three tasks: FrogJmp, PermMissingElem and TapeEquilibrium.

wtorek, 16 czerwca 2015

Arrays in JavaScript - how to create an array and fill it with numbers

Most common way (and fastest if array would be big, please check jsperf.com/array-magic-vs-for):
var arr = [];
var max = 100;
for (var i = 0; i < max; i++) {
  arr.push(i);
}

But if array wouldn't be so big, we can use:
var max = 7;
var arr = Array.apply(null, {length: max}).map(Number.call, Number);

Of course very often we need some specific values. Fortunately map() gives us many options:
var max = 9;
var arr1 = Array.
   apply(null, {length: max}).
   map(function(item, index){ return ++index;});
var arr2 = Array.
   apply(null, {length: max}).
   map(Function.call, Math.random);