Discord - -📌 License -Copyright (C) 2022-2024 bitpredator - -This program Is free software: you can redistribute it And/Or modify it under the terms Of the GNU General Public License As published by the Free Software Foundation, either version 3 Of the License, Or (at your option) any later version. - -This program Is distributed In the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty Of MERCHANTABILITY Or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License For more details. - -ATTENTION: -You are not authorized to change the name of the resource and the resources within it. - -If you want to contribute you can open a pull request. - -You are not authorized to sell this software (this is free project). - -This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. - -You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/. - -## Info -This Script will allow you to simulate the creation of sandwiches using flour and water \ No newline at end of file diff --git a/server-data/resources/[bpt_addons]/bpt_fisherman/bpt_fishermanjob.sql b/server-data/resources/[bpt_addons]/bpt_fisherman/bpt_fishermanjob.sql deleted file mode 100644 index e6b254bad..000000000 --- a/server-data/resources/[bpt_addons]/bpt_fisherman/bpt_fishermanjob.sql +++ /dev/null @@ -1,23 +0,0 @@ -INSERT INTO `addon_account` (name, label, shared) VALUES - ('society_fisherman', 'Fisherman', 1) -; - -INSERT INTO `datastore` (name, label, shared) VALUES - ('society_fisherman', 'Fisherman', 1) -; - -INSERT INTO `addon_inventory` (name, label, shared) VALUES - ('society_fisherman', 'Fisherman', 1) -; - -INSERT INTO `jobs` (name, label) VALUES - ('fisherman', 'Fisherman') -; - -INSERT INTO `job_grades` (job_name, grade, name, label, salary, skin_male, skin_female) VALUES - ('fisherman',0,'ontrial','Ontrial',12,'{"hair_2":0,"hair_color_2":0,"torso_1":32,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":31,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":0,"age_2":0,"glasses_2":0,"ears_2":0,"arms":27,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}'), - ('fisherman',1,'employee','Employee',24,'{"hair_2":0,"hair_color_2":0,"torso_1":32,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":31,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":0,"age_2":0,"glasses_2":0,"ears_2":0,"arms":27,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}'), - ('fisherman',2,'driver','Driver',36,'{"hair_2":0,"hair_color_2":0,"torso_1":26,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":57,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":4,"age_2":0,"glasses_2":0,"ears_2":0,"arms":11,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":0,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}'), - ('fisherman',3,'responsible','Responsible',48,'{"hair_2":0,"hair_color_2":0,"torso_1":26,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":57,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":4,"age_2":0,"glasses_2":0,"ears_2":0,"arms":11,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":0,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}'), - ('fisherman',4,'boss','Boss',0,'{"hair_2":0,"hair_color_2":0,"torso_1":29,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":31,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":4,"age_2":0,"glasses_2":0,"ears_2":0,"arms":1,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":0,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":4,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}') -; \ No newline at end of file diff --git a/server-data/resources/[bpt_addons]/bpt_fisherman/client/main.lua b/server-data/resources/[bpt_addons]/bpt_fisherman/client/main.lua deleted file mode 100644 index f57cde19c..000000000 --- a/server-data/resources/[bpt_addons]/bpt_fisherman/client/main.lua +++ /dev/null @@ -1,374 +0,0 @@ -local HasAlreadyEnteredMarker -local CurrentAction, CurrentActionMsg, CurrentActionData = nil, "", {} -local LastZone - -RegisterNetEvent("esx:playerLoaded") -AddEventHandler("esx:playerLoaded", function(xPlayer) - ESX.PlayerData = xPlayer - ESX.PlayerLoaded = true -end) - -RegisterNetEvent("esx:onPlayerLogout") -AddEventHandler("esx:onPlayerLogout", function() - ESX.PlayerLoaded = false - ESX.PlayerData = {} -end) - -RegisterNetEvent("esx:setJob") -AddEventHandler("esx:setJob", function(job) - ESX.PlayerData.job = job -end) - -function DrawSub(msg, time) - ClearPrints() - BeginTextCommandPrint("STRING") - AddTextComponentSubstringPlayerName(msg) - EndTextCommandPrint(time, 1) -end - -function ShowLoadingPromt(msg, time, type) - CreateThread(function() - Wait(0) - - BeginTextCommandBusyspinnerOn("STRING") - AddTextComponentSubstringPlayerName(msg) - EndTextCommandBusyspinnerOn(type) - Wait(time) - - BusyspinnerOff() - end) -end - -function OpenCloakroom() - local elements = { - { unselectable = true, icon = "fas fa-shirt", title = TranslateCap("cloakroom_menu") }, - { icon = "fas fa-shirt", title = TranslateCap("wear_citizen"), value = "wear_citizen" }, - { icon = "fas fa-shirt", title = TranslateCap("wear_work"), value = "wear_work" }, - } - - ESX.OpenContext("right", elements, function(_, element) - if element.value == "wear_citizen" then - ESX.TriggerServerCallback("esx_skin:getPlayerSkin", function(skin) - TriggerEvent("skinchanger:loadSkin", skin) - end) - elseif element.value == "wear_work" then - ESX.TriggerServerCallback("esx_skin:getPlayerSkin", function(skin, jobSkin) - if skin.sex == 0 then - TriggerEvent("skinchanger:loadClothes", skin, jobSkin.skin_male) - else - TriggerEvent("skinchanger:loadClothes", skin, jobSkin.skin_female) - end - end) - end - ESX.CloseContext() - end, function() - CurrentAction = "cloakroom" - CurrentActionMsg = TranslateCap("cloakroom_prompt") - CurrentActionData = {} - end) -end - -function OpenVehicleSpawnerMenu() - local elements = { - { unselectable = true, icon = "fas fa-car", title = TranslateCap("spawn_veh") }, - } - - if Config.EnableSocietyOwnedVehicles then - ESX.TriggerServerCallback("bpt_society:getVehiclesInGarage", function(vehicles) - if #vehicles == 0 then - ESX.ShowNotification(TranslateCap("empty_garage")) - return - end - - for i = 1, #vehicles, 1 do - elements[#elements + 1] = { - icon = "fas fa-car", - title = GetDisplayNameFromVehicleModel(vehicles[i].model) .. " [" .. vehicles[i].plate .. "]", - value = vehicles[i], - } - end - - ESX.OpenContext("right", elements, function(_, element) - if not ESX.Game.IsSpawnPointClear(Config.Zones.VehicleSpawnPoint.Pos, 5.0) then - ESX.ShowNotification(TranslateCap("spawnpoint_blocked")) - return - end - - if element.value == nil then - print("ERROR: Context menu clicked item value is nil!") - return - end - - local vehicleProps = element.value - ESX.TriggerServerCallback("bpt_fishermanjob:SpawnVehicle", function() - return - end, vehicleProps.model, vehicleProps) - TriggerServerEvent("bpt_society:removeVehicleFromGarage", "fisherman", vehicleProps) - end, function() - CurrentAction = "vehicle_spawner" - CurrentActionMsg = TranslateCap("spawner_prompt") - CurrentActionData = {} - end) - end, "fisherman") - else -- not society vehicles - if #Config.AuthorizedVehicles == 0 then - ESX.ShowNotification(TranslateCap("empty_garage")) - return - end - - for i = 1, #Config.AuthorizedVehicles, 1 do - elements[#elements + 1] = { - icon = "fas fa-car", - title = Config.AuthorizedVehicles[i].label, - value = Config.AuthorizedVehicles[i].model, - } - end - - ESX.OpenContext("right", elements, function(_, element) - if not ESX.Game.IsSpawnPointClear(Config.Zones.VehicleSpawnPoint.Pos, 5.0) then - ESX.ShowNotification(TranslateCap("spawnpoint_blocked")) - return - end - - if element.value == nil then - print("ERROR: Context menu clicked item value is nil!") - return - end - - ESX.TriggerServerCallback("bpt_fishermanjob:SpawnVehicle", function() - ESX.ShowNotification(TranslateCap("vehicle_spawned"), "success") - end, element.value, { plate = "FISH JOB" }) - ESX.CloseContext() - end, function() - CurrentAction = "vehicle_spawner" - CurrentActionMsg = TranslateCap("spawner_prompt") - CurrentActionData = {} - end) - end -end - -function DeleteJobVehicle() - if Config.EnableSocietyOwnedVehicles then - local vehicleProps = ESX.Game.GetVehicleProperties(CurrentActionData.vehicle) - TriggerServerEvent("bpt_society:putVehicleInGarage", "fisherman", vehicleProps) - ESX.Game.DeleteVehicle(CurrentActionData.vehicle) - else - if IsInAuthorizedVehicle() then - ESX.Game.DeleteVehicle(CurrentActionData.vehicle) - else - ESX.ShowNotification(TranslateCap("only_fisherman")) - end - end -end - -function OpenFishermanActionsMenu() - local elements = { - { unselectable = true, icon = "fas fa-fisherman", title = TranslateCap("fisherman") }, - { icon = "fas fa-box", title = TranslateCap("deposit_stock"), value = "put_stock" }, - { icon = "fas fa-box", title = TranslateCap("take_stock"), value = "get_stock" }, - } - - if Config.EnablePlayerManagement and ESX.PlayerData.job ~= nil and ESX.PlayerData.job.grade_name == "boss" then - elements[#elements + 1] = { - icon = "fas fa-wallet", - title = TranslateCap("boss_actions"), - value = "boss_actions", - } - end - - ESX.OpenContext("right", elements, function(_, element) - if Config.OxInventory and (element.value == "put_stock" or element.value == "get_stock") then - exports.ox_inventory:openInventory("stash", "society_fisherman") - return ESX.CloseContext() - elseif element.value == "put_stock" then - OpenPutStocksMenu() - elseif element.value == "get_stock" then - OpenGetStocksMenu() - elseif element.value == "boss_actions" then - TriggerEvent("bpt_society:openBossMenu", "fisherman", function(_, menu) - menu.close() - end) - end - end, function() - CurrentAction = "fisherman_actions_menu" - CurrentActionMsg = TranslateCap("press_to_open") - CurrentActionData = {} - end) -end - -function OpenMobileFishermanActionsMenu() - local elements = { - { unselectable = true, icon = "fas fa-fisherman", title = TranslateCap("fisherman") }, - { icon = "fas fa-scroll", title = TranslateCap("billing"), value = "billing" }, - } - - ESX.OpenContext("right", elements, function(_, element) - if element.value == "billing" then - local elements2 = { - { unselectable = true, icon = "fas fa-fisherman", title = element.title }, - { - title = TranslateCap("amount"), - input = true, - inputType = "number", - inputMin = 1, - inputMax = 10000000, - inputPlaceholder = TranslateCap("bill_amount"), - }, - { icon = "fas fa-check-double", title = TranslateCap("confirm"), value = "confirm" }, - } - - ESX.OpenContext("right", elements2, function(menu2) - local amount = tonumber(menu2.eles[2].inputValue) - if amount == nil then - ESX.ShowNotification(TranslateCap("amount_invalid")) - else - ESX.CloseContext() - local closestPlayer, closestDistance = ESX.Game.GetClosestPlayer() - if closestPlayer == -1 or closestDistance > 3.0 then - ESX.ShowNotification(TranslateCap("no_players_near")) - else - TriggerServerEvent("bpt_billing:sendBill", GetPlayerServerId(closestPlayer), "society_fisherman", "Fisherman", amount) - ESX.ShowNotification(TranslateCap("billing_sent")) - end - end - end) - end - end) -end - -function IsInAuthorizedVehicle() - local playerPed = PlayerPedId() - local vehModel = GetEntityModel(GetVehiclePedIsIn(playerPed, false)) - - for i = 1, #Config.AuthorizedVehicles, 1 do - if vehModel == joaat(Config.AuthorizedVehicles[i].model) then - return true - end - end - - return false -end - -AddEventHandler("bpt_fishermanjob:hasEnteredMarker", function(zone) - if zone == "VehicleSpawner" then - CurrentAction = "vehicle_spawner" - CurrentActionMsg = TranslateCap("spawner_prompt") - CurrentActionData = {} - elseif zone == "VehicleDeleter" then - local playerPed = PlayerPedId() - local vehicle = GetVehiclePedIsIn(playerPed, false) - - if IsPedInAnyVehicle(playerPed, false) and GetPedInVehicleSeat(vehicle, -1) == playerPed then - CurrentAction = "delete_vehicle" - CurrentActionMsg = TranslateCap("store_veh") - CurrentActionData = { - vehicle = vehicle, - } - end - elseif zone == "FishermanActions" then - CurrentAction = "fisherman_actions_menu" - CurrentActionMsg = TranslateCap("press_to_open") - CurrentActionData = {} - elseif zone == "Cloakroom" then - CurrentAction = "cloakroom" - CurrentActionMsg = TranslateCap("cloakroom_prompt") - CurrentActionData = {} - end -end) - -AddEventHandler("bpt_fishermanjob:hasExitedMarker", function() - ESX.CloseContext() - CurrentAction = nil -end) - --- Create Blips -CreateThread(function() - local blip = AddBlipForCoord(Config.Zones.FishermanActions.Pos.x, Config.Zones.FishermanActions.Pos.y, Config.Zones.FishermanActions.Pos.z) - - SetBlipSprite(blip, 478) - SetBlipDisplay(blip, 4) - SetBlipScale(blip, 1.0) - SetBlipColour(blip, 21) - SetBlipAsShortRange(blip, true) - - BeginTextCommandSetBlipName("STRING") - AddTextComponentSubstringPlayerName(TranslateCap("blip_fisherman")) - EndTextCommandSetBlipName(blip) -end) - --- Enter / Exit marker events, and draw markers -CreateThread(function() - while true do - local sleep = 1500 - if ESX.PlayerData.job and ESX.PlayerData.job.name == "fisherman" then - local coords = GetEntityCoords(PlayerPedId()) - local isInMarker, currentZone = false - local inVeh = IsPedInAnyVehicle(PlayerPedId()) - - for k, v in pairs(Config.Zones) do - local zonePos = vector3(v.Pos.x, v.Pos.y, v.Pos.z) - local distance = #(coords - zonePos) - - if v.Type ~= -1 and distance < Config.DrawDistance then - sleep = 0 - if k == "VehicleDeleter" then - if inVeh then - DrawMarker(v.Type, v.Pos.x, v.Pos.y, v.Pos.z, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, v.Size.x, v.Size.y, v.Size.z, v.Color.r, v.Color.g, v.Color.b, 100, false, false, 2, v.Rotate, nil, nil, false) - end - else - DrawMarker(v.Type, v.Pos.x, v.Pos.y, v.Pos.z, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, v.Size.x, v.Size.y, v.Size.z, v.Color.r, v.Color.g, v.Color.b, 100, false, false, 2, v.Rotate, nil, nil, false) - end - end - - if distance < v.Size.x then - isInMarker, currentZone = true, k - end - end - - if (isInMarker and not HasAlreadyEnteredMarker) or (isInMarker and LastZone ~= currentZone) then - HasAlreadyEnteredMarker, LastZone = true, currentZone - TriggerEvent("bpt_fishermanjob:hasEnteredMarker", currentZone) - end - - if not isInMarker and HasAlreadyEnteredMarker then - HasAlreadyEnteredMarker = false - TriggerEvent("bpt_fishermanjob:hasExitedMarker", LastZone) - end - end - Wait(sleep) - end -end) - --- Key Controls -CreateThread(function() - while true do - local sleep = 1500 - if CurrentAction and not ESX.PlayerData.dead then - sleep = 0 - ESX.ShowHelpNotification(CurrentActionMsg) - - if IsControlJustReleased(0, 38) and ESX.PlayerData.job and ESX.PlayerData.job.name == "fisherman" then - if CurrentAction == "fisherman_actions_menu" then - OpenFishermanActionsMenu() - elseif CurrentAction == "cloakroom" then - OpenCloakroom() - elseif CurrentAction == "vehicle_spawner" then - OpenVehicleSpawnerMenu() - elseif CurrentAction == "delete_vehicle" then - DeleteJobVehicle() - end - - CurrentAction = nil - end - end - Wait(sleep) - end -end) - -RegisterCommand("fishermanmenu", function() - if not ESX.PlayerData.dead and Config.EnablePlayerManagement and ESX.PlayerData.job and ESX.PlayerData.job.name == "fisherman" then - OpenMobileFishermanActionsMenu() - end -end, false) - -RegisterKeyMapping("fishermanmenu", "Open Fisherman Menu", "keyboard", "f6") diff --git a/server-data/resources/[bpt_addons]/bpt_fisherman/config.lua b/server-data/resources/[bpt_addons]/bpt_fisherman/config.lua deleted file mode 100644 index c12f8f037..000000000 --- a/server-data/resources/[bpt_addons]/bpt_fisherman/config.lua +++ /dev/null @@ -1,53 +0,0 @@ -Config = {} -Config.DrawDistance = 10.0 -- How close do you need to be for the markers to be drawn (in GTA units). -Config.EnablePlayerManagement = true -- Enable society managing. -Config.EnableSocietyOwnedVehicles = false -Config.Locale = "it" -Config.OxInventory = ESX.GetConfig().OxInventory - -Config.AuthorizedVehicles = { - { model = "rumpo", label = "Rumpo" }, -} - -Config.Zones = { - - VehicleSpawner = { - Pos = { x = -351.956055, y = -2790.316406, z = 5.993408 }, - Size = { x = 0.6, y = 0.6, z = 0.6 }, - Color = { r = 204, g = 204, b = 0 }, - Type = 36, - Rotate = true, - }, - - VehicleSpawnPoint = { - Pos = { x = -363.270325, y = -2775.824219, z = 5.993408 }, - Size = { x = 1.5, y = 1.5, z = 1.0 }, - Type = -1, - Rotate = false, - Heading = 225.0, - }, - - VehicleDeleter = { - Pos = { x = -348.118683, y = -2760.224121, z = 5.027100 }, - Size = { x = 3.0, y = 3.0, z = 0.25 }, - Color = { r = 255, g = 0, b = 0 }, - Type = 1, - Rotate = false, - }, - - FishermanActions = { - Pos = { x = -327.547241, y = -2769.125244, z = 5.201416 }, - Size = { x = 0.6, y = 0.6, z = 0.6 }, - Color = { r = 204, g = 204, b = 0 }, - Type = 20, - Rotate = true, - }, - - Cloakroom = { - Pos = { x = -323.604401, y = -2784.065918, z = 5.201416 }, - Size = { x = 0.6, y = 0.6, z = 0.6 }, - Color = { r = 204, g = 204, b = 0 }, - Type = 21, - Rotate = true, - }, -} diff --git a/server-data/resources/[bpt_addons]/bpt_fisherman/fxmanifest.lua b/server-data/resources/[bpt_addons]/bpt_fisherman/fxmanifest.lua deleted file mode 100644 index 0d5c4ff1d..000000000 --- a/server-data/resources/[bpt_addons]/bpt_fisherman/fxmanifest.lua +++ /dev/null @@ -1,25 +0,0 @@ -fx_version("adamant") - -game("gta5") - -description("bpt_fishermanjob") -lua54("yes") -version("1.0.1") - -shared_script("@es_extended/imports.lua") - -client_scripts({ - "@es_extended/locale.lua", - "locales/*.lua", - "config.lua", - "client/main.lua", -}) - -server_scripts({ - "@es_extended/locale.lua", - "locales/*.lua", - "config.lua", - "server/main.lua", -}) - -dependency("es_extended") diff --git a/server-data/resources/[bpt_addons]/bpt_fisherman/locales/en.lua b/server-data/resources/[bpt_addons]/bpt_fisherman/locales/en.lua deleted file mode 100644 index 953e14dc4..000000000 --- a/server-data/resources/[bpt_addons]/bpt_fisherman/locales/en.lua +++ /dev/null @@ -1,30 +0,0 @@ -Locales["en"] = { - -- cloakroom - ["cloakroom_menu"] = "cloakroom", - ["cloakroom_prompt"] = "press [E] to access the cloakroom.", - ["wear_citizen"] = "civilian clothes", - ["wear_work"] = "work clothes", - -- Inventory - ["deposit_stock"] = "Deposit stock", - ["take_stock"] = "Take stock", - ["have_deposited"] = "Have deposited", - ["quantity_invalid"] = "Quantity invelid", - -- garage - ["spawner_prompt"] = "press [E] to access the Garage.", - ["vehicle_spawned"] = "Vehicle picked up successfully!", - ["store_veh"] = "press [E] to deposit the vehicle", - ["spawn_veh"] = "vehicle spawns", - ["spawnpoint_blocked"] = "the spawnpoint is blocked!", - ["only_fisherman"] = "you can only deposit company vehicles.", - ["amount_invalid"] = "invalid amount", - ["press_to_open"] = "press [E] to access the menu", - ["invoice_amount"] = "invoice amount", - ["no_players_near"] = "no players nearby", - ["boss_actions"] = "Boss actions", - ["blip_fisherman"] = "Fisherman", - ["fisherman"] = "fisherman", - -- billing - ["bill_amount"] = "Amount to bill..", - ["confirm"] = "Confirm", - ["amount"] = "amount", -} diff --git a/server-data/resources/[bpt_addons]/bpt_fisherman/locales/it.lua b/server-data/resources/[bpt_addons]/bpt_fisherman/locales/it.lua deleted file mode 100644 index 7b025fd83..000000000 --- a/server-data/resources/[bpt_addons]/bpt_fisherman/locales/it.lua +++ /dev/null @@ -1,30 +0,0 @@ -Locales["it"] = { - -- cloakroom - ["cloakroom_menu"] = "guardaroba", - ["cloakroom_prompt"] = "premi [E] per accedere al guardaroba.", - ["wear_citizen"] = "abiti civili", - ["wear_work"] = "abiti da lavoro", - -- Inventory - ["deposit_stock"] = "Depositare", - ["take_stock"] = "Prendi", - ["have_deposited"] = "Hai depositato", - ["quantity_invalid"] = "Qunatità non valida", - -- garage - ["spawner_prompt"] = "premi [E] per accedere al Garage.", - ["vehicle_spawned"] = "Veicolo ritirato con successo!", - ["store_veh"] = "premi [E] per depositare il veicolo", - ["spawn_veh"] = "spawn veicolo", - ["spawnpoint_blocked"] = "lo spawnpoint è bloccato !", - ["only_fisherman"] = "puoi solo depositare veicoli aziendali.", - ["amount_invalid"] = "importo non valido", - ["press_to_open"] = "premi [E] per accedere al menu", - ["invoice_amount"] = "importo della fattura", - ["no_players_near"] = "nessun giocatore nelle vicinanze", - ["boss_actions"] = "Azioni del boss", - ["blip_fisherman"] = "Fisherman", - ["fisherman"] = "fisherman", - -- billing - ["bill_amount"] = "importo della fattura", - ["confirm"] = "Conferma", - ["amount"] = "Importo", -} diff --git a/server-data/resources/[bpt_addons]/bpt_fisherman/localization/bpt_fishermanjob_it.sql b/server-data/resources/[bpt_addons]/bpt_fisherman/localization/bpt_fishermanjob_it.sql deleted file mode 100644 index 524d3802d..000000000 --- a/server-data/resources/[bpt_addons]/bpt_fisherman/localization/bpt_fishermanjob_it.sql +++ /dev/null @@ -1,23 +0,0 @@ -INSERT INTO `addon_account` (name, label, shared) VALUES - ('society_fisherman', 'Fisherman', 1) -; - -INSERT INTO `datastore` (name, label, shared) VALUES - ('society_fisherman', 'Fisherman', 1) -; - -INSERT INTO `addon_inventory` (name, label, shared) VALUES - ('society_fisherman', 'Fisherman', 1) -; - -INSERT INTO `jobs` (name, label) VALUES - ('fisherman', 'Fisherman') -; - -INSERT INTO `job_grades` (job_name, grade, name, label, salary, skin_male, skin_female) VALUES - ('fisherman',0,'ontrial','in prova',12,'{"hair_2":0,"hair_color_2":0,"torso_1":32,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":31,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":0,"age_2":0,"glasses_2":0,"ears_2":0,"arms":27,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}'), - ('fisherman',1,'employee','dipendente',24,'{"hair_2":0,"hair_color_2":0,"torso_1":32,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":31,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":0,"age_2":0,"glasses_2":0,"ears_2":0,"arms":27,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}'), - ('fisherman',2,'driver','autista',36,'{"hair_2":0,"hair_color_2":0,"torso_1":26,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":57,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":4,"age_2":0,"glasses_2":0,"ears_2":0,"arms":11,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":0,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}'), - ('fisherman',3,'responsible','responsabile',48,'{"hair_2":0,"hair_color_2":0,"torso_1":26,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":57,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":4,"age_2":0,"glasses_2":0,"ears_2":0,"arms":11,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":0,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}'), - ('fisherman',4,'boss','Direttore',0,'{"hair_2":0,"hair_color_2":0,"torso_1":29,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":31,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":4,"age_2":0,"glasses_2":0,"ears_2":0,"arms":1,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":0,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":0,"bproof_1":0,"mask_1":0,"decals_1":0,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":4,"eyebrows_1":0,"face":0,"shoes_1":10,"pants_1":24}', '{"hair_2":0,"hair_color_2":0,"torso_1":57,"bags_1":0,"helmet_2":0,"chain_2":0,"eyebrows_3":0,"makeup_3":0,"makeup_2":0,"tshirt_1":38,"makeup_1":0,"bags_2":0,"makeup_4":0,"eyebrows_4":0,"chain_1":0,"lipstick_4":0,"bproof_2":0,"hair_color_1":0,"decals_2":0,"pants_2":1,"age_2":0,"glasses_2":0,"ears_2":0,"arms":21,"lipstick_1":0,"ears_1":-1,"mask_2":0,"sex":1,"lipstick_3":0,"helmet_1":-1,"shoes_2":0,"beard_2":0,"beard_1":0,"lipstick_2":0,"beard_4":0,"glasses_1":5,"bproof_1":0,"mask_1":0,"decals_1":1,"hair_1":0,"eyebrows_2":0,"beard_3":0,"age_1":0,"tshirt_2":0,"skin":0,"torso_2":0,"eyebrows_1":0,"face":0,"shoes_1":49,"pants_1":11}') -; \ No newline at end of file diff --git a/server-data/resources/[bpt_addons]/bpt_fisherman/server/main.lua b/server-data/resources/[bpt_addons]/bpt_fisherman/server/main.lua deleted file mode 100644 index 0f93551a9..000000000 --- a/server-data/resources/[bpt_addons]/bpt_fisherman/server/main.lua +++ /dev/null @@ -1,80 +0,0 @@ -TriggerEvent("bpt_society:registerSociety", "fisherman", "Fisherman", "society_fisherman", "society_fisherman", "society_fisherman", { - type = "public", -}) - -if Config.MaxInService ~= -1 then - TriggerEvent("esx_service:activateService", "fisherman", Config.MaxInService) -end - -ESX.RegisterServerCallback("bpt_fishermanjob:SpawnVehicle", function(source, cb, model, props) - local xPlayer = ESX.GetPlayerFromId(source) - - if xPlayer.job.name ~= "fisherman" then - print(("[^3WARNING^7] Player ^5%s^7 attempted to Exploit Vehicle Spawing!!"):format(source)) - return - end - local SpawnPoint = vector3(Config.Zones.VehicleSpawnPoint.Pos.x, Config.Zones.VehicleSpawnPoint.Pos.y, Config.Zones.VehicleSpawnPoint.Pos.z) - ESX.OneSync.SpawnVehicle(joaat(model), SpawnPoint, Config.Zones.VehicleSpawnPoint.Heading, props, function() - local vehicle = NetworkGetEntityFromNetworkId() - while GetVehicleNumberPlateText(vehicle) ~= props.plate do - Wait(0) - end - TaskWarpPedIntoVehicle(GetPlayerPed(source), vehicle, -1) - end) - cb() -end) - -RegisterNetEvent("bpt_fishermanjob:getStockItem") -AddEventHandler("bpt_fishermanjob:getStockItem", function(itemName, count) - local xPlayer = ESX.GetPlayerFromId(source) - - if xPlayer.job.name == "fisherman" then - TriggerEvent("bpt_addoninventory:getSharedInventory", "society_fisherman", function(inventory) - local item = inventory.getItem(itemName) - - -- is there enough in the society? - if count > 0 and item.count >= count then - -- can the player carry the said amount of x item? - if xPlayer.canCarryItem(itemName, count) then - inventory.removeItem(itemName, count) - xPlayer.addInventoryItem(itemName, count) - xPlayer.showNotification(TranslateCap("have_withdrawn", count, item.label)) - else - xPlayer.showNotification(TranslateCap("player_cannot_hold")) - end - else - xPlayer.showNotification(TranslateCap("quantity_invalid")) - end - end) - else - print(("[^3WARNING^7] Player ^5%s^7 attempted ^5bpt_fishermanjob:getStockItem^7 (cheating)"):format(source)) - end -end) - -ESX.RegisterServerCallback("bpt_fishermanjob:getStockItems", function(_, cb) - TriggerEvent("bpt_addoninventory:getSharedInventory", "society_fisherman", function(inventory) - cb(inventory.items) - end) -end) - -RegisterNetEvent("bpt_fishermanjob:putStockItems") -AddEventHandler("bpt_fishermanjob:putStockItems", function(itemName, count) - local xPlayer = ESX.GetPlayerFromId(source) - local sourceItem = xPlayer.getInventoryItem(itemName) - - if xPlayer.job.name == "fisherman" then - TriggerEvent("bpt_addoninventory:getSharedInventory", "society_fisherman", function(inventory) - local item = inventory.getItem(itemName) - - if sourceItem.count >= count and count > 0 then - xPlayer.removeInventoryItem(itemName, count) - inventory.addItem(itemName, count) - xPlayer.showNotification(TranslateCap("have_deposited", count, item.label)) - else - xPlayer.showNotification(TranslateCap("quantity_invalid")) - end - end) - else - print(("[^3WARNING^7] Player ^5%s^7 attempted ^5bpt_fishermanjob:putStockItems^7 (cheating)"):format(source)) - end -end) diff --git a/server-data/resources/[bpt_addons]/bpt_idcard/html/assets/js/materialize.js b/server-data/resources/[bpt_addons]/bpt_idcard/html/assets/js/materialize.js index 48cc41287..79f6d7c12 100644 --- a/server-data/resources/[bpt_addons]/bpt_idcard/html/assets/js/materialize.js +++ b/server-data/resources/[bpt_addons]/bpt_idcard/html/assets/js/materialize.js @@ -3,6 +3,7 @@ * Copyright 2014-2017 Materialize * MIT License (https://raw.githubusercontent.com/Dogfalo/materialize/master/LICENSE) */ +// eslint-disable-next-line max-statements-per-line const _get = function get(object, property, receiver) { // eslint-disable-next-line max-statements-per-line if (object === null) object = Function.prototype; const desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { @@ -31,15 +32,21 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons (function(factory) { window.cash = factory(); })(function() { + // eslint-disable-next-line prefer-const const doc = document, + // eslint-disable-next-line prefer-const win = window, + // eslint-disable-next-line prefer-const ArrayProto = Array.prototype, + // eslint-disable-next-line prefer-const slice = ArrayProto.slice, + // eslint-disable-next-line prefer-const filter = ArrayProto.filter, push = ArrayProto.push; - // eslint-disable-next-line no-empty-function + // eslint-disable-next-line prefer-const, no-empty-function const noop = function() { }, + // eslint-disable-next-line prefer-const isFunction = function(item) { // @see https://crbug.com/568448 return typeof item === typeof noop && item.call; @@ -48,8 +55,11 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons return typeof item === typeof ''; }; + // eslint-disable-next-line prefer-const const idMatch = /^#[\w-]*$/, + // eslint-disable-next-line prefer-const classMatch = /^\.[\w-]*$/, + // eslint-disable-next-line prefer-const htmlMatch = /<.+>/, singlet = /^\w+$/; @@ -82,53 +92,53 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons } } - class Init { - constructor(selector, context) { - if (!selector) { - return this; - } + function Init(selector, context) { + if (!selector) { + return this; + } - // If already a cash collection, don't do any further processing - if (selector.cash && selector !== win) { - return selector; - } + // If already a cash collection, don't do any further processing + if (selector.cash && selector !== win) { + return selector; + } - let elems = selector, i = 0, length; + let elems = selector, + i = 0, + length; - if (isString(selector)) { - elems = idMatch.test(selector) ? - // If an ID use the faster getElementById check - doc.getElementById(selector.slice(1)) : htmlMatch.test(selector) ? - // If HTML, parse it into real elements - parseHTML(selector) : - // else use `find` - find(selector, context); + if (isString(selector)) { + elems = idMatch.test(selector) ? + // If an ID use the faster getElementById check + doc.getElementById(selector.slice(1)) : htmlMatch.test(selector) ? + // If HTML, parse it into real elements + parseHTML(selector) : + // else use `find` + find(selector, context); - // If function, use as shortcut for DOM ready - } - else if (isFunction(selector)) { - onReady(selector); return this; - } + // If function, use as shortcut for DOM ready + } + else if (isFunction(selector)) { + onReady(selector); return this; + } - if (!elems) { - return this; - } + if (!elems) { + return this; + } - // If a single DOM element is passed in or received via ID, return the single element - if (elems.nodeType || elems === win) { - this[0] = elems; - this.length = 1; - } - else { - // Treat like an array and loop through each item. - length = this.length = elems.length; - for (; i < length; i++) { - this[i] = elems[i]; - } + // If a single DOM element is passed in or received via ID, return the single element + if (elems.nodeType || elems === win) { + this[0] = elems; + this.length = 1; + } + else { + // Treat like an array and loop through each item. + length = this.length = elems.length; + for (; i < length; i++) { + this[i] = elems[i]; } - - return this; } + + return this; } function cash(selector, context) { @@ -298,1832 +308,1654 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons }); - const notWhiteMatch = /\S+/g; - - function getClasses(c) { - return isString(c) && c.match(notWhiteMatch); - } - - function hasClass(v, c) { - return v.classList ? v.classList.contains(c) : new RegExp('(^| )' + c + '( |$)', 'gi').test(v.className); - } + var notWhiteMatch = /\S+/g; + + function getClasses(c) { + return isString(c) && c.match(notWhiteMatch); + } + + function hasClass(v, c) { + return v.classList ? v.classList.contains(c) : new RegExp("(^| )" + c + "( |$)", "gi").test(v.className); + } + + function addClass(v, c, spacedName) { + if (v.classList) { + v.classList.add(c); + } else if (spacedName.indexOf(" " + c + " ")) { + v.className += " " + c; + } + } + + function removeClass(v, c) { + if (v.classList) { + v.classList.remove(c); + } else { + v.className = v.className.replace(c, ""); + } + } + + fn.extend({ + addClass: function (c) { + var classes = getClasses(c); + + return classes ? this.each(function (v) { + var spacedName = " " + v.className + " "; + each(classes, function (c) { + addClass(v, c, spacedName); + }); + }) : this; + }, + + attr: function (name, value) { + if (!name) { + return undefined; + } + + if (isString(name)) { + if (value === undefined) { + return this[0] ? this[0].getAttribute ? this[0].getAttribute(name) : this[0][name] : undefined; + } + + return this.each(function (v) { + if (v.setAttribute) { + v.setAttribute(name, value); + } else { + v[name] = value; + } + }); + } + + for (var key in name) { + this.attr(key, name[key]); + } + + return this; + }, + + hasClass: function (c) { + var check = false, + classes = getClasses(c); + if (classes && classes.length) { + this.each(function (v) { + check = hasClass(v, classes[0]); + return !check; + }); + } + return check; + }, + + prop: function (name, value) { + if (isString(name)) { + return value === undefined ? this[0][name] : this.each(function (v) { + v[name] = value; + }); + } + + for (var key in name) { + this.prop(key, name[key]); + } + + return this; + }, + + removeAttr: function (name) { + return this.each(function (v) { + if (v.removeAttribute) { + v.removeAttribute(name); + } else { + delete v[name]; + } + }); + }, + + removeClass: function (c) { + if (!arguments.length) { + return this.attr("class", ""); + } + var classes = getClasses(c); + return classes ? this.each(function (v) { + each(classes, function (c) { + removeClass(v, c); + }); + }) : this; + }, + + removeProp: function (name) { + return this.each(function (v) { + delete v[name]; + }); + }, + + toggleClass: function (c, state) { + if (state !== undefined) { + return this[state ? "addClass" : "removeClass"](c); + } + var classes = getClasses(c); + return classes ? this.each(function (v) { + var spacedName = " " + v.className + " "; + each(classes, function (c) { + if (hasClass(v, c)) { + removeClass(v, c); + } else { + addClass(v, c, spacedName); + } + }); + }) : this; + } + }); + + fn.extend({ + add: function (selector, context) { + return unique(cash.merge(this, cash(selector, context))); + }, + + each: function (callback) { + each(this, callback); + return this; + }, + + eq: function (index) { + return cash(this.get(index)); + }, + + filter: function (selector) { + if (!selector) { + return this; + } + + var comparator = isFunction(selector) ? selector : getCompareFunction(selector); + + return cash(filter.call(this, function (e) { + return comparator(e, selector); + })); + }, + + first: function () { + return this.eq(0); + }, + + get: function (index) { + if (index === undefined) { + return slice.call(this); + } + return index < 0 ? this[index + this.length] : this[index]; + }, + + index: function (elem) { + var child = elem ? cash(elem)[0] : this[0], + collection = elem ? this : cash(child).parent().children(); + return slice.call(collection).indexOf(child); + }, + + last: function () { + return this.eq(-1); + } + + }); + + var camelCase = function () { + var camelRegex = /(?:^\w|[A-Z]|\b\w)/g, + whiteSpace = /[\s-_]+/g; + return function (str) { + return str.replace(camelRegex, function (letter, index) { + return letter[index === 0 ? "toLowerCase" : "toUpperCase"](); + }).replace(whiteSpace, ""); + }; + }(); + + var getPrefixedProp = function () { + var cache = {}, + doc = document, + div = doc.createElement("div"), + style = div.style; + + return function (prop) { + prop = camelCase(prop); + if (cache[prop]) { + return cache[prop]; + } + + var ucProp = prop.charAt(0).toUpperCase() + prop.slice(1), + prefixes = ["webkit", "moz", "ms", "o"], + props = (prop + " " + prefixes.join(ucProp + " ") + ucProp).split(" "); + + each(props, function (p) { + if (p in style) { + cache[p] = prop = cache[prop] = p; + return false; + } + }); + + return cache[prop]; + }; + }(); + + cash.prefixedProp = getPrefixedProp; + cash.camelCase = camelCase; + + fn.extend({ + css: function (prop, value) { + if (isString(prop)) { + prop = getPrefixedProp(prop); + return arguments.length > 1 ? this.each(function (v) { + return v.style[prop] = value; + }) : win.getComputedStyle(this[0])[prop]; + } + + for (var key in prop) { + this.css(key, prop[key]); + } + + return this; + } + + }); + + function compute(el, prop) { + return parseInt(win.getComputedStyle(el[0], null)[prop], 10) || 0; + } + + each(["Width", "Height"], function (v) { + var lower = v.toLowerCase(); + + fn[lower] = function () { + return this[0].getBoundingClientRect()[lower]; + }; + + fn["inner" + v] = function () { + return this[0]["client" + v]; + }; + + fn["outer" + v] = function (margins) { + return this[0]["offset" + v] + (margins ? compute(this, "margin" + (v === "Width" ? "Left" : "Top")) + compute(this, "margin" + (v === "Width" ? "Right" : "Bottom")) : 0); + }; + }); + + function registerEvent(node, eventName, callback) { + var eventCache = getData(node, "_cashEvents") || setData(node, "_cashEvents", {}); + eventCache[eventName] = eventCache[eventName] || []; + eventCache[eventName].push(callback); + node.addEventListener(eventName, callback); + } + + function removeEvent(node, eventName, callback) { + var events = getData(node, "_cashEvents"), + eventCache = events && events[eventName], + index; + + if (!eventCache) { + return; + } + + if (callback) { + node.removeEventListener(eventName, callback); + index = eventCache.indexOf(callback); + if (index >= 0) { + eventCache.splice(index, 1); + } + } else { + each(eventCache, function (event) { + node.removeEventListener(eventName, event); + }); + eventCache = []; + } + } + + fn.extend({ + off: function (eventName, callback) { + return this.each(function (v) { + return removeEvent(v, eventName, callback); + }); + }, + + on: function (eventName, delegate, callback, runOnce) { + // jshint ignore:line + var originalCallback; + if (!isString(eventName)) { + for (var key in eventName) { + this.on(key, delegate, eventName[key]); + } + return this; + } + + if (isFunction(delegate)) { + callback = delegate; + delegate = null; + } + + if (eventName === "ready") { + onReady(callback); + return this; + } + + if (delegate) { + originalCallback = callback; + callback = function (e) { + var t = e.target; + while (!matches(t, delegate)) { + if (t === this || t === null) { + return t = false; + } + + t = t.parentNode; + } + + if (t) { + originalCallback.call(t, e); + } + }; + } + + return this.each(function (v) { + var finalCallback = callback; + if (runOnce) { + finalCallback = function () { + callback.apply(this, arguments); + removeEvent(v, eventName, finalCallback); + }; + } + registerEvent(v, eventName, finalCallback); + }); + }, + + one: function (eventName, delegate, callback) { + return this.on(eventName, delegate, callback, true); + }, + + ready: onReady, + + /** + * Modified + * Triggers browser event + * @param String eventName + * @param Object data - Add properties to event object + */ + trigger: function (eventName, data) { + if (document.createEvent) { + var evt = document.createEvent('HTMLEvents'); + evt.initEvent(eventName, true, false); + evt = this.extend(evt, data); + return this.each(function (v) { + return v.dispatchEvent(evt); + }); + } + } + + }); + + function encode(name, value) { + return "&" + encodeURIComponent(name) + "=" + encodeURIComponent(value).replace(/%20/g, "+"); + } + + function getSelectMultiple_(el) { + var values = []; + each(el.options, function (o) { + if (o.selected) { + values.push(o.value); + } + }); + return values.length ? values : null; + } + + function getSelectSingle_(el) { + var selectedIndex = el.selectedIndex; + return selectedIndex >= 0 ? el.options[selectedIndex].value : null; + } + + function getValue(el) { + var type = el.type; + if (!type) { + return null; + } + switch (type.toLowerCase()) { + case "select-one": + return getSelectSingle_(el); + case "select-multiple": + return getSelectMultiple_(el); + case "radio": + return el.checked ? el.value : null; + case "checkbox": + return el.checked ? el.value : null; + default: + return el.value ? el.value : null; + } + } + + fn.extend({ + serialize: function () { + var query = ""; + + each(this[0].elements || this, function (el) { + if (el.disabled || el.tagName === "FIELDSET") { + return; + } + var name = el.name; + switch (el.type.toLowerCase()) { + case "file": + case "reset": + case "submit": + case "button": + break; + case "select-multiple": + var values = getValue(el); + if (values !== null) { + each(values, function (value) { + query += encode(name, value); + }); + } + break; + default: + var value = getValue(el); + if (value !== null) { + query += encode(name, value); + } + } + }); + + return query.substr(1); + }, + + val: function (value) { + if (value === undefined) { + return getValue(this[0]); + } + + return this.each(function (v) { + return v.value = value; + }); + } + + }); + + function insertElement(el, child, prepend) { + if (prepend) { + var first = el.childNodes[0]; + el.insertBefore(child, first); + } else { + el.appendChild(child); + } + } + + function insertContent(parent, child, prepend) { + var str = isString(child); + + if (!str && child.length) { + each(child, function (v) { + return insertContent(parent, v, prepend); + }); + return; + } + + each(parent, str ? function (v) { + return v.insertAdjacentHTML(prepend ? "afterbegin" : "beforeend", child); + } : function (v, i) { + return insertElement(v, i === 0 ? child : child.cloneNode(true), prepend); + }); + } + + fn.extend({ + after: function (selector) { + cash(selector).insertAfter(this); + return this; + }, + + append: function (content) { + insertContent(this, content); + return this; + }, + + appendTo: function (parent) { + insertContent(cash(parent), this); + return this; + }, + + before: function (selector) { + cash(selector).insertBefore(this); + return this; + }, + + clone: function () { + return cash(this.map(function (v) { + return v.cloneNode(true); + })); + }, + + empty: function () { + this.html(""); + return this; + }, + + html: function (content) { + if (content === undefined) { + return this[0].innerHTML; + } + var source = content.nodeType ? content[0].outerHTML : content; + return this.each(function (v) { + return v.innerHTML = source; + }); + }, + + insertAfter: function (selector) { + var _this = this; + + cash(selector).each(function (el, i) { + var parent = el.parentNode, + sibling = el.nextSibling; + _this.each(function (v) { + parent.insertBefore(i === 0 ? v : v.cloneNode(true), sibling); + }); + }); + + return this; + }, + + insertBefore: function (selector) { + var _this2 = this; + cash(selector).each(function (el, i) { + var parent = el.parentNode; + _this2.each(function (v) { + parent.insertBefore(i === 0 ? v : v.cloneNode(true), el); + }); + }); + return this; + }, + + prepend: function (content) { + insertContent(this, content, true); + return this; + }, + + prependTo: function (parent) { + insertContent(cash(parent), this, true); + return this; + }, + + remove: function () { + return this.each(function (v) { + if (!!v.parentNode) { + return v.parentNode.removeChild(v); + } + }); + }, + + text: function (content) { + if (content === undefined) { + return this[0].textContent; + } + return this.each(function (v) { + return v.textContent = content; + }); + } + + }); + + var docEl = doc.documentElement; + + fn.extend({ + position: function () { + var el = this[0]; + return { + left: el.offsetLeft, + top: el.offsetTop + }; + }, + + offset: function () { + var rect = this[0].getBoundingClientRect(); + return { + top: rect.top + win.pageYOffset - docEl.clientTop, + left: rect.left + win.pageXOffset - docEl.clientLeft + }; + }, + + offsetParent: function () { + return cash(this[0].offsetParent); + } + + }); + + fn.extend({ + children: function (selector) { + var elems = []; + this.each(function (el) { + push.apply(elems, el.children); + }); + elems = unique(elems); + + return !selector ? elems : elems.filter(function (v) { + return matches(v, selector); + }); + }, + + closest: function (selector) { + if (!selector || this.length < 1) { + return cash(); + } + if (this.is(selector)) { + return this.filter(selector); + } + return this.parent().closest(selector); + }, + + is: function (selector) { + if (!selector) { + return false; + } + + var match = false, + comparator = getCompareFunction(selector); + + this.each(function (el) { + match = comparator(el, selector); + return !match; + }); + + return match; + }, + + find: function (selector) { + if (!selector || selector.nodeType) { + return cash(selector && this.has(selector).length ? selector : null); + } + + var elems = []; + this.each(function (el) { + push.apply(elems, find(selector, el)); + }); + + return unique(elems); + }, + + has: function (selector) { + var comparator = isString(selector) ? function (el) { + return find(selector, el).length !== 0; + } : function (el) { + return el.contains(selector); + }; + + return this.filter(comparator); + }, + + next: function () { + return cash(this[0].nextElementSibling); + }, + + not: function (selector) { + if (!selector) { + return this; + } + + var comparator = getCompareFunction(selector); + + return this.filter(function (el) { + return !comparator(el, selector); + }); + }, + + parent: function () { + var result = []; + + this.each(function (item) { + if (item && item.parentNode) { + result.push(item.parentNode); + } + }); + + return unique(result); + }, + + parents: function (selector) { + var last, + result = []; + + this.each(function (item) { + last = item; + + while (last && last.parentNode && last !== doc.body.parentNode) { + last = last.parentNode; + + if (!selector || selector && matches(last, selector)) { + result.push(last); + } + } + }); + + return unique(result); + }, + + prev: function () { + return cash(this[0].previousElementSibling); + }, + + siblings: function (selector) { + var collection = this.parent().children(selector), + el = this[0]; + + return collection.filter(function (i) { + return i !== el; + }); + } - function addClass(v, c, spacedName) { - if (v.classList) { - v.classList.add(c); - } - else if (spacedName.indexOf(' ' + c + ' ')) { - v.className += ' ' + c; - } - } + }); - function removeClass(v, c) { - if (v.classList) { - v.classList.remove(c); - } - else { - v.className = v.className.replace(c, ''); - } - } + return cash; +}); +; +var Component = function () { + /** + * Generic constructor for all components + * @constructor + * @param {Element} el + * @param {Object} options + */ + function Component(classDef, el, options) { + _classCallCheck(this, Component); - fn.extend({ - addClass: function(c) { - const classes = getClasses(c); - - return classes ? this.each(function(v) { - const spacedName = ' ' + v.className + ' '; - // eslint-disable-next-line no-shadow - each(classes, function(c) { - addClass(v, c, spacedName); - }); - }) : this; - }, + // Display error if el is valid HTML Element + if (!(el instanceof Element)) { + console.error(Error(el + ' is not an HTML Element')); + } - attr: function(name, value) { - if (!name) { - return undefined; - } + // If exists, destroy and reinitialize in child + var ins = classDef.getInstance(el); + if (!!ins) { + ins.destroy(); + } - if (isString(name)) { - if (value === undefined) { - return this[0] ? this[0].getAttribute ? this[0].getAttribute(name) : this[0][name] : undefined; - } + this.el = el; + this.$el = cash(el); + } - return this.each(function(v) { - if (v.setAttribute) { - v.setAttribute(name, value); - } - else { - v[name] = value; - } - }); - } + /** + * Initializes components + * @param {class} classDef + * @param {Element | NodeList | jQuery} els + * @param {Object} options + */ - for (const key in name) { - this.attr(key, name[key]); - } - return this; - }, + _createClass(Component, null, [{ + key: "init", + value: function init(classDef, els, options) { + var instances = null; + if (els instanceof Element) { + instances = new classDef(els, options); + } else if (!!els && (els.jquery || els.cash || els instanceof NodeList)) { + var instancesArr = []; + for (var i = 0; i < els.length; i++) { + instancesArr.push(new classDef(els[i], options)); + } + instances = instancesArr; + } + + return instances; + } + }]); + + return Component; +}(); - hasClass: function(c) { - let check = false, - // eslint-disable-next-line prefer-const - classes = getClasses(c); - if (classes && classes.length) { - this.each(function(v) { - check = hasClass(v, classes[0]); - return !check; - }); - } - return check; - }, +; // Required for Meteor package, the use of window prevents export by Meteor +(function (window) { + if (window.Package) { + M = {}; + } else { + window.M = {}; + } - prop: function(name, value) { - if (isString(name)) { - return value === undefined ? this[0][name] : this.each(function(v) { - v[name] = value; - }); - } + // Check for jQuery + M.jQueryLoaded = !!window.jQuery; +})(window); - for (const key in name) { - this.prop(key, name[key]); - } +// AMD +if (typeof define === "function" && define.amd) { + define("M", [], function () { + return M; + }); + + // Common JS +} else if (typeof exports !== 'undefined' && !exports.nodeType) { + if (typeof module !== 'undefined' && !module.nodeType && module.exports) { + exports = module.exports = M; + } + exports.default = M; +} - return this; - }, +M.keys = { + TAB: 9, + ENTER: 13, + ESC: 27, + ARROW_UP: 38, + ARROW_DOWN: 40 +}; - removeAttr: function(name) { - return this.each(function(v) { - if (v.removeAttribute) { - v.removeAttribute(name); - } - else { - delete v[name]; - } - }); - }, +/** + * TabPress Keydown handler + */ +M.tabPressed = false; +var docHandleKeydown = function (e) { + if (e.which === M.keys.TAB) { + M.tabPressed = true; + } +}; +var docHandleKeyup = function (e) { + if (e.which === M.keys.TAB) { + M.tabPressed = false; + } +}; +document.addEventListener('keydown', docHandleKeydown); +document.addEventListener('keyup', docHandleKeyup); - removeClass: function(c) { - if (!arguments.length) { - return this.attr('class', ''); - } - const classes = getClasses(c); - return classes ? this.each(function(v) { - // eslint-disable-next-line no-shadow - each(classes, function(c) { - removeClass(v, c); - }); - }) : this; - }, +/** + * Initialize jQuery wrapper for plugin + * @param {Class} plugin javascript class + * @param {string} pluginName jQuery plugin name + * @param {string} classRef Class reference name + */ +M.initializeJqueryWrapper = function (plugin, pluginName, classRef) { + jQuery.fn[pluginName] = function (methodOrOptions) { + // Call plugin method if valid method name is passed in + if (plugin.prototype[methodOrOptions]) { + var params = Array.prototype.slice.call(arguments, 1); + + // Getter methods + if (methodOrOptions.slice(0, 3) === 'get') { + var instance = this.first()[0][classRef]; + return instance[methodOrOptions].apply(instance, params); + } + + // Void methods + return this.each(function () { + var instance = this[classRef]; + instance[methodOrOptions].apply(instance, params); + }); + + // Initialize plugin if options or no argument is passed in + } else if (typeof methodOrOptions === 'object' || !methodOrOptions) { + plugin.init(this, arguments[0]); + return this; + } + + // Return error if an unrecognized method name is passed in + jQuery.error("Method " + methodOrOptions + " does not exist on jQuery." + pluginName); + }; +}; - removeProp: function(name) { - return this.each(function(v) { - delete v[name]; - }); - }, +/** + * Automatically initialize components + * @param {Element} context DOM Element to search within for components + */ +M.AutoInit = function (context) { + // Use document.body if no context is given + var root = !!context ? context : document.body; + + var registry = { + Autocomplete: root.querySelectorAll('.autocomplete:not(.no-autoinit)'), + Carousel: root.querySelectorAll('.carousel:not(.no-autoinit)'), + Chips: root.querySelectorAll('.chips:not(.no-autoinit)'), + Collapsible: root.querySelectorAll('.collapsible:not(.no-autoinit)'), + Datepicker: root.querySelectorAll('.datepicker:not(.no-autoinit)'), + Dropdown: root.querySelectorAll('.dropdown-trigger:not(.no-autoinit)'), + Materialbox: root.querySelectorAll('.materialboxed:not(.no-autoinit)'), + Modal: root.querySelectorAll('.modal:not(.no-autoinit)'), + Parallax: root.querySelectorAll('.parallax:not(.no-autoinit)'), + Pushpin: root.querySelectorAll('.pushpin:not(.no-autoinit)'), + ScrollSpy: root.querySelectorAll('.scrollspy:not(.no-autoinit)'), + FormSelect: root.querySelectorAll('select:not(.no-autoinit)'), + Sidenav: root.querySelectorAll('.sidenav:not(.no-autoinit)'), + Tabs: root.querySelectorAll('.tabs:not(.no-autoinit)'), + TapTarget: root.querySelectorAll('.tap-target:not(.no-autoinit)'), + Timepicker: root.querySelectorAll('.timepicker:not(.no-autoinit)'), + Tooltip: root.querySelectorAll('.tooltipped:not(.no-autoinit)'), + FloatingActionButton: root.querySelectorAll('.fixed-action-btn:not(.no-autoinit)') + }; + + for (var pluginName in registry) { + var plugin = M[pluginName]; + plugin.init(registry[pluginName]); + } +}; - toggleClass: function(c, state) { - if (state !== undefined) { - return this[state ? 'addClass' : 'removeClass'](c); - } - const classes = getClasses(c); - return classes ? this.each(function(v) { - const spacedName = ' ' + v.className + ' '; - // eslint-disable-next-line no-shadow - each(classes, function(c) { - if (hasClass(v, c)) { - removeClass(v, c); - } - else { - addClass(v, c, spacedName); - } - }); - }) : this; - }, - }); +/** + * Generate approximated selector string for a jQuery object + * @param {jQuery} obj jQuery object to be parsed + * @returns {string} + */ +M.objectSelectorString = function (obj) { + var tagStr = obj.prop('tagName') || ''; + var idStr = obj.attr('id') || ''; + var classStr = obj.attr('class') || ''; + return (tagStr + idStr + classStr).replace(/\s/g, ''); +}; - fn.extend({ - add: function(selector, context) { - return unique(cash.merge(this, cash(selector, context))); - }, +// Unique Random ID +M.guid = function () { + function s4() { + return Math.floor((1 + Math.random()) * 0x10000).toString(16).substring(1); + } + return function () { + return s4() + s4() + '-' + s4() + '-' + s4() + '-' + s4() + '-' + s4() + s4() + s4(); + }; +}(); - each: function(callback) { - each(this, callback); - return this; - }, +/** + * Escapes hash from special characters + * @param {string} hash String returned from this.hash + * @returns {string} + */ +M.escapeHash = function (hash) { + return hash.replace(/(:|\.|\[|\]|,|=|\/)/g, "\\$1"); +}; - eq: function(index) { - return cash(this.get(index)); - }, +M.elementOrParentIsFixed = function (element) { + var $element = $(element); + var $checkElements = $element.add($element.parents()); + var isFixed = false; + $checkElements.each(function () { + if ($(this).css("position") === "fixed") { + isFixed = true; + return false; + } + }); + return isFixed; +}; - filter: function(selector) { - if (!selector) { - return this; - } +/** + * @typedef {Object} Edges + * @property {Boolean} top If the top edge was exceeded + * @property {Boolean} right If the right edge was exceeded + * @property {Boolean} bottom If the bottom edge was exceeded + * @property {Boolean} left If the left edge was exceeded + */ - const comparator = isFunction(selector) ? selector : getCompareFunction(selector); +/** + * @typedef {Object} Bounding + * @property {Number} left left offset coordinate + * @property {Number} top top offset coordinate + * @property {Number} width + * @property {Number} height + */ - return cash(filter.call(this, function(e) { - return comparator(e, selector); - })); - }, +/** + * Escapes hash from special characters + * @param {Element} container Container element that acts as the boundary + * @param {Bounding} bounding element bounding that is being checked + * @param {Number} offset offset from edge that counts as exceeding + * @returns {Edges} + */ +M.checkWithinContainer = function (container, bounding, offset) { + var edges = { + top: false, + right: false, + bottom: false, + left: false + }; - first: function() { - return this.eq(0); - }, + var containerRect = container.getBoundingClientRect(); - get: function(index) { - if (index === undefined) { - return slice.call(this); - } - return index < 0 ? this[index + this.length] : this[index]; - }, + var scrollLeft = container.scrollLeft; + var scrollTop = container.scrollTop; - index: function(elem) { - // eslint-disable-next-line prefer-const - let child = elem ? cash(elem)[0] : this[0], - // eslint-disable-next-line prefer-const - collection = elem ? this : cash(child).parent().children(); - return slice.call(collection).indexOf(child); - }, + var scrolledX = bounding.left - scrollLeft; + var scrolledY = bounding.top - scrollTop; - last: function() { - return this.eq(-1); - }, + // Check for container and viewport for each edge + if (scrolledX < containerRect.left + offset || scrolledX < offset) { + edges.left = true; + } - }); + if (scrolledX + bounding.width > containerRect.right - offset || scrolledX + bounding.width > window.innerWidth - offset) { + edges.right = true; + } - const camelCase = function() { - const camelRegex = /(?:^\w|[A-Z]|\b\w)/g, - whiteSpace = /[\s-_]+/g; - return function(str) { - return str.replace(camelRegex, function(letter, index) { - return letter[index === 0 ? 'toLowerCase' : 'toUpperCase'](); - }).replace(whiteSpace, ''); - }; - }(); - - const getPrefixedProp = function() { - const cache = {}, - // eslint-disable-next-line no-shadow - doc = document, - div = doc.createElement('div'), - style = div.style; - - return function(prop) { - prop = camelCase(prop); - if (cache[prop]) { - return cache[prop]; - } + if (scrolledY < containerRect.top + offset || scrolledY < offset) { + edges.top = true; + } - const ucProp = prop.charAt(0).toUpperCase() + prop.slice(1), - prefixes = ['webkit', 'moz', 'ms', 'o'], - props = (prop + ' ' + prefixes.join(ucProp + ' ') + ucProp).split(' '); + if (scrolledY + bounding.height > containerRect.bottom - offset || scrolledY + bounding.height > window.innerHeight - offset) { + edges.bottom = true; + } - each(props, function(p) { - if (p in style) { - cache[p] = prop = cache[prop] = p; - return false; - } - }); + return edges; +}; - return cache[prop]; - }; - }(); +M.checkPossibleAlignments = function (el, container, bounding, offset) { + var canAlign = { + top: true, + right: true, + bottom: true, + left: true, + spaceOnTop: null, + spaceOnRight: null, + spaceOnBottom: null, + spaceOnLeft: null + }; + + var containerAllowsOverflow = getComputedStyle(container).overflow === 'visible'; + var containerRect = container.getBoundingClientRect(); + var containerHeight = Math.min(containerRect.height, window.innerHeight); + var containerWidth = Math.min(containerRect.width, window.innerWidth); + var elOffsetRect = el.getBoundingClientRect(); + + var scrollLeft = container.scrollLeft; + var scrollTop = container.scrollTop; + + var scrolledX = bounding.left - scrollLeft; + var scrolledYTopEdge = bounding.top - scrollTop; + var scrolledYBottomEdge = bounding.top + elOffsetRect.height - scrollTop; + + // Check for container and viewport for left + canAlign.spaceOnRight = !containerAllowsOverflow ? containerWidth - (scrolledX + bounding.width) : window.innerWidth - (elOffsetRect.left + bounding.width); + if (canAlign.spaceOnRight < 0) { + canAlign.left = false; + } + + // Check for container and viewport for Right + canAlign.spaceOnLeft = !containerAllowsOverflow ? scrolledX - bounding.width + elOffsetRect.width : elOffsetRect.right - bounding.width; + if (canAlign.spaceOnLeft < 0) { + canAlign.right = false; + } + + // Check for container and viewport for Top + canAlign.spaceOnBottom = !containerAllowsOverflow ? containerHeight - (scrolledYTopEdge + bounding.height + offset) : window.innerHeight - (elOffsetRect.top + bounding.height + offset); + if (canAlign.spaceOnBottom < 0) { + canAlign.top = false; + } + + // Check for container and viewport for Bottom + canAlign.spaceOnTop = !containerAllowsOverflow ? scrolledYBottomEdge - (bounding.height - offset) : elOffsetRect.bottom - (bounding.height + offset); + if (canAlign.spaceOnTop < 0) { + canAlign.bottom = false; + } + + return canAlign; +}; - cash.prefixedProp = getPrefixedProp; - cash.camelCase = camelCase; +M.getOverflowParent = function (element) { + if (element == null) { + return null; + } - fn.extend({ - css: function(prop, value) { - if (isString(prop)) { - prop = getPrefixedProp(prop); - return arguments.length > 1 ? this.each(function(v) { - return v.style[prop] = value; - }) : win.getComputedStyle(this[0])[prop]; - } + if (element === document.body || getComputedStyle(element).overflow !== 'visible') { + return element; + } - for (const key in prop) { - this.css(key, prop[key]); - } + return M.getOverflowParent(element.parentElement); +}; - return this; - }, +/** + * Gets id of component from a trigger + * @param {Element} trigger trigger + * @returns {string} + */ +M.getIdFromTrigger = function (trigger) { + var id = trigger.getAttribute('data-target'); + if (!id) { + id = trigger.getAttribute('href'); + if (id) { + id = id.slice(1); + } else { + id = ""; + } + } + return id; +}; - }); +/** + * Multi browser support for document scroll top + * @returns {Number} + */ +M.getDocumentScrollTop = function () { + return window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0; +}; - function compute(el, prop) { - return parseInt(win.getComputedStyle(el[0], null)[prop], 10) || 0; - } +/** + * Multi browser support for document scroll left + * @returns {Number} + */ +M.getDocumentScrollLeft = function () { + return window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0; +}; - each(['Width', 'Height'], function(v) { - const lower = v.toLowerCase(); +/** + * @typedef {Object} Edges + * @property {Boolean} top If the top edge was exceeded + * @property {Boolean} right If the right edge was exceeded + * @property {Boolean} bottom If the bottom edge was exceeded + * @property {Boolean} left If the left edge was exceeded + */ - fn[lower] = function() { - return this[0].getBoundingClientRect()[lower]; - }; +/** + * @typedef {Object} Bounding + * @property {Number} left left offset coordinate + * @property {Number} top top offset coordinate + * @property {Number} width + * @property {Number} height + */ - fn['inner' + v] = function() { - return this[0]['client' + v]; - }; +/** + * Get time in ms + * @license https://raw.github.com/jashkenas/underscore/master/LICENSE + * @type {function} + * @return {number} + */ +var getTime = Date.now || function () { + return new Date().getTime(); +}; - fn['outer' + v] = function(margins) { - return this[0]['offset' + v] + (margins ? compute(this, 'margin' + (v === 'Width' ? 'Left' : 'Top')) + compute(this, 'margin' + (v === 'Width' ? 'Right' : 'Bottom')) : 0); - }; - }); +/** + * Returns a function, that, when invoked, will only be triggered at most once + * during a given window of time. Normally, the throttled function will run + * as much as it can, without ever going more than once per `wait` duration; + * but if you'd like to disable the execution on the leading edge, pass + * `{leading: false}`. To disable execution on the trailing edge, ditto. + * @license https://raw.github.com/jashkenas/underscore/master/LICENSE + * @param {function} func + * @param {number} wait + * @param {Object=} options + * @returns {Function} + */ +M.throttle = function (func, wait, options) { + var context = void 0, + args = void 0, + result = void 0; + var timeout = null; + var previous = 0; + options || (options = {}); + var later = function () { + previous = options.leading === false ? 0 : getTime(); + timeout = null; + result = func.apply(context, args); + context = args = null; + }; + return function () { + var now = getTime(); + if (!previous && options.leading === false) previous = now; + var remaining = wait - (now - previous); + context = this; + args = arguments; + if (remaining <= 0) { + clearTimeout(timeout); + timeout = null; + previous = now; + result = func.apply(context, args); + context = args = null; + } else if (!timeout && options.trailing !== false) { + timeout = setTimeout(later, remaining); + } + return result; + }; +}; +; /* + v2.2.0 + 2017 Julian Garnier + Released under the MIT license + */ +var $jscomp = { scope: {} }; $jscomp.defineProperty = "function" == typeof Object.defineProperties ? Object.defineProperty : function (e, r, p) { + if (p.get || p.set) throw new TypeError("ES3 does not support getters and setters."); e != Array.prototype && e != Object.prototype && (e[r] = p.value); +}; $jscomp.getGlobal = function (e) { + return "undefined" != typeof window && window === e ? e : "undefined" != typeof global && null != global ? global : e; +}; $jscomp.global = $jscomp.getGlobal(this); $jscomp.SYMBOL_PREFIX = "jscomp_symbol_"; +$jscomp.initSymbol = function () { + $jscomp.initSymbol = function () { }; $jscomp.global.Symbol || ($jscomp.global.Symbol = $jscomp.Symbol); +}; $jscomp.symbolCounter_ = 0; $jscomp.Symbol = function (e) { + return $jscomp.SYMBOL_PREFIX + (e || "") + $jscomp.symbolCounter_++; +}; +$jscomp.initSymbolIterator = function () { + $jscomp.initSymbol(); var e = $jscomp.global.Symbol.iterator; e || (e = $jscomp.global.Symbol.iterator = $jscomp.global.Symbol("iterator")); "function" != typeof Array.prototype[e] && $jscomp.defineProperty(Array.prototype, e, { + configurable: !0, writable: !0, value: function () { + return $jscomp.arrayIterator(this); + } + }); $jscomp.initSymbolIterator = function () { }; +}; $jscomp.arrayIterator = function (e) { + var r = 0; return $jscomp.iteratorPrototype(function () { + return r < e.length ? { done: !1, value: e[r++] } : { done: !0 }; + }); +}; +$jscomp.iteratorPrototype = function (e) { + $jscomp.initSymbolIterator(); e = { next: e }; e[$jscomp.global.Symbol.iterator] = function () { + return this; + }; return e; +}; $jscomp.array = $jscomp.array || {}; $jscomp.iteratorFromArray = function (e, r) { + $jscomp.initSymbolIterator(); e instanceof String && (e += ""); var p = 0, + m = { + next: function () { + if (p < e.length) { + var u = p++; return { value: r(u, e[u]), done: !1 }; + } m.next = function () { + return { done: !0, value: void 0 }; + }; return m.next(); + } + }; m[Symbol.iterator] = function () { + return m; + }; return m; +}; +$jscomp.polyfill = function (e, r, p, m) { + if (r) { + p = $jscomp.global; e = e.split("."); for (m = 0; m < e.length - 1; m++) { + var u = e[m]; u in p || (p[u] = {}); p = p[u]; + } e = e[e.length - 1]; m = p[e]; r = r(m); r != m && null != r && $jscomp.defineProperty(p, e, { configurable: !0, writable: !0, value: r }); + } +}; $jscomp.polyfill("Array.prototype.keys", function (e) { + return e ? e : function () { + return $jscomp.iteratorFromArray(this, function (e) { + return e; + }); + }; +}, "es6-impl", "es3"); var $jscomp$this = this; +(function (r) { + M.anime = r(); +})(function () { + function e(a) { + if (!h.col(a)) try { + return document.querySelectorAll(a); + } catch (c) { } + } function r(a, c) { + for (var d = a.length, b = 2 <= arguments.length ? arguments[1] : void 0, f = [], n = 0; n < d; n++) { + if (n in a) { + var k = a[n]; c.call(b, k, n, a) && f.push(k); + } + } return f; + } function p(a) { + return a.reduce(function (a, d) { + return a.concat(h.arr(d) ? p(d) : d); + }, []); + } function m(a) { + if (h.arr(a)) return a; + h.str(a) && (a = e(a) || a); return a instanceof NodeList || a instanceof HTMLCollection ? [].slice.call(a) : [a]; + } function u(a, c) { + return a.some(function (a) { + return a === c; + }); + } function C(a) { + var c = {}, + d; for (d in a) { + c[d] = a[d]; + } return c; + } function D(a, c) { + var d = C(a), + b; for (b in a) { + d[b] = c.hasOwnProperty(b) ? c[b] : a[b]; + } return d; + } function z(a, c) { + var d = C(a), + b; for (b in c) { + d[b] = h.und(a[b]) ? c[b] : a[b]; + } return d; + } function T(a) { + a = a.replace(/^#?([a-f\d])([a-f\d])([a-f\d])$/i, function (a, c, d, k) { + return c + c + d + d + k + k; + }); var c = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(a); + a = parseInt(c[1], 16); var d = parseInt(c[2], 16), + c = parseInt(c[3], 16); return "rgba(" + a + "," + d + "," + c + ",1)"; + } function U(a) { + function c(a, c, b) { + 0 > b && (b += 1); 1 < b && --b; return b < 1 / 6 ? a + 6 * (c - a) * b : .5 > b ? c : b < 2 / 3 ? a + (c - a) * (2 / 3 - b) * 6 : a; + } var d = /hsl\((\d+),\s*([\d.]+)%,\s*([\d.]+)%\)/g.exec(a) || /hsla\((\d+),\s*([\d.]+)%,\s*([\d.]+)%,\s*([\d.]+)\)/g.exec(a); a = parseInt(d[1]) / 360; var b = parseInt(d[2]) / 100, + f = parseInt(d[3]) / 100, + d = d[4] || 1; if (0 == b) f = b = a = f; else { + var n = .5 > f ? f * (1 + b) : f + b - f * b, + k = 2 * f - n, + f = c(k, n, a + 1 / 3), + b = c(k, n, a); a = c(k, n, a - 1 / 3); + } return "rgba(" + 255 * f + "," + 255 * b + "," + 255 * a + "," + d + ")"; + } function y(a) { + if (a = /([\+\-]?[0-9#\.]+)(%|px|pt|em|rem|in|cm|mm|ex|ch|pc|vw|vh|vmin|vmax|deg|rad|turn)?$/.exec(a)) return a[2]; + } function V(a) { + if (-1 < a.indexOf("translate") || "perspective" === a) return "px"; if (-1 < a.indexOf("rotate") || -1 < a.indexOf("skew")) return "deg"; + } function I(a, c) { + return h.fnc(a) ? a(c.target, c.id, c.total) : a; + } function E(a, c) { + if (c in a.style) return getComputedStyle(a).getPropertyValue(c.replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase()) || "0"; + } function J(a, c) { + if (h.dom(a) && u(W, c)) return "transform"; if (h.dom(a) && (a.getAttribute(c) || h.svg(a) && a[c])) return "attribute"; if (h.dom(a) && "transform" !== c && E(a, c)) return "css"; if (null != a[c]) return "object"; + } function X(a, c) { + var d = V(c), + d = -1 < c.indexOf("scale") ? 1 : 0 + d; a = a.style.transform; if (!a) return d; for (var b = [], f = [], n = [], k = /(\w+)\((.+?)\)/g; b = k.exec(a);) { + f.push(b[1]), n.push(b[2]); + } a = r(n, function (a, b) { + return f[b] === c; + }); return a.length ? a[0] : d; + } function K(a, c) { + switch (J(a, c)) { + case "transform": + return X(a, c); case "css": + return E(a, c); case "attribute": + return a.getAttribute(c); + }return a[c] || 0; + } function L(a, c) { + var d = /^(\*=|\+=|-=)/.exec(a); if (!d) return a; var b = y(a) || 0; c = parseFloat(c); a = parseFloat(a.replace(d[0], "")); switch (d[0][0]) { + case "+": + return c + a + b; case "-": + return c - a + b; case "*": + return c * a + b; + } + } function F(a, c) { + return Math.sqrt(Math.pow(c.x - a.x, 2) + Math.pow(c.y - a.y, 2)); + } function M(a) { + a = a.points; for (var c = 0, d, b = 0; b < a.numberOfItems; b++) { + var f = a.getItem(b); 0 < b && (c += F(d, f)); d = f; + } return c; + } function N(a) { + if (a.getTotalLength) return a.getTotalLength(); switch (a.tagName.toLowerCase()) { + case "circle": + return 2 * Math.PI * a.getAttribute("r"); case "rect": + return 2 * a.getAttribute("width") + 2 * a.getAttribute("height"); case "line": + return F({ x: a.getAttribute("x1"), y: a.getAttribute("y1") }, { x: a.getAttribute("x2"), y: a.getAttribute("y2") }); case "polyline": + return M(a); case "polygon": + var c = a.points; return M(a) + F(c.getItem(c.numberOfItems - 1), c.getItem(0)); + } + } function Y(a, c) { + function d(b) { + b = void 0 === b ? 0 : b; return a.el.getPointAtLength(1 <= c + b ? c + b : 0); + } var b = d(), + f = d(-1), + n = d(1); switch (a.property) { + case "x": + return b.x; case "y": + return b.y; + case "angle": + return 180 * Math.atan2(n.y - f.y, n.x - f.x) / Math.PI; + } + } function O(a, c) { + var d = /-?\d*\.?\d+/g, + b; b = h.pth(a) ? a.totalLength : a; if (h.col(b)) { + if (h.rgb(b)) { + var f = /rgb\((\d+,\s*[\d]+,\s*[\d]+)\)/g.exec(b); b = f ? "rgba(" + f[1] + ",1)" : b; + } else b = h.hex(b) ? T(b) : h.hsl(b) ? U(b) : void 0; + } else f = (f = y(b)) ? b.substr(0, b.length - f.length) : b, b = c && !/\s/g.test(b) ? f + c : f; b += ""; return { original: b, numbers: b.match(d) ? b.match(d).map(Number) : [0], strings: h.str(a) || c ? b.split(d) : [] }; + } function P(a) { + a = a ? p(h.arr(a) ? a.map(m) : m(a)) : []; return r(a, function (a, d, b) { + return b.indexOf(a) === d; + }); + } function Z(a) { + var c = P(a); return c.map(function (a, b) { + return { target: a, id: b, total: c.length }; + }); + } function aa(a, c) { + var d = C(c); if (h.arr(a)) { + var b = a.length; 2 !== b || h.obj(a[0]) ? h.fnc(c.duration) || (d.duration = c.duration / b) : a = { value: a }; + } return m(a).map(function (a, b) { + b = b ? 0 : c.delay; a = h.obj(a) && !h.pth(a) ? a : { value: a }; h.und(a.delay) && (a.delay = b); return a; + }).map(function (a) { + return z(a, d); + }); + } function ba(a, c) { + var d = {}, + b; for (b in a) { + var f = I(a[b], c); h.arr(f) && (f = f.map(function (a) { + return I(a, c); + }), 1 === f.length && (f = f[0])); d[b] = f; + } d.duration = parseFloat(d.duration); d.delay = parseFloat(d.delay); return d; + } function ca(a) { + return h.arr(a) ? A.apply(this, a) : Q[a]; + } function da(a, c) { + var d; return a.tweens.map(function (b) { + b = ba(b, c); var f = b.value, + e = K(c.target, a.name), + k = d ? d.to.original : e, + k = h.arr(f) ? f[0] : k, + w = L(h.arr(f) ? f[1] : f, k), + e = y(w) || y(k) || y(e); b.from = O(k, e); b.to = O(w, e); b.start = d ? d.end : a.offset; b.end = b.start + b.delay + b.duration; b.easing = ca(b.easing); b.elasticity = (1E3 - Math.min(Math.max(b.elasticity, 1), 999)) / 1E3; b.isPath = h.pth(f); b.isColor = h.col(b.from.original); b.isColor && (b.round = 1); return d = b; + }); + } function ea(a, c) { + return r(p(a.map(function (a) { + return c.map(function (b) { + var c = J(a.target, b.name); if (c) { + var d = da(b, a); b = { type: c, property: b.name, animatable: a, tweens: d, duration: d[d.length - 1].end, delay: d[0].delay }; + } else b = void 0; return b; + }); + })), function (a) { + return !h.und(a); + }); + } function R(a, c, d, b) { + var f = "delay" === a; return c.length ? (f ? Math.min : Math.max).apply(Math, c.map(function (b) { + return b[a]; + })) : f ? b.delay : d.offset + b.delay + b.duration; + } function fa(a) { + var c = D(ga, a), + d = D(S, a), + b = Z(a.targets), + f = [], + e = z(c, d), + k; for (k in a) { + e.hasOwnProperty(k) || "targets" === k || f.push({ name: k, offset: e.offset, tweens: aa(a[k], d) }); + } a = ea(b, f); return z(c, { children: [], animatables: b, animations: a, duration: R("duration", a, c, d), delay: R("delay", a, c, d) }); + } function q(a) { + function c() { + return window.Promise && new Promise(function (a) { + return p = a; + }); + } function d(a) { + return g.reversed ? g.duration - a : a; + } function b(a) { + for (var b = 0, c = {}, d = g.animations, f = d.length; b < f;) { + var e = d[b], + k = e.animatable, + h = e.tweens, + n = h.length - 1, + l = h[n]; n && (l = r(h, function (b) { + return a < b.end; + })[0] || l); for (var h = Math.min(Math.max(a - l.start - l.delay, 0), l.duration) / l.duration, w = isNaN(h) ? 1 : l.easing(h, l.elasticity), h = l.to.strings, p = l.round, n = [], m = void 0, m = l.to.numbers.length, t = 0; t < m; t++) { + var x = void 0, + x = l.to.numbers[t], + q = l.from.numbers[t], + x = l.isPath ? Y(l.value, w * x) : q + w * (x - q); p && (l.isColor && 2 < t || (x = Math.round(x * p) / p)); n.push(x); + } if (l = h.length) for (m = h[0], w = 0; w < l; w++) { + p = h[w + 1], t = n[w], isNaN(t) || (m = p ? m + (t + p) : m + (t + " ")); + } else m = n[0]; ha[e.type](k.target, e.property, m, c, k.id); e.currentValue = m; b++; + } if (b = Object.keys(c).length) for (d = 0; d < b; d++) { + H || (H = E(document.body, "transform") ? "transform" : "-webkit-transform"), g.animatables[d].target.style[H] = c[d].join(" "); + } g.currentTime = a; g.progress = a / g.duration * 100; + } function f(a) { + if (g[a]) g[a](g); + } function e() { + g.remaining && !0 !== g.remaining && g.remaining--; + } function k(a) { + var k = g.duration, + n = g.offset, + w = n + g.delay, + r = g.currentTime, + x = g.reversed, + q = d(a); if (g.children.length) { + var u = g.children, + v = u.length; + if (q >= g.currentTime) for (var G = 0; G < v; G++) { + u[G].seek(q); + } else for (; v--;) { + u[v].seek(q); + } + } if (q >= w || !k) g.began || (g.began = !0, f("begin")), f("run"); if (q > n && q < k) b(q); else if (q <= n && 0 !== r && (b(0), x && e()), q >= k && r !== k || !k) b(k), x || e(); f("update"); a >= k && (g.remaining ? (t = h, "alternate" === g.direction && (g.reversed = !g.reversed)) : (g.pause(), g.completed || (g.completed = !0, f("complete"), "Promise" in window && (p(), m = c()))), l = 0); + } a = void 0 === a ? {} : a; var h, + t, + l = 0, + p = null, + m = c(), + g = fa(a); g.reset = function () { + var a = g.direction, + c = g.loop; g.currentTime = 0; g.progress = 0; g.paused = !0; g.began = !1; g.completed = !1; g.reversed = "reverse" === a; g.remaining = "alternate" === a && 1 === c ? 2 : c; b(0); for (a = g.children.length; a--;) { + g.children[a].reset(); + } + }; g.tick = function (a) { + h = a; t || (t = h); k((l + h - t) * q.speed); + }; g.seek = function (a) { + k(d(a)); + }; g.pause = function () { + var a = v.indexOf(g); -1 < a && v.splice(a, 1); g.paused = !0; + }; g.play = function () { + g.paused && (g.paused = !1, t = 0, l = d(g.currentTime), v.push(g), B || ia()); + }; g.reverse = function () { + g.reversed = !g.reversed; t = 0; l = d(g.currentTime); + }; g.restart = function () { + g.pause(); + g.reset(); g.play(); + }; g.finished = m; g.reset(); g.autoplay && g.play(); return g; + } var ga = { update: void 0, begin: void 0, run: void 0, complete: void 0, loop: 1, direction: "normal", autoplay: !0, offset: 0 }, + S = { duration: 1E3, delay: 0, easing: "easeOutElastic", elasticity: 500, round: 0 }, + W = "translateX translateY translateZ rotate rotateX rotateY rotateZ scale scaleX scaleY scaleZ skewX skewY perspective".split(" "), + H, + h = { + arr: function (a) { + return Array.isArray(a); + }, obj: function (a) { + return -1 < Object.prototype.toString.call(a).indexOf("Object"); + }, + pth: function (a) { + return h.obj(a) && a.hasOwnProperty("totalLength"); + }, svg: function (a) { + return a instanceof SVGElement; + }, dom: function (a) { + return a.nodeType || h.svg(a); + }, str: function (a) { + return "string" === typeof a; + }, fnc: function (a) { + return "function" === typeof a; + }, und: function (a) { + return "undefined" === typeof a; + }, hex: function (a) { + return (/(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(a) + ); + }, rgb: function (a) { + return (/^rgb/.test(a) + ); + }, hsl: function (a) { + return (/^hsl/.test(a) + ); + }, col: function (a) { + return h.hex(a) || h.rgb(a) || h.hsl(a); + } + }, + A = function () { + function a(a, d, b) { + return (((1 - 3 * b + 3 * d) * a + (3 * b - 6 * d)) * a + 3 * d) * a; + } return function (c, d, b, f) { + if (0 <= c && 1 >= c && 0 <= b && 1 >= b) { + var e = new Float32Array(11); if (c !== d || b !== f) for (var k = 0; 11 > k; ++k) { + e[k] = a(.1 * k, c, b); + } return function (k) { + if (c === d && b === f) return k; if (0 === k) return 0; if (1 === k) return 1; for (var h = 0, l = 1; 10 !== l && e[l] <= k; ++l) { + h += .1; + } --l; var l = h + (k - e[l]) / (e[l + 1] - e[l]) * .1, + n = 3 * (1 - 3 * b + 3 * c) * l * l + 2 * (3 * b - 6 * c) * l + 3 * c; if (.001 <= n) { + for (h = 0; 4 > h; ++h) { + n = 3 * (1 - 3 * b + 3 * c) * l * l + 2 * (3 * b - 6 * c) * l + 3 * c; if (0 === n) break; var m = a(l, c, b) - k, + l = l - m / n; + } k = l; + } else if (0 === n) k = l; else { + var l = h, + h = h + .1, + g = 0; do { + m = l + (h - l) / 2, n = a(m, c, b) - k, 0 < n ? h = m : l = m; + } while (1e-7 < Math.abs(n) && 10 > ++g); k = m; + } return a(k, d, f); + }; + } + }; + }(), + Q = function () { + function a(a, b) { + return 0 === a || 1 === a ? a : -Math.pow(2, 10 * (a - 1)) * Math.sin(2 * (a - 1 - b / (2 * Math.PI) * Math.asin(1)) * Math.PI / b); + } var c = "Quad Cubic Quart Quint Sine Expo Circ Back Elastic".split(" "), + d = { + In: [[.55, .085, .68, .53], [.55, .055, .675, .19], [.895, .03, .685, .22], [.755, .05, .855, .06], [.47, 0, .745, .715], [.95, .05, .795, .035], [.6, .04, .98, .335], [.6, -.28, .735, .045], a], Out: [[.25, .46, .45, .94], [.215, .61, .355, 1], [.165, .84, .44, 1], [.23, 1, .32, 1], [.39, .575, .565, 1], [.19, 1, .22, 1], [.075, .82, .165, 1], [.175, .885, .32, 1.275], function (b, c) { + return 1 - a(1 - b, c); + }], InOut: [[.455, .03, .515, .955], [.645, .045, .355, 1], [.77, 0, .175, 1], [.86, 0, .07, 1], [.445, .05, .55, .95], [1, 0, 0, 1], [.785, .135, .15, .86], [.68, -.55, .265, 1.55], function (b, c) { + return .5 > b ? a(2 * b, c) / 2 : 1 - a(-2 * b + 2, c) / 2; + }] + }, + b = { linear: A(.25, .25, .75, .75) }, + f = {}, + e; for (e in d) { + f.type = e, d[f.type].forEach(function (a) { + return function (d, f) { + b["ease" + a.type + c[f]] = h.fnc(d) ? d : A.apply($jscomp$this, d); + }; + }(f)), f = { type: f.type }; + } return b; + }(), + ha = { + css: function (a, c, d) { + return a.style[c] = d; + }, attribute: function (a, c, d) { + return a.setAttribute(c, d); + }, object: function (a, c, d) { + return a[c] = d; + }, transform: function (a, c, d, b, f) { + b[f] || (b[f] = []); b[f].push(c + "(" + d + ")"); + } + }, + v = [], + B = 0, + ia = function () { + function a() { + B = requestAnimationFrame(c); + } function c(c) { + var b = v.length; if (b) { + for (var d = 0; d < b;) { + v[d] && v[d].tick(c), d++; + } a(); + } else cancelAnimationFrame(B), B = 0; + } return a; + }(); q.version = "2.2.0"; q.speed = 1; q.running = v; q.remove = function (a) { + a = P(a); for (var c = v.length; c--;) { + for (var d = v[c], b = d.animations, f = b.length; f--;) { + u(a, b[f].animatable.target) && (b.splice(f, 1), b.length || d.pause()); + } + } + }; q.getValue = K; q.path = function (a, c) { + var d = h.str(a) ? e(a)[0] : a, + b = c || 100; return function (a) { + return { el: d, property: a, totalLength: N(d) * (b / 100) }; + }; + }; q.setDashoffset = function (a) { + var c = N(a); a.setAttribute("stroke-dasharray", c); return c; + }; q.bezier = A; q.easings = Q; q.timeline = function (a) { + var c = q(a); c.pause(); c.duration = 0; c.add = function (d) { + c.children.forEach(function (a) { + a.began = !0; a.completed = !0; + }); m(d).forEach(function (b) { + var d = z(b, D(S, a || {})); d.targets = d.targets || a.targets; b = c.duration; var e = d.offset; d.autoplay = !1; d.direction = c.direction; d.offset = h.und(e) ? b : L(e, b); c.began = !0; c.completed = !0; c.seek(d.offset); d = q(d); d.began = !0; d.completed = !0; d.duration > b && (c.duration = d.duration); c.children.push(d); + }); c.seek(0); c.reset(); c.autoplay && c.restart(); return c; + }; return c; + }; q.random = function (a, c) { + return Math.floor(Math.random() * (c - a + 1)) + a; + }; return q; +}); +; (function ($, anim) { + 'use strict'; + + var _defaults = { + accordion: true, + onOpenStart: undefined, + onOpenEnd: undefined, + onCloseStart: undefined, + onCloseEnd: undefined, + inDuration: 300, + outDuration: 300 + }; + + /** + * @class + * + */ - function registerEvent(node, eventName, callback) { - const eventCache = getData(node, '_cashEvents') || setData(node, '_cashEvents', {}); - eventCache[eventName] = eventCache[eventName] || []; - eventCache[eventName].push(callback); - node.addEventListener(eventName, callback); - } + var Collapsible = function (_Component) { + _inherits(Collapsible, _Component); - function removeEvent(node, eventName, callback) { - // eslint-disable-next-line prefer-const - let events = getData(node, '_cashEvents'), - eventCache = events && events[eventName], - index; - - if (!eventCache) { - return; - } - - if (callback) { - node.removeEventListener(eventName, callback); - index = eventCache.indexOf(callback); - if (index >= 0) { - eventCache.splice(index, 1); - } - } - else { - each(eventCache, function(event) { - node.removeEventListener(eventName, event); - }); - eventCache = []; - } - } - - fn.extend({ - off: function(eventName, callback) { - return this.each(function(v) { - return removeEvent(v, eventName, callback); - }); - }, - - on: function(eventName, delegate, callback, runOnce) { - // jshint ignore:line - let originalCallback; - if (!isString(eventName)) { - for (const key in eventName) { - this.on(key, delegate, eventName[key]); - } - return this; - } - - if (isFunction(delegate)) { - callback = delegate; - delegate = null; - } - - if (eventName === 'ready') { - onReady(callback); - return this; - } - - if (delegate) { - originalCallback = callback; - callback = function(e) { - let t = e.target; - while (!matches(t, delegate)) { - if (t === this || t === null) { - return t = false; - } - - t = t.parentNode; - } - - if (t) { - originalCallback.call(t, e); - } - }; - } - - return this.each(function(v) { - let finalCallback = callback; - if (runOnce) { - finalCallback = function() { - callback.apply(this, arguments); - removeEvent(v, eventName, finalCallback); - }; - } - registerEvent(v, eventName, finalCallback); - }); - }, - - one: function(eventName, delegate, callback) { - return this.on(eventName, delegate, callback, true); - }, - - ready: onReady, - - /** - * Modified - * Triggers browser event - * @param String eventName - * @param Object data - Add properties to event object - */ - trigger: function(eventName, data) { - if (document.createEvent) { - let evt = document.createEvent('HTMLEvents'); - evt.initEvent(eventName, true, false); - evt = this.extend(evt, data); - return this.each(function(v) { - return v.dispatchEvent(evt); - }); - } - }, - - }); - - function encode(name, value) { - return '&' + encodeURIComponent(name) + '=' + encodeURIComponent(value).replace(/%20/g, '+'); - } - - function getSelectMultiple_(el) { - const values = []; - each(el.options, function(o) { - if (o.selected) { - values.push(o.value); - } - }); - return values.length ? values : null; - } - - function getSelectSingle_(el) { - const selectedIndex = el.selectedIndex; - return selectedIndex >= 0 ? el.options[selectedIndex].value : null; - } - - function getValue(el) { - const type = el.type; - if (!type) { - return null; - } - switch (type.toLowerCase()) { - case 'select-one': - return getSelectSingle_(el); - case 'select-multiple': - return getSelectMultiple_(el); - case 'radio': - return el.checked ? el.value : null; - case 'checkbox': - return el.checked ? el.value : null; - default: - return el.value ? el.value : null; - } - } - - fn.extend({ - serialize: function() { - let query = ''; - - each(this[0].elements || this, function(el) { - if (el.disabled || el.tagName === 'FIELDSET') { - return; - } - const name = el.name; - switch (el.type.toLowerCase()) { - case 'file': - case 'reset': - case 'submit': - case 'button': - break; - case 'select-multiple': - // eslint-disable-next-line no-var - var values = getValue(el); - if (values !== null) { - each(values, function(value) { - query += encode(name, value); - }); - } - break; - default: - // eslint-disable-next-line no-var - var value = getValue(el); - if (value !== null) { - query += encode(name, value); - } - } - }); - - return query.substr(1); - }, - - val: function(value) { - if (value === undefined) { - return getValue(this[0]); - } - - return this.each(function(v) { - return v.value = value; - }); - }, - - }); - - function insertElement(el, child, prepend) { - if (prepend) { - const first = el.childNodes[0]; - el.insertBefore(child, first); - } - else { - el.appendChild(child); - } - } - - function insertContent(parent, child, prepend) { - const str = isString(child); - - if (!str && child.length) { - each(child, function(v) { - return insertContent(parent, v, prepend); - }); - return; - } - - each(parent, str ? function(v) { - return v.insertAdjacentHTML(prepend ? 'afterbegin' : 'beforeend', child); - } : function(v, i) { - return insertElement(v, i === 0 ? child : child.cloneNode(true), prepend); - }); - } - - fn.extend({ - after: function(selector) { - cash(selector).insertAfter(this); - return this; - }, - - append: function(content) { - insertContent(this, content); - return this; - }, - - appendTo: function(parent) { - insertContent(cash(parent), this); - return this; - }, - - before: function(selector) { - cash(selector).insertBefore(this); - return this; - }, - - clone: function() { - return cash(this.map(function(v) { - return v.cloneNode(true); - })); - }, - - empty: function() { - this.html(''); - return this; - }, - - html: function(content) { - if (content === undefined) { - return this[0].innerHTML; - } - const source = content.nodeType ? content[0].outerHTML : content; - return this.each(function(v) { - return v.innerHTML = source; - }); - }, - - insertAfter: function(selector) { - const _this = this; - - cash(selector).each(function(el, i) { - const parent = el.parentNode, - sibling = el.nextSibling; - _this.each(function(v) { - parent.insertBefore(i === 0 ? v : v.cloneNode(true), sibling); - }); - }); - - return this; - }, - - insertBefore: function(selector) { - const _this2 = this; - cash(selector).each(function(el, i) { - const parent = el.parentNode; - _this2.each(function(v) { - parent.insertBefore(i === 0 ? v : v.cloneNode(true), el); - }); - }); - return this; - }, - - prepend: function(content) { - insertContent(this, content, true); - return this; - }, - - prependTo: function(parent) { - insertContent(cash(parent), this, true); - return this; - }, - - remove: function() { - return this.each(function(v) { - if (v.parentNode) { - return v.parentNode.removeChild(v); - } - }); - }, - - text: function(content) { - if (content === undefined) { - return this[0].textContent; - } - return this.each(function(v) { - return v.textContent = content; - }); - }, - - }); - - const docEl = doc.documentElement; - - fn.extend({ - position: function() { - const el = this[0]; - return { - left: el.offsetLeft, - top: el.offsetTop, - }; - }, - - offset: function() { - const rect = this[0].getBoundingClientRect(); - return { - top: rect.top + win.pageYOffset - docEl.clientTop, - left: rect.left + win.pageXOffset - docEl.clientLeft, - }; - }, - - offsetParent: function() { - return cash(this[0].offsetParent); - }, - - }); - - fn.extend({ - children: function(selector) { - let elems = []; - this.each(function(el) { - push.apply(elems, el.children); - }); - elems = unique(elems); - - return !selector ? elems : elems.filter(function(v) { - return matches(v, selector); - }); - }, - - closest: function(selector) { - if (!selector || this.length < 1) { - return cash(); - } - if (this.is(selector)) { - return this.filter(selector); - } - return this.parent().closest(selector); - }, - - is: function(selector) { - if (!selector) { - return false; - } - - let match = false, - // eslint-disable-next-line prefer-const - comparator = getCompareFunction(selector); - - this.each(function(el) { - match = comparator(el, selector); - return !match; - }); - - return match; - }, - - find: function(selector) { - if (!selector || selector.nodeType) { - return cash(selector && this.has(selector).length ? selector : null); - } - - const elems = []; - this.each(function(el) { - push.apply(elems, find(selector, el)); - }); - - return unique(elems); - }, - - has: function(selector) { - const comparator = isString(selector) ? function(el) { - return find(selector, el).length !== 0; - } : function(el) { - return el.contains(selector); - }; - - return this.filter(comparator); - }, - - next: function() { - return cash(this[0].nextElementSibling); - }, - - not: function(selector) { - if (!selector) { - return this; - } - - const comparator = getCompareFunction(selector); - - return this.filter(function(el) { - return !comparator(el, selector); - }); - }, - - parent: function() { - const result = []; - - this.each(function(item) { - if (item && item.parentNode) { - result.push(item.parentNode); - } - }); - - return unique(result); - }, - - parents: function(selector) { - let last, - // eslint-disable-next-line prefer-const - result = []; - - this.each(function(item) { - last = item; - - while (last && last.parentNode && last !== doc.body.parentNode) { - last = last.parentNode; - - if (!selector || selector && matches(last, selector)) { - result.push(last); - } - } - }); - - return unique(result); - }, - - prev: function() { - return cash(this[0].previousElementSibling); - }, - - siblings: function(selector) { - const collection = this.parent().children(selector), - el = this[0]; - - return collection.filter(function(i) { - return i !== el; - }); - }, - - }); - - return cash; -}); -; -const Component = function() { - /** - * Generic constructor for all components - * @constructor - * @param {Element} el - * @param {Object} options - */ - // eslint-disable-next-line no-shadow - class Component { - constructor(classDef, el) { - _classCallCheck(this, Component); - - // Display error if el is valid HTML Element - if (!(el instanceof Element)) { - console.error(Error(el + ' is not an HTML Element')); - } - - // If exists, destroy and reinitialize in child - const ins = classDef.getInstance(el); - if (ins) { - ins.destroy(); - } - - this.el = el; - this.$el = cash(el); - } - } - - /** - * Initializes components - * @param {class} classDef - * @param {Element | NodeList | jQuery} els - * @param {Object} options - */ - - - _createClass(Component, null, [{ - key: 'init', - value: function init(classDef, els, options) { - let instances = null; - if (els instanceof Element) { - instances = new classDef(els, options); - } - else if (!!els && (els.jquery || els.cash || els instanceof NodeList)) { - const instancesArr = []; - for (let i = 0; i < els.length; i++) { - instancesArr.push(new classDef(els[i], options)); - } - instances = instancesArr; - } - - return instances; - }, - }]); - - return Component; -}();; - -(function(window) { - if (window.Package) { - M = {}; - } - else { - window.M = {}; - } - - // Check for jQuery - M.jQueryLoaded = !!window.jQuery; -})(window); - -// AMD -if (typeof define === 'function' && define.amd) { - define('M', [], function() { - return M; - }); - - // Common JS -} -else if (typeof exports !== 'undefined' && !exports.nodeType) { - if (typeof module !== 'undefined' && !module.nodeType && module.exports) { - exports = module.exports = M; - } - exports.default = M; -} - -M.keys = { - TAB: 9, - ENTER: 13, - ESC: 27, - ARROW_UP: 38, - ARROW_DOWN: 40, -}; - -/** - * TabPress Keydown handler - */ -M.tabPressed = false; -const docHandleKeydown = function(e) { - if (e.which === M.keys.TAB) { - M.tabPressed = true; - } -}; -const docHandleKeyup = function(e) { - if (e.which === M.keys.TAB) { - M.tabPressed = false; - } -}; -document.addEventListener('keydown', docHandleKeydown); -document.addEventListener('keyup', docHandleKeyup); - -/** - * Initialize jQuery wrapper for plugin - * @param {Class} plugin javascript class - * @param {string} pluginName jQuery plugin name - * @param {string} classRef Class reference name - */ -M.initializeJqueryWrapper = function(plugin, pluginName, classRef) { - jQuery.fn[pluginName] = function(methodOrOptions) { - // Call plugin method if valid method name is passed in - if (plugin.prototype[methodOrOptions]) { - const params = Array.prototype.slice.call(arguments, 1); - - // Getter methods - if (methodOrOptions.slice(0, 3) === 'get') { - const instance = this.first()[0][classRef]; - return instance[methodOrOptions].apply(instance, params); - } - - // Void methods - return this.each(function() { - const instance = this[classRef]; - instance[methodOrOptions].apply(instance, params); - }); - - // Initialize plugin if options or no argument is passed in - } - else if (typeof methodOrOptions === 'object' || !methodOrOptions) { - plugin.init(this, arguments[0]); - return this; - } - - // Return error if an unrecognized method name is passed in - jQuery.error('Method ' + methodOrOptions + ' does not exist on jQuery.' + pluginName); - }; -}; - -/** - * Automatically initialize components - * @param {Element} context DOM Element to search within for components - */ -M.AutoInit = function(context) { - // Use document.body if no context is given - const root = context ? context : document.body; - - const registry = { - Autocomplete: root.querySelectorAll('.autocomplete:not(.no-autoinit)'), - Carousel: root.querySelectorAll('.carousel:not(.no-autoinit)'), - Chips: root.querySelectorAll('.chips:not(.no-autoinit)'), - Collapsible: root.querySelectorAll('.collapsible:not(.no-autoinit)'), - Datepicker: root.querySelectorAll('.datepicker:not(.no-autoinit)'), - Dropdown: root.querySelectorAll('.dropdown-trigger:not(.no-autoinit)'), - Materialbox: root.querySelectorAll('.materialboxed:not(.no-autoinit)'), - Modal: root.querySelectorAll('.modal:not(.no-autoinit)'), - Parallax: root.querySelectorAll('.parallax:not(.no-autoinit)'), - Pushpin: root.querySelectorAll('.pushpin:not(.no-autoinit)'), - ScrollSpy: root.querySelectorAll('.scrollspy:not(.no-autoinit)'), - FormSelect: root.querySelectorAll('select:not(.no-autoinit)'), - Sidenav: root.querySelectorAll('.sidenav:not(.no-autoinit)'), - Tabs: root.querySelectorAll('.tabs:not(.no-autoinit)'), - TapTarget: root.querySelectorAll('.tap-target:not(.no-autoinit)'), - Timepicker: root.querySelectorAll('.timepicker:not(.no-autoinit)'), - Tooltip: root.querySelectorAll('.tooltipped:not(.no-autoinit)'), - FloatingActionButton: root.querySelectorAll('.fixed-action-btn:not(.no-autoinit)'), - }; - - for (const pluginName in registry) { - const plugin = M[pluginName]; - plugin.init(registry[pluginName]); - } -}; - -/** - * Generate approximated selector string for a jQuery object - * @param {jQuery} obj jQuery object to be parsed - * @returns {string} - */ -M.objectSelectorString = function(obj) { - const tagStr = obj.prop('tagName') || ''; - const idStr = obj.attr('id') || ''; - const classStr = obj.attr('class') || ''; - return (tagStr + idStr + classStr).replace(/\s/g, ''); -}; - -// Unique Random ID -M.guid = function() { - function s4() { - return Math.floor((1 + Math.random()) * 0x10000).toString(16).substring(1); - } - return function() { - return s4() + s4() + '-' + s4() + '-' + s4() + '-' + s4() + '-' + s4() + s4() + s4(); - }; -}(); - -/** - * Escapes hash from special characters - * @param {string} hash String returned from this.hash - * @returns {string} - */ -M.escapeHash = function(hash) { - return hash.replace(/\\/g, '\\\\').replace(/(:|\.|\[|\]|,|=|\/)/g, '\\$1'); -}; - -M.elementOrParentIsFixed = function(element) { - const $element = $(element); - const $checkElements = $element.add($element.parents()); - let isFixed = false; - $checkElements.each(function() { - if ($(this).css('position') === 'fixed') { - isFixed = true; - return false; - } - }); - return isFixed; -}; - -/** - * @typedef {Object} Edges - * @property {Boolean} top If the top edge was exceeded - * @property {Boolean} right If the right edge was exceeded - * @property {Boolean} bottom If the bottom edge was exceeded - * @property {Boolean} left If the left edge was exceeded - */ - -/** - * @typedef {Object} Bounding - * @property {Number} left left offset coordinate - * @property {Number} top top offset coordinate - * @property {Number} width - * @property {Number} height - */ - -/** - * Escapes hash from special characters - * @param {Element} container Container element that acts as the boundary - * @param {Bounding} bounding element bounding that is being checked - * @param {Number} offset offset from edge that counts as exceeding - * @returns {Edges} - */ -M.checkWithinContainer = function(container, bounding, offset) { - const edges = { - top: false, - right: false, - bottom: false, - left: false, - }; - - const containerRect = container.getBoundingClientRect(); - - const scrollLeft = container.scrollLeft; - const scrollTop = container.scrollTop; - - const scrolledX = bounding.left - scrollLeft; - const scrolledY = bounding.top - scrollTop; - - // Check for container and viewport for each edge - if (scrolledX < containerRect.left + offset || scrolledX < offset) { - edges.left = true; - } - - if (scrolledX + bounding.width > containerRect.right - offset || scrolledX + bounding.width > window.innerWidth - offset) { - edges.right = true; - } - - if (scrolledY < containerRect.top + offset || scrolledY < offset) { - edges.top = true; - } - - if (scrolledY + bounding.height > containerRect.bottom - offset || scrolledY + bounding.height > window.innerHeight - offset) { - edges.bottom = true; - } - - return edges; -}; - -M.checkPossibleAlignments = function(el, container, bounding, offset) { - const canAlign = { - top: true, - right: true, - bottom: true, - left: true, - spaceOnTop: null, - spaceOnRight: null, - spaceOnBottom: null, - spaceOnLeft: null, - }; - - const containerAllowsOverflow = getComputedStyle(container).overflow === 'visible'; - const containerRect = container.getBoundingClientRect(); - const containerHeight = Math.min(containerRect.height, window.innerHeight); - const containerWidth = Math.min(containerRect.width, window.innerWidth); - const elOffsetRect = el.getBoundingClientRect(); - - const scrollLeft = container.scrollLeft; - const scrollTop = container.scrollTop; - - const scrolledX = bounding.left - scrollLeft; - const scrolledYTopEdge = bounding.top - scrollTop; - const scrolledYBottomEdge = bounding.top + elOffsetRect.height - scrollTop; - - // Check for container and viewport for left - canAlign.spaceOnRight = !containerAllowsOverflow ? containerWidth - (scrolledX + bounding.width) : window.innerWidth - (elOffsetRect.left + bounding.width); - if (canAlign.spaceOnRight < 0) { - canAlign.left = false; - } - - // Check for container and viewport for Right - canAlign.spaceOnLeft = !containerAllowsOverflow ? scrolledX - bounding.width + elOffsetRect.width : elOffsetRect.right - bounding.width; - if (canAlign.spaceOnLeft < 0) { - canAlign.right = false; - } - - // Check for container and viewport for Top - canAlign.spaceOnBottom = !containerAllowsOverflow ? containerHeight - (scrolledYTopEdge + bounding.height + offset) : window.innerHeight - (elOffsetRect.top + bounding.height + offset); - if (canAlign.spaceOnBottom < 0) { - canAlign.top = false; - } - - // Check for container and viewport for Bottom - canAlign.spaceOnTop = !containerAllowsOverflow ? scrolledYBottomEdge - (bounding.height - offset) : elOffsetRect.bottom - (bounding.height + offset); - if (canAlign.spaceOnTop < 0) { - canAlign.bottom = false; - } - - return canAlign; -}; - -M.getOverflowParent = function(element) { - if (element == null) { - return null; - } - - if (element === document.body || getComputedStyle(element).overflow !== 'visible') { - return element; - } - - return M.getOverflowParent(element.parentElement); -}; - -/** - * Gets id of component from a trigger - * @param {Element} trigger trigger - * @returns {string} - */ -M.getIdFromTrigger = function(trigger) { - let id = trigger.getAttribute('data-target'); - if (!id) { - id = trigger.getAttribute('href'); - if (id) { - id = id.slice(1); - } - else { - id = ''; - } - } - return id; -}; - -/** - * Multi browser support for document scroll top - * @returns {Number} - */ -M.getDocumentScrollTop = function() { - return window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0; -}; - -/** - * Multi browser support for document scroll left - * @returns {Number} - */ -M.getDocumentScrollLeft = function() { - return window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0; -}; - -/** - * @typedef {Object} Edges - * @property {Boolean} top If the top edge was exceeded - * @property {Boolean} right If the right edge was exceeded - * @property {Boolean} bottom If the bottom edge was exceeded - * @property {Boolean} left If the left edge was exceeded - */ - -/** - * @typedef {Object} Bounding - * @property {Number} left left offset coordinate - * @property {Number} top top offset coordinate - * @property {Number} width - * @property {Number} height - */ - -/** - * Get time in ms - * @license https://raw.github.com/jashkenas/underscore/master/LICENSE - * @type {function} - * @return {number} - */ -const getTime = Date.now || function() { - return new Date().getTime(); -}; - -/** - * Returns a function, that, when invoked, will only be triggered at most once - * during a given window of time. Normally, the throttled function will run - * as much as it can, without ever going more than once per `wait` duration; - * but if you'd like to disable the execution on the leading edge, pass - * `{leading: false}`. To disable execution on the trailing edge, ditto. - * @license https://raw.github.com/jashkenas/underscore/master/LICENSE - * @param {function} func - * @param {number} wait - * @param {Object=} options - * @returns {Function} - */ -M.throttle = function(func, wait, options) { - let context = void 0, - args = void 0, - result = void 0; - let timeout = null; - let previous = 0; - options || (options = {}); - const later = function() { - previous = options.leading === false ? 0 : getTime(); - timeout = null; - result = func.apply(context, args); - context = args = null; - }; - return function() { - const now = getTime(); - if (!previous && options.leading === false) previous = now; - const remaining = wait - (now - previous); - context = this; - args = arguments; - if (remaining <= 0) { - clearTimeout(timeout); - timeout = null; - previous = now; - result = func.apply(context, args); - context = args = null; - } - else if (!timeout && options.trailing !== false) { - timeout = setTimeout(later, remaining); - } - return result; - }; -}; -// eslint-disable-next-line no-inline-comments -; /* - v2.2.0 - 2017 Julian Garnier - Released under the MIT license - */ -const $jscomp = { scope: {} }; $jscomp.defineProperty = typeof Object.defineProperties == 'function' ? Object.defineProperty : function(e, r, p) { - if (p.get || p.set) throw new TypeError('ES3 does not support getters and setters.'); e != Array.prototype && e != Object.prototype && (e[r] = p.value); -}; $jscomp.getGlobal = function(e) { - return typeof window != 'undefined' && window === e ? e : typeof global != 'undefined' && global != null ? global : e; -// eslint-disable-next-line max-statements-per-line -}; $jscomp.global = $jscomp.getGlobal(this); $jscomp.SYMBOL_PREFIX = 'jscomp_symbol_'; -$jscomp.initSymbol = function() { - // eslint-disable-next-line no-empty-function - $jscomp.initSymbol = function() { }; $jscomp.global.Symbol || ($jscomp.global.Symbol = $jscomp.Symbol); -// eslint-disable-next-line max-statements-per-line -}; $jscomp.symbolCounter_ = 0; $jscomp.Symbol = function(e) { - return $jscomp.SYMBOL_PREFIX + (e || '') + $jscomp.symbolCounter_++; -}; -$jscomp.initSymbolIterator = function() { - // eslint-disable-next-line max-statements-per-line - $jscomp.initSymbol(); let e = $jscomp.global.Symbol.iterator; e || (e = $jscomp.global.Symbol.iterator = $jscomp.global.Symbol('iterator')); typeof Array.prototype[e] != 'function' && $jscomp.defineProperty(Array.prototype, e, { - configurable: !0, writable: !0, value: function() { - return $jscomp.arrayIterator(this); - }, - // eslint-disable-next-line no-empty-function - }); $jscomp.initSymbolIterator = function() { }; -}; $jscomp.arrayIterator = function(e) { - let r = 0; return $jscomp.iteratorPrototype(function() { - return r < e.length ? { done: !1, value: e[r++] } : { done: !0 }; - }); -}; -$jscomp.iteratorPrototype = function(e) { - // eslint-disable-next-line max-statements-per-line - $jscomp.initSymbolIterator(); e = { next: e }; e[$jscomp.global.Symbol.iterator] = function() { - return this; - }; return e; -// eslint-disable-next-line max-statements-per-line -}; $jscomp.array = $jscomp.array || {}; $jscomp.iteratorFromArray = function(e, r) { - // eslint-disable-next-line max-statements-per-line, no-var - $jscomp.initSymbolIterator(); e instanceof String && (e += ''); var p = 0, - m = { - next: function() { - if (p < e.length) { - const u = p++; return { value: r(u, e[u]), done: !1 }; - } m.next = function() { - return { done: !0, value: void 0 }; - }; return m.next(); - }, - }; m[Symbol.iterator] = function() { - return m; - }; return m; -}; -$jscomp.polyfill = function(e, r, p, m) { - if (r) { - // eslint-disable-next-line max-statements-per-line - p = $jscomp.global; e = e.split('.'); for (m = 0; m < e.length - 1; m++) { - // eslint-disable-next-line max-statements-per-line - const u = e[m]; u in p || (p[u] = {}); p = p[u]; - // eslint-disable-next-line max-statements-per-line - } e = e[e.length - 1]; m = p[e]; r = r(m); r != m && r != null && $jscomp.defineProperty(p, e, { configurable: !0, writable: !0, value: r }); - } -}; $jscomp.polyfill('Array.prototype.keys', function(e) { - return e ? e : function() { - // eslint-disable-next-line no-shadow - return $jscomp.iteratorFromArray(this, function(e) { - return e; - }); - }; -}, 'es6-impl', 'es3'); const $jscomp$this = this; -(function(r) { - M.anime = r(); -})(function() { - function e(a) { - if (!h.col(a)) { - try { - return document.querySelectorAll(a); - } - // eslint-disable-next-line no-unused-vars, no-inline-comments - catch (c) { /* empty */ } - } - } function r(a, c) { - // eslint-disable-next-line no-var - for (var d = a.length, b = arguments.length >= 2 ? arguments[1] : void 0, f = [], n = 0; n < d; n++) { - if (n in a) { - const k = a[n]; c.call(b, k, n, a) && f.push(k); - } - } return f; - } function p(a) { - // eslint-disable-next-line no-shadow - return a.reduce(function(a, d) { - return a.concat(h.arr(d) ? p(d) : d); - }, []); - } function m(a) { - if (h.arr(a)) return a; - h.str(a) && (a = e(a) || a); return a instanceof NodeList || a instanceof HTMLCollection ? [].slice.call(a) : [a]; - } function u(a, c) { - // eslint-disable-next-line no-shadow - return a.some(function(a) { - return a === c; - }); - } function C(a) { - // eslint-disable-next-line prefer-const - let c = {}, - d; for (d in a) { - c[d] = a[d]; - } return c; - } function D(a, c) { - // eslint-disable-next-line prefer-const - let d = C(a), - b; for (b in a) { - d[b] = Object.prototype.hasOwnProperty.call(c, b) ? c[b] : a[b]; - } return d; - } function z(a, c) { - // eslint-disable-next-line prefer-const - let d = C(a), - b; for (b in c) { - d[b] = h.und(a[b]) ? c[b] : a[b]; - } return d; - } function T(a) { - a = a.replace(/^#?([a-f\d])([a-f\d])([a-f\d])$/i, function(_a, c, d, k) { - return c + c + d + d + k + k; - // eslint-disable-next-line no-var - }); var c = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(a); - // eslint-disable-next-line no-var - a = parseInt(c[1], 16); var d = parseInt(c[2], 16), - // eslint-disable-next-line no-redeclare - c = parseInt(c[3], 16); return 'rgba(' + a + ',' + d + ',' + c + ',1)'; - } function U(a) { - // eslint-disable-next-line no-shadow - function c(a, c, b) { - // eslint-disable-next-line max-statements-per-line - b < 0 && (b += 1); b > 1 && --b; return b < 1 / 6 ? a + 6 * (c - a) * b : b < 0.5 ? c : b < 2 / 3 ? a + (c - a) * (2 / 3 - b) * 6 : a; - // eslint-disable-next-line no-var, max-statements-per-line - } var d = /hsl\((\d+),\s*([\d.]+)%,\s*([\d.]+)%\)/g.exec(a) || /hsla\((\d+),\s*([\d.]+)%,\s*([\d.]+)%,\s*([\d.]+)\)/g.exec(a); a = parseInt(d[1]) / 360; var b = parseInt(d[2]) / 100, - f = parseInt(d[3]) / 100, - // eslint-disable-next-line no-redeclare, max-statements-per-line - d = d[4] || 1; if (b == 0) {f = b = a = f;} - else { - // eslint-disable-next-line no-var - var n = f < 0.5 ? f * (1 + b) : f + b - f * b, - k = 2 * f - n, - // eslint-disable-next-line no-redeclare - f = c(k, n, a + 1 / 3), - // eslint-disable-next-line no-redeclare - b = c(k, n, a); a = c(k, n, a - 1 / 3); - } return 'rgba(' + 255 * f + ',' + 255 * b + ',' + 255 * a + ',' + d + ')'; - } function y(a) { - // eslint-disable-next-line no-cond-assign - if (a = /([+-]?[0-9#.]+)(%|px|pt|em|rem|in|cm|mm|ex|ch|pc|vw|vh|vmin|vmax|deg|rad|turn)?$/.exec(a)) return a[2]; - } function V(a) { - if (a.indexOf('translate') > -1 || a === 'perspective') return 'px'; if (a.indexOf('rotate') > -1 || a.indexOf('skew') > -1) return 'deg'; - } function I(a, c) { - return h.fnc(a) ? a(c.target, c.id, c.total) : a; - } function E(a, c) { - if (c in a.style) return getComputedStyle(a).getPropertyValue(c.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase()) || '0'; - } function J(a, c) { - // eslint-disable-next-line max-statements-per-line - if (h.dom(a) && u(W, c)) return 'transform'; if (h.dom(a) && (a.getAttribute(c) || h.svg(a) && a[c])) return 'attribute'; if (h.dom(a) && c !== 'transform' && E(a, c)) return 'css'; if (a[c] != null) return 'object'; - } function X(a, c) { - // eslint-disable-next-line no-var - var d = V(c), - // eslint-disable-next-line no-redeclare, max-statements-per-line, no-var, no-cond-assign - d = c.indexOf('scale') > -1 ? 1 : 0 + d; a = a.style.transform; if (!a) return d; for (var b = [], f = [], n = [], k = /(\w+)\((.+?)\)/g; b = k.exec(a);) { - f.push(b[1]), n.push(b[2]); - // eslint-disable-next-line no-shadow - } a = r(n, function(_a, b) { - return f[b] === c; - }); return a.length ? a[0] : d; - } function K(a, c) { - switch (J(a, c)) { - case 'transform': - return X(a, c); case 'css': - return E(a, c); case 'attribute': - return a.getAttribute(c); - } return a[c] || 0; - } function L(a, c) { - // eslint-disable-next-line max-statements-per-line - const d = /^(\*=|\+=|-=)/.exec(a); if (!d) return a; const b = y(a) || 0; c = parseFloat(c); a = parseFloat(a.replace(d[0], '')); switch (d[0][0]) { - case '+': - return c + a + b; case '-': - return c - a + b; case '*': - return c * a + b; - } - } function F(a, c) { - return Math.sqrt(Math.pow(c.x - a.x, 2) + Math.pow(c.y - a.y, 2)); - } function M(a) { - // eslint-disable-next-line no-var - a = a.points; for (var c = 0, d, b = 0; b < a.numberOfItems; b++) { - // eslint-disable-next-line max-statements-per-line - const f = a.getItem(b); b > 0 && (c += F(d, f)); d = f; - } return c; - } function N(a) { - if (a.getTotalLength) return a.getTotalLength(); switch (a.tagName.toLowerCase()) { - case 'circle': - return 2 * Math.PI * a.getAttribute('r'); case 'rect': - return 2 * a.getAttribute('width') + 2 * a.getAttribute('height'); case 'line': - return F({ x: a.getAttribute('x1'), y: a.getAttribute('y1') }, { x: a.getAttribute('x2'), y: a.getAttribute('y2') }); case 'polyline': - return M(a); case 'polygon': - // eslint-disable-next-line no-var - var c = a.points; return M(a) + F(c.getItem(c.numberOfItems - 1), c.getItem(0)); - } - } function Y(a, c) { - function d(b) { - b = void 0 === b ? 0 : b; return a.el.getPointAtLength(c + b >= 1 ? c + b : 0); - } const b = d(), - f = d(-1), - n = d(1); switch (a.property) { - case 'x': - return b.x; case 'y': - return b.y; - case 'angle': - return 180 * Math.atan2(n.y - f.y, n.x - f.x) / Math.PI; - } - } function O(a, c) { - // eslint-disable-next-line prefer-const - let d = /-?\d*\.?\d+/g, - // eslint-disable-next-line max-statements-per-line - b; b = h.pth(a) ? a.totalLength : a; if (h.col(b)) { - if (h.rgb(b)) { - // eslint-disable-next-line no-var - var f = /rgb\((\d+,\s*[\d]+,\s*[\d]+)\)/g.exec(b); b = f ? 'rgba(' + f[1] + ',1)' : b; - } - else {b = h.hex(b) ? T(b) : h.hsl(b) ? U(b) : void 0;} - } - // eslint-disable-next-line no-cond-assign, max-statements-per-line - else {f = (f = y(b)) ? b.substr(0, b.length - f.length) : b, b = c && !/\s/g.test(b) ? f + c : f;} b += ''; return { original: b, numbers: b.match(d) ? b.match(d).map(Number) : [0], strings: h.str(a) || c ? b.split(d) : [] }; - } function P(a) { - // eslint-disable-next-line no-shadow - a = a ? p(h.arr(a) ? a.map(m) : m(a)) : []; return r(a, function(a, d, b) { - return b.indexOf(a) === d; - }); - } function Z(a) { - // eslint-disable-next-line no-shadow - const c = P(a); return c.map(function(a, b) { - return { target: a, id: b, total: c.length }; - }); - } function aa(a, c) { - const d = C(c); if (h.arr(a)) { - const b = a.length; b !== 2 || h.obj(a[0]) ? h.fnc(c.duration) || (d.duration = c.duration / b) : a = { value: a }; - // eslint-disable-next-line no-shadow - } return m(a).map(function(a, b) { - // eslint-disable-next-line max-statements-per-line - b = b ? 0 : c.delay; a = h.obj(a) && !h.pth(a) ? a : { value: a }; h.und(a.delay) && (a.delay = b); return a; - // eslint-disable-next-line no-shadow - }).map(function(a) { - return z(a, d); - }); - } function ba(a, c) { - // eslint-disable-next-line prefer-const - let d = {}, - b; for (b in a) { - // eslint-disable-next-line no-shadow - let f = I(a[b], c); h.arr(f) && (f = f.map(function(a) { - return I(a, c); - }), f.length === 1 && (f = f[0])); d[b] = f; - // eslint-disable-next-line max-statements-per-line - } d.duration = parseFloat(d.duration); d.delay = parseFloat(d.delay); return d; - } function ca(a) { - return h.arr(a) ? A.apply(this, a) : Q[a]; - } function da(a, c) { - let d; return a.tweens.map(function(b) { - // eslint-disable-next-line no-var - b = ba(b, c); var f = b.value, - // eslint-disable-next-line no-shadow - e = K(c.target, a.name), - k = d ? d.to.original : e, - // eslint-disable-next-line no-redeclare - k = h.arr(f) ? f[0] : k, - w = L(h.arr(f) ? f[1] : f, k), - // eslint-disable-next-line no-redeclare, max-statements-per-line - e = y(w) || y(k) || y(e); b.from = O(k, e); b.to = O(w, e); b.start = d ? d.end : a.offset; b.end = b.start + b.delay + b.duration; b.easing = ca(b.easing); b.elasticity = (1E3 - Math.min(Math.max(b.elasticity, 1), 999)) / 1E3; b.isPath = h.pth(f); b.isColor = h.col(b.from.original); b.isColor && (b.round = 1); return d = b; - }); - } function ea(a, c) { - // eslint-disable-next-line no-shadow - return r(p(a.map(function(a) { - return c.map(function(b) { - // eslint-disable-next-line no-shadow - const c = J(a.target, b.name); if (c) { - const d = da(b, a); b = { type: c, property: b.name, animatable: a, tweens: d, duration: d[d.length - 1].end, delay: d[0].delay }; - } - else {b = void 0;} return b; - }); - // eslint-disable-next-line no-shadow - })), function(a) { - return !h.und(a); - }); - } function R(a, c, d, b) { - // eslint-disable-next-line no-shadow - const f = a === 'delay'; return c.length ? (f ? Math.min : Math.max).apply(Math, c.map(function(b) { - return b[a]; - })) : f ? b.delay : d.offset + b.delay + b.duration; - } function fa(a) { - // eslint-disable-next-line prefer-const - let c = D(ga, a), - // eslint-disable-next-line prefer-const - d = D(S, a), - // eslint-disable-next-line prefer-const - b = Z(a.targets), - // eslint-disable-next-line prefer-const - f = [], - // eslint-disable-next-line no-shadow, prefer-const - e = z(c, d), - k; for (k in a) { - Object.prototype.hasOwnProperty.call(e, k) || k === 'targets' || f.push({ name: k, offset: e.offset, tweens: aa(a[k], d) }); - // eslint-disable-next-line max-statements-per-line - } a = ea(b, f); return z(c, { children: [], animatables: b, animations: a, duration: R('duration', a, c, d), delay: R('delay', a, c, d) }); - } function q(a) { - function c() { - // eslint-disable-next-line no-shadow - return window.Promise && new Promise(function(a) { - return p = a; - }); - // eslint-disable-next-line no-shadow - } function d(a) { - return g.reversed ? g.duration - a : a; - // eslint-disable-next-line no-shadow - } function b(a) { - // eslint-disable-next-line no-var, no-shadow - for (var b = 0, c = {}, d = g.animations, f = d.length; b < f;) { - // eslint-disable-next-line no-var, no-shadow - var e = d[b], - // eslint-disable-next-line no-shadow - k = e.animatable, - h = e.tweens, - n = h.length - 1, - // eslint-disable-next-line no-shadow - l = h[n]; n && (l = r(h, function(b) { - return a < b.end; - // eslint-disable-next-line no-var, no-redeclare - })[0] || l); for (var h = Math.min(Math.max(a - l.start - l.delay, 0), l.duration) / l.duration, w = isNaN(h) ? 1 : l.easing(h, l.elasticity), h = l.to.strings, p = l.round, n = [], m = void 0, m = l.to.numbers.length, t = 0; t < m; t++) { - // eslint-disable-next-line no-var - var x = void 0, - // eslint-disable-next-line no-redeclare - x = l.to.numbers[t], - // eslint-disable-next-line no-shadow - q = l.from.numbers[t], - // eslint-disable-next-line no-redeclare, max-statements-per-line - x = l.isPath ? Y(l.value, w * x) : q + w * (x - q); p && (l.isColor && t > 2 || (x = Math.round(x * p) / p)); n.push(x); - // eslint-disable-next-line no-cond-assign - } if (l = h.length) { - for (m = h[0], w = 0; w < l; w++) { - p = h[w + 1], t = n[w], isNaN(t) || (m = p ? m + (t + p) : m + (t + ' ')); - } - } - // eslint-disable-next-line max-statements-per-line - else {m = n[0];} ha[e.type](k.target, e.property, m, c, k.id); e.currentValue = m; b++; - // eslint-disable-next-line no-cond-assign - } if (b = Object.keys(c).length) { - for (d = 0; d < b; d++) { - H || (H = E(document.body, 'transform') ? 'transform' : '-webkit-transform'), g.animatables[d].target.style[H] = c[d].join(' '); - } - // eslint-disable-next-line max-statements-per-line - } g.currentTime = a; g.progress = a / g.duration * 100; - // eslint-disable-next-line no-shadow - } function f(a) { - if (g[a]) g[a](g); - // eslint-disable-next-line no-shadow - } function e() { - g.remaining && !0 !== g.remaining && g.remaining--; - // eslint-disable-next-line no-shadow - } function k(a) { - // eslint-disable-next-line no-shadow - const k = g.duration, - n = g.offset, - w = n + g.delay, - // eslint-disable-next-line no-shadow - r = g.currentTime, - x = g.reversed, - // eslint-disable-next-line no-shadow - q = d(a); if (g.children.length) { - // eslint-disable-next-line no-shadow, prefer-const - let u = g.children, - v = u.length; - if (q >= g.currentTime) { - for (let G = 0; G < v; G++) { - u[G].seek(q); - } - } - else { - for (; v--;) { - u[v].seek(q); - } - } - // eslint-disable-next-line max-statements-per-line - } if (q >= w || !k) g.began || (g.began = !0, f('begin')), f('run'); if (q > n && q < k) b(q); else if (q <= n && r !== 0 && (b(0), x && e()), q >= k && r !== k || !k) b(k), x || e(); f('update'); a >= k && (g.remaining ? (t = h, g.direction === 'alternate' && (g.reversed = !g.reversed)) : (g.pause(), g.completed || (g.completed = !0, f('complete'), 'Promise' in window && (p(), m = c()))), l = 0); - // eslint-disable-next-line max-statements-per-line, no-var - } a = void 0 === a ? {} : a; var h, - t, - l = 0, - // eslint-disable-next-line no-shadow - p = null, - // eslint-disable-next-line no-shadow - m = c(), - g = fa(a); g.reset = function() { - // eslint-disable-next-line no-shadow - let a = g.direction, - // eslint-disable-next-line no-shadow, prefer-const, max-statements-per-line - c = g.loop; g.currentTime = 0; g.progress = 0; g.paused = !0; g.began = !1; g.completed = !1; g.reversed = a === 'reverse'; g.remaining = a === 'alternate' && c === 1 ? 2 : c; b(0); for (a = g.children.length; a--;) { - g.children[a].reset(); - } - // eslint-disable-next-line no-shadow - }; g.tick = function(a) { - // eslint-disable-next-line max-statements-per-line - h = a; t || (t = h); k((l + h - t) * q.speed); - // eslint-disable-next-line no-shadow - }; g.seek = function(a) { - k(d(a)); - }; g.pause = function() { - // eslint-disable-next-line max-statements-per-line, no-shadow - const a = v.indexOf(g); a > -1 && v.splice(a, 1); g.paused = !0; - }; g.play = function() { - g.paused && (g.paused = !1, t = 0, l = d(g.currentTime), v.push(g), B || ia()); - }; g.reverse = function() { - // eslint-disable-next-line max-statements-per-line - g.reversed = !g.reversed; t = 0; l = d(g.currentTime); - }; g.restart = function() { - g.pause(); - g.reset(); g.play(); - // eslint-disable-next-line max-statements-per-line - }; g.finished = m; g.reset(); g.autoplay && g.play(); return g; - // eslint-disable-next-line no-var - } var ga = { update: void 0, begin: void 0, run: void 0, complete: void 0, loop: 1, direction: 'normal', autoplay: !0, offset: 0 }, - S = { duration: 1E3, delay: 0, easing: 'easeOutElastic', elasticity: 500, round: 0 }, - W = 'translateX translateY translateZ rotate rotateX rotateY rotateZ scale scaleX scaleY scaleZ skewX skewY perspective'.split(' '), - H, - h = { - arr: function(a) { - return Array.isArray(a); - }, obj: function(a) { - return Object.prototype.toString.call(a).indexOf('Object') > -1; - }, - pth: function(a) { - return h.obj(a) && Object.prototype.hasOwnProperty.call(a, 'totalLength'); - }, svg: function(a) { - return a instanceof SVGElement; - }, dom: function(a) { - return a.nodeType || h.svg(a); - }, str: function(a) { - return typeof a === 'string'; - }, fnc: function(a) { - return typeof a === 'function'; - }, und: function(a) { - return typeof a === 'undefined'; - }, hex: function(a) { - return (/(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(a) - ); - }, rgb: function(a) { - return (/^rgb/.test(a) - ); - }, hsl: function(a) { - return (/^hsl/.test(a) - ); - }, col: function(a) { - return h.hex(a) || h.rgb(a) || h.hsl(a); - }, - }, - A = function() { - // eslint-disable-next-line no-shadow - function a(a, d, b) { - return (((1 - 3 * b + 3 * d) * a + (3 * b - 6 * d)) * a + 3 * d) * a; - } return function(c, d, b, f) { - if (c >= 0 && c <= 1 && b >= 0 && b <= 1) { - // eslint-disable-next-line no-shadow - const e = new Float32Array(11); if (c !== d || b !== f) { - for (let k = 0; k < 11; ++k) { - e[k] = a(0.1 * k, c, b); - } - } return function(k) { - // eslint-disable-next-line max-statements-per-line, no-var, no-shadow - if (c === d && b === f) return k; if (k === 0) return 0; if (k === 1) return 1; for (var h = 0, l = 1; l !== 10 && e[l] <= k; ++l) { - h += 0.1; - // eslint-disable-next-line max-statements-per-line, no-var, no-redeclare - } --l; var l = h + (k - e[l]) / (e[l + 1] - e[l]) * 0.1, - n = 3 * (1 - 3 * b + 3 * c) * l * l + 2 * (3 * b - 6 * c) * l + 3 * c; if (n >= 0.001) { - for (h = 0; h < 4; ++h) { - // eslint-disable-next-line max-statements-per-line, no-var, no-shadow - n = 3 * (1 - 3 * b + 3 * c) * l * l + 2 * (3 * b - 6 * c) * l + 3 * c; if (n === 0) break; var m = a(l, c, b) - k, - // eslint-disable-next-line no-redeclare - l = l - m / n; - } k = l; - } - else if (n === 0) {k = l;} - else { - // eslint-disable-next-line no-var, no-redeclare - var l = h, - // eslint-disable-next-line no-redeclare - h = h + 0.1, - g = 0; do { - m = l + (h - l) / 2, n = a(m, c, b) - k, n > 0 ? h = m : l = m; - } while (Math.abs(n) > 1e-7 && ++g < 10); k = m; - } return a(k, d, f); - }; - } - }; - }(), - Q = function() { - // eslint-disable-next-line no-shadow - function a(a, b) { - return a === 0 || a === 1 ? a : -Math.pow(2, 10 * (a - 1)) * Math.sin(2 * (a - 1 - b / (2 * Math.PI) * Math.asin(1)) * Math.PI / b); - // eslint-disable-next-line prefer-const - } let c = 'Quad Cubic Quart Quint Sine Expo Circ Back Elastic'.split(' '), - // eslint-disable-next-line prefer-const - d = { - // eslint-disable-next-line no-shadow - In: [[0.55, 0.085, 0.68, 0.53], [0.55, 0.055, 0.675, 0.19], [0.895, 0.03, 0.685, 0.22], [0.755, 0.05, 0.855, 0.06], [0.47, 0, 0.745, 0.715], [0.95, 0.05, 0.795, 0.035], [0.6, 0.04, 0.98, 0.335], [0.6, -0.28, 0.735, 0.045], a], Out: [[0.25, 0.46, 0.45, 0.94], [0.215, 0.61, 0.355, 1], [0.165, 0.84, 0.44, 1], [0.23, 1, 0.32, 1], [0.39, 0.575, 0.565, 1], [0.19, 1, 0.22, 1], [0.075, 0.82, 0.165, 1], [0.175, 0.885, 0.32, 1.275], function(b, c) { - return 1 - a(1 - b, c); - // eslint-disable-next-line no-shadow - }], InOut: [[0.455, 0.03, 0.515, 0.955], [0.645, 0.045, 0.355, 1], [0.77, 0, 0.175, 1], [0.86, 0, 0.07, 1], [0.445, 0.05, 0.55, 0.95], [1, 0, 0, 1], [0.785, 0.135, 0.15, 0.86], [0.68, -0.55, 0.265, 1.55], function(b, c) { - return b < 0.5 ? a(2 * b, c) / 2 : 1 - a(-2 * b + 2, c) / 2; - }], - }, - // eslint-disable-next-line prefer-const - b = { linear: A(0.25, 0.25, 0.75, 0.75) }, - f = {}, - // eslint-disable-next-line no-shadow - e; for (e in d) { - // eslint-disable-next-line no-shadow - f.type = e, d[f.type].forEach(function(a) { - // eslint-disable-next-line no-shadow - return function(d, f) { - b['ease' + a.type + c[f]] = h.fnc(d) ? d : A.apply($jscomp$this, d); - }; - }(f)), f = { type: f.type }; - } return b; - }(), - ha = { - css: function(a, c, d) { - return a.style[c] = d; - }, attribute: function(a, c, d) { - return a.setAttribute(c, d); - }, object: function(a, c, d) { - return a[c] = d; - }, transform: function(_a, c, d, b, f) { - b[f] || (b[f] = []); b[f].push(c + '(' + d + ')'); - }, - }, - v = [], - B = 0, - ia = function() { - function a() { - B = requestAnimationFrame(c); - // eslint-disable-next-line no-shadow - } function c(c) { - const b = v.length; if (b) { - for (let d = 0; d < b;) { - v[d] && v[d].tick(c), d++; - } a(); - } - else {cancelAnimationFrame(B), B = 0;} - } return a; - // eslint-disable-next-line max-statements-per-line - }(); q.version = '2.2.0'; q.speed = 1; q.running = v; q.remove = function(a) { - a = P(a); for (let c = v.length; c--;) { - for (let d = v[c], b = d.animations, f = b.length; f--;) { - u(a, b[f].animatable.target) && (b.splice(f, 1), b.length || d.pause()); - } - } - // eslint-disable-next-line max-statements-per-line - }; q.getValue = K; q.path = function(a, c) { - const d = h.str(a) ? e(a)[0] : a, - // eslint-disable-next-line no-shadow - b = c || 100; return function(a) { - return { el: d, property: a, totalLength: N(d) * (b / 100) }; - }; - }; q.setDashoffset = function(a) { - // eslint-disable-next-line max-statements-per-line - const c = N(a); a.setAttribute('stroke-dasharray', c); return c; - // eslint-disable-next-line max-statements-per-line - }; q.bezier = A; q.easings = Q; q.timeline = function(a) { - // eslint-disable-next-line max-statements-per-line - const c = q(a); c.pause(); c.duration = 0; c.add = function(d) { - // eslint-disable-next-line no-shadow - c.children.forEach(function(a) { - a.began = !0; a.completed = !0; - }); m(d).forEach(function(b) { - // eslint-disable-next-line no-shadow, max-statements-per-line - let d = z(b, D(S, a || {})); d.targets = d.targets || a.targets; b = c.duration; const e = d.offset; d.autoplay = !1; d.direction = c.direction; d.offset = h.und(e) ? b : L(e, b); c.began = !0; c.completed = !0; c.seek(d.offset); d = q(d); d.began = !0; d.completed = !0; d.duration > b && (c.duration = d.duration); c.children.push(d); - // eslint-disable-next-line max-statements-per-line - }); c.seek(0); c.reset(); c.autoplay && c.restart(); return c; - }; return c; - }; q.random = function(a, c) { - return Math.floor(Math.random() * (c - a + 1)) + a; - }; return q; -}); -; (function($, anim) { - 'use strict'; - - const _defaults = { - accordion: true, - onOpenStart: undefined, - onOpenEnd: undefined, - onCloseStart: undefined, - onCloseEnd: undefined, - inDuration: 300, - outDuration: 300, - }; - - /** - * @class - * - */ - - const Collapsible = function(_Component) { - _inherits(Collapsible, _Component); - - /** + /** * Construct Collapsible instance * @constructor * @param {Element} el * @param {Object} options */ - // eslint-disable-next-line no-shadow - function Collapsible(el, options) { - _classCallCheck(this, Collapsible); + function Collapsible(el, options) { + _classCallCheck(this, Collapsible); - const _this3 = _possibleConstructorReturn(this, (Collapsible.__proto__ || Object.getPrototypeOf(Collapsible)).call(this, Collapsible, el, options)); + var _this3 = _possibleConstructorReturn(this, (Collapsible.__proto__ || Object.getPrototypeOf(Collapsible)).call(this, Collapsible, el, options)); - _this3.el.M_Collapsible = _this3; + _this3.el.M_Collapsible = _this3; - /** + /** * Options for the collapsible * @member Collapsible#options * @prop {Boolean} [accordion=false] - Type of the collapsible @@ -2134,328 +1966,324 @@ $jscomp.polyfill = function(e, r, p, m) { * @prop {Number} inDuration - Transition in duration in milliseconds. * @prop {Number} outDuration - Transition duration in milliseconds. */ - _this3.options = $.extend({}, Collapsible.defaults, options); + _this3.options = $.extend({}, Collapsible.defaults, options); - // Setup tab indices - _this3.$headers = _this3.$el.children('li').children('.collapsible-header'); - _this3.$headers.attr('tabindex', 0); + // Setup tab indices + _this3.$headers = _this3.$el.children('li').children('.collapsible-header'); + _this3.$headers.attr('tabindex', 0); - _this3._setupEventHandlers(); + _this3._setupEventHandlers(); - // Open first active - const $activeBodies = _this3.$el.children('li.active').children('.collapsible-body'); - if (_this3.options.accordion) { - // Handle Accordion - $activeBodies.first().css('display', 'block'); - } - else { - // Handle Expandables - $activeBodies.css('display', 'block'); - } - return _this3; - } + // Open first active + var $activeBodies = _this3.$el.children('li.active').children('.collapsible-body'); + if (_this3.options.accordion) { + // Handle Accordion + $activeBodies.first().css('display', 'block'); + } else { + // Handle Expandables + $activeBodies.css('display', 'block'); + } + return _this3; + } - _createClass(Collapsible, [{ - key: 'destroy', + _createClass(Collapsible, [{ + key: "destroy", - /** + /** * Teardown component */ - value: function destroy() { - this._removeEventHandlers(); - this.el.M_Collapsible = undefined; - }, + value: function destroy() { + this._removeEventHandlers(); + this.el.M_Collapsible = undefined; + } - /** + /** * Setup Event Handlers */ - }, { - key: '_setupEventHandlers', - value: function _setupEventHandlers() { - const _this4 = this; + }, { + key: "_setupEventHandlers", + value: function _setupEventHandlers() { + var _this4 = this; - this._handleCollapsibleClickBound = this._handleCollapsibleClick.bind(this); - this._handleCollapsibleKeydownBound = this._handleCollapsibleKeydown.bind(this); - this.el.addEventListener('click', this._handleCollapsibleClickBound); - this.$headers.each(function(header) { - header.addEventListener('keydown', _this4._handleCollapsibleKeydownBound); - }); - }, + this._handleCollapsibleClickBound = this._handleCollapsibleClick.bind(this); + this._handleCollapsibleKeydownBound = this._handleCollapsibleKeydown.bind(this); + this.el.addEventListener('click', this._handleCollapsibleClickBound); + this.$headers.each(function (header) { + header.addEventListener('keydown', _this4._handleCollapsibleKeydownBound); + }); + } - /** + /** * Remove Event Handlers */ - }, { - key: '_removeEventHandlers', - value: function _removeEventHandlers() { - this.el.removeEventListener('click', this._handleCollapsibleClickBound); - }, + }, { + key: "_removeEventHandlers", + value: function _removeEventHandlers() { + this.el.removeEventListener('click', this._handleCollapsibleClickBound); + } - /** + /** * Handle Collapsible Click * @param {Event} e */ - }, { - key: '_handleCollapsibleClick', - value: function _handleCollapsibleClick(e) { - const $header = $(e.target).closest('.collapsible-header'); - if (e.target && $header.length) { - const $collapsible = $header.closest('.collapsible'); - if ($collapsible[0] === this.el) { - const $collapsibleLi = $header.closest('li'); - const $collapsibleLis = $collapsible.children('li'); - const isActive = $collapsibleLi[0].classList.contains('active'); - const index = $collapsibleLis.index($collapsibleLi); - - if (isActive) { - this.close(index); - } - else { - this.open(index); - } - } - } - }, - - /** + }, { + key: "_handleCollapsibleClick", + value: function _handleCollapsibleClick(e) { + var $header = $(e.target).closest('.collapsible-header'); + if (e.target && $header.length) { + var $collapsible = $header.closest('.collapsible'); + if ($collapsible[0] === this.el) { + var $collapsibleLi = $header.closest('li'); + var $collapsibleLis = $collapsible.children('li'); + var isActive = $collapsibleLi[0].classList.contains('active'); + var index = $collapsibleLis.index($collapsibleLi); + + if (isActive) { + this.close(index); + } else { + this.open(index); + } + } + } + } + + /** * Handle Collapsible Keydown * @param {Event} e */ - }, { - key: '_handleCollapsibleKeydown', - value: function _handleCollapsibleKeydown(e) { - if (e.keyCode === 13) { - this._handleCollapsibleClickBound(e); - } - }, + }, { + key: "_handleCollapsibleKeydown", + value: function _handleCollapsibleKeydown(e) { + if (e.keyCode === 13) { + this._handleCollapsibleClickBound(e); + } + } - /** + /** * Animate in collapsible slide * @param {Number} index - 0th index of slide */ - }, { - key: '_animateIn', - value: function _animateIn(index) { - const _this5 = this; - - const $collapsibleLi = this.$el.children('li').eq(index); - if ($collapsibleLi.length) { - const $body = $collapsibleLi.children('.collapsible-body'); - - anim.remove($body[0]); - $body.css({ - display: 'block', - overflow: 'hidden', - height: 0, - paddingTop: '', - paddingBottom: '', - }); - - const pTop = $body.css('padding-top'); - const pBottom = $body.css('padding-bottom'); - const finalHeight = $body[0].scrollHeight; - $body.css({ - paddingTop: 0, - paddingBottom: 0, - }); - - anim({ - targets: $body[0], - height: finalHeight, - paddingTop: pTop, - paddingBottom: pBottom, - duration: this.options.inDuration, - easing: 'easeInOutCubic', - complete: function() { - $body.css({ - overflow: '', - paddingTop: '', - paddingBottom: '', - height: '', - }); - - // onOpenEnd callback - if (typeof _this5.options.onOpenEnd === 'function') { - _this5.options.onOpenEnd.call(_this5, $collapsibleLi[0]); - } - }, - }); - } - }, - - /** + }, { + key: "_animateIn", + value: function _animateIn(index) { + var _this5 = this; + + var $collapsibleLi = this.$el.children('li').eq(index); + if ($collapsibleLi.length) { + var $body = $collapsibleLi.children('.collapsible-body'); + + anim.remove($body[0]); + $body.css({ + display: 'block', + overflow: 'hidden', + height: 0, + paddingTop: '', + paddingBottom: '' + }); + + var pTop = $body.css('padding-top'); + var pBottom = $body.css('padding-bottom'); + var finalHeight = $body[0].scrollHeight; + $body.css({ + paddingTop: 0, + paddingBottom: 0 + }); + + anim({ + targets: $body[0], + height: finalHeight, + paddingTop: pTop, + paddingBottom: pBottom, + duration: this.options.inDuration, + easing: 'easeInOutCubic', + complete: function (anim) { + $body.css({ + overflow: '', + paddingTop: '', + paddingBottom: '', + height: '' + }); + + // onOpenEnd callback + if (typeof _this5.options.onOpenEnd === 'function') { + _this5.options.onOpenEnd.call(_this5, $collapsibleLi[0]); + } + } + }); + } + } + + /** * Animate out collapsible slide * @param {Number} index - 0th index of slide to open */ - }, { - key: '_animateOut', - value: function _animateOut(index) { - const _this6 = this; - - const $collapsibleLi = this.$el.children('li').eq(index); - if ($collapsibleLi.length) { - const $body = $collapsibleLi.children('.collapsible-body'); - anim.remove($body[0]); - $body.css('overflow', 'hidden'); - anim({ - targets: $body[0], - height: 0, - paddingTop: 0, - paddingBottom: 0, - duration: this.options.outDuration, - easing: 'easeInOutCubic', - complete: function() { - $body.css({ - height: '', - overflow: '', - padding: '', - display: '', - }); - - // onCloseEnd callback - if (typeof _this6.options.onCloseEnd === 'function') { - _this6.options.onCloseEnd.call(_this6, $collapsibleLi[0]); - } - }, - }); - } - }, - - /** + }, { + key: "_animateOut", + value: function _animateOut(index) { + var _this6 = this; + + var $collapsibleLi = this.$el.children('li').eq(index); + if ($collapsibleLi.length) { + var $body = $collapsibleLi.children('.collapsible-body'); + anim.remove($body[0]); + $body.css('overflow', 'hidden'); + anim({ + targets: $body[0], + height: 0, + paddingTop: 0, + paddingBottom: 0, + duration: this.options.outDuration, + easing: 'easeInOutCubic', + complete: function () { + $body.css({ + height: '', + overflow: '', + padding: '', + display: '' + }); + + // onCloseEnd callback + if (typeof _this6.options.onCloseEnd === 'function') { + _this6.options.onCloseEnd.call(_this6, $collapsibleLi[0]); + } + } + }); + } + } + + /** * Open Collapsible * @param {Number} index - 0th index of slide */ - }, { - key: 'open', - value: function open(index) { - const _this7 = this; - - const $collapsibleLi = this.$el.children('li').eq(index); - if ($collapsibleLi.length && !$collapsibleLi[0].classList.contains('active')) { - - // onOpenStart callback - if (typeof this.options.onOpenStart === 'function') { - this.options.onOpenStart.call(this, $collapsibleLi[0]); - } - - // Handle accordion behavior - if (this.options.accordion) { - const $collapsibleLis = this.$el.children('li'); - const $activeLis = this.$el.children('li.active'); - $activeLis.each(function(el) { - // eslint-disable-next-line no-shadow - const index = $collapsibleLis.index($(el)); - _this7.close(index); - }); - } - - // Animate in - $collapsibleLi[0].classList.add('active'); - this._animateIn(index); - } - }, - - /** + }, { + key: "open", + value: function open(index) { + var _this7 = this; + + var $collapsibleLi = this.$el.children('li').eq(index); + if ($collapsibleLi.length && !$collapsibleLi[0].classList.contains('active')) { + + // onOpenStart callback + if (typeof this.options.onOpenStart === 'function') { + this.options.onOpenStart.call(this, $collapsibleLi[0]); + } + + // Handle accordion behavior + if (this.options.accordion) { + var $collapsibleLis = this.$el.children('li'); + var $activeLis = this.$el.children('li.active'); + $activeLis.each(function (el) { + var index = $collapsibleLis.index($(el)); + _this7.close(index); + }); + } + + // Animate in + $collapsibleLi[0].classList.add('active'); + this._animateIn(index); + } + } + + /** * Close Collapsible * @param {Number} index - 0th index of slide */ - }, { - key: 'close', - value: function close(index) { - const $collapsibleLi = this.$el.children('li').eq(index); - if ($collapsibleLi.length && $collapsibleLi[0].classList.contains('active')) { - - // onCloseStart callback - if (typeof this.options.onCloseStart === 'function') { - this.options.onCloseStart.call(this, $collapsibleLi[0]); - } - - // Animate out - $collapsibleLi[0].classList.remove('active'); - this._animateOut(index); - } - }, - }], [{ - key: 'init', - value: function init(els, options) { - return _get(Collapsible.__proto__ || Object.getPrototypeOf(Collapsible), 'init', this).call(this, this, els, options); - }, - - /** + }, { + key: "close", + value: function close(index) { + var $collapsibleLi = this.$el.children('li').eq(index); + if ($collapsibleLi.length && $collapsibleLi[0].classList.contains('active')) { + + // onCloseStart callback + if (typeof this.options.onCloseStart === 'function') { + this.options.onCloseStart.call(this, $collapsibleLi[0]); + } + + // Animate out + $collapsibleLi[0].classList.remove('active'); + this._animateOut(index); + } + } + }], [{ + key: "init", + value: function init(els, options) { + return _get(Collapsible.__proto__ || Object.getPrototypeOf(Collapsible), "init", this).call(this, this, els, options); + } + + /** * Get Instance */ - }, { - key: 'getInstance', - value: function getInstance(el) { - const domElem = el.jquery ? el[0] : el; - return domElem.M_Collapsible; - }, - }, { - key: 'defaults', - get: function() { - return _defaults; - }, - }]); + }, { + key: "getInstance", + value: function getInstance(el) { + var domElem = !!el.jquery ? el[0] : el; + return domElem.M_Collapsible; + } + }, { + key: "defaults", + get: function () { + return _defaults; + } + }]); - return Collapsible; - }(Component); + return Collapsible; + }(Component); - M.Collapsible = Collapsible; + M.Collapsible = Collapsible; - if (M.jQueryLoaded) { - M.initializeJqueryWrapper(Collapsible, 'collapsible', 'M_Collapsible'); - } + if (M.jQueryLoaded) { + M.initializeJqueryWrapper(Collapsible, 'collapsible', 'M_Collapsible'); + } })(cash, M.anime); -; (function($, anim) { - 'use strict'; - - const _defaults = { - alignment: 'left', - autoFocus: true, - constrainWidth: true, - container: null, - coverTrigger: true, - closeOnClick: true, - hover: false, - inDuration: 150, - outDuration: 250, - onOpenStart: null, - onOpenEnd: null, - onCloseStart: null, - onCloseEnd: null, - }; - - /** +; (function ($, anim) { + 'use strict'; + + var _defaults = { + alignment: 'left', + autoFocus: true, + constrainWidth: true, + container: null, + coverTrigger: true, + closeOnClick: true, + hover: false, + inDuration: 150, + outDuration: 250, + onOpenStart: null, + onOpenEnd: null, + onCloseStart: null, + onCloseEnd: null + }; + + /** * @class */ - const Dropdown = function(_Component2) { - _inherits(Dropdown, _Component2); + var Dropdown = function (_Component2) { + _inherits(Dropdown, _Component2); - // eslint-disable-next-line no-shadow - function Dropdown(el, options) { - _classCallCheck(this, Dropdown); + function Dropdown(el, options) { + _classCallCheck(this, Dropdown); - const _this8 = _possibleConstructorReturn(this, (Dropdown.__proto__ || Object.getPrototypeOf(Dropdown)).call(this, Dropdown, el, options)); + var _this8 = _possibleConstructorReturn(this, (Dropdown.__proto__ || Object.getPrototypeOf(Dropdown)).call(this, Dropdown, el, options)); - _this8.el.M_Dropdown = _this8; - Dropdown._dropdowns.push(_this8); + _this8.el.M_Dropdown = _this8; + Dropdown._dropdowns.push(_this8); - _this8.id = M.getIdFromTrigger(el); - _this8.dropdownEl = document.getElementById(_this8.id); - _this8.$dropdownEl = $(_this8.dropdownEl); + _this8.id = M.getIdFromTrigger(el); + _this8.dropdownEl = document.getElementById(_this8.id); + _this8.$dropdownEl = $(_this8.dropdownEl); - /** + /** * Options for the dropdown * @member Dropdown#options * @prop {String} [alignment='left'] - Edge which the dropdown is aligned to @@ -2472,631 +2300,616 @@ $jscomp.polyfill = function(e, r, p, m) { * @prop {Function} onCloseStart - Function called when dropdown starts closing * @prop {Function} onCloseEnd - Function called when dropdown finishes closing */ - _this8.options = $.extend({}, Dropdown.defaults, options); + _this8.options = $.extend({}, Dropdown.defaults, options); - /** + /** * Describes open/close state of dropdown * @type {Boolean} */ - _this8.isOpen = false; + _this8.isOpen = false; - /** + /** * Describes if dropdown content is scrollable * @type {Boolean} */ - _this8.isScrollable = false; + _this8.isScrollable = false; - /** + /** * Describes if touch moving on dropdown content * @type {Boolean} */ - _this8.isTouchMoving = false; + _this8.isTouchMoving = false; - _this8.focusedIndex = -1; - _this8.filterQuery = []; + _this8.focusedIndex = -1; + _this8.filterQuery = []; - // Move dropdown-content after dropdown-trigger - if (_this8.options.container) { - $(_this8.options.container).append(_this8.dropdownEl); - } - else { - _this8.$el.after(_this8.dropdownEl); - } + // Move dropdown-content after dropdown-trigger + if (!!_this8.options.container) { + $(_this8.options.container).append(_this8.dropdownEl); + } else { + _this8.$el.after(_this8.dropdownEl); + } - _this8._makeDropdownFocusable(); - _this8._resetFilterQueryBound = _this8._resetFilterQuery.bind(_this8); - _this8._handleDocumentClickBound = _this8._handleDocumentClick.bind(_this8); - _this8._handleDocumentTouchmoveBound = _this8._handleDocumentTouchmove.bind(_this8); - _this8._handleDropdownKeydownBound = _this8._handleDropdownKeydown.bind(_this8); - _this8._handleTriggerKeydownBound = _this8._handleTriggerKeydown.bind(_this8); - _this8._setupEventHandlers(); - return _this8; - } + _this8._makeDropdownFocusable(); + _this8._resetFilterQueryBound = _this8._resetFilterQuery.bind(_this8); + _this8._handleDocumentClickBound = _this8._handleDocumentClick.bind(_this8); + _this8._handleDocumentTouchmoveBound = _this8._handleDocumentTouchmove.bind(_this8); + _this8._handleDropdownKeydownBound = _this8._handleDropdownKeydown.bind(_this8); + _this8._handleTriggerKeydownBound = _this8._handleTriggerKeydown.bind(_this8); + _this8._setupEventHandlers(); + return _this8; + } - _createClass(Dropdown, [{ - key: 'destroy', + _createClass(Dropdown, [{ + key: "destroy", - /** + /** * Teardown component */ - value: function destroy() { - this._resetDropdownStyles(); - this._removeEventHandlers(); - Dropdown._dropdowns.splice(Dropdown._dropdowns.indexOf(this), 1); - this.el.M_Dropdown = undefined; - }, + value: function destroy() { + this._resetDropdownStyles(); + this._removeEventHandlers(); + Dropdown._dropdowns.splice(Dropdown._dropdowns.indexOf(this), 1); + this.el.M_Dropdown = undefined; + } - /** + /** * Setup Event Handlers */ - }, { - key: '_setupEventHandlers', - value: function _setupEventHandlers() { - // Trigger keydown handler - this.el.addEventListener('keydown', this._handleTriggerKeydownBound); - - // Hover event handlers - if (this.options.hover) { - this._handleMouseEnterBound = this._handleMouseEnter.bind(this); - this.el.addEventListener('mouseenter', this._handleMouseEnterBound); - this._handleMouseLeaveBound = this._handleMouseLeave.bind(this); - this.el.addEventListener('mouseleave', this._handleMouseLeaveBound); - this.dropdownEl.addEventListener('mouseleave', this._handleMouseLeaveBound); - - // Click event handlers - } - else { - this._handleClickBound = this._handleClick.bind(this); - this.el.addEventListener('click', this._handleClickBound); - } - }, - - /** + }, { + key: "_setupEventHandlers", + value: function _setupEventHandlers() { + // Trigger keydown handler + this.el.addEventListener('keydown', this._handleTriggerKeydownBound); + + // Hover event handlers + if (this.options.hover) { + this._handleMouseEnterBound = this._handleMouseEnter.bind(this); + this.el.addEventListener('mouseenter', this._handleMouseEnterBound); + this._handleMouseLeaveBound = this._handleMouseLeave.bind(this); + this.el.addEventListener('mouseleave', this._handleMouseLeaveBound); + this.dropdownEl.addEventListener('mouseleave', this._handleMouseLeaveBound); + + // Click event handlers + } else { + this._handleClickBound = this._handleClick.bind(this); + this.el.addEventListener('click', this._handleClickBound); + } + } + + /** * Remove Event Handlers */ - }, { - key: '_removeEventHandlers', - value: function _removeEventHandlers() { - // Trigger keydown handler - this.el.removeEventListener('keydown', this._handleTriggerKeydownBound); - - if (this.options.hover) { - this.el.removeEventHandlers('mouseenter', this._handleMouseEnterBound); - this.el.removeEventHandlers('mouseleave', this._handleMouseLeaveBound); - this.dropdownEl.removeEventHandlers('mouseleave', this._handleMouseLeaveBound); - } - else { - this.el.removeEventListener('click', this._handleClickBound); - } - }, - }, { - key: '_setupTemporaryEventHandlers', - value: function _setupTemporaryEventHandlers() { - // Use capture phase event handler to prevent click - document.body.addEventListener('click', this._handleDocumentClickBound, true); - document.body.addEventListener('touchend', this._handleDocumentClickBound); - document.body.addEventListener('touchmove', this._handleDocumentTouchmoveBound); - this.dropdownEl.addEventListener('keydown', this._handleDropdownKeydownBound); - }, - }, { - key: '_removeTemporaryEventHandlers', - value: function _removeTemporaryEventHandlers() { - // Use capture phase event handler to prevent click - document.body.removeEventListener('click', this._handleDocumentClickBound, true); - document.body.removeEventListener('touchend', this._handleDocumentClickBound); - document.body.removeEventListener('touchmove', this._handleDocumentTouchmoveBound); - this.dropdownEl.removeEventListener('keydown', this._handleDropdownKeydownBound); - }, - }, { - key: '_handleClick', - value: function _handleClick(e) { - e.preventDefault(); - this.open(); - }, - }, { - key: '_handleMouseEnter', - value: function _handleMouseEnter() { - this.open(); - }, - }, { - key: '_handleMouseLeave', - value: function _handleMouseLeave(e) { - const toEl = e.toElement || e.relatedTarget; - const leaveToDropdownContent = !!$(toEl).closest('.dropdown-content').length; - let leaveToActiveDropdownTrigger = false; - - const $closestTrigger = $(toEl).closest('.dropdown-trigger'); - if ($closestTrigger.length && !!$closestTrigger[0].M_Dropdown && $closestTrigger[0].M_Dropdown.isOpen) { - leaveToActiveDropdownTrigger = true; - } - - // Close hover dropdown if mouse did not leave to either active dropdown-trigger or dropdown-content - if (!leaveToActiveDropdownTrigger && !leaveToDropdownContent) { - this.close(); - } - }, - }, { - key: '_handleDocumentClick', - value: function _handleDocumentClick(e) { - const _this9 = this; - - const $target = $(e.target); - if (this.options.closeOnClick && $target.closest('.dropdown-content').length && !this.isTouchMoving) { - // isTouchMoving to check if scrolling on mobile. - setTimeout(function() { - _this9.close(); - }, 0); - } - else if ($target.closest('.dropdown-trigger').length || !$target.closest('.dropdown-content').length) { - setTimeout(function() { - _this9.close(); - }, 0); - } - this.isTouchMoving = false; - }, - }, { - key: '_handleTriggerKeydown', - value: function _handleTriggerKeydown(e) { - // ARROW DOWN OR ENTER WHEN SELECT IS CLOSED - open Dropdown - if ((e.which === M.keys.ARROW_DOWN || e.which === M.keys.ENTER) && !this.isOpen) { - e.preventDefault(); - this.open(); - } - }, - - /** + }, { + key: "_removeEventHandlers", + value: function _removeEventHandlers() { + // Trigger keydown handler + this.el.removeEventListener('keydown', this._handleTriggerKeydownBound); + + if (this.options.hover) { + this.el.removeEventHandlers('mouseenter', this._handleMouseEnterBound); + this.el.removeEventHandlers('mouseleave', this._handleMouseLeaveBound); + this.dropdownEl.removeEventHandlers('mouseleave', this._handleMouseLeaveBound); + } else { + this.el.removeEventListener('click', this._handleClickBound); + } + } + }, { + key: "_setupTemporaryEventHandlers", + value: function _setupTemporaryEventHandlers() { + // Use capture phase event handler to prevent click + document.body.addEventListener('click', this._handleDocumentClickBound, true); + document.body.addEventListener('touchend', this._handleDocumentClickBound); + document.body.addEventListener('touchmove', this._handleDocumentTouchmoveBound); + this.dropdownEl.addEventListener('keydown', this._handleDropdownKeydownBound); + } + }, { + key: "_removeTemporaryEventHandlers", + value: function _removeTemporaryEventHandlers() { + // Use capture phase event handler to prevent click + document.body.removeEventListener('click', this._handleDocumentClickBound, true); + document.body.removeEventListener('touchend', this._handleDocumentClickBound); + document.body.removeEventListener('touchmove', this._handleDocumentTouchmoveBound); + this.dropdownEl.removeEventListener('keydown', this._handleDropdownKeydownBound); + } + }, { + key: "_handleClick", + value: function _handleClick(e) { + e.preventDefault(); + this.open(); + } + }, { + key: "_handleMouseEnter", + value: function _handleMouseEnter() { + this.open(); + } + }, { + key: "_handleMouseLeave", + value: function _handleMouseLeave(e) { + var toEl = e.toElement || e.relatedTarget; + var leaveToDropdownContent = !!$(toEl).closest('.dropdown-content').length; + var leaveToActiveDropdownTrigger = false; + + var $closestTrigger = $(toEl).closest('.dropdown-trigger'); + if ($closestTrigger.length && !!$closestTrigger[0].M_Dropdown && $closestTrigger[0].M_Dropdown.isOpen) { + leaveToActiveDropdownTrigger = true; + } + + // Close hover dropdown if mouse did not leave to either active dropdown-trigger or dropdown-content + if (!leaveToActiveDropdownTrigger && !leaveToDropdownContent) { + this.close(); + } + } + }, { + key: "_handleDocumentClick", + value: function _handleDocumentClick(e) { + var _this9 = this; + + var $target = $(e.target); + if (this.options.closeOnClick && $target.closest('.dropdown-content').length && !this.isTouchMoving) { + // isTouchMoving to check if scrolling on mobile. + setTimeout(function () { + _this9.close(); + }, 0); + } else if ($target.closest('.dropdown-trigger').length || !$target.closest('.dropdown-content').length) { + setTimeout(function () { + _this9.close(); + }, 0); + } + this.isTouchMoving = false; + } + }, { + key: "_handleTriggerKeydown", + value: function _handleTriggerKeydown(e) { + // ARROW DOWN OR ENTER WHEN SELECT IS CLOSED - open Dropdown + if ((e.which === M.keys.ARROW_DOWN || e.which === M.keys.ENTER) && !this.isOpen) { + e.preventDefault(); + this.open(); + } + } + + /** * Handle Document Touchmove * @param {Event} e */ - }, { - key: '_handleDocumentTouchmove', - value: function _handleDocumentTouchmove(e) { - const $target = $(e.target); - if ($target.closest('.dropdown-content').length) { - this.isTouchMoving = true; - } - }, + }, { + key: "_handleDocumentTouchmove", + value: function _handleDocumentTouchmove(e) { + var $target = $(e.target); + if ($target.closest('.dropdown-content').length) { + this.isTouchMoving = true; + } + } - /** + /** * Handle Dropdown Keydown * @param {Event} e */ - }, { - key: '_handleDropdownKeydown', - value: function _handleDropdownKeydown(e) { - if (e.which === M.keys.TAB) { - e.preventDefault(); - this.close(); - - // Navigate down dropdown list - } - else if ((e.which === M.keys.ARROW_DOWN || e.which === M.keys.ARROW_UP) && this.isOpen) { - e.preventDefault(); - const direction = e.which === M.keys.ARROW_DOWN ? 1 : -1; - let newFocusedIndex = this.focusedIndex; - let foundNewIndex = false; - do { - newFocusedIndex = newFocusedIndex + direction; - - if (!!this.dropdownEl.children[newFocusedIndex] && this.dropdownEl.children[newFocusedIndex].tabIndex !== -1) { - foundNewIndex = true; - break; - } - } while (newFocusedIndex < this.dropdownEl.children.length && newFocusedIndex >= 0); - - if (foundNewIndex) { - this.focusedIndex = newFocusedIndex; - this._focusFocusedItem(); - } - - // ENTER selects choice on focused item - } - else if (e.which === M.keys.ENTER && this.isOpen) { - // Search for and