'Add animation to alternating horizontal panes [duplicate]

I have a working snippet for two horizontal panes that alternate when clicking on the splitter. I need to add a simple animation to the splitter so that it moves from on side to another in half a second. How can I achieve this?

function changeThis()
{
var getF = document.getElementById("first");
    var getS = document.getElementById("second");
    if(getF.style.width == "0%") {
    getF.style.width="100%";
    getS.style.width="0%";
    } else {
    getF.style.width="0%";
    getS.style.width="100%";
    }
   
}
.splitter {
    width: 100%;
    height: 100px;
    display: flex;
}

#separator {
    cursor: pointer;
    background-color: #aaa;
    background-repeat: no-repeat;
    background-position: center;
    width: 10px;
    height: 100%;

    /* Prevent the browser's built-in drag from interfering */
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

#first {
    background-color: #dde;
    width: 100%;
    height: 100%;
    min-width: 10px;
}

#second {
    background-color: #eee;
    width: 0%;
    height: 100%;
    min-width: 10px;
}
<div class="splitter">
    <div id="first"></div>
    <div id="separator" onclick="changeThis()"></div>
    <div id="second" ></div>
</div>


Solution 1:[1]

You can add css transition

function changeThis()
{
var getF = document.getElementById("first");
    var getS = document.getElementById("second");
    if(getF.style.width == "0%") {
    getF.style.width="100%";
    getS.style.width="0%";
    } else {
    getF.style.width="0%";
    getS.style.width="100%";
    }
   
}
.splitter {
    width: 100%;
    height: 100px;
    display: flex;
}

#separator {
    cursor: pointer;
    background-color: #aaa;
    background-repeat: no-repeat;
    background-position: center;
    width: 10px;
    height: 100%;

    /* Prevent the browser's built-in drag from interfering */
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

#first {
    background-color: #dde;
    width: 100%;
    height: 100%;
    min-width: 10px;
    
    /** add animation */
    transition: .5s width linear;
}

#second {
    background-color: #eee;
    width: 0%;
    height: 100%;
    min-width: 10px;
    
     /** add animation */
    transition: .5s width linear;
}
<div class="splitter">
    <div id="first"></div>
    <div id="separator" onclick="changeThis()"></div>
    <div id="second" ></div>
</div>

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1 Юрий Копоть