diff --git a/маджонг_2.0.0.html b/маджонг_2.0.0.html
index f2e54b1..dc61f61 100644
--- a/маджонг_2.0.0.html
+++ b/маджонг_2.0.0.html
@@ -180,7 +180,7 @@ var murom = муром;
[
"игра.реакции",
-"// // // //

function ПоказатьСферу(мир)
{
    this.исполнить = function()
    {
        var форма = new THREE.SphereBufferGeometry(0.1, 32, 32);
        var сфера = new THREE.Mesh(форма);
        var корень = мир.состояние["корень"];
        корень.add(сфера);
    };
}

// // // //

function ПодготовитьСцену(мир)
{
    this.исполнить = function()
    {
        мир.состояние["камера"].position.z = 10;
        // Создаём источник света.
        var свет = new THREE.DirectionalLight(0xffffff, 1);
        свет.position.set(-0.5, 0.5, 1).normalize();
        var сцена = мир.состояние["сцена"];
        сцена.add(свет);
        // Создаём корень.
        var корень = new THREE.Group();
        сцена.add(корень);
        мир.состояние["корень"] = корень;
    };
}

// // // //

function ВыбратьПервуюТему(мир)
{
    this.исполнить = function()
    {
        var темы = мир.состояние["темы"];
        темы.выбрать(0);
    };
}

// // // //

function ДобавитьТемыВстроенные(мир)
{
    this.исполнить = function()
    {
        var темы = мир.состояние["темы"];
        var т64 = МОД.модуль("темы встроенные").code64;
        eval(муром.atob(т64));
        темы.добавить(МР());
    };
}

// // // //

function СоздатьЗавТем(мир)
{
    this.исполнить = function()
    {
        мир.состояние["темы"] = new Набор();
    };
}

// // // //

function ВыбратьПервуюРаскладку(мир)
{
    this.исполнить = function()
    {
        var раскладки = мир.состояние["раскладки"];
        раскладки.выбрать(0);
    };
}

// // // //

function СинхритьСписокРаскладокСЗавом(мир)
{
    this.исполнить = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var self = this;
        раскладки.изменилиСписок.подписать(function() {
            self.обновитьСписок();
        });
        раскладки.изменилиВыбор.подписать(function() {
            self.обновитьВыбор();
        });
    };
    
    this.обновитьСписок = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var список = мир.состояние["список раскладок"];
        var именаОписания = this.именаОписанияРаскладок(раскладки.список);
        список.задать(именаОписания);
    };
    
    this.обновитьВыбор = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var список = мир.состояние["список раскладок"];
        список.выбрать(раскладки.выбор);
    };
    
    this.именаОписанияРаскладок = function()
    {
        var раскладки = мир.состояние["раскладки"].список;
        var список = [];
        for (var номер in раскладки)
        {
            var р = раскладки[номер];
            список.push([р.имя, р.описание]);
        }
        return список;
    };
}

// // // //

function ДобавитьОтладочныеРаскладки(мир)
{
    this.исполнить = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var р64 = МОД.модуль("отладочные раскладки").code64;
        eval(муром.atob(р64));
        раскладки.добавить(МР());
    };
}

// // // //

function ДобавитьВстроенныеРаскладки(мир)
{
    this.исполнить = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var р64 = МОД.модуль("встроенные раскладки").code64;
        eval(муром.atob(р64));
        раскладки.добавить(МР());
    };
}

// // // //

function СоздатьСписокРаскладок(мир)
{
    this.исполнить = function()
    {
        мир.состояние["список раскладок"] = new Список("раскладки-раскладки");
    };
}

// // // //

function СоздатьЗавРаскладок(мир)
{
    this.исполнить = function()
    {
        мир.состояние["раскладки"] = new Набор();
    };
}

// // // //

function ПереключитьЭкранРаскладок(мир)
{
    this.исполнить = function()
    {
        $("#раскладки").fadeToggle("fast");
    };
}

// // // //

function ДобавитьЭкранРаскладок(мир)
{
    this.исполнить = function()
    {
        var html =
`
<div id="раскладки-раскладки" class="uk-child-width-1-1 uk-grid-small uk-grid-match" uk-grid></div>
<a id="раскладки-скрыть" class="uk-icon-button" uk-icon="close"></a>
`;
        var css =
`
#раскладки-скрыть
{
    position: absolute;
    bottom: 1em;
    left: 1em;
}
#раскладки-раскладки
{
    position: absolute;
    right: 0;
    top: 1em;
    bottom: 1em;
    padding: 1em;
    width: 20em;
    overflow-y: scroll;
}
`;
        добавитьЭкран("раскладки", html, css);
        $("#раскладки")
            .hide()
            .css("background", "linear-gradient(270deg, white, white 20em, rgba(255,255,255,0)")
            ;
        $("#раскладки-скрыть").click(function(e) {
            мир.события["переключить раскладки"].уведомить();
        });
    };
}

// // // //

function ДобавитьЭкранОсновной(мир)
{
    this.исполнить = function()
    {
        var html =
`
<a id="основной-раскладки" class="uk-icon-button" uk-icon="thumbnails" uk-tooltip="title: Раскладки; delay: 500"></a>
`;
        var css =
`
#основной-раскладки
{
    position: absolute;
    bottom: 1em;
    left: 1em;
}
`;
        добавитьЭкран("основной", html, css);
        $("#основной-раскладки").click(function(e) {
            мир.события["переключить раскладки"].уведомить();
        });
    };
}

// // // //

function ВывестиПростоТекст(мир)
{
    this.исполнить = function()
    {
        console.log("Просто текст", new Date());
    };
}

// // // //

function УлавливатьВыборСфер(мир)
{
    добавитьСловарь(мир.состояние, {
        "номер выбранной сферы": null,
        "номера выбранных сфер": [],
    });
    
    this.исполнить = function()
    {
        мир.состояние["улавливатель"] = new THREE.Raycaster();
        this.отслеживатьНастолки();
        this.отслеживатьМобилки();
    };
    this.отслеживатьНастолки = function()
    {
        var self = this;
        window.addEventListener(
            "click",
            function(событие) {
                var позиция = new THREE.Vector2();
                позиция.x = (событие.clientX / window.innerWidth) * 2 - 1;
                позиция.y = - (событие.clientY / window.innerHeight) * 2 + 1;
                self.выбрать(позиция);
            }
        );
    };
    this.отслеживатьМобилки = function()
    {
        var self = this;
        window.addEventListener(
            "touchstart",
            function(событие) {
                var позиция = new THREE.Vector2();
                позиция.x = (событие.touches[0].clientX / window.innerWidth) * 2 - 1;
                позиция.y = - (событие.touches[0].clientY / window.innerHeight) * 2 + 1;
                self.выбрать(позиция);
            }
        );
        // Исправляем улавливание нажатий на iOS.
        // https://stackoverflow.com/a/31459240/3404710
        var отрисовщик = мир.состояние["отрисовщик"];
        отрисовщик.domElement.style.cursor = "pointer";
    };
    this.выбрать = function(позиция)
    {
        var улавливатель = мир.состояние["улавливатель"];
        var камера = мир.состояние["камера"];
        var корень = мир.состояние["корень"];
        улавливатель.setFromCamera(позиция, камера);
        var пересечения = улавливатель.intersectObjects(корень.children);
        if (пересечения.length)
        {
            var сфера = пересечения[0].object;
            var номер = this.номерСферы(сфера.id);
            if (номер)
            {
                мир.состояние["номер выбранной сферы"] = номер;
                мир.состояние["номера выбранных сфер"].push(номер);
                мир.события["выбор"].уведомить();
            }
        }
    };
    this.номерСферы = function(id)
    {
        var сферы = мир.состояние["сферы"];
        for (var номер in сферы)
        {
            var сфера = сферы[номер];
            if (сфера.id == id)
            {
                return номер;
            }
        }
        
        return null;
    };
}
",
+"// // // //

function ПоказатьСферу(мир)
{
    this.исполнить = function()
    {
        var форма = new THREE.SphereBufferGeometry(0.05, 32, 32);
        var сфера = new THREE.Mesh(форма);
        var корень = мир.состояние["корень"];
        корень.add(сфера);
    };
}

// // // //

function ПодготовитьСцену(мир)
{
    this.исполнить = function()
    {
        мир.состояние["камера"].position.z = 10;
        // Создаём источник света.
        var свет = new THREE.DirectionalLight(0xffffff, 1);
        свет.position.set(-0.5, 0.5, 1).normalize();
        var сцена = мир.состояние["сцена"];
        сцена.add(свет);
        // Создаём корень.
        var корень = new THREE.Group();
        сцена.add(корень);
        мир.состояние["корень"] = корень;
    };
}

// // // //

function ВыбратьПервуюТему(мир)
{
    this.исполнить = function()
    {
        var темы = мир.состояние["темы"];
        темы.выбрать(0);
    };
}

// // // //

function ДобавитьТемыВстроенные(мир)
{
    this.исполнить = function()
    {
        var темы = мир.состояние["темы"];
        var т64 = МОД.модуль("темы встроенные").code64;
        eval(муром.atob(т64));
        темы.добавить(МР());
    };
}

// // // //

function СоздатьЗавТем(мир)
{
    this.исполнить = function()
    {
        мир.состояние["темы"] = new Набор();
    };
}

// // // //

function ВыбратьПервуюРаскладку(мир)
{
    this.исполнить = function()
    {
        var раскладки = мир.состояние["раскладки"];
        раскладки.выбрать(0);
    };
}

// // // //

function СинхритьСписокРаскладокСЗавом(мир)
{
    this.исполнить = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var self = this;
        раскладки.изменилиСписок.подписать(function() {
            self.обновитьСписок();
        });
        раскладки.изменилиВыбор.подписать(function() {
            self.обновитьВыбор();
        });
    };
    
    this.обновитьСписок = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var список = мир.состояние["список раскладок"];
        var именаОписания = this.именаОписанияРаскладок(раскладки.список);
        список.задать(именаОписания);
    };
    
    this.обновитьВыбор = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var список = мир.состояние["список раскладок"];
        список.выбрать(раскладки.выбор);
    };
    
    this.именаОписанияРаскладок = function()
    {
        var раскладки = мир.состояние["раскладки"].список;
        var список = [];
        for (var номер in раскладки)
        {
            var р = раскладки[номер];
            список.push([р.имя, р.описание]);
        }
        return список;
    };
}

// // // //

function ДобавитьОтладочныеРаскладки(мир)
{
    this.исполнить = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var р64 = МОД.модуль("отладочные раскладки").code64;
        eval(муром.atob(р64));
        раскладки.добавить(МР());
    };
}

// // // //

function ДобавитьВстроенныеРаскладки(мир)
{
    this.исполнить = function()
    {
        var раскладки = мир.состояние["раскладки"];
        var р64 = МОД.модуль("встроенные раскладки").code64;
        eval(муром.atob(р64));
        раскладки.добавить(МР());
    };
}

// // // //

function СоздатьСписокРаскладок(мир)
{
    this.исполнить = function()
    {
        мир.состояние["список раскладок"] = new Список("раскладки-раскладки");
    };
}

// // // //

function СоздатьЗавРаскладок(мир)
{
    this.исполнить = function()
    {
        мир.состояние["раскладки"] = new Набор();
    };
}

// // // //

function ПереключитьЭкранРаскладок(мир)
{
    this.исполнить = function()
    {
        $("#раскладки").fadeToggle("fast");
    };
}

// // // //

function ДобавитьЭкранРаскладок(мир)
{
    this.исполнить = function()
    {
        var html =
`
<div id="раскладки-раскладки" class="uk-child-width-1-1 uk-grid-small uk-grid-match" uk-grid></div>
<a id="раскладки-скрыть" class="uk-icon-button" uk-icon="close"></a>
`;
        var css =
`
#раскладки-скрыть
{
    position: absolute;
    bottom: 1em;
    left: 1em;
}
#раскладки-раскладки
{
    position: absolute;
    right: 0;
    top: 1em;
    bottom: 1em;
    padding: 1em;
    width: 20em;
    overflow-y: scroll;
}
`;
        добавитьЭкран("раскладки", html, css);
        $("#раскладки")
            .hide()
            .css("background", "linear-gradient(270deg, white, white 20em, rgba(255,255,255,0)")
            ;
        $("#раскладки-скрыть").click(function(e) {
            мир.события["переключить раскладки"].уведомить();
        });
    };
}

// // // //

function ДобавитьЭкранОсновной(мир)
{
    this.исполнить = function()
    {
        var html =
`
<a id="основной-раскладки" class="uk-icon-button" uk-icon="thumbnails" uk-tooltip="title: Раскладки; delay: 500"></a>
`;
        var css =
`
#основной-раскладки
{
    position: absolute;
    bottom: 1em;
    left: 1em;
}
`;
        добавитьЭкран("основной", html, css);
        $("#основной-раскладки").click(function(e) {
            мир.события["переключить раскладки"].уведомить();
        });
    };
}

// // // //

function ВывестиПростоТекст(мир)
{
    this.исполнить = function()
    {
        console.log("Просто текст", new Date());
    };
}

// // // //

function УлавливатьВыборСфер(мир)
{
    добавитьСловарь(мир.состояние, {
        "номер выбранной сферы": null,
        "номера выбранных сфер": [],
    });
    
    this.исполнить = function()
    {
        мир.состояние["улавливатель"] = new THREE.Raycaster();
        this.отслеживатьНастолки();
        this.отслеживатьМобилки();
    };
    this.отслеживатьНастолки = function()
    {
        var self = this;
        window.addEventListener(
            "click",
            function(событие) {
                var позиция = new THREE.Vector2();
                позиция.x = (событие.clientX / window.innerWidth) * 2 - 1;
                позиция.y = - (событие.clientY / window.innerHeight) * 2 + 1;
                self.выбрать(позиция);
            }
        );
    };
    this.отслеживатьМобилки = function()
    {
        var self = this;
        window.addEventListener(
            "touchstart",
            function(событие) {
                var позиция = new THREE.Vector2();
                позиция.x = (событие.touches[0].clientX / window.innerWidth) * 2 - 1;
                позиция.y = - (событие.touches[0].clientY / window.innerHeight) * 2 + 1;
                self.выбрать(позиция);
            }
        );
        // Исправляем улавливание нажатий на iOS.
        // https://stackoverflow.com/a/31459240/3404710
        var отрисовщик = мир.состояние["отрисовщик"];
        отрисовщик.domElement.style.cursor = "pointer";
    };
    this.выбрать = function(позиция)
    {
        var улавливатель = мир.состояние["улавливатель"];
        var камера = мир.состояние["камера"];
        var корень = мир.состояние["корень"];
        улавливатель.setFromCamera(позиция, камера);
        var пересечения = улавливатель.intersectObjects(корень.children);
        if (пересечения.length)
        {
            var сфера = пересечения[0].object;
            var номер = this.номерСферы(сфера.id);
            if (номер)
            {
                мир.состояние["номер выбранной сферы"] = номер;
                мир.состояние["номера выбранных сфер"].push(номер);
                мир.события["выбор"].уведомить();
            }
        }
    };
    this.номерСферы = function(id)
    {
        var сферы = мир.состояние["сферы"];
        for (var номер in сферы)
        {
            var сфера = сферы[номер];
            if (сфера.id == id)
            {
                return номер;
            }
        }
        
        return null;
    };
}
",
{"status":true}
],
@@ -206,16 +206,23 @@ var murom = муром;
],
+[
+"Image_Upload_Preview",
+"",
+{"status":false}
+],
+
+
[
"темы.реакции",
-"function ДобавитьСвоё(мир)
{
    this.исполнить = function()
    {
        var html =
`
<div class="uk-panel uk-panel-scrollable">
<div id="parent" class="uk-container uk-container-center uk-background-muted">
    <form>
        <input type="file" multiple accepts="image/*" id="input"/>
    </form>
</div>
</div>
`;
        var контейнер = document.getElementById("контейнер-для-тестов");
        контейнер.innerHTML += html;
        var ввод = document.getElementById("input");
        var self = this;
        ввод.onchange = function() { self.загрузить(ввод.files); };
    };
    this.загрузить = function(файлы)
    {
        console.log("загрузить файлов:", файлы);
        for (var номер in файлы)
        {
            var файл = файлы[номер];
            this.загрузитьФайл(файл);
        }
    };
    this.загрузитьФайл = function(файл)
    {
        var чтец = new FileReader();
        чтец.onload = function(событие)
        {
            var родитель = document.getElementById("parent");
            var img = document.createElement("img");
            img.classList.add("uk-margin");
            img.src = событие.target.result;
            родитель.appendChild(img);
        };
        чтец.readAsDataURL(файл);
    };
}

// // // //

function ДобавитьПример(мир)
{
    this.исполнить = function()
    {
        var html =
`
<div class="uk-container uk-container-center uk-text-center">
  <div class="uk-thumbnail uk-margin-top">
    <img class="uk-margin" src="abc">
    <form>
      <label class="uk-button uk-button-primary">
        <span>Select Image</span>
        <input type="file" accepts="image/*" id="file_input_demo" class="uk-invisible uk-position-absolute" />
      </label>
    </form>
  </div>
</div>
`;

        var контейнер = document.getElementById("контейнер-для-тестов");
        контейнер.innerHTML += html;
        

    //new Image_Upload_Preview( document.getElementById('file_input_demo'), $('img') );
    //new Image_Upload_Preview( $('input[type=file]'), $('img') );
    new Image_Upload_Preview( $('#file_input_demo'), $('img') );
    };
    
}

// // // //

function ДобавитьПанельЗагрузки(мир)
{
    this.исполнить = function()
    {
        var html =
`
<div class="js-upload uk-placeholder uk-text-center">
    <span uk-icon="icon: cloud-upload"></span>
    <span class="uk-text-middle">Attach binaries by dropping them here or</span>
    <div uk-form-custom>
        <input type="file" multiple id="loader">
        <span class="uk-link">selecting them</span>
    </div>
</div>
<progress id="js-progressbar" class="uk-progress" value="0" max="100" hidden></progress>
`;
        var контейнер = document.getElementById("контейнер-для-тестов");
        контейнер.innerHTML += html;
        
        function вывестиИзображения()
        {
            console.log("НАДО вывести изображения");
            var loader = document.getElementById("loader");
            console.log("Файлы:", loader.files);
        }
        
    var bar = document.getElementById('js-progressbar');
    UIkit.upload('.js-upload', {
        url: '',
        multiple: true,

        beforeSend: function () {
            console.log('beforeSend', arguments);
        },
        beforeAll: function () {
            console.log('beforeAll', arguments);
        },
        load: function () {
            console.log('load', arguments);
        },
        error: function () {
            console.log('error', arguments);
        },
        complete: function () {
            console.log('complete', arguments);
        },

        loadStart: function (e) {
            console.log('loadStart', arguments);

            bar.removeAttribute('hidden');
            bar.max = e.total;
            bar.value = e.loaded;
        },

        progress: function (e) {
            console.log('progress', arguments);

            bar.max = e.total;
            bar.value = e.loaded;
        },

        loadEnd: function (e) {
            console.log('loadEnd', arguments);
            console.log('value', e.loaded);

            bar.max = e.total;
            bar.value = e.loaded;
        },

        completeAll: function () {
            console.log('completeAll', arguments);

            setTimeout(function () {
                bar.setAttribute('hidden', 'hidden');
            }, 1000);

            console.log('Upload Completed');
            вывестиИзображения();
            
        }
    });

    };
}

// // // //

function ДобавитьКонтейнерДляТестов(мир)
{
    this.исполнить = function()
    {
        добавитьЭкран("контейнер-для-тестов", "", "");
    }
}

// Класс для тестов.
var Image_Upload_Preview = function ( file_input, image_element ){

    /**
     * Checks for supported features
     * @returns {boolean}
     */
    this.is_supported = function(){

        if( ! FileReader instanceof Function ){
            console.error(':( Your browser noes not support the FileReader...');
            return false;
        }
    };


    /**
     * Checks the inputs provided
     * @returns {boolean}
     */
    this.validate_inputs = function(){

        /**
         * Fail if:
         * 1. Not a HTML Input Element
         * 2. Not a File Input Element
         *
         */
        if( ! $(file_input).get(0) instanceof HTMLInputElement || $(file_input).first().attr('type') != 'file' ){
            console.error( 'Invalid Element provided...' );
            return false;
        }

        /**
         * Fail if:
         * 1. Image Element provided is invalid
         */
        if( ! $(image_element).get(0) instanceof HTMLImageElement ){
            console.error( 'Invalid Image Element provided...' );
            return false;
        }

    };


    /**
     * Only proceed if all the preliminary checks have passed
     */
    if( this.is_supported() || this.validate_inputs() ){
        return false;
    }


    /**
     * Set the file input to only accept images
     */
    $(file_input).attr('accept','image/*');


    $(file_input).change(function(){

        /**
         * Fail if:
         * 1. 'files' data is non existent
         * 2. 'files' data has no data in it
         */
        if( !this.files || this.files.length < 1 ){
            console.error('No files data exists for this file input...');
            return false;
        }


        var file_reader = new FileReader();

        file_reader.onload = function( reader_result ) {

            var image_result = null;

            /**
             * Legacy lookup for the result
             */
            image_result = reader_result.target && reader_result.target.result ? reader_result.target.result : image_result ;
            image_result = !image_result && reader_result.srcElement && reader_result.srcElement.result ? reader_result.srcElement.result : image_result ;

            $( image_element ).attr( 'src', image_result );
        };

        file_reader.readAsDataURL( this.files[0] );
    });

}",
+"
// // // //

function УстановитьЗагрузкуИзображений(мир)
{
    this.исполнить = function()
    {
        var ввод = document.getElementById("темы-загрузить-изображения");
        var self = this;
        ввод.onchange = function() {
            self.загрузить(ввод.files);
        };
    };
    this.свободныеПозиции = function()
    {
        var изо = мир.состояние["изображения"];
        var позиции = [];
        for (var номер = 0; номер < 42; ++номер)
        {
            if (изо[номер].src)
            {
                // How to check empty/undefined/null string in JavaScript?
                // https://stackoverflow.com/a/154068/3404710
            }
            else
            {
                позиции.push(номер);
            }
        }
        
        return позиции;
    };
    this.загрузить = function(файлы)
    {
        var позиции = this.свободныеПозиции();
        for (var номер = 0; номер < файлы.length; ++номер)
        {
            // Не загружаем при отсутствии свободных позиций.
            if (!позиции.length)
            {
                console.warn("Не хватает доступных позиций для загрузки изображений");
                return;
            }
            var файл = файлы[номер];
            var позиция = позиции.shift();
            this.загрузитьФайл(файл, позиция);
        }
    };
    this.загрузитьФайл = function(файл, позиция)
    {
        var чтец = new FileReader();
        var self = this;
        чтец.onload = function(событие)
        {
            var изо = мир.состояние["изображения"];
            var img = изо[позиция];
            img.src = событие.target.result;
        };
        чтец.readAsDataURL(файл);
    };
}

// // // //

function ПодготовитьПозицииИзображений(мир)
{
    this.исполнить = function()
    {
        var изо = {};
        var img = $("img");
        for (var номер = 0; номер < 42; ++номер)
        {
            изо[номер] = img[номер];
        }
        мир.состояние["изображения"] = изо;
    };
}

// // // //

function ДобавитьСетку(мир)
{
    this.исполнить = function()
    {
        function элемент(номер)
        {
            var html =
                `
<div>
    <div class="uk-card uk-card-default uk-card-small">
        <div class="uk-card-header uk-text-center">
                `
                + номер +
                `
        </div>
        <div class="uk-card-body">
            <img class="uk-height-small uk-width-small uk-align-center">
        </div>
    </div>
</div>
                `;
            return html;
        }
        var элементы = "";
        for (var номер = 1; номер <= 42; ++номер)
        {
            var эл = элемент(номер);
            элементы += эл;
        }
        var html =
            `
<div class="uk-grid-match uk-grid-small uk-padding-small uk-child-width-1-1 uk-child-width-1-2@m uk-child-width-1-3@l uk-child-width-1-4@xl uk-child-width-1-5@xxl" uk-grid uk-height-match="target: > div > .uk-card">
            `
            + элементы +
            `
</div>
            `;
        $("#темы-область-левая")
            .append(html)
            .css("overflow-y", "scroll")
            ;
    }
}

// // // //

function ДобавитьЭкранТем(мир)
{
    this.исполнить = function()
    {
        var html =
            `
<div id="темы-область-левая">
</div>

<div id="темы-область-центральная-верх">
    <div uk-form-custom>
        <a class="uk-icon-button uk-margin-small-bottom" uk-icon="upload" uk-tooltip="title: Загрузить изображения; delay: 500"">
            <input id="темы-загрузить-изображения" type="file" multiple accepts="image/*">
        </a>
    </div>
</div>    
    
    
    
</div>

<div id="темы-область-центральная-низ">
</div>

<div id="темы-область-правая-верх">
    <iframe id="встройка">
        <p>ОШИБКА Ваш веб-браузер не поддерживает iframe</p>
        <p>ERROR Your web browser does not support iframes</p>
    </iframe>
</div>

<div id="темы-область-правая-низ">
</div>
            `;
        var css =
            `
#темы-область-левая
{
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    width: calc(50% - 2em);
}

#темы-область-центральная-верх
{
    position: fixed;
    top: 0;
    height: 50%;
    left: 50%;
    width: 4em;
    transform: translateX(-2em);
    text-align: center;
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    padding-top: 1em;
}

#темы-область-центральная-низ
{
    position: fixed;
    bottom: 0;
    height: 50%;
    left: 50%;
    width: 4em;
    transform: translateX(-2em);
    text-align: center;
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    padding-top: 1em;
}

#темы-область-правая-верх
{
    position: fixed;
    top: 0;
    height: 50%;
    right: 0;
    width: calc(50% - 2em - 1px);
}

#темы-область-правая-низ
{
    position: fixed;
    bottom: 0;
    height: 50%;
    right: 0;
    width: calc(50% - 2em - 1px);
}
            `;
        добавитьЭкран("темы", html, css);
    }
}

// // // //

function ДобавитьСвоё(мир)
{
    this.исполнить = function()
    {
        var html =
`
<div class="uk-panel uk-panel-scrollable">
<div id="parent" class="uk-container uk-container-center uk-background-muted">
    <form>
        <input type="file" multiple accepts="image/*" id="input"/>
    </form>
</div>
</div>
`;
        var контейнер = document.getElementById("контейнер-для-тестов");
        контейнер.innerHTML += html;
        var ввод = document.getElementById("input");
        var self = this;
        ввод.onchange = function() { self.загрузить(ввод.files); };
    };
    this.загрузить = function(файлы)
    {
        console.log("загрузить файлов:", файлы);
        for (var номер in файлы)
        {
            var файл = файлы[номер];
            this.загрузитьФайл(файл);
        }
    };
    this.загрузитьФайл = function(файл)
    {
        var чтец = new FileReader();
        чтец.onload = function(событие)
        {
            var родитель = document.getElementById("parent");
            var img = document.createElement("img");
            img.classList.add("uk-margin");
            img.src = событие.target.result;
            родитель.appendChild(img);
        };
        чтец.readAsDataURL(файл);
    };
}

// // // //

function ДобавитьПример(мир)
{
    this.исполнить = function()
    {
        var html =
`
<div class="uk-container uk-container-center uk-text-center">
  <div class="uk-thumbnail uk-margin-top">
    <img class="uk-margin" src="abc">
    <form>
      <label class="uk-button uk-button-primary">
        <span>Select Image</span>
        <input type="file" accepts="image/*" id="file_input_demo" class="uk-invisible uk-position-absolute" />
      </label>
    </form>
  </div>
</div>
`;

        var контейнер = document.getElementById("контейнер-для-тестов");
        контейнер.innerHTML += html;
        

    //new Image_Upload_Preview( document.getElementById('file_input_demo'), $('img') );
    //new Image_Upload_Preview( $('input[type=file]'), $('img') );
    new Image_Upload_Preview( $('#file_input_demo'), $('img') );
    };
    
}

// // // //

function ДобавитьПанельЗагрузки(мир)
{
    this.исполнить = function()
    {
        var html =
`
<div class="js-upload uk-placeholder uk-text-center">
    <span uk-icon="icon: cloud-upload"></span>
    <span class="uk-text-middle">Attach binaries by dropping them here or</span>
    <div uk-form-custom>
        <input type="file" multiple id="loader">
        <span class="uk-link">selecting them</span>
    </div>
</div>
<progress id="js-progressbar" class="uk-progress" value="0" max="100" hidden></progress>
`;
        var контейнер = document.getElementById("контейнер-для-тестов");
        контейнер.innerHTML += html;
        
        function вывестиИзображения()
        {
            console.log("НАДО вывести изображения");
            var loader = document.getElementById("loader");
            console.log("Файлы:", loader.files);
        }
        
    var bar = document.getElementById('js-progressbar');
    UIkit.upload('.js-upload', {
        url: '',
        multiple: true,

        beforeSend: function () {
            console.log('beforeSend', arguments);
        },
        beforeAll: function () {
            console.log('beforeAll', arguments);
        },
        load: function () {
            console.log('load', arguments);
        },
        error: function () {
            console.log('error', arguments);
        },
        complete: function () {
            console.log('complete', arguments);
        },

        loadStart: function (e) {
            console.log('loadStart', arguments);

            bar.removeAttribute('hidden');
            bar.max = e.total;
            bar.value = e.loaded;
        },

        progress: function (e) {
            console.log('progress', arguments);

            bar.max = e.total;
            bar.value = e.loaded;
        },

        loadEnd: function (e) {
            console.log('loadEnd', arguments);
            console.log('value', e.loaded);

            bar.max = e.total;
            bar.value = e.loaded;
        },

        completeAll: function () {
            console.log('completeAll', arguments);

            setTimeout(function () {
                bar.setAttribute('hidden', 'hidden');
            }, 1000);

            console.log('Upload Completed');
            вывестиИзображения();
            
        }
    });

    };
}

// // // //

function ДобавитьКонтейнерДляТестов(мир)
{
    this.исполнить = function()
    {
        добавитьЭкран("контейнер-для-тестов", "", "");
    }
}
",
{"status":true}
],
[
"темы.последовательность",
-"0L/Rg9GB0Log0YLQtdC8CiAgICDQtNC+0LHQsNCy0LjRgtGMINC60L7QvdGC0LXQudC90LXRgCDQtNC70Y8g0YLQtdGB0YLQvtCyCiAgICDQtNC+0LHQsNCy0LjRgtGMINGB0LLQvtGRCiMgICAg0LTQvtCx0LDQstC40YLRjCDQv9GA0LjQvNC10YAKIyAgICDQtNC+0LHQsNCy0LjRgtGMINC/0LDQvdC10LvRjCDQt9Cw0LPRgNGD0LfQutC4",
+"0L/Rg9GB0Log0YLQtdC8CiMgICAg0LTQvtCx0LDQstC40YLRjCDQutC+0L3RgtC10LnQvdC10YAg0LTQu9GPINGC0LXRgdGC0L7QsgojICAgINC00L7QsdCw0LLQuNGC0Ywg0YHQstC+0ZEKIyAgICDQtNC+0LHQsNCy0LjRgtGMINC/0YDQuNC80LXRgAojICAgINC00L7QsdCw0LLQuNGC0Ywg0L/QsNC90LXQu9GMINC30LDQs9GA0YPQt9C60LgKICAgINC00L7QsdCw0LLQuNGC0Ywg0Y3QutGA0LDQvSDRgtC10LwKICAgINC00L7QsdCw0LLQuNGC0Ywg0YHQtdGC0LrRgwogICAg0L/QvtC00LPQvtGC0L7QstC40YLRjCDQv9C+0LfQuNGG0LjQuCDQuNC30L7QsdGA0LDQttC10L3QuNC5CiAgICDRg9GB0YLQsNC90L7QstC40YLRjCDQt9Cw0LPRgNGD0LfQutGDINC40LfQvtCx0YDQsNC20LXQvdC40Lk=",
{"status":false}
],