Language = 'en' // "en", "es", "fr", "de", "pt", "it", "pl", "nl", "ru", "tr", "hu", "ro", "cs", "sv", "ar"
CurrentPage = "properties"
PropertyCreationPanelType = 'house'
PropertyCreationType = 'SHELL'
PropertyCreationKey = null
PropertyInfos = ['','','']
CurrentPropertySelectionPage = 1
CurrentCameraSelectionPage = 1
CurrentProperty = null
PurchaseType = 'purchase'
AdminPropertyType = 'house_admin'
QuestionPanel = []
RealEstate = false
InSoldProperties = false
SellType = 'instant'
ChoosedPropertyForSell = ''
ChoosedPaint = 0
ChosedFurnitureType = 'all'
InsideOrOutside = ''
Loader = false
IsDUIDotOpened = false
LastProperty = null
ControlSectionState = 'house'
ChosedMovingFurnitureType = null
OpenedTutoralFrom = ''
CurrentTutorialPage = 0
Myproperties = null
BGBlur = true
BackgroundBlurFunction(BGBlur)
let translations = {};
async function loadTranslations(lang) {
    try {
        const response = await fetch(`../locales/${lang}.json`);
        translations = await response.json();
        updateText()
    } catch (error) {
        console.error("Error loading translation:", error);
    }
}
function updateText() {
    document.querySelectorAll("[data-i18n]").forEach(element => {
        const key = element.getAttribute("data-i18n");
        if (element.hasAttribute("placeholder")) {
            element.setAttribute("placeholder", translations[key]);
        } else {
            element.innerHTML = translations[key]; 
        }
    });
}
loadTranslations(Language)
function t(key) {
    return translations[key] || key; 
}
window.addEventListener('message', function(event) {
    let data = event.data
    if (data.action === "OpenDuiMenu") {
        
        let DoorStatus = data.dooropen
        let PropertyType = data.ptype
        let DuiActionTable = data.table
        document.querySelector(".button_option_panel .property_type img").src = PropertyType=='house'?"assets/house.png":"assets/garage.png"
        if (DoorStatus){
            document.querySelector(".button_option_panel .small_icon").classList.remove("red")
            document.querySelector(".button_option_panel .state").classList.remove("red")
            document.querySelector(".button_option_panel .small_icon").classList.add("green")
            document.querySelector(".button_option_panel .state").classList.add("green")
            setTimeout(() => {
                $('.button_option_panel .state').html(t('open'))
            }, 10);
            $('.button_option_panel .top_section').css('box-shadow', 'inset -200px 0px 100px -100px rgba(121, 215, 190, 0.8)')
        }
        else{
            document.querySelector(".button_option_panel .small_icon").classList.remove("green")
            document.querySelector(".button_option_panel .state").classList.remove("green")
            document.querySelector(".button_option_panel .small_icon").classList.add("red")
            document.querySelector(".button_option_panel .state").classList.add("red")
            setTimeout(() => {
                $('.button_option_panel .state').html(t('closed'))
            }, 10);
            $('.button_option_panel .top_section').css('box-shadow', 'inset -200px 0px 100px -100px rgba(249, 84, 84, 0.8)')
        }
        $(".action_container").html("")
        for (let i = 0; i < DuiActionTable.length; i++) {
            $(".action_container").append(`
                
            `)
        }
        $(".dui_section").css("display", "block")
        document.getElementById('dot_signal').style.animation = "reverse_popup_anim 0.35s ease, dot_animation2 2s infinite";
        setTimeout(() => {
            $(".dot_signal").css("display", "none")
            setTimeout(() => {
                $(".button_option_panel").css("display", "block")
                if (IsDUIDotOpened){
                    let elements = document.getElementsByClassName('popup_anim');
                    for (let i = 0; i < elements.length; i++) {
                        elements[i].style.animation = "popup_anim 0.35s ease";
                    }
                    IsDUIDotOpened = false
                }
            }, 20);
        }, 300);
    }
    else if (data.action === "OpenDuiDot") {
        
        IsDUIDotOpened = true
        $(".dui_section").css("display", "block")
        let elements = document.getElementsByClassName('popup_anim');
        for (let i = 0; i < elements.length; i++) {
            elements[i].style.animation = "reverse_popup_anim 0.35s ease";
        }
        setTimeout(() => {
            $(".button_option_panel").css("display", "none")
            setTimeout(() => {
                $(".dot_signal").css("display", "flex")
                document.getElementById('dot_signal').style.animation = "popup_anim 0.35s ease, dot_animation2 2s infinite";
            }, 20);
        }, 300);
    }
    else if (data.action === "OpenVehicleMenu") {
        VehicleData = data.vehicledata
        VehicleRepairing = data.repairing
        $(".dui_section").css("display", "block")
        $(".vehicle_info").css("display", "block")
        $(".first_layer").css("display", "block")
        CreateVehicleMenu()
        $(".second_layer").css("display", "none")
    }
    else if (data.action === "OpenVehicleMenu2") {
        VehicleData = data.vehicledata
        VehicleRepairing = data.repairing
        $(".dui_section").css("display", "block")
        $(".vehicle_info").css("display", "block")
        $(".second_layer").css("display", "block")
        CreateVehicleMenu()
        $(".first_layer").css("display", "none")
    }
    else if (data.action === "OpenApartmentMenu") {
        ApartmentTable = data.table
        SelectedApartment = data.selectedapartment - 1
        Currency = data.currencyform
        CreateApartmenteMenu()
        $(".dui_section").css("display", "block")
        $(".apartment_selector").css("display", "block")
        document.querySelector(".selected").style.opacity = "0";
    }
    else if (data.action === "OpenApartmentMenu2") {
        ApartmentTable = data.table
        SelectedApartment = data.selectedapartment - 1
        Currency = data.currencyform
        CreateApartmenteMenu()
        $(".dui_section").css("display", "block")
        $(".apartment_selector").css("display", "block")
        $(".apartment_selector").css("background-color", "transparent")
        document.querySelectorAll(".apartment_selector *").forEach(el => {
            el.style.opacity = "0";
        });
        document.querySelectorAll(".upper_layer").forEach(el => {
            el.style.opacity = "1";
        });
        document.querySelectorAll(".upper_layer *").forEach(el => {
            el.style.opacity = "0";
        });
        document.querySelector(".selected").style.opacity = "1";
        document.querySelectorAll(".selected *").forEach(el => {
            el.style.opacity = "1";
        });
    }
    else if (data.action === "CloseDui") {
        $(".dui_section").css("display", "none")
    }
    if (data.action === "OpenPropertyMenu") {
        Myproperties = data.table
        WifiUnlockPrice = data.wifiunlockprice
        Currency = data.currencyform
        OsTime = data.ostime
        SellToGameMultiplier = data.fastsalepurchaseprice
        MaxDelayedPriceMultiplier = data.delayedsalepurchaseprice
        GarageUpgrade = data.garageupgrade
        Furnitures = data.furnitures 
        KeyPrices = data.keyprices 
        ClosestProperty = data.selectedproperty
        SecurityObjects = data.securityobjects
        BrutalKeys = data.brutalkey
        BackgroundBlurFunction(BGBlur)
        show('properties_menu')
        if (CurrentPage == 'furnitures'){
            CurrentPage = 'properties'
        }
        BackgroundBlur("plugin_1", 'properties_panel')
        if (data.type == 'open'){
            SwitchPage(CurrentPage)
        }
        else{
            SwitchPage(CurrentPage, true)
        }
    } 
    else if (data.action === "OpenHouseCreationMenu") {
        show('property_creation_menu')
        PropertyTypes = data.types
        GarageIDs = data.allgarageid
        CreatePropertyCreation('house')
        PropertyCreationPanelType = 'house'
        BackgroundBlur("plugin_2", 'panel_creation')
    }
    else if (data.action === "OpenGarageCreationMenu") {
        PropertyTypes = data.types
        GarageIDs = data.allgarageid
        BackgroundBlurFunction(BGBlur)
        CreatePropertyCreation('garage')
        PropertyCreationPanelType = 'garage'
        show('property_creation_menu')
        BackgroundBlur("plugin_2", 'panel_creation')
    }
    else if (data.action === "OpenControlHelp") {
        HintTable = data.table
        ScreenTitle = data.text
        BackgroundBlurFunction(BGBlur)
        CreateHintMenu(data.furniture)
        show('hint_menu')
        show('screen_title')
    }
    else if (data.action === "HideControlHelp") {
        hide('hint_menu')
        hide('screen_title')
    }
    else if (data.action === "HideFurnitureInfos") {
        BackgroundBlurFunction(BGBlur)
        if (data.updatedfurnitures != undefined){
            Myproperties[CurrentProperty].furnitures = data.updatedfurnitures
        }
        $('#panel_chosed_furniture').css('animation', 'none')
        $('#panel_chosed_furniture').css('animation', 'reverse_Basic_popup 0.3s ease both')
        setTimeout(() => {
            BackgroundBlur("plugin_4", 'panel_chosed_furniture')
            $('.chosed_furniture').css('display', 'none')
        }, 300);
        CreateFurnitureMenu()
    }
    else if (data.action === "BringFurnituresUp") {
        $('#panel_furniture').css('animation', 'Basic_popup 0.3s ease both')
        $('#panel_chosed_furniture').css('animation', 'Basic_popup 0.3s ease both')
        $('.preferences_con').css('animation', 'Basic_popup 0.3s ease both')
        BackgroundBlurFunction(BGBlur)
        let interval = setInterval(() => {
            BackgroundBlur("plugin_4", 'panel_chosed_furniture')
            BackgroundBlur("plugin_3", 'panel_furniture')
        }, 1);
        setTimeout(() => {
            clearInterval(interval)
        }, 600);
    }
    else if (data.action === "OpenPurchaseMenu") {
        Currency = data.currencyform
        PurchasePropertyData = data.propertydata
        PropertyDebt = data.debt
        PurchaseData = data.purchasedata
        BillingCycle = data.billingcycle
        BackgroundBlurFunction(BGBlur)
        CreatePurchaseMenu()
        show('property_purchase_menu')
        BackgroundBlur("plugin_5", 'panel_purchase')
    }
    else if (data.action === "OpenAdminPropertiesMenu") {
        AdminTable = data.housingdata
        Currency = data.currencyform
        RealEstate = false
        BackgroundBlurFunction(BGBlur)
        show('admin_menu')
        CreateAdminMenu(document.getElementById('admin_search_input').value)
        BackgroundBlur("plugin_admin", 'panel_admin')
    }
    else if (data.action === "OpenRealEstatePropertiesMenu") {
        Balance = data.realestate.balance
        SoldProperties = data.realestate.soldProperties
        AdminTable = data.housingdata
        Currency = data.currencyform
        CanOpenBalance = data.balancemenu
        RealEstate = true
        BackgroundBlurFunction(BGBlur)
        show('admin_menu')
        CreateRealEstateMenu(document.getElementById('admin_search_input').value)
        BackgroundBlur("plugin_admin", 'panel_admin')
    }
    else if (data.action === "successCreation") {
        document.getElementById('rentable_input').checked = false
        document.getElementById('property_name').value = ''
        document.getElementById('property_price').value = ''
        document.getElementById('property_img').value = ''
        document.getElementById('street_number').value = ''
        document.getElementById('garage_id_input').value = ''
        document.getElementById('vehicle_exit').value = ''
        document.getElementById('entry_door').value = ''
        document.getElementById('street_input').value = ''
        if (document.getElementById('exit_door')){
            document.getElementById('exit_door').value = ''
        }
    }
    else if (data.action === "OpenCloakroomMenu") {
        show('clothe_menu')
        $(".clothe_conatiner").html("")
        Clothe = data.table
        if (Clothe.length > 0) {
            for (let index = 0; index < Clothe.length; index++) {
                $(".clothe_conatiner").append(`
                    
                        ${Clothe[index].label}
                        
                     
                `)
            }
        } else {
            $(".clothe_conatiner").html("There are no available clothes")
        }
        BackgroundBlurFunction(BGBlur)
        BackgroundBlur("plugin3", 'panel_clothe')
    } 
    else if (data.action === "FadeOut") {
        $('.loading_screen').css('display', 'block')
        $('.top_box').css('animation', 'box 0.7s ease both')
        $('.bottom_box').css('animation', 'bottom_box 0.7s ease both')
        $('.appear_con').css('animation', 'logo_container 0.7s ease both 0.6s')
    }
    else if (data.action === "FadeIn") {
        $('.top_box').css('animation', 'reverse_box 0.7s ease both 0.6s')
        $('.bottom_box').css('animation', 'reverse_bottom_box 0.7s ease both 0.6s')
        $('.appear_con').css('animation', 'reverse_logo_container 0.7s ease both')
        if (Loader){
            clearTimeout(Loader)
        }
        Loader = setTimeout(() => {
            $('.loading_screen').css('display', 'none')
            Loader = false
        }, 1200);
    } 
    else if (data.action === "close") {
        Close()
    }
})
document.onkeydown = function(data) {
    if (event.key == 'Escape') {
        Close()
    } 
    if (event.key == 'Backspace') {
        UnselectFurniture()
    } 
}
function Close() {
    hide('properties_menu')
    hide('property_creation_menu')
    hide('property_purchase_menu')
    hide('admin_menu')
    hide('question_panel')
    hide('data_entry_panel')
    hide('property_sell_menu')
    hide('balance_panel')
    hide('furniture_menu')
    hide('tutorial_menu')
    hide('property_purchase_menu_from_rent')
    hide('clothe_menu')
    ResetFurniturePanel()
    $('.property_sell_menu').css('display', 'none')
    $('.property_purchase_menu_from_rent').css('display', 'none')
    $('.admin_menu .panel').css("filter", "brightness(100%)")
    $('.properties_menu .panel').css("filter", "brightness(100%)")
    document.removeEventListener("click", handleClick)
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "close"}))
}
function BackgroundBlurFunction(data){
    BGBlur = data
    if (!BGBlur){
        document.querySelectorAll('*').forEach(el => {
            el.style.backdropFilter = 'none';
        });
        $('.panel').css('background-color', 'background-color: rgba(61, 65, 70, 1);')
    }
}
function UnselectFurniture(){
    window.postMessage({ action: 'HideFurnitureInfos' }, '*');
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "unselectFurniture"}))
}
function SendClothe(skin) {
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({
        action: "cloakroom",
        skin
    }))
}
function OpenTutorialPanel(OpenedFrom){
    TutorialImages = {
        properties: [
            ['https://i.ibb.co/XZN7KTDZ/tutorial-properties.png', t('properties_1')],
            ['https://i.ibb.co/d4PkN2By/tutorial-messages.png', t('properties_2')],
            ['https://i.ibb.co/7JFP5xyd/tutorial-rename.png', t('properties_3')],
            ['https://i.ibb.co/JWGCpZ7j/tutorial-keys.png', t('properties_4')]
        ],
        controls: [
            ['https://i.ibb.co/93gc4nzP/tutorial-bills.png', t('controls_1')],
            ['https://i.ibb.co/TDRzV3Zm/tutorial-rent.png', t('controls_2')],
            ['https://i.ibb.co/60CPZ274/tutorial-security.png', t('controls_3')],
            ['https://i.ibb.co/FkJxZFj4/tutorial-paints.png', t('controls_4')]
        ],
        cameras: [
            ['https://i.ibb.co/qLB19T8G/tutorial-cameras.png', t('cameras_1')]
        ],
        furnitures: [
            ['https://i.ibb.co/CpYnhRh7/tutorial-furniture-1.png', t('furnitures_1')],
            ['https://i.ibb.co/DfRfdxwQ/tutorial-furniture-2.png', t('furnitures_2')]
        ],
    }
    OpenedTutoralFrom = OpenedFrom
    TutorialTable = []
    CurrentTutorialPage = 0
    if (OpenedFrom == 'properties_menu'){
        if (CurrentPage == 'garage'){
            return
        }
        TutorialTable = TutorialImages[CurrentPage]
        hide('properties_menu')
    }
    else if(OpenedFrom == 'furniture'){
        TutorialTable = TutorialImages['furnitures']
    }
    $(".page_chooser#tutorial_chooser").html('')
    for (let i = 0; i < TutorialTable.length; i++) {
        $(".page_chooser#tutorial_chooser").append(`
            
                ${i == SelectedApartment?'
':''}
                
${ApartmentTable[i].label}
                ${ApartmentTable[i].propertyid}
                ${status_txt}
                ${ApartmentTable[i].owner}
            H'+AdminTable[i].house +'  G'+AdminTable[i].garage +'  ${AttachedProperty}${AdminTable[i].id} `
                        }
                        else{
                            if (AdminTable[i].type == 'APARTMENT'){
                                IdButton = `${AdminTable[i].id}
`
                            }
                            else{
                                IdButton = `
                                
                                
                                ${AdminTable[i].type == 'APARTMENT'?'':`
`}
                                
${AdminTable[i].label}
                                ${IdButton}
                                
${AdminTable[i].salePrice.toLocaleString('hu-HU')+' '+Currency}
                                ${t('owner')}
                                ${AdminTable[i].owner}
                                
                                    
                                        ${t("remove")} 
                                    
                                    
                                        ${t('switch')} 
                                    
                                 
                             
                        `)
                    }
                }
            }
        }
        else{
            $('.properties_container').html(`${t('no_properties_to_show')} 
`)
        }
        
    }
}
function CreateRealEstateMenu(filter){
    if (InSoldProperties){
        ChangeSoldProperties(filter)
    }
    $('.balance_panel .balance').html(Balance.toLocaleString('hu-HU')+' '+Currency)
    $('.sold_btn').css("display", "block")
    if (!CanOpenBalance){
        $('#balance_btn').css("display", "none")
    }
    if (filter != null){
        filter = filter.toUpperCase()
    }
    else{
        filter = ''
    }
    $('.properties_container').html('')
    if (AdminTable.length > 0){
        for (const i in AdminTable) {
            if (((AdminPropertyType == 'house_admin') && (AdminTable[i].ptype == 'house')) || ((AdminPropertyType == 'garage_admin') && (AdminTable[i].ptype == 'garage'))){
                if (AdminTable[i].label.toUpperCase().indexOf(filter) > -1){
                    $('.properties_container').append(`
                        
                            
                            ${AdminTable[i].label}
                            ${AdminTable[i].id}
                            ${AdminTable[i].salePrice.toLocaleString('hu-HU')+' '+Currency}
                            ${t('type')}
                            ${AdminTable[i].type}
                            
                                ${t('delete')} 
                            
                         
                    `)
                }
            }
        }
    }
    else{
        $('.properties_container').html(`${t('no_properties_to_show')} 
`)
    }
}
function ChangeSoldProperties(filter){
    if (!InSoldProperties){
        InSoldProperties = true
        document.getElementById("sold_btn").classList.add("active")
        document.querySelector(".slider#admin").style.display = 'none'
        if (filter != null){
            filter = filter.toUpperCase()
        }
        else{
            filter = ''
        }
        $('.properties_container').html('')
        for (const i in SoldProperties) {
            if (SoldProperties[i].label.toUpperCase().indexOf(filter) > -1){
                $('.properties_container').append(`
                    
                        
                        ${SoldProperties[i].label}
                        ${SoldProperties[i].id}
                        
                            
                            
                                ${SoldProperties[i].price.toLocaleString('hu-HU')+' '+Currency}
                             
                         
                        
                            
                            
                                
                                    
                                        ${Math.round((SoldProperties[i].profit/SoldProperties[i].price*100) * 10) / 10}%
                                     
                                    
                                        ${SoldProperties[i].profit.toLocaleString('hu-HU')+' '+Currency}
                                     
                                 
                             
                         
                     
                `)
            }
        }
    }
    else{
        InSoldProperties = false
        document.getElementById("sold_btn").classList.remove("active")
        document.querySelector(".slider#admin").style.display = 'block'
        CreateRealEstateMenu(document.getElementById('admin_search_input').value)
    }
}
function TeleportToProperty(propertyID){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "teleportToProperty", propertyID}))
}
function ChangeAdminPropertyType(id){
    AdminPropertyType = id
    let rect = document.getElementById(id).getBoundingClientRect();
    let parentRect = document.querySelector(".slider_container#admin").getBoundingClientRect();
    let elementCenterY = rect.left - parentRect.left;
    document.querySelector(".slider#admin").style.left = `${elementCenterY-3}px`;
    CreateAdminMenu(document.getElementById('admin_search_input').value)
}
function CreateHintMenu(value){
    if (value){
        $('.hint_menu .right_side').css('display', 'flex')
    }
    else{
        $('.hint_menu .right_side').css('display', 'none')
    }
    
    $('.screen_title .text').html('
`)
            for (let i = 0; i < item[0].length; i++) {
                $('.hint_menu .left_side #hint'+HintCount).append(`${item[0][i]}
`)
            }
            $('.hint_menu .left_side #hint'+HintCount).append(`${item[1]}
`)
        } else {
            $('.hint_menu .left_side').append(``)
        }
    });
}
function PurchaseProperty(){
    if (PurchaseType == 'purchase'){
        $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "purchaseProperty"}))
    }
    else{
        $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "rentProperty"}))
    }
}
function GiveBid(){
    let amount = document.getElementById('bid_input').value.replace(/\s/g, "")
    TriggerCallback('giveBid', {amount}).done((cb) => {
        PurchaseData = cb
        RefreshBid(false)
        document.getElementById('bid_input').value = ''
    });
}
function SendViewProperty(){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "viewProperty"}))
}
function CreatePurchaseMenu(){
    if (PurchasePropertyData.ptype == 'house'){
        if (PurchasePropertyData.type == 'APARTMENT'){
            $('.property_purchase_menu .title').html(t('aparment_purchase'))
        }
        else{
            $('.property_purchase_menu .title').html(t('house_purchase'))
        }
        
        document.querySelector(".property_purchase_menu .big_icon img").src = "assets/house.png"
        $("#garage_section_con").css("display", "flex")
        if (PurchasePropertyData.garage == 0){
            document.getElementById("property_garage").classList.add("gray")
            $(".property_purchase_menu #property_garage").html('
')
    }
    else{
        $('#property_price_container').html(`
            
        `)
        let Percentage = Math.round((100-(PurchaseData.price/PurchaseData.originalPrice)*100) * 10) / 10 
        if (Percentage > 0){
            $(".property_purchase_menu #property_deal_percentage").html('
                
                    ${t('buying_price')}${t('amount_you_bought_the_property')} 
                 
                
             
            
                
                    ${t('price')}${t('amount_you_get_instant')} 
                 
                
             
            ${t('sell')} 
        `)
    }
    else{
        $('.property_sell_menu .container').html(`
            ${t('sell_property_to_player')}
            
                
                    ${t('max_price')}${t('max_you_can_sell')} 
                 
                
             
            ${t('price')}
            
                
            ${t('phone_number')}
            
                
            ${t('sell')} 
        `)
    }
}
function SellProperty(){
    let salePrice
    let phoneNumber
    if (document.getElementById('sell_price') != undefined){
        salePrice = document.getElementById('sell_price').value.replace(/\s/g, "")
        phoneNumber = document.getElementById('sell_phone').value
    }
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "saleProperty", propertyID:Myproperties[ChoosedPropertyForSell].id, sellType:SellType, salePrice, phoneNumber}))
    hide('property_sell_menu')
    $('.properties_menu .panel').css("filter", "brightness(100%)")
    CurrentProperty = (CurrentPropertySelectionPage*6)-6
    SelectProperty(CurrentProperty)
    if (document.getElementById('select_'+CurrentProperty)){
        document.getElementById('select_'+CurrentProperty).disabled = true
    }
}
function CancelSaleProperty(ChoosedProperty){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "cancelSale", propertyID:Myproperties[ChoosedProperty].id}))
}
function ChangePurchaseType(id){
    let rect = document.getElementById(id).getBoundingClientRect();
    let parentRect = document.querySelector(".slider_container#purchase").getBoundingClientRect();
    let elementCenterY = rect.left - parentRect.left;
    if (elementCenterY == 0){elementCenterY = 7}
    document.querySelector(".slider#purchase").style.left = `${elementCenterY}px`;
    PurchaseType = id
    if (id == 'purchase'){
        $('.property_rent_part').css('display', 'none')
        $('.property_purchase_part').css('display', 'flex')
        if (PurchasePropertyData.ptype == 'house'){
            $('.property_purchase_menu .title').html(t('house_purchase'))
        }
        else{
            $('.property_purchase_menu .title').html(t('garage_purchase'))
        }
        if (PurchasePropertyData.phone != '' && PurchasePropertyData.phone != null){
            $('.offer_part').css('display', 'none')
            $(".property_phone").css('display', 'flex')
            $("#property_phone").html(PurchasePropertyData.phone)
        }
        else{
            $('.offer_part').css('display', 'flex')
            $(".property_phone").css('display', 'none')
        }
        $("#purchase_property_btn").html(t('purchase'))
    }
    else{
        $('.property_purchase_part').css('display', 'none')
        $('.property_rent_part').css('display', 'flex')
        if (PurchasePropertyData.ptype == 'house'){
            $('.property_purchase_menu .title').html(t('house_rent'))
        }
        else{
            $('.property_purchase_menu .title').html(t('garage_rent'))
        }
        $("#purchase_property_btn").html(t('rent'))
        $(".property_purchase_menu #property_price").html(PurchaseData.price.toLocaleString('hu-HU')+' '+Currency)
        $(".property_purchase_menu #property_rent").html(PurchaseData.rent.toLocaleString('hu-HU')+' '+Currency)
    }
}
function CreatePropertyCreation(Type){
    $('.dropdown_container .dropdown-menu').html('')
    for (const key in PropertyTypes['SHELL']) {
        $('.dropdown_container .dropdown-menu').append(`
            ${PropertyTypes['SHELL'][key].label} You don't have any cameras. Buy one from the electronics category to use it.
")
    }
    
}
function LoadCamerasForPage(){
    $(".list_container#cam_list").html('')
    for (let i = (CurrentCameraSelectionPage*6)-6; i < CurrentCameraSelectionPage*6; i++) {
        if (Myproperties[CurrentProperty].cams[i] != undefined){
            if (Myproperties[CurrentProperty].cams[i].camdata != undefined){
                $(".list_container#cam_list").append(`
                    
                        
                        CAM #${i+1}
                        ${t('state')}
                        ${Myproperties[CurrentProperty].cams[i].status?`
                            
${t('online')}
                            ${t('select')} 
                            `:`
                            
${t('offline')}
                             ${t('select')} 
                            `}
                        
                    
 
                `)
            }
            else{
                $(".list_container#cam_list").append(`
                    
                        
                        CAM #${i+1}
                        ${t('state')}
                        ${Myproperties[CurrentProperty].cams[i].status?`
                            
${t('online')}
                            ${t('setup')} 
                            `:`
                            
${t('offline')}
                            ${t('setup')} 
                            `}
                    
 
                `)
            }
        }
        else{
            $(".list_container#cam_list").append(`
                 
            `)
        }
    }
}
function SendCameraSetup(objectid){
    Close()
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "cameraSetup", propertyID:Myproperties[CurrentProperty].id, objectid}))
}
function SendCameraSelect(objectid){
    Close()
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "cameraSelect", propertyID:Myproperties[CurrentProperty].id, objectid}))
}
/////////////////////////////////////////////////////////////////////[PROPERTY PAGE]/////////////////////////////////////////////////////////////////
function ChoosePropertyPage(element, number){
    CurrentPropertySelectionPage = number+1
    for (let i = 0; i < NumberOfPages; i++) {
        document.getElementById("page_"+i).classList.remove("choosed")
    }
    element.classList.add("choosed")
    LoadPropertiesForPage()
}
function CreatePropertyPage(){
    NumberOfPages = (Myproperties.length-(Myproperties.length%7))/7+1
    $(".page_chooser#property_chooser").html('')
    for (let i = 0; i < NumberOfPages; i++) {
        if (CurrentPropertySelectionPage-1 == i){
            $(".page_chooser#property_chooser").append(`
                H'+Myproperties[i].house +'  G'+Myproperties[i].garage +'  
                    
                    ${PropertyButton}
                    
${Myproperties[i].label}
                    ${AttachedProperty}${Myproperties[i].id}
                    ${t('tenure')}
                    ${Myproperties[i].isRented?t('renter'):t('owner')}
                    ${t('select')} 
                 
            `)
        }
        else{
            $(".list_container#property_list").append(`
                
            `)
        }
    }
    if (CurrentProperty == null || ClosestProperty != null){
        // Selects the closest of your properties from the menu
        if (ClosestProperty != null){
            for (let i = 0; i < Myproperties.length; i++) {
                if (Myproperties[i].id == ClosestProperty){
                    if (document.getElementById('select_'+CurrentProperty)){
                        document.getElementById('select_'+CurrentProperty).disabled = false
                    }
                    if (document.getElementById('select_'+i)){
                        document.getElementById('select_'+i).disabled = true
                    }
                    if (CurrentProperty == null || ControlSectionState != Myproperties[i].ptype){
                        CurrentProperty = i
                        LoadControlSection()
                    }
                    CurrentProperty = i
                    LoadBasicPropertyDatas()
                    CreateMessages()
                    ClosestProperty = null
                    if (Myproperties[CurrentProperty].type != 'MLO'){
                        $('.door_lock_btn').css('display', 'none')
                    }
                    else{
                        $('.door_lock_btn').css('display', 'block')
                    }
                    $('.key_count').html(Myproperties[CurrentProperty].keysquantity)
                    return
                }
            }
            CurrentProperty = (CurrentPropertySelectionPage*6)-6
            SelectProperty(CurrentProperty)
            document.getElementById('select_'+CurrentProperty).disabled = true
            ClosestProperty = null
        }
        else{
            CurrentProperty = (CurrentPropertySelectionPage*6)-6
            SelectProperty(CurrentProperty)
            document.getElementById('select_'+CurrentProperty).disabled = true
        }
    }
    else if (CurrentProperty != null){
        if (Myproperties[CurrentProperty].type != 'MLO'){
            $('.door_lock_btn').css('display', 'none')
        }
        else{
            $('.door_lock_btn').css('display', 'block')
        }
        $('.key_count').html(Myproperties[CurrentProperty].keysquantity)
    }
}
function SelectProperty(number){
    AllElements = document.getElementsByClassName('select_btn')
    for (const key in AllElements) {
        AllElements[key].disabled = false
    }
    if (document.getElementById('select_'+number)){
        document.getElementById('select_'+number).disabled = true
    }
    
    CurrentProperty = number
    LoadBasicPropertyDatas()
    LoadControlSection()
    CreateMessages()
    if (Myproperties[CurrentProperty].type != 'MLO'){
        $('.door_lock_btn').css('display', 'none')
    }
    else{
        $('.door_lock_btn').css('display', 'block')
    }
    $('.key_count').html(Myproperties[CurrentProperty].keysquantity)
}
function LoadBasicPropertyDatas(){
    document.getElementById('property_name_in').value = Myproperties[CurrentProperty].label
    $(".properties_menu .street").html(Myproperties[CurrentProperty].address)
    if (Myproperties[CurrentProperty].doorOpen){
        $(".properties_menu .state#property_menu").html(t('open'))
        $(".properties_menu .state#property_menu").css("color", '#79D7BE')
        document.getElementById("header_door").classList.remove("red")
        document.getElementById("header_door").classList.add("green")
    }
    else{
        $(".properties_menu .state#property_menu").html(t('closed'))
        $(".properties_menu .state#property_menu").css("color", '#F95454')
        document.getElementById("header_door").classList.remove("green")
        document.getElementById("header_door").classList.add("red")
    }
    
}
function CreateMessages(){
    $('.notifications').html("")
    if (Myproperties[CurrentProperty].messages.length > 0){
        for (let i = 0; i < Myproperties[CurrentProperty].messages.length; i++) {
            let notify_icon
            if (Myproperties[CurrentProperty].messages[i].type == 'check'){
                notify_icon = '
                    ${notify_icon}
                    ${Myproperties[CurrentProperty].messages[i].title}
                    ${date.toLocaleString("hu-HU", options)}
                    ${Myproperties[CurrentProperty].messages[i].message}
                 
            `)
        }
        if (LastProperty == undefined || LastProperty != CurrentProperty){
            let Notifies = document.getElementsByClassName("notify_element")
            for (let index = 0; index < Notifies.length; index++) {
                Notifies[index].style.animation = 'none'
                Notifies[index].offsetHeight
                Notifies[index].style.animation = "notify_element 0.4s ease both " + (index / 60) + "s"
            }
        }
    }
    else{
        $('.notifications').html("You don't have any messages!
")
    }
    LastProperty = CurrentProperty
    const element = document.getElementById("notifications");
    element.scrollTop = element.scrollHeight;
}
function LoadControlSection(){
    ControlSectionState = Myproperties[CurrentProperty].ptype
    if (Myproperties[CurrentProperty].ptype == 'house'){
        $('.hidden_logo').css('opacity', '0')
        $('.control_section#property_control').css('height', '275px')
        $('.control_section#property_control').html(`
            
            
            
            
            
        `)
    }
    else{
        $('.hidden_logo').css('opacity', '1')
        $('.control_section#property_control').css('height', '140px')
        $('.control_section#property_control').html(`
            
            
            
        `)
    }
}
function ChangePaint(id){
    let PaintsLength = 0
    for (const key in Myproperties[CurrentProperty].paints) {
        PaintsLength =  PaintsLength + 1
    }
    if (id == 'left_arrow'){
        if (0 > ChoosedPaint - 1){
            ChoosedPaint = PaintsLength - 1
        }
        else{
            ChoosedPaint = ChoosedPaint - 1
        }
    }
    else{
        if (ChoosedPaint + 1 >= PaintsLength){
            ChoosedPaint = 0
        }
        else{
            ChoosedPaint = ChoosedPaint + 1
        }
    }
    $('.paint_viewer').css('background-image', `url('${Myproperties[CurrentProperty].paints[ChoosedPaint].link}')`)
    if (Myproperties[CurrentProperty].theme == ChoosedPaint){
        $('#change_paint').css('display', 'none')
    }
    else{
        $('#change_paint').css('display', 'block')
        $('#change_paint').html(Myproperties[CurrentProperty].paints[ChoosedPaint].price.toLocaleString('hu-HU')+' '+Currency)
    }
}
function SwitchPage(id, noanim){
    CurrentPage = id
    let rect = document.getElementById(id).getBoundingClientRect();
    let parentRect = document.querySelector("#property_control").getBoundingClientRect();
    let elementCenterY = rect.top - parentRect.top;
    document.querySelector(".selector#property").style.top = `${elementCenterY}px`;
    if (id == 'properties'){
        if (BrutalKeys){
            $('.right_container').html(`
                
                    
                    ${t('remained')}
                    
                    
                        ${KeyPrices.newkey .toLocaleString('hu-HU')+' '+Currency}
                     
                    
                        ${KeyPrices.lockreplacement.toLocaleString('hu-HU')+' '+Currency}
                     
                 
            `)
        }
        else{
            $('.right_container').html(`
               
                    
                    
                    
                    
                    ${t('remained')}
                    
                    
                        ${KeyPrices.newkey .toLocaleString('hu-HU')+' '+Currency}
                     
                    
                        ${KeyPrices.lockreplacement.toLocaleString('hu-HU')+' '+Currency}
                     
                 
            `)
        }
        
        $('.bottom_container').html(`
            
            
                
            
            
        `)
        CreatePropertyPage()
        LoadBasicPropertyDatas()
    }
    else if (id == 'controls'){
        if (Myproperties[CurrentProperty].isRented){
            $('.right_container').html(`
                
                     
                     ${t('rent')}
                     ${t('balance')}
                     ${Myproperties[CurrentProperty].bills.rent.toLocaleString('hu-HU')+' '+Currency}
                      0?'':'disabled'}>${Myproperties[CurrentProperty].bills.rent > 0?t('pay'):t('all_paid')} 
                  
            `)
        }
        else{
            if (Myproperties[CurrentProperty].paints != null){
                $('.right_container').html(`
                    
                        
                        
                            
                        ${Myproperties[CurrentProperty].paints[Myproperties[CurrentProperty].theme].price.toLocaleString('hu-HU')+' '+Currency} 
                     
                `)
            }
            else{
                $('.right_container').html(`
                    
                        ${t('no_available_paints')}
                     
                `)
            }
        }
        $('.bottom_container').html(`
            
                
                    
                    ${t('electricity')}
                    ${t('balance')}
                    ${Myproperties[CurrentProperty].bills.electricity.toLocaleString('hu-HU')+' '+Currency}
                     0?'':'disabled'}>${Myproperties[CurrentProperty].bills.electricity > 0?t('pay'):t('all_paid')} 
                 
                
                    
                    ${t('gas')}
                    ${t('balance')}
                    ${Myproperties[CurrentProperty].bills.gas.toLocaleString('hu-HU')+' '+Currency}
                     0?'':'disabled'}>${Myproperties[CurrentProperty].bills.gas > 0?t('pay'):t('all_paid')} 
                 
                
                    
                    ${t('water')}
                    ${t('balance')}
                    ${Myproperties[CurrentProperty].bills.water.toLocaleString('hu-HU')+' '+Currency}
                     0?'':'disabled'}>${Myproperties[CurrentProperty].bills.water > 0?t('pay'):t('all_paid')} 
                 
             
            
                
                    
                    ${t('wifi')}
                    ${Myproperties[CurrentProperty].securityData.wifi?t('unlocked'):t('locked')}
                    ${t('wifi_description')}
                    ${Myproperties[CurrentProperty].securityData.wifi?t('balance'):t('price')}
                    ${(Myproperties[CurrentProperty].securityData.wifi?Myproperties[CurrentProperty].bills.wifi:WifiUnlockPrice).toLocaleString('hu-HU')+' '+Currency}
                    ${Myproperties[CurrentProperty].securityData.wifi?t('pay'):t('unlock')} 
                 
                
                    
                    ${t('security')}
                    ${t('level')} ${Myproperties[CurrentProperty].securityData.level}
                    ${t('security_description')}
                    ${t('next_level')}
                    ${Myproperties[CurrentProperty].securityData.nextPrice != undefined?Myproperties[CurrentProperty].securityData.nextPrice+' '+Currency:t('max')}
                    ${Myproperties[CurrentProperty].securityData.maxLevel == true?t('max_level'):t('upgrade')} 
                 
              
        `)
        CreateMessages()
        LoadBasicPropertyDatas()
    }
    else if (id == 'garage'){
        if (Myproperties[CurrentProperty].isRented){
            $('.right_container').html(`
                
                     
                     ${t('rent')}
                     ${t('balance')}
                     ${Myproperties[CurrentProperty].bills.rent.toLocaleString('hu-HU')+' '+Currency}
                      0?'':'disabled'}>${Myproperties[CurrentProperty].bills.rent > 0?t('pay'):t('all_paid')} 
                  
            `)
        }
        else{
            if (Myproperties[CurrentProperty].paints != null){
                $('.right_container').html(`
                    
                        
                        
                            
                        ${Myproperties[CurrentProperty].paints[Myproperties[CurrentProperty].theme].price.toLocaleString('hu-HU')+' '+Currency} 
                     
                `)
            }
            else{
                $('.right_container').html(`
                    
                        ${t('no_available_paints')}
                     
                `)
            }
        }
        $('.bottom_container').html(`
            
            
            
                
                    
                    ${t('cleaning')}
                    ${Myproperties[CurrentProperty].lastPaid.cleaning?t('unlocked'):t('locked')}
                    ${t('cleaning_description')}
                    ${GarageUpgrade.Clean .price.toLocaleString('hu-HU')+' '+Currency} 
                 
                
                    
                    ${t('repairing')}
                    ${Myproperties[CurrentProperty].lastPaid.repairing?t('unlocked'):t('locked')}
                    ${t('repairing_description')}
                    ${GarageUpgrade.Repair.price.toLocaleString('hu-HU')+' '+Currency} 
                 
             
        `)
        CreateMessages()
        LoadBasicPropertyDatas()
        
        for (let i = 0; i < Myproperties[CurrentProperty].vehicleSpaces; i++) {
            $(".space_container").append(`
                 
            `)
        }
        for (let i = 0; i < Myproperties[CurrentProperty].vehicleSpaces; i++) {
            if (Myproperties[CurrentProperty].vehicles2[i] != undefined){
                let dashoffset = 440-140*((Myproperties[CurrentProperty].vehicles2[i].ostime-Myproperties[CurrentProperty].vehicles2[i].stored)/Myproperties[CurrentProperty].vehicles2[i].repairtime)
                if (Myproperties[CurrentProperty].vehicles2[i].ostime - Myproperties[CurrentProperty].vehicles2[i].stored > Myproperties[CurrentProperty].vehicles2[i].repairtime){
                    dashoffset = 440-140
                }
                $(".vehicles_container").append(`
                    
                        
                            
                                 
                        
                        ${Myproperties[CurrentProperty].vehicles2[i].name}
                        ${Myproperties[CurrentProperty].vehicles2[i].plate}
        
                     
                `)
            }
            else{
                $(".vehicles_container").append(`
                   
                `)
            }
        }
         
    }
    else if (id == 'cameras'){
        $('.right_container').html(`
            
                 
                 ${t('cctv_station')}
                 ${t('state')}
                 ${Myproperties[CurrentProperty].securityData.status?`
${t('online')}
`:`
${t('offline')}
`}
                 
${t('repair')} 
              
        `)
        $('.bottom_container').html(`
            
                
                
        `)
        CreateCameraPage()
        CreateMessages()
        LoadBasicPropertyDatas()
    }
    else if (id == 'furnitures'){
        noanim = true
        TriggerCallback('furnituresMenu', {}).done((cb) => {
            if (cb != false){
                InsideOrOutside = cb
                hide('properties_menu')
                show('furniture_menu')
                CreateFurnitureMenu()
                BackgroundBlur("plugin_3", 'panel_furniture')
            }
            else{
                SwitchPage('properties')
            }
        });
    }
    let HomeCons = document.getElementsByClassName("home_con")
    for (let index = 0; index < HomeCons.length; index++) {
        HomeCons[index].style.animation = 'none'
        if (!noanim){
            HomeCons[index].offsetHeight
            HomeCons[index].style.animation = "Home_cons 0.4s ease both " + (index / 100) + "s"
        }
    }
}
function SendCCTVRepair(){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "repairCCTVStation", propertyID:Myproperties[CurrentProperty].id}))
}
function SendOpenDoorLock(){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "manageDoorLocks", propertyID:Myproperties[CurrentProperty].id}))
}
function SendChangeLock(){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "lockReplacement", propertyID:Myproperties[CurrentProperty].id}))
}
function SendBuyKey(){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "addNewKey", propertyID:Myproperties[CurrentProperty].id}))
}
function SendGarageUpgrade(type){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "garageUpgrade", propertyID:Myproperties[CurrentProperty].id, type}))
}
function SendPayBill(type){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "payBill", propertyID:Myproperties[CurrentProperty].id, type}))
}
function SendUpgradeSecurity(){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "upgradeSecurity", propertyID:Myproperties[CurrentProperty].id}))
}
function SendPropertyNameChange(newLabel){
    if (newLabel != Myproperties[CurrentProperty].label){
        $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "changePropertyLabel", propertyID:Myproperties[CurrentProperty].id, newLabel}))
    }
}
function handleClick(event) {
    let input = document.getElementById("property_name_in")
    let sell_menu = document.getElementById("property_sell_menu")
    let purchase_menu = document.getElementById("property_purchase_menu_from_rent")
    if (event.target !== input) {
        SendPropertyNameChange(input.value);
    }
    if (!sell_menu.contains(event.target) && sell_menu.style.display == 'block') {
        hide('property_sell_menu')
        $('.properties_menu .panel').css("filter", "brightness(100%)")
    }
    if (!purchase_menu.contains(event.target) && purchase_menu.style.display == 'block'){
        hide('property_purchase_menu_from_rent')
        $('.properties_menu .panel').css("filter", "brightness(100%)")
    }
}
function CheckIfCanCreateProperty(){
    if ((PropertyCreationKey != null || PropertyCreationType == 'MLO') && document.getElementById('property_name').value.length > 0 
        && document.getElementById('property_price').value.length > 0 
        && document.getElementById('entry_door').value.length > 0 
        && document.getElementById('street_number').value.length > 0 
        && ((document.getElementById('vehicle_exit').value.length > 0 && PropertyCreationPanelType == 'garage') || PropertyCreationPanelType != 'garage')
        && ((PropertyCreationType == 'SHELL' && document.getElementById('exit_door').value.length > 0) || PropertyCreationType != 'SHELL')){
        document.getElementById('create_property_btn').disabled = false
    }
    else{
        document.getElementById('create_property_btn').disabled = true
    }
}
function CreateProperty(){
    let Rentable = document.getElementById('rentable_input').checked
    let Name = document.getElementById('property_name').value
    let Price = document.getElementById('property_price').value
    let URL = document.getElementById('property_img').value
    let Number = document.getElementById('street_number').value
    let Garage = document.getElementById('garage_id_input').value
    let VehicleExit = document.getElementById('vehicle_exit').value
    let table = [PropertyCreationType, PropertyCreationKey, Rentable, Name, Price.replace(/\s/g, ""), URL, PropertyInfos[0], null, PropertyInfos[1], Number, Garage, VehicleExit]
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "createProperty", table}))
}
function CheckGarageID(value){
    let Found = false
    for (let i = 0; i < GarageIDs.length; i++) {
        if (value.toUpperCase() == GarageIDs[i]){
            Found = true
        }
    }
    if (Found){
        $('#garage_id_input').css('border', 'solid 2px rgba(121, 215, 190, 0.719)')
        $('#garage_id_input').css('background-color', 'rgba(121, 215, 190, 0.288)')
    }
    else{
        $('#garage_id_input').css('border', 'solid 2px rgba(211, 211, 211, 0.705)')
        $('#garage_id_input').css('background-color', 'rgba(255, 255, 255, 0.212)')
    }
}
function GetPlayerCurrentCoord(){
    TriggerCallback('GetPlayerCoord', {}).done((cb) => {
        PropertyInfos = cb
        document.getElementById('entry_door').value = PropertyInfos[0]
        document.getElementById('street_input').value = PropertyInfos[1]
        document.getElementById('street_number').value = PropertyInfos[2]
        CheckIfCanCreateProperty()
    });
}
function GetExitCoord(){
    Close()
    TriggerCallback('shellPositions', {model:PropertyCreationKey}).done((cb) => {
        show('property_creation_menu')
        if (cb != 'nil'){
            document.getElementById('exit_door').value = cb
        }
        else{
            document.getElementById('exit_door').value = ''
        }
        CheckIfCanCreateProperty()
    });
}
function GetVehicleExitCoord(){
    Close()
    TriggerCallback('vehiclePosition', {}).done((cb) => {
        show('property_creation_menu')
        if (cb != 'nil'){
            document.getElementById('vehicle_exit').value = cb
        }
        CheckIfCanCreateProperty()
    });
}
function ChangeDropdownText(Label, key){
    PropertyCreationKey = key
    $('.option_dropdown_btn').html(Label)
    CheckIfCanCreateProperty()
    if (document.getElementById('set_exit_door')){
        document.getElementById('set_exit_door').disabled = false
    }
}
function ChangeProperyInType(id){
    PropertyCreationType = id
    if (id == 'SHELL' || id == 'IPL'){
        $('#panel_creation .dropdown_container').html(`
            
                ${t('choose')} 
                
            
        `)
        if (id == 'SHELL'){
            $('.dropdown_container .dropdown-menu').html('')
            for (const key in PropertyTypes['SHELL']) {
                $('.dropdown_container .dropdown-menu').append(`
                    ${PropertyTypes['SHELL'][key].label} ${PropertyTypes['IPL'][key].label} 
                    
            `)
        }
        if (PropertyCreationPanelType == 'house'){
            $('.house_con.garage_id').css('display', 'block')
        }
    }
    else{
        $('#panel_creation .dropdown_container').html(``)
        $('#panel_creation .doors_container').html(`
            
                
        `)
        $('.house_con.garage_id').css('display', 'none')
    }
    BackgroundBlur("plugin_2", 'panel_creation')
    CheckIfCanCreateProperty()
}
function TriggerCallback(event, data) {
    data.action = event;
    return $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify(data)).promise();
}
function BackgroundBlur(element, target) {
    if (BGBlur){
        var bodyRect = document.body.getBoundingClientRect();
        let elemRect = getTotalBoundingBox(target); 
        
        if (!elemRect) return;
    
        let offset = [
            (elemRect.top - bodyRect.top)-1, 
            ((elemRect.right - bodyRect.right) * (-1))-1, 
            (elemRect.bottom - bodyRect.bottom)+1, 
            (elemRect.left - bodyRect.left)-1
        ];
    
        $('#' + element).css('clip-path', `inset(${offset[0]}px ${offset[1]}px calc(100% - ${offset[2]}px) ${offset[3]}px)`);
    }
    else{
        $('#' + element).css('display', 'none')
    }
}
function getTotalBoundingBox(target) {
    const elem = document.getElementById(target);
    if (!elem) return null;
    let elemRect = elem.getBoundingClientRect();
    let minX = elemRect.left;
    let minY = elemRect.top;
    let maxX = elemRect.right;
    let maxY = elemRect.bottom;
    Array.from(elem.children).forEach(child => {
        let childRect = child.getBoundingClientRect();
        minX = Math.min(minX, childRect.left!=0?childRect.left:99999);
        minY = Math.min(minY, childRect.top!=0?childRect.top:99999);
        maxX = Math.max(maxX, childRect.right);
        maxY = Math.max(maxY, childRect.bottom);
    });
    return {
        width: maxX - minX,
        height: maxY - minY,
        left: minX,
        top: minY,
        right: maxX,
        bottom: maxY
    };
}
function show(element) {
    $("#" + element).css("display", "block")
    document.getElementById(element).style.animation = "showmenu 0.35s ease";
}
function hide(element) {
    document.getElementById(element).style.animation = "hidemenu 0.3s ease";
    setTimeout(function() {
        $("#" + element).css("display", "none")
    }, 300)
}
function show2(element) {
    $("#" + element).css("display", "block")
    document.getElementById(element).style.animation = "Home_cons 0.3s ease";
}
function hide2(element) {
    document.getElementById(element).style.animation = "reverse_Home_cons 0.2s ease";
    setTimeout(function() {
        $("#" + element).css("display", "none")
    }, 200)
}
function isNumber(evt) {
    evt = (evt) ? evt : window.event
    var charCode = (evt.which) ? evt.which : evt.keyCode
    if (charCode > 31 && (charCode < 48 || charCode > 57)) {
        return false
    }
    return true
}
function formatMoney(input) {
    let value = input.value.replace(/\D/g, '');
    if (value === '') {
        input.value = '';
        return;
    }
    let formattedValue = parseInt(value, 10).toLocaleString('hu-HU');
    input.value = formattedValue;
}
function fancyTimeFormat(duration)
{   
    var hrs = ~~(duration / 3600);
    var mins = ~~((duration % 3600) / 60);
    var secs = ~~duration % 60;
    var ret = "";
    if (hrs > 0) {
        ret += "" + hrs + ":" + (mins < 10 ? "0" : "");
    }
    ret += "" + mins + ":" + (secs < 10 ? "0" : "");
    ret += "" + secs;
    return ret;
}
function fancyTimeFormat2(duration)
{   
    var hrs = ~~(duration / 3600);
    var mins = ~~((duration % 3600) / 60);
    var secs = ~~duration % 60;
    var ret = "";
    if (hrs > 0) {
        ret += "" + hrs + "d " + (mins < 10 ? "0" : "");
    }
    ret += "" + mins + "h " + (secs < 10 ? "0" : "");
    ret += "" + secs + 'm';
    return ret;
}
function fancyTimeFormat3(duration)
{   
    var hrs = ~~(duration / 3600);
    var mins = ~~((duration % 3600) / 60);
    var secs = ~~duration % 60;
    var ret = "";
    if (hrs > 0) {
        ret += "" + hrs + "h " + (mins < 10 ? "0" : "");
    }
    ret += "" + mins + "m "// + (secs < 10 ? "0" : "");
    //ret += "" + secs + "s";
    return ret;
}
/////////////////////////////////////////////////////////[FURNITURE MENU]////////////////////////////////////////////////////////////////////////
function SendClosedFurniture(){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: 'backToPropertyMenu'}))
}
function ResetFurniturePanel(){
    $('#panel_furniture').css('animation', 'none')
    $('#panel_chosed_furniture').css('animation', 'none')
    $('.preferences_con').css('animation', 'none')
}
function SwitchFurnitureType(id){
    let rect = document.getElementById(id).getBoundingClientRect();
    let parentRect = document.querySelector("#furniture_control").getBoundingClientRect();
    let elementCenterY = rect.top - parentRect.top;
    document.querySelector(".selector#furniture").style.top = `${elementCenterY}px`;
    ChosedFurnitureType = id
    CreateFurnitureMenu()
}
function CreateFurnitureMenu(){
    $('.furniture_type_contanier .moving_element').html('')
    let RowCount = 0
    let RowElementCount = 1
    let disableCategory
    let OneEnabledCategory = null
    if (ChosedFurnitureType == 'owned'){
        let IsFunctionRun = false
        for (let i = 0; i < Furnitures.length; i++) {
            RowElementCount = RowElementCount + 1
            if (RowCount == 0 && RowElementCount == 2){
                $('.furniture_type_contanier .moving_element').append(` 
`)
            }
            if (RowCount % 2 != 0){
                if (RowElementCount > 3){
                    RowElementCount = 0
                    RowCount = RowCount + 1
                    $('.furniture_type_contanier .moving_element').append(` 
`)
                }
            }
            else{
                if (RowElementCount > 4){
                    RowElementCount = 0
                    RowCount = RowCount + 1
                    $('.furniture_type_contanier .moving_element').append(` 
`)
                }
            }
            disableCategory = true
            if (Myproperties[CurrentProperty].furnitures.length > 0){
                for (let _i = 0; _i < Furnitures[i].objects.length; _i++) {
                    for (let index = 0; index < Myproperties[CurrentProperty].furnitures.length; index++) {
                        if (Furnitures[i].objects[_i].options != undefined){
                            for (const key in Furnitures[i].objects[_i].options) {
                                if (Myproperties[CurrentProperty].furnitures[index].obj == Furnitures[i].objects[_i].options[key].model){
                                    disableCategory = false
                                }
                            }
                        }
                        else if (Myproperties[CurrentProperty].furnitures[index].obj == Furnitures[i].objects[_i].model){
                            disableCategory = false
                        }
                    }
                }
            }
            else{
                $('.furniture_container').html('')
            }
            $('.furniture_type_contanier .moving_element #row_'+RowCount).append(`
                
            `)
            if (!disableCategory){
                disableCategory = i
                OneEnabledCategory = i
                if (ChosedMovingFurnitureType == null){
                    IsFunctionRun = true
                    ChooseFurnitureType(document.getElementById(Furnitures[i].category), i, 'owned')
                }
                else if(ChosedMovingFurnitureType == i){
                    IsFunctionRun = true
                    ChooseFurnitureType(document.getElementById(Furnitures[ChosedMovingFurnitureType].category), ChosedMovingFurnitureType, 'owned')
                }
            }
        }
        if (!IsFunctionRun){
            if (OneEnabledCategory != null){
                ChooseFurnitureType(document.getElementById(Furnitures[OneEnabledCategory].category), OneEnabledCategory, 'owned')
            }
            else{
                $('.furniture_container').html(`${t('not_have_furniture')}
`)
            }
        }
    }
    else{
        for (let i = 0; i < Furnitures.length; i++) {
            RowElementCount = RowElementCount + 1
            if (RowCount == 0 && RowElementCount == 2){
                $('.furniture_type_contanier .moving_element').append(` 
`)
            }
            if (RowCount % 2 != 0){
                if (RowElementCount > 3){
                    RowElementCount = 0
                    RowCount = RowCount + 1
                    $('.furniture_type_contanier .moving_element').append(` 
`)
                }
            }
            else{
                if (RowElementCount > 4){
                    RowElementCount = 0
                    RowCount = RowCount + 1
                    $('.furniture_type_contanier .moving_element').append(` 
`)
                }
            }
            $('.furniture_type_contanier .moving_element #row_'+RowCount).append(`
                
            `)
        }
        if (ChosedMovingFurnitureType == null){
            ChooseFurnitureType(document.getElementById(Furnitures[Math.round((Furnitures.length-1)/2)].category), Math.round((Furnitures.length-1)/2))
        }
        else{
            ChooseFurnitureType(document.getElementById(Furnitures[ChosedMovingFurnitureType].category), ChosedMovingFurnitureType)
        }
    }
    ScaleObjects()
}
function ChooseFurnitureType(element, FurnitureKey, type) {
    if (!MovingElement){
        ChosedMovingFurnitureType = FurnitureKey
        document.querySelectorAll(".furniture_type_element").forEach(el => {
            el.classList.remove('choosed_furniture_type')
        });
        element.classList.add('choosed_furniture_type')
        $('.furniture_container').html('')
        let IsSecurityObject = false 
        for (let i = 0; i < Furnitures[FurnitureKey].objects.length; i++) {
            IsSecurityObject = false 
            for (const key in SecurityObjects.cameras) {
                if (SecurityObjects.cameras[key] == Furnitures[FurnitureKey].objects[i].model){
                    IsSecurityObject = true
                }
            }
            for (const key in SecurityObjects.databases) {
                if (SecurityObjects.databases[key] == Furnitures[FurnitureKey].objects[i].model){
                    IsSecurityObject = true
                }
            }
            if (type == 'owned'){
                for (let _i = 0; _i < Myproperties[CurrentProperty].furnitures.length; _i++) {
                    let CanbeShowed = false
                    if (Furnitures[FurnitureKey].objects[i].options != undefined){
                        for (const key in Furnitures[FurnitureKey].objects[i].options) {
                            if (Furnitures[FurnitureKey].objects[i].options[key].model == Myproperties[CurrentProperty].furnitures[_i].obj){
                                CanbeShowed = true
                            }
                        }
                    }
                    else if(Furnitures[FurnitureKey].objects[i].model == Myproperties[CurrentProperty].furnitures[_i].obj){
                        CanbeShowed = true
                    }
                    if (CanbeShowed){
                        $('.furniture_container').append(`
                            
                                
                                ${Myproperties[CurrentProperty].furnitures[_i].type == 'outside'?'
':''}
                                ${IsSecurityObject?'
':''}
                             
                        `)
                    }
                }
            }
            else{
                $('.furniture_container').append(`
                    
                        
                        ${Furnitures[FurnitureKey].objects[i].options != undefined?'
':''}
                        ${IsSecurityObject?'
':''}
                     
                `)
            }
        }
        HideChosedFurniture()
    }
}
function HideChosedFurniture(){
    $('#panel_chosed_furniture').css('animation', 'reverse_Basic_popup 0.3s ease')
    setTimeout(() => {
        BackgroundBlur("plugin_4", 'panel_chosed_furniture')
        $('.chosed_furniture').css('display', 'none')
    }, 300);
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "unselectFurniture"}))
}
function ShowChosedFurniture(){
    $('#panel_chosed_furniture').css('animation', 'Basic_popup 0.3s ease')
    $('.chosed_furniture').css('display', 'block')
    setTimeout(() => {
        BackgroundBlur("plugin_4", 'panel_chosed_furniture')
    }, 200);
}
function EditFurniture(objectid, FurnitureKey, i, price){
    ShowChosedFurniture()
    let furniture_elements = document.getElementsByClassName("furniture_element")
    for (let _i = 0; _i < furniture_elements.length; _i++) {
        if (furniture_elements[_i]){
            furniture_elements[_i].classList.remove('chosed')
        }
    }
    document.getElementById('furniture_'+i).classList.add('chosed')
    $('#panel_chosed_furniture .price').html(price.toLocaleString('hu-HU')+Currency)
    $('#buy_furniture').css('display', 'none')
    $('#sell_furniture').css('display', 'block')
    $('.color_container').css('display', 'none')
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "editFurniture", objectid, propertyID:Myproperties[CurrentProperty].id}))
}
function SelectFurniture(model, price, FurnitureKey, i){
    ShowChosedFurniture()
    for (let _i = 0; _i < Furnitures[FurnitureKey].objects.length; _i++) {
        document.getElementById('furniture_'+_i).classList.remove('chosed')
    }
    document.getElementById('furniture_'+i).classList.add('chosed')
    if (Furnitures[FurnitureKey].objects[i].options == undefined){
        $('.color_container').css('display', 'none')
    }
    else{
        $('.color_container').css('display', 'flex')
        $('.color_container').html('')
        for (const key in Furnitures[FurnitureKey].objects[i].options) {
            $('.color_container').append(`${Number(key)+1} `)
        }
    }
    BackgroundBlur("plugin_4", 'panel_chosed_furniture')
    $('#panel_chosed_furniture .price').html(price.toLocaleString('hu-HU')+Currency)
    $('#buy_furniture').css('display', 'block')
    $('#sell_furniture').css('display', 'none')
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "selectFurniture", model, propertyID:Myproperties[CurrentProperty].id}))
}
function SendChangePosition(){
    $('#panel_furniture').css('animation', 'reverse_Basic_popup 0.3s ease both')
    $('#panel_chosed_furniture').css('animation', 'reverse_Basic_popup 0.3s ease both')
    $('.preferences_con').css('animation', 'reverse_Basic_popup 0.3s ease both')
    setTimeout(() => {
        BackgroundBlur("plugin_4", 'panel_chosed_furniture')
        BackgroundBlur("plugin_3", 'panel_furniture')
    }, 600);
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "furniturePositioning", propertyID:Myproperties[CurrentProperty].id}))
}
function SendBuyFurniture(){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "buyFurniture", propertyID:Myproperties[CurrentProperty].id}))
}
function SendSellFurniture(){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "deleteFurniture", propertyID:Myproperties[CurrentProperty].id}))
}
function SendChangeModel(model){
    $.post('https://' + GetParentResourceName() + '/UseButton', JSON.stringify({action: "changeFurniture", propertyID:Myproperties[CurrentProperty].id, model}))
}
let isMousePressed = false; // Flag to check if the mouse is pressed
let MovingElement = false
let elementToMove = document.getElementById("moving_element");
let parentElement = document.getElementById("furniture_type_contanier"); // The parent element
let startX = 0, startY = 0, currentX = 0, currentY = 0; // Position tracking
document.getElementById("furniture_type_contanier").addEventListener("mousedown", function(event) {
    if (event.button === 0) { // Left click pressed
        isMousePressed = true;
        // Get element's current transform values
        const transform = getComputedStyle(elementToMove).transform;
        if (transform !== "none") {
            const matrix = new DOMMatrix(transform);
            currentX = matrix.m41; // X translation
            currentY = matrix.m42; // Y translation
        }
        // Capture the offset to prevent jumping
        startX = event.clientX - currentX;
        startY = event.clientY - currentY;
        function moveElement(e) {
            if (!isMousePressed) return;
            MovingElement = true
            // Calculate new position based on mouse movement
            let translateX = e.clientX - startX;
            let translateY = e.clientY - startY;
            // Get parent boundaries
            const parentRect = parentElement.getBoundingClientRect();
            const elemRect = elementToMove.getBoundingClientRect();
            // Constrain within parent
            const minX = 0;
            const minY = 0;
            const maxX = parentRect.width - elemRect.width;
            const maxY = parentRect.height - elemRect.height;
            // Smooth boundary effect (soft stop)
            if (translateX < minX) translateX = minX - (minX - translateX) * 0.2;
            if (translateY < minY) translateY = minY - (minY - translateY) * 0.2;
            if (translateX > maxX) translateX = maxX + (translateX - maxX) * 0.2;
            if (translateY > maxY) translateY = maxY + (translateY - maxY) * 0.2;
            // Apply the transform (translate)
            elementToMove.style.transform = `translate(${translateX}px, ${translateY}px)`;
            ScaleObjects()
        }
        // Add event listeners
        document.addEventListener("mousemove", moveElement);
        document.addEventListener("mouseup", function stopMoving() {
            isMousePressed = false;
            MovingElement = false
            // Get parent boundaries again for smooth reset
            const parentRect = parentElement.getBoundingClientRect();
            const elemRect = elementToMove.getBoundingClientRect();
            let translateX = currentX;
            let translateY = currentY;
            // Ensure it stays inside parent (reset position if out)
            if (elemRect.left < parentRect.left) translateX = 0;
            if (elemRect.top < parentRect.top) translateY = 0;
            if (elemRect.right > parentRect.right) translateX = parentRect.width - elemRect.width;
            if (elemRect.bottom > parentRect.bottom) translateY = parentRect.height - elemRect.height;
            // Smooth transition back to boundary
            const overflowThreshold = 10;
            if (
                elemRect.left < parentRect.left - overflowThreshold ||
                elemRect.top < parentRect.top - overflowThreshold ||
                elemRect.right > parentRect.right + overflowThreshold ||
                elemRect.bottom > parentRect.bottom + overflowThreshold
            ){
                elementToMove.style.transition = "transform 0.3s ease-out";
                elementToMove.style.transform = `translate(${translateX}px, ${translateY}px)`;
                const startTime = Date.now();
                    function loop() {
                        const currentTime = Date.now();
                
                        if (currentTime - startTime >= 300) {
                            return;
                        }
                        ScaleObjects()
                
                        setTimeout(loop, 1); 
                    }
                
                    loop();
    
                setTimeout(() => {
                    elementToMove.style.transition = ""; 
                }, 300);
            }
            document.removeEventListener("mousemove", moveElement);
            document.removeEventListener("mouseup", stopMoving);
        });
    }
});
function ScaleObjects(){
    const parentRect = parentElement.getBoundingClientRect();
    const children = parentElement.getElementsByClassName("furniture_type_element");
    Array.from(children).forEach(child => {
        const rect = child.getBoundingClientRect();
        const centerX = rect.left + rect.width / 2;
        const centerY = rect.top + rect.height / 2;
        const parentCenterX = parentRect.left + parentRect.width / 2;
        const parentCenterY = parentRect.top + parentRect.height / 2;
        const distance = Math.sqrt((parentCenterX - centerX) ** 2 + (parentCenterY - centerY) ** 2);
        child.style.opacity = 1.7 - distance / 100;
        let childProperties = getObjectProperties(distance);
        child.style.transform = `scale(${childProperties.scale})`;
    });
}
function getObjectProperties(distance) {
    const minDistance = 75;
    const maxDistance = 140;
    // Scale range (0.75 to 0)
    const minScale = 0.1;
    const maxScale = 1;
    // Clamp the distance
    distance = Math.min(Math.max(distance, minDistance), maxDistance);
    // Normalize distance (0 when at maxDistance, 1 when at minDistance)
    let normalized = 1 - (distance - minDistance) / (maxDistance - minDistance);
    // Calculate scale
    let scale = minScale + normalized * (maxScale - minScale);
    return { scale };
}