.doc-grid.svelte-oo2rz4{display:grid;grid-template-columns:100px 1fr;grid-gap:1rem}.photo.svelte-oo2rz4{width:100%;object-fit:contain;position:absolute;top:0;left:0}.img.svelte-oo2rz4{padding-top:134%;overflow:hidden;position:relative}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Doctors.svelte","sources":["Doctors.svelte"],"sourcesContent":["<script>\n    import axios from \"axios\";\n    import {speciality, loading, doctor, w, filial, searchText} from \"../../store\";\n    import { notifier } from \"@beyonk/svelte-notifications\";\n    import Modal from \"../../components/Modal.svelte\";\n\n    let doctors = [], showModal, showMoreInfoModal;\n    let timer;\n\n    $: getDocs($speciality, $filial);\n\n    function toggleModal(){\n        if(timer) {\n            clearTimeout(timer);\n            timer = undefined;\n        }\n\n        timer = setTimeout( () => showModal = true, 300 );\n    }\n\n\n    function selectItem(srv){\n        showModal = false;\n        $doctor = srv;\n    }\n\n    async function getDocs(){\n\n        if(!$speciality) return;\n        if(!$filial) return;\n        if($loading) return;\n\n        doctors = [];\n\n        $doctor = \"\";\n\n        $loading = true;\n\n        try {\n            const res = await axios.post(\"doctors/doctors.json\", { speciality: $speciality['Специальность'], filial: $filial['Офис'] });\n\n            const filteredDocs = new Set();\n\n            if($searchText && $speciality.doctors && $speciality.doctors.length){\n                $speciality.doctors.forEach( doc => {\n                    res.data.forEach( item => {\n                        if(doc['Врач'] === item['Врач']) filteredDocs.add(item['Врач']);\n                    });\n                });\n\n                filteredDocs.forEach( f => {\n                    res.data.forEach( item => {\n                        if(f === item['Врач']) doctors.push(item);\n                    });\n                });\n            }\n            else doctors = res.data;\n\n            if(doctors && doctors.length === 1) $doctor = doctors[0];\n            if(doctors && doctors.length > 1) toggleModal();\n        }\n        catch (e) {\n            doctors = [];\n            if(e && e.response) notifier.danger(e.response.data);\n        }\n\n        $loading = false;\n    }\n</script>\n\n<div class=\"border mt-3 bg-white rounded-lg overflow-hidden shadow-sm\" class:d-none={ !($speciality && $filial) }>\n    <div class=\"bg-light py-2 pl-3 pr-2 d-flex align-items-center justify-content-between\">\n        <b>\n            Специалист\n        </b>\n        <button\n            class=\"btn btn-sm btn-outline-light rounded-pill py-0\"\n            on:click={ toggleModal }\n            class:d-none={ doctors.length < 1 }\n        >\n            Изменить\n        </button>\n    </div>\n\n    {#if !$loading && doctors.length === 0}\n        <div class=\"alert alert-danger m-2\">\n            Для выбранной специальности не найдено ни одного специалиста\n        </div>\n    {:else}\n        <div class=\"rounded bg-white py-2 px-3 mb-0\">\n            {#if $doctor}\n                <div class=\"doc-grid\">\n                    <div class=\"img rounded-lg\">\n                        <img\n                            class=\"photo\"\n                            src={`/specialists/${$doctor['Врач']}.jpeg`}\n                            alt={$doctor['ФИО']}\n                        >\n                        <!--\n                        {#if $doctor['СсылкаНаФото']}\n                            <img class=\"photo\" src={$doctor['СсылкаНаФото']} alt=\"\">\n                        {:else}\n                            <div class=\"bg-light h-100 w-100 d-flex align-items-center justify-content-center position-absolute\" style=\"top: 0; left: 0;\">\n                                <img class=\"icon\" src=\"/avatar.svg\" alt=\"\">\n                            </div>\n                        {/if}\n                        -->\n                    </div>\n                    <div class=\"d-flex flex-column justify-content-start align-items-start\">\n                        <h5 class=\"mt-3\">\n                            { $doctor['Фамилия'] } { $doctor['Имя'] } { $doctor['Отчество'] }\n                        </h5>\n                        <div class=\"mb-2 mt-2\">\n                            <button\n                                class=\"btn btn-sm btn-gold rounded-pill py-0\"\n                                on:click={ () => showMoreInfoModal = true }\n                            >\n                                Подробнее о враче\n                            </button>\n                        </div>\n                    </div>\n                </div>\n                {#if $doctor['КраткоеОписание']}\n                    <div class=\"alert alert-warning px-3 py-1 mt-3 mb-0\">\n                        { $doctor['КраткоеОписание'] }\n                    </div>\n                {/if}\n            {:else}\n                Не выбран специалист\n            {/if}\n        </div>\n    {/if}\n</div>\n\n<Modal bind:show={showModal} title=\"Выберите специалиста\">\n    {#each doctors as item}\n        <div class=\"mx-n2 py-2 px-3 border-bottom d-flex align-items-center justify-content-between cursor-pointer bg-light_hover\" on:click={ () => selectItem(item) }>\n            <span class=\"ml-0\">\n                {item['Фамилия']} {item['Имя']} {item['Отчество']}\n            </span>\n            <i class=\"fas fa-chevron-right fa-15x text-primary ml-3\"></i>\n        </div>\n    {:else}\n        <div class=\"\">\n            Не найдено специалистов\n        </div>\n    {/each}\n</Modal>\n\n<Modal bind:show={showMoreInfoModal} title=\"О специалисте\">\n    <h5 class=\"p-3\">\n        { $doctor['Фамилия'] } { $doctor['Имя'] } { $doctor['Отчество'] }\n    </h5>\n\n    <div class=\"p-3 text-center\">\n        <img\n            src={`/specialists/${$doctor['Врач']}.jpeg`}\n            alt={$doctor['ФИО']}\n            class=\"img-fluid rounded-lg\"\n            style=\"max-width: 300px\"\n        >\n    </div>\n\n    <!--\n    {#if $doctor['СсылкаНаФото']}\n        <div class=\"p-3 text-center\">\n            <img src={$doctor['СсылкаНаФото']} alt=\"\" class=\"img-fluid rounded-lg\" style=\"max-width: 300px\">\n        </div>\n    {/if}\n    -->\n\n    {#if $doctor['КраткоеОписание']}\n        <div class=\"p-3\">\n            {@html $doctor['КраткоеОписание'] }\n        </div>\n    {/if}\n\n    {#if $doctor['ОбщаяИнформация']}\n        <div class=\"p-3\">\n            {@html $doctor['ОбщаяИнформация'] }\n        </div>\n    {/if}\n</Modal>\n\n<style>\n\n    .doc-grid {\n        display: grid;\n        grid-template-columns: 100px 1fr;\n        grid-gap: 1rem;\n    }\n\n    .photo {\n        width: 100%;\n        object-fit: contain;\n        position: absolute;\n        top: 0;\n        left: 0;\n    }\n\n    .img {\n        padding-top: 134%;\n        overflow: hidden;\n        position: relative;\n    }\n\n    .icon {\n        opacity: 0.2;\n        height: 50%;\n    }\n\n</style>"],"names":[],"mappings":"AA0LI,SAAS,cAAC,CAAC,AACP,OAAO,CAAE,IAAI,CACb,qBAAqB,CAAE,KAAK,CAAC,GAAG,CAChC,QAAQ,CAAE,IAAI,AAClB,CAAC,AAED,MAAM,cAAC,CAAC,AACJ,KAAK,CAAE,IAAI,CACX,UAAU,CAAE,OAAO,CACnB,QAAQ,CAAE,QAAQ,CAClB,GAAG,CAAE,CAAC,CACN,IAAI,CAAE,CAAC,AACX,CAAC,AAED,IAAI,cAAC,CAAC,AACF,WAAW,CAAE,IAAI,CACjB,QAAQ,CAAE,MAAM,CAChB,QAAQ,CAAE,QAAQ,AACtB,CAAC"} */
