.block.svelte-k37vy0{display:block}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"App.svelte","sources":["App.svelte"],"sourcesContent":["<script>\n    import {spring} from 'svelte/motion';\n    import ky from \"ky\";\n\n    import clipboard from \"../actions/clipboard\";\n\n    import CancelForm from \"./CancelForm.svelte\";\n    import RejectForm from \"./RejectForm.svelte\";\n    import TimeCalculator from \"./TimeCalculator.svelte\";\n\n    import {date, fdate} from \"./date\";\n\n    export let user;\n\n    let current = {};\n    let history = null;\n    let notifications = [];\n    let loading = {\n        calling: false,\n        history: false,\n        task: false,\n    };\n    let calling = false;\n\n    let count = 0;\n\n    const displayed_count = spring();\n    $: displayed_count.set(count);\n\n    $: counter_class = (() => {\n        if (count >= 100) {\n            return \"label label-success\";\n        }\n\n        if (count >= 20) {\n            return \"label label-warning\";\n        }\n\n        return \"label label-danger\";\n    })()\n\n    const connect = () => {\n        setInterval(() => {\n            try {\n                ky.get(`https://ws.make-connect.ru/operator/${user.id}`)\n                    .json()\n                    .then(res => {\n                        count = res.count ?? 0;\n                    })\n                    .catch(() => {\n                        count = 0;\n                    });\n            } catch (e) {\n                console.log(e.message);\n            }\n\n        }, 10000);\n    }\n\n    connect();\n\n    const notify = {\n        success: (content) => notifications.push({content, type: 'success'}),\n        info: (content) => notifications.push({content, type: 'info'}),\n        warning: (content) => notifications.push({content, type: 'warning'}),\n        error: (content) => notifications.push({content, type: 'danger'}),\n    }\n\n    async function loadTask() {\n        loading.task = true\n        current = ky.get('/queue/next', {\n            searchParams: {user_id: user.id},\n        }).json().then(async res => {\n            current = res;\n            return res;\n        }).catch((error) => {\n            switch (error.response?.status) {\n                case 404:\n                    notify.error('Очередь пуста или не найдено задание подходящее под условия выборки');\n                    break;\n                default:\n                    notify.error('При получении задания возникла ошибка');\n            }\n        }).finally(() => loading.task = false);\n    }\n\n    async function loadHistory() {\n        loading.history = true;\n        ky.get(\"/queue/ri\", {searchParams: {phone: current.task.phone}})\n            .json()\n            .then(res => {\n                loading.history = false;\n                history = res;\n            })\n            .catch(() => {\n                loading.history = false;\n                notify.error('При загрузке истории произошла ошибка');\n            });\n    }\n\n    async function call() {\n        loading.calling = true;\n        return ky.post(\"/ajax/cc_operator_start_call.php\", {json: {task_id: current.task.id, user_id: user.id}})\n            .json()\n            .then((res) => {\n                if (String(res.status) === 'ok' && res.cbs_id) {\n                    current.task.call_id = res.cbs_id;\n                    status = true;\n                }\n                loading.calling = false;\n            }).catch((err) => {\n                loading.calling = false;\n                console.log(err);\n            });\n    }\n\n    function onSuccess() {\n        current = {}\n        history = null;\n    }\n\n    const systemStatuses = {\n        1: \"Оператор отклонил звонок\",\n        2: \"Оператор перенес задание\",\n        3: \"Оператор завершил задание\",\n    };\n\n    $: status = current?.task?.call_id ? true : null;\n\n    $: blocked = current?.task?.blocked;\n\n    $: phone = current?.task?.phone;\n\n    $: classColorTextPhone = current?.task?.isLandlineNumber ? 'text-danger' : '';\n\n    $: checkPhone = !blocked?.length && current?.task?.callable;\n</script>\n\n<style>\n    .block {\n        display: block;\n    }\n</style>\n\n<div class=\"container-fluid\">\n    <div class=\"row\">\n        {#if notifications.length}\n            <div class=\"col-md-offset-2 col-md-8\" style=\"position: absolute; z-index: 9999;\">\n                {#each notifications as {type, content}, i}\n                    <div class=\"alert alert- alert-{type}\">\n                        {content}\n                        <button type=\"button\" class=\"close\" aria-label=\"Close\"\n                                on:click={() => {notifications.splice(i, 1); notifications = [...notifications]}}>\n                            <span aria-hidden=\"true\">&times;</span>\n                        </button>\n                    </div>\n                {/each}\n            </div>\n        {/if}\n        <h4>Количество заданий в очереди: <span class={counter_class}>{Math.floor($displayed_count)}</span></h4>\n        {#if current.task}\n            <div class=\"col-md-7\">\n                <h3>Карточка задания</h3>\n                <ul class=\"list-group\">\n                    <li class=\"block\">\n                        Номер абонента:\n                        {#if current.phonebook}\n                            <b class=\"text-success font-mono\">{current.phonebook.name}</b>\n                        {:else}\n                            <b class=\"font-mono {classColorTextPhone}\">{\n                                current.task.phone.match(/[0-9]/)\n                                    ? current.task.phone.replace(/(\\d)(\\d{3})(\\d{3})(\\d{2})(\\d{2})/, (_, p1, p2, p3, p4, p5) => `${p1} (${p2}) ${p3}-${p4}-${p5}`)\n                                    : current.task.phone\n                            }</b>\n                            <span class=\"glyphicon glyphicon-copy\" data-clipboard-text={current.task.phone} use:clipboard></span>\n                        {/if}\n                    </li>\n                    <li class=\"block\">\n                        Название списка:\n                        <b>{current.task.name}</b>\n                    </li>\n                    <li class=\"block\">\n                        ID элемента:\n                        <b>{current.task.creator_id}</b>\n                        ID задания:\n                        <b>{current.task.id}</b>\n                    </li>\n                </ul>\n\n                <h3>Комментарий</h3>\n                <p>{@html current.task.comment}</p>\n\n                <h3>\n                    Временная зона абонента\n                    {#if current.task.operator}\n                        <small>\n                            <TimeCalculator zone={current.task.operator.zone_utc}/>\n                        </small>\n                    {/if}\n                </h3>\n                {#if current.task?.operator}\n                    <ul class=\"list-group\">\n                        <li class=\"block\">\n                            Оператор:\n                            <b>{current.task.operator.name}</b>\n                        </li>\n                        <li class=\"block\">\n                            Регион:\n                            <b>{current.task.operator.region}</b>\n                        </li>\n                        <li class=\"block\">\n                            Время абонента:\n                            <b>{date().utc().add(current.task.operator.zone_utc, 'h').format('DD-MM-YYYY HH:mm')}</b>\n                            МСК {['', '+'][+(current.task.operator.zone_msk > 0)]}{current.task.operator.zone_msk}\n                            (UTC {['', '+'][+(current.task.operator.zone_utc > 0)]}{current.task.operator.zone_utc})\n                        </li>\n                    </ul>\n                {:else}\n                    <b>Не определена</b>\n                {/if}\n\n                <h3>Информация о наличии номера в списках блокировок</h3>\n                <ul class=\"list-group\">\n                    {#if blocked}\n                        {#each blocked as {type, comment, duration, created_at}}\n                            <li class=\"block text-danger\">от {fdate(created_at)} {type === 255 ? `(Перманентно)` : duration ? `(${duration})` : ' '} : {comment}</li>\n                        {/each}\n                    {:else}\n                        <li class=\"block\">Нет</li>\n                    {/if}\n                </ul>\n\n                <h3>История заданий по элементу</h3>\n                {#if current.task.prev.length}\n                    <div class=\"table-responsive\">\n                        <table class=\"table table-striped\">\n                            <thead>\n                            <tr>\n                                <th>Дата и время</th>\n                                <th>Оператор</th>\n                                <th>Статус оператора</th>\n                                <th>Статус системы</th>\n                                <th>Комментарий</th>\n                            </tr>\n                            </thead>\n                            <tbody>\n                            {#each current.task.prev as {\n                                element_created_at,\n                                task_started_at,\n                                operator,\n                                operator_status,\n                                system_status,\n                                comment\n                            }}\n                                <tr>\n                                    <td>{task_started_at ? fdate(task_started_at) : '-'}</td>\n                                    <td>{operator}</td>\n                                    <td>{operator_status || '-'}</td>\n                                    <td>{systemStatuses[system_status] || '-'}</td>\n                                    <td>{comment || ''}</td>\n                                </tr>\n                            {/each}\n                            </tbody>\n                        </table>\n                    </div>\n                {:else}\n                    Это первый звонок по заданию\n                {/if}\n\n                <h3>История звонков КЦ данному пользователю</h3>\n                {#if current.prev.length}\n                    <div class=\"table-responsive\">\n                        <table class=\"table table-striped\">\n                            <thead>\n                            <tr>\n                                <th>Дата и время</th>\n                                <th>Оператор</th>\n                                <th>Статус оператора</th>\n                                <th>Статус системы</th>\n                                <th>Комментарий</th>\n                            </tr>\n                            </thead>\n                            <tbody>\n                            {#each current.prev as {\n                                element_created_at,\n                                task_started_at,\n                                operator,\n                                operator_status,\n                                system_status,\n                                comment\n                            }}\n                                <tr>\n                                    <td>{task_started_at ? fdate(task_started_at) : '-'}</td>\n                                    <td>{operator}</td>\n                                    <td>{operator_status || '-'}</td>\n                                    <td>{systemStatuses[system_status] || '-'}</td>\n                                    <td>{comment || ''}</td>\n                                </tr>\n                            {/each}\n                            </tbody>\n                        </table>\n                    </div>\n                {:else}\n                    Это первый звонок по заданию\n                {/if}\n\n                <h3>Общая история звонков данному пользователю</h3>\n                {#if current.calls.cb.length}\n                    <h4>Обратные звонки</h4>\n                    <div class=\"table-responsive\">\n                        <table class=\"table table-striped\">\n                            <tbody>\n                            {#each current.calls.cb as {dt, name}}\n                                <tr>\n                                    <td>{fdate(dt)}</td>\n                                    <td>{name}</td>\n                                </tr>\n                            {/each}\n                            </tbody>\n                        </table>\n                    </div>\n                {/if}\n                {#if current.calls.cf.length}\n                    <h4>Прямые звонки</h4>\n                    <div class=\"table-responsive\">\n                        <table class=\"table table-striped\">\n                            <tbody>\n                            {#each current.calls.cf as {dt, name}}\n                                <tr>\n                                    <td>{fdate(dt)}</td>\n                                    <td>{name}</td>\n                                </tr>\n                            {/each}\n                            </tbody>\n                        </table>\n                    </div>\n                {/if}\n\n                <h3>История посещения страниц</h3>\n\n                {#if history === null}\n                    <button class=\"btn btn-default\" disabled=\"{loading.history}\" on:click={loadHistory}>\n                        {loading.history ? 'Загрузка...' : 'Загрузить'}\n                    </button>\n                {:else if history.length}\n                    <div class=\"table-responsive\">\n                        <table class=\"table table-striped\">\n                            <thead>\n                            <tr>\n                                <th>Дата и время</th>\n                                <th>URL</th>\n                            </tr>\n                            </thead>\n                            <tbody>\n                            {#each history as {\n                                date,\n                                url\n                            }}\n                                <tr>\n                                    <td>{fdate(date)}</td>\n                                    <td>{url}</td>\n                                </tr>\n                            {/each}\n                            </tbody>\n                        </table>\n                    </div>\n                {:else}\n                    <p>Нет информации о посещениях</p>\n                {/if}\n            </div>\n            <div class=\"col-md-offset-1 col-md-4\">\n                {#if status !== null}\n                    <svelte:component\n                            this={status ? CancelForm : RejectForm}\n                            call_id=\"{current.task.call_id}\"\n                            user_self_limit=\"{current.task.self_limit}\"\n                            {user}\n                            on:success={onSuccess}\n                            on:cancel={() => status = null}\n                    />\n                {:else}\n                    <button class=\"btn btn-success btn-lg\" disabled=\"{loading.calling || !checkPhone}\"\n                            on:click|preventDefault={call}>\n                        Позвонить\n                    </button>\n                    <button class=\"btn btn-danger btn-lg\" disabled=\"{loading.calling}\"\n                            on:click|preventDefault={() => status = false }>\n                        Отказаться\n                    </button>\n                {/if}\n            </div>\n        {:else}\n            <div class=\"col-md-12\">\n                <button\n                        class=\"btn btn-{loading.task ? 'default' : 'success'}\"\n                        disabled=\"{loading.task}\"\n                        on:click=\"{loadTask}\">\n                    {loading.task ? 'Загрузка...' : 'Получить задание'}\n                </button>\n            </div>\n        {/if}\n    </div>\n</div>\n"],"names":[],"mappings":"AA2II,MAAM,cAAC,CAAC,AACJ,OAAO,CAAE,KAAK,AAClB,CAAC"} */.mr-4.svelte-1pwe8zn{margin-right:4px}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"CancelForm.svelte","sources":["CancelForm.svelte"],"sourcesContent":["<svelte:head>\n    <link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/flatpickr/dist/flatpickr.min.css\">\n</svelte:head>\n\n<script>\n    import {createEventDispatcher, onMount} from \"svelte\";\n    import ky from \"ky\";\n    import Joi from \"joi\";\n\n    import flatpickr from \"../actions/flatpickr\";\n\n    import TagsManager from \"./Tags/Manager.svelte\";\n\n    import {date} from \"./date\";\n\n    const now = date().subtract(1, 'minute');\n\n    export let call_id, user, user_self_limit;\n\n    const dispatch = createEventDispatcher();\n\n    let statuses = [];\n\n    onMount(() => {\n        ky.get('/queue/statuses', {searchParams: {user_id: user.id}}).json().then(result => {\n            statuses = result.filter(o => o.group === 0).sort((a, b) => a.sort < b.sort ? -1 : a.sort > b.sort ? 1 : 0);\n        })\n    })\n\n    function validateString(val, min, max, required = true) {\n        let validator = Joi.string().min(min).max(max);\n\n        validator = required ? validator.required() : validator.empty(\"\");\n        return !!validator.validate(val.trim()).error;\n    }\n\n    let move = '',\n        to_blacklist = false,\n        finish_status = null,\n        blacklist_comment = {\n            min: 5,\n            max: 250,\n            val: '',\n        },\n        call_comment = {\n            min: 5,\n            max: 250,\n            val: '',\n        },\n        comment = {\n            min: 5,\n            max: 250,\n            val: '',\n        },\n        myself = false;\n\n    $: blacklist_comment = {\n        ...blacklist_comment,\n        valid: validateString(blacklist_comment.val, blacklist_comment.min, blacklist_comment.max),\n    }\n    $: comment = {\n        ...comment,\n        valid: validateString(comment.val, comment.min, comment.max),\n    }\n    $: call_comment = {\n        ...call_comment,\n        valid: validateString(call_comment.val, call_comment.min, call_comment.max, false),\n    }\n\n    const schema = Joi.object({\n        move_required: Joi.boolean(),\n        move: Joi.when('move_required', {\n            is: true,\n            then: Joi.date().greater(now.$d),\n            otherwise: Joi.alternatives([\n                Joi.date().greater(now.$d),\n                Joi.string().valid(\"\"),\n            ]),\n        }),\n        to_blacklist: Joi.boolean(),\n        blacklist_comment: Joi.when(\"to_blacklist\", {\n            is: true,\n            then: Joi.string().trim().min(blacklist_comment.min).max(blacklist_comment.max),\n            otherwise: Joi.string().empty(\"\")\n        }),\n        finish_status: Joi.number().valid(...statuses.map(i => i)).required(),\n        myself: Joi.boolean(),\n        comment_required: Joi.boolean(),\n        comment: Joi.when(\"comment_required\", {\n            is: true,\n            then: Joi.string().trim().min(comment.min).max(comment.max).required(),\n            otherwise: Joi.string().empty(\"\")\n        }),\n        call_comment: Joi.string().trim().min(call_comment.min).max(call_comment.max).empty(\"\")\n    });\n\n\n    let process = false;\n\n    async function submit() {\n        process = true;\n        return ky.post(\"/queue/done\", {\n            searchParams: {user_id: user.id},\n            json: {\n                move,\n                blacklist_comment: blacklist_comment.val,\n                finish_status,\n                myself,\n                comment: comment.val,\n                call_comment: call_comment.val,\n            }\n        })\n            .json()\n            .then((res) => {\n                process = false;\n                dispatch(\"success\");\n            })\n            .catch((err) => {\n                process = false;\n            });\n    }\n\n    let fp;\n\n    $: validation = schema.validate({\n        move,\n        move_required,\n        to_blacklist,\n        blacklist_comment: blacklist_comment.val,\n        finish_status,\n        myself,\n        comment: comment.val,\n        comment_required,\n        call_comment: call_comment.val,\n    }, {});\n\n    $: current_status = statuses.find(s => s.id === finish_status);\n\n    $: comment_required = Boolean(current_status?.comment_required || false);\n    $: self_assigned = Boolean(current_status?.self_assigned || false);\n    $: limit_self_operators = Boolean(current_status?.limit_self_operators || false);\n    $: can_move = Boolean(current_status?.can_move || false);\n    $: block_phone = Boolean(current_status?.block_phone || false);\n    $: to_self = Boolean(current_status?.to_self || false);\n    $: move_required = Boolean(current_status?.move_required || false);\n    $: to_block = Boolean(current_status?.to_block || false);\n\n    $: if (!can_move) {\n        move = '';\n    }\n\n    $: if (finish_status) {\n        to_blacklist = !to_block && block_phone;\n        myself = to_self;\n    }\n\n    $: length = {\n        comment: comment.val.length,\n        blacklist_comment: blacklist_comment.val.length,\n        call_comment: call_comment.val.length\n    };\n</script>\n\n<style>\n    .mr-4 {\n        margin-right: 4px;\n    }\n</style>\n\n<form on:submit|preventDefault={submit}>\n    <div>\n        {#if can_move}\n            <p>Пользователь хочет, чтобы ему перезвонили?</p>\n\n            <div class=\"form-group\"\n                 class:has-error={move_required && !move}>\n                <span class=\"input-group date\">\n                    <input type=\"text\" class=\"form-control\" bind:value=\"{move}\" bind:this={fp} use:flatpickr={now.add(1, 'minute')}\n                           placeholder=\"оставьте поле пустым, если не нужно перезванивать\">\n                    <span class=\"input-group-addon\" on:click={move ? () => move = '' : () => fp.click()}>\n                        <span class=\"glyphicon {move ? 'glyphicon-remove' : 'glyphicon-calendar'}\"></span>\n                    </span>\n                </span>\n            </div>\n        {/if}\n\n        {#if !to_block && !move_required && !move}\n            <ul class=\"list-group\">\n                <li class=\"list-group-item\">Занести в черный список\n                    <div class=\"material-switch pull-right\">\n                        <input id=\"cc_blacklist\" name=\"cc_blacklist\" type=\"checkbox\" bind:checked=\"{to_blacklist}\" disabled=\"{block_phone}\">\n                        <label for=\"cc_blacklist\" class=\"label-danger\"></label>\n                    </div>\n                </li>\n            </ul>\n            {#if to_blacklist}\n                <div class=\"form-group\"\n                     class:has-error={blacklist_comment.valid}>\n                    <span class=\"form-group\">\n                        <input type=\"text\" class=\"form-control\" name=\"cc_blacklist_comment\"\n                               bind:value=\"{blacklist_comment.val}\"\n                               placeholder=\"Комментарий\">\n                        <small class=\"pull-right mr-4 { blacklist_comment.valid ? 'text-danger' : 'text-success'}\">\n                            {blacklist_comment.val.length}/{blacklist_comment.max}\n                        </small>\n                    </span>\n                </div>\n            {/if}\n        {/if}\n    </div>\n    <div style=\"padding-top: 30px\">\n        <p>Укажите статус (обязательное поле):</p>\n        <code>Лимиты по новым номерам на себя [{user_self_limit || 0} из 20]</code>\n        <select name=\"cc_finish_status\" class=\"form-control\" id=\"cc_finish_status\" size=\"1\" bind:value={finish_status}>\n            {#if !finish_status}\n                <option value=\"0\">-- Выбрать --</option>\n            {/if}\n            {#each statuses as {id, name}}\n                <option value=\"{id}\">{name}</option>\n            {/each}\n        </select>\n        <p></p>\n        {#if self_assigned}\n            <ul class=\"list-group\">\n                <li class=\"list-group-item\">Назначить на себя\n                    <div class=\"material-switch pull-right\">\n                        <input id=\"cc_myself\" type=\"checkbox\" bind:checked={myself}>\n                        <label for=\"cc_myself\" class=\"label-default\"></label>\n                    </div>\n                </li>\n            </ul>\n        {/if}\n        {#if limit_self_operators}\n            <div class=\"alert alert-warning\">\n                У вас исчерпан лимит в день по назначению <br>\n                Новых номеров на себя!\n            </div>\n        {/if}\n        {#if comment_required}\n            <div class=\"form-group\"\n                 class:has-error={comment.valid}>\n                <p>Укажите комментарий (обязательное поле):</p>\n                <textarea class=\"form-control\" cols=\"20\" rows=\"3\" bind:value={comment.val}></textarea>\n                <small class=\"pull-right mr-4 { comment.valid ? 'text-danger' : 'text-success'}\">\n                    {comment.val.length}/{comment.max}\n                </small>\n                <p></p>\n            </div>\n        {/if}\n\n        <p>\n            Укажите комментарий к звонку:\n            <br>\n            <small>Оставьте пустым, если хотите оставить звонок без комментария</small>\n        </p>\n        <div class=\"form-group\"\n             class:has-error={call_comment.valid}>\n            <textarea class=\"form-control\" cols=\"20\" rows=\"3\" bind:value={call_comment.val}></textarea>\n            <small class=\"pull-right mr-4 { call_comment.valid ? 'text-danger' : 'text-success'}\">\n                {call_comment.val.length}/{call_comment.max}\n            </small>\n        </div>\n        <p></p>\n        <TagsManager client_id=\"{user.client_id}\" call_type=1 call_id=\"{call_id}\"/>\n        <p>&nbsp;</p>\n        <button type=\"submit\" class=\"btn btn-success\" disabled=\"{!!validation.error || process}\">\n            Сохранить\n        </button>\n    </div>\n</form>\n"],"names":[],"mappings":"AAoKI,KAAK,eAAC,CAAC,AACH,YAAY,CAAE,GAAG,AACrB,CAAC"} */.tags-manager .mb-4{margin-bottom:4px}.tags-manager .mr-4{margin-right:4px}.tags-manager .tag{border:1px solid #999;color:#000;font-size:11px}.tags-manager .tag:hover{color:#000}.tags-manager .tag-success{background-color:#bffdd4}.tags-manager .tag-warning{background-color:#fbfdbf}.tags-manager .tag-danger{background-color:#fdcfbf}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWFuYWdlci5zdmVsdGUiLCJzb3VyY2VzIjpbIk1hbmFnZXIuc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxzY3JpcHQ+XG4gICAgaW1wb3J0IGt5IGZyb20gXCJreVwiO1xuICAgIGltcG9ydCB7b25Nb3VudH0gZnJvbSBcInN2ZWx0ZVwiO1xuXG4gICAgaW1wb3J0IE1vZGFsIGZyb20gXCIuL01vZGFsLnN2ZWx0ZVwiO1xuXG4gICAgZXhwb3J0IGxldCBjbGllbnRfaWQsIGNhbGxfdHlwZSwgY2FsbF9pZDtcblxuICAgIGxldCBzZWxlY3RlZCA9ICcnO1xuICAgIGxldCB0YWdzID0gW107XG4gICAgbGV0IHNob3dNb2RhbCA9IGZhbHNlO1xuXG4gICAgY29uc3QgaW1wb3J0YW50cyA9IHtcbiAgICAgICAgMTogXCJzdWNjZXNzXCIsXG4gICAgICAgIDI6IFwid2FybmluZ1wiLFxuICAgICAgICAzOiBcImRhbmdlclwiLFxuICAgIH07XG5cbiAgICBvbk1vdW50KGFzeW5jICgpID0+IHtcbiAgICAgICAgYXdhaXQgbG9hZFRhZ3MoKS50aGVuKCgpID0+IGxvYWRDYWxsVGFncygpKTtcbiAgICB9KTtcblxuICAgIGNvbnN0IHRhZ3NUb1N0cmluZyA9ICh2KSA9PiAodi5sZW5ndGggPyBgLSR7di5qb2luKFwiLVwiKX0tYCA6IFwiXCIpO1xuICAgIGNvbnN0IHN0cmluZ1RvVGFncyA9ICh2KSA9PiB2LnNwbGl0KFwiLVwiKS5maWx0ZXIoQm9vbGVhbik7XG5cblxuICAgICQ6IHNlbGVjdFN0cmluZyA9IHRhZ3NUb1N0cmluZyhjdXJyZW50U2VsZWN0Lm1hcCgodikgPT4gdi5pZCkpO1xuICAgICQ6IGN1cnJlbnRTZWxlY3QgPVxuICAgICAgICB0YWdzLmxlbmd0aCAmJiBzZWxlY3RlZFxuICAgICAgICAgICAgPyBzdHJpbmdUb1RhZ3Moc2VsZWN0ZWQpLm1hcCgoaWQpID0+IHRhZ3MuZmluZCgodGFnKSA9PiB0YWcuaWQgPT09IGlkKSlcbiAgICAgICAgICAgIDogW107XG5cbiAgICBhc3luYyBmdW5jdGlvbiBsb2FkVGFncygpIHtcbiAgICAgICAgY29uc3QgcmVzID0gYXdhaXQga3kucG9zdChgL2FwaS92Mi90YWdzP2FjdGl2ZWAsIHtcbiAgICAgICAgICAgIGpzb246IHtjbGllbnRfaWQsIHRvcF91c2VyOiBmYWxzZX0sXG4gICAgICAgIH0pO1xuICAgICAgICB0YWdzID0gYXdhaXQgcmVzLmpzb24oKS50aGVuKCh7ZGF0YX0pID0+IGRhdGEpO1xuICAgIH1cblxuICAgIGFzeW5jIGZ1bmN0aW9uIGxvYWRDYWxsVGFncygpIHtcbiAgICAgICAgY29uc3QgcmVzID0gYXdhaXQga3kuZ2V0KGAvYXBpL3YyL3RhZ3MvY2FsbC8ke2NhbGxfdHlwZX0vJHtjYWxsX2lkfWApO1xuICAgICAgICBzZWxlY3RlZCA9IGF3YWl0IHJlcy5qc29uKCkudGhlbigoe2RhdGF9KSA9PiBkYXRhKTtcbiAgICB9XG5cbiAgICBjb25zdCBvcGVuID0gKCkgPT4gKHNob3dNb2RhbCA9IHRydWUpO1xuICAgIGNvbnN0IGNsb3NlID0gKCkgPT4gKHNob3dNb2RhbCA9IGZhbHNlKTtcblxuICAgIGNvbnN0IHNhdmUgPSBhc3luYyAoZSkgPT4ge1xuICAgICAgICBjdXJyZW50U2VsZWN0ID0gZS5kZXRhaWw7XG4gICAgICAgIGF3YWl0IGt5LnBvc3QoYC9hcGkvdjIvdGFncy9jYWxsLyR7Y2FsbF90eXBlfS8ke2NhbGxfaWR9YCwge1xuICAgICAgICAgICAganNvbjoge3RhZ3M6IHRhZ3NUb1N0cmluZyhjdXJyZW50U2VsZWN0Lm1hcCgodikgPT4gdi5pZCkpfVxuICAgICAgICB9KTtcbiAgICAgICAgY2xvc2UoKTtcbiAgICB9O1xuPC9zY3JpcHQ+XG5cbjxzdHlsZSBsYW5nPVwic2Nzc1wiIGdsb2JhbD46Z2xvYmFsKC50YWdzLW1hbmFnZXIpIDpnbG9iYWwoLm1iLTQpIHtcbiAgbWFyZ2luLWJvdHRvbTogNHB4O1xufVxuOmdsb2JhbCgudGFncy1tYW5hZ2VyKSA6Z2xvYmFsKC5tci00KSB7XG4gIG1hcmdpbi1yaWdodDogNHB4O1xufVxuOmdsb2JhbCgudGFncy1tYW5hZ2VyKSA6Z2xvYmFsKC50YWcpIHtcbiAgYm9yZGVyOiAxcHggc29saWQgIzk5OTtcbiAgY29sb3I6ICMwMDA7XG4gIGZvbnQtc2l6ZTogMTFweDtcbn1cbjpnbG9iYWwoLnRhZ3MtbWFuYWdlcikgOmdsb2JhbCgudGFnOmhvdmVyKSB7XG4gIGNvbG9yOiAjMDAwO1xufVxuOmdsb2JhbCgudGFncy1tYW5hZ2VyKSA6Z2xvYmFsKC50YWctc3VjY2Vzcykge1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjYmZmZGQ0O1xufVxuOmdsb2JhbCgudGFncy1tYW5hZ2VyKSA6Z2xvYmFsKC50YWctd2FybmluZykge1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjZmJmZGJmO1xufVxuOmdsb2JhbCgudGFncy1tYW5hZ2VyKSA6Z2xvYmFsKC50YWctZGFuZ2VyKSB7XG4gIGJhY2tncm91bmQtY29sb3I6ICNmZGNmYmY7XG59PC9zdHlsZT5cblxuPGRpdiBjbGFzcz1cInRhZ3MtbWFuYWdlclwiPlxuICAgIDxpbnB1dCB0eXBlPVwiaGlkZGVuXCIgdmFsdWU9e3NlbGVjdFN0cmluZ30vPlxuICAgIHsjaWYgc2hvd01vZGFsfVxuICAgICAgICA8TW9kYWxcbiAgICAgICAgICAgICAgICB7dGFnc31cbiAgICAgICAgICAgICAgICB7aW1wb3J0YW50c31cbiAgICAgICAgICAgICAgICBjdXJyZW50U2VsZWN0PXtjdXJyZW50U2VsZWN0fVxuICAgICAgICAgICAgICAgIG9uOmNsb3NlPXtjbG9zZX1cbiAgICAgICAgICAgICAgICBvbjpzYXZlPXtzYXZlfS8+XG4gICAgey9pZn1cbiAgICB7I2VhY2ggY3VycmVudFNlbGVjdCBhcyB0YWcsIGl9XG4gICAgICAgIDxidXR0b25cbiAgICAgICAgICAgICAgICBjbGFzcz1cImJ0biBidG4tc20gdGFnIHRhZy17aW1wb3J0YW50c1t0YWcuaW1wb3J0YW50XX0gbXItNCBtYi00XCJcbiAgICAgICAgICAgICAgICBvbjpjbGlja3xwcmV2ZW50RGVmYXVsdD17b3Blbn0+XG4gICAgICAgICAgICB7dGFnLm5hbWV9XG4gICAgICAgIDwvYnV0dG9uPlxuICAgIHsvZWFjaH1cblxuICAgIHsjaWYgIWN1cnJlbnRTZWxlY3QubGVuZ3RofVxuICAgICAgICA8YnV0dG9uIGNsYXNzPVwiYnRuIGJ0bi1kZWZhdWx0IGJ0bi1zbVwiIG9uOmNsaWNrfHByZXZlbnREZWZhdWx0PXtvcGVufT7QlNC+0LHQsNCy0LjRgtGMPC9idXR0b24+XG4gICAgey9pZn1cbjwvZGl2PlxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdEa0MsYUFBYSxBQUFDLENBQUMsQUFBUSxLQUFLLEFBQUUsQ0FBQyxBQUMvRCxhQUFhLENBQUUsR0FBRyxBQUNwQixDQUFDLEFBQ08sYUFBYSxBQUFDLENBQUMsQUFBUSxLQUFLLEFBQUUsQ0FBQyxBQUNyQyxZQUFZLENBQUUsR0FBRyxBQUNuQixDQUFDLEFBQ08sYUFBYSxBQUFDLENBQUMsQUFBUSxJQUFJLEFBQUUsQ0FBQyxBQUNwQyxNQUFNLENBQUUsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQ3RCLEtBQUssQ0FBRSxJQUFJLENBQ1gsU0FBUyxDQUFFLElBQUksQUFDakIsQ0FBQyxBQUNPLGFBQWEsQUFBQyxDQUFDLEFBQVEsVUFBVSxBQUFFLENBQUMsQUFDMUMsS0FBSyxDQUFFLElBQUksQUFDYixDQUFDLEFBQ08sYUFBYSxBQUFDLENBQUMsQUFBUSxZQUFZLEFBQUUsQ0FBQyxBQUM1QyxnQkFBZ0IsQ0FBRSxPQUFPLEFBQzNCLENBQUMsQUFDTyxhQUFhLEFBQUMsQ0FBQyxBQUFRLFlBQVksQUFBRSxDQUFDLEFBQzVDLGdCQUFnQixDQUFFLE9BQU8sQUFDM0IsQ0FBQyxBQUNPLGFBQWEsQUFBQyxDQUFDLEFBQVEsV0FBVyxBQUFFLENBQUMsQUFDM0MsZ0JBQWdCLENBQUUsT0FBTyxBQUMzQixDQUFDIn0= */