diff --git a/.gitignore b/.gitignore index a67d42b..a00e0f4 100644 --- a/.gitignore +++ b/.gitignore @@ -1,6 +1,502 @@ -composer.phar -/vendor/ +# Created by https://www.gitignore.io/api/vim,phpunit,phpstorm+all,visualstudio,visualstudiocode +# Edit at https://www.gitignore.io/?templates=vim,phpunit,phpstorm+all,visualstudio,visualstudiocode -# Commit your application's lock file https://getcomposer.org/doc/01-basic-usage.md#commit-your-composer-lock-file-to-version-control -# You may choose to ignore a library lock file http://getcomposer.org/doc/02-libraries.md#lock-file -# composer.lock +### PhpStorm+all ### +# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and WebStorm +# Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839 + +# User-specific stuff +.idea/**/workspace.xml +.idea/**/tasks.xml +.idea/**/usage.statistics.xml +.idea/**/dictionaries +.idea/**/shelf + +# Generated files +.idea/**/contentModel.xml + +# Sensitive or high-churn files +.idea/**/dataSources/ +.idea/**/dataSources.ids +.idea/**/dataSources.local.xml +.idea/**/sqlDataSources.xml +.idea/**/dynamic.xml +.idea/**/uiDesigner.xml +.idea/**/dbnavigator.xml + +# Gradle +.idea/**/gradle.xml +.idea/**/libraries + +# Gradle and Maven with auto-import +# When using Gradle or Maven with auto-import, you should exclude module files, +# since they will be recreated, and may cause churn. Uncomment if using +# auto-import. +# .idea/modules.xml +# .idea/*.iml +# .idea/modules +# *.iml +# *.ipr + +# CMake +cmake-build-*/ + +# Mongo Explorer plugin +.idea/**/mongoSettings.xml + +# File-based project format +*.iws + +# IntelliJ +out/ + +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Cursive Clojure plugin +.idea/replstate.xml + +# Crashlytics plugin (for Android Studio and IntelliJ) +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties + +# Editor-based Rest Client +.idea/httpRequests + +# Android studio 3.1+ serialized cache file +.idea/caches/build_file_checksums.ser + +### PhpStorm+all Patch ### +# Ignores the whole .idea folder and all .iml files +# See https://github.com/joeblau/gitignore.io/issues/186 and https://github.com/joeblau/gitignore.io/issues/360 + +.idea/ + +# Reason: https://github.com/joeblau/gitignore.io/issues/186#issuecomment-249601023 + +*.iml +modules.xml +.idea/misc.xml +*.ipr + +# Sonarlint plugin +.idea/sonarlint + +### PHPUnit ### +# Covers PHPUnit +# Reference: https://phpunit.de/ + +# Generated files +.phpunit.result.cache + +# PHPUnit +/app/phpunit.xml +phpunit.xml + +# Build data +/build/ + +### Vim ### +# Swap +[._]*.s[a-v][a-z] +[._]*.sw[a-p] +[._]s[a-rt-v][a-z] +[._]ss[a-gi-z] +[._]sw[a-p] + +# Session +Session.vim +Sessionx.vim + +# Temporary +.netrwhist +*~ + +# Auto-generated tag files +tags + +# Persistent undo +[._]*.un~ + +# Coc configuration directory +.vim + +### VisualStudioCode ### +.vscode/* +!.vscode/settings.json +!.vscode/tasks.json +!.vscode/launch.json +!.vscode/extensions.json + +### VisualStudioCode Patch ### +# Ignore all local history of files +.history + +### VisualStudio ### +## Ignore Visual Studio temporary files, build results, and +## files generated by popular Visual Studio add-ons. +## +## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore + +# User-specific files +*.rsuser +*.suo +*.user +*.userosscache +*.sln.docstates + +# User-specific files (MonoDevelop/Xamarin Studio) +*.userprefs + +# Mono auto generated files +mono_crash.* + +# Build results +[Dd]ebug/ +[Dd]ebugPublic/ +[Rr]elease/ +[Rr]eleases/ +x64/ +x86/ +[Aa][Rr][Mm]/ +[Aa][Rr][Mm]64/ +bld/ +[Bb]in/ +[Oo]bj/ +[Ll]og/ + +# Visual Studio 2015/2017 cache/options directory +.vs/ +# Uncomment if you have tasks that create the project's static files in wwwroot +#wwwroot/ + +# Visual Studio 2017 auto generated files +Generated\ Files/ + +# MSTest test Results +[Tt]est[Rr]esult*/ +[Bb]uild[Ll]og.* + +# NUnit +*.VisualState.xml +TestResult.xml +nunit-*.xml + +# Build Results of an ATL Project +[Dd]ebugPS/ +[Rr]eleasePS/ +dlldata.c + +# Benchmark Results +BenchmarkDotNet.Artifacts/ + +# .NET Core +project.lock.json +project.fragment.lock.json +artifacts/ + +# StyleCop +StyleCopReport.xml + +# Files built by Visual Studio +*_i.c +*_p.c +*_h.h +*.ilk +*.obj +*.iobj +*.pch +*.pdb +*.ipdb +*.pgc +*.pgd +*.rsp +*.sbr +*.tlb +*.tli +*.tlh +*.tmp +*.tmp_proj +*_wpftmp.csproj +*.log +*.vspscc +*.vssscc +.builds +*.pidb +*.svclog +*.scc + +# Chutzpah Test files +_Chutzpah* + +# Visual C++ cache files +ipch/ +*.aps +*.ncb +*.opendb +*.opensdf +*.sdf +*.cachefile +*.VC.db +*.VC.VC.opendb + +# Visual Studio profiler +*.psess +*.vsp +*.vspx +*.sap + +# Visual Studio Trace Files +*.e2e + +# TFS 2012 Local Workspace +$tf/ + +# Guidance Automation Toolkit +*.gpState + +# ReSharper is a .NET coding add-in +_ReSharper*/ +*.[Rr]e[Ss]harper +*.DotSettings.user + +# JustCode is a .NET coding add-in +.JustCode + +# TeamCity is a build add-in +_TeamCity* + +# DotCover is a Code Coverage Tool +*.dotCover + +# AxoCover is a Code Coverage Tool +.axoCover/* +!.axoCover/settings.json + +# Visual Studio code coverage results +*.coverage +*.coveragexml + +# NCrunch +_NCrunch_* +.*crunch*.local.xml +nCrunchTemp_* + +# MightyMoose +*.mm.* +AutoTest.Net/ + +# Web workbench (sass) +.sass-cache/ + +# Installshield output folder +[Ee]xpress/ + +# DocProject is a documentation generator add-in +DocProject/buildhelp/ +DocProject/Help/*.HxT +DocProject/Help/*.HxC +DocProject/Help/*.hhc +DocProject/Help/*.hhk +DocProject/Help/*.hhp +DocProject/Help/Html2 +DocProject/Help/html + +# Click-Once directory +publish/ + +# Publish Web Output +*.[Pp]ublish.xml +*.azurePubxml +# Note: Comment the next line if you want to checkin your web deploy settings, +# but database connection strings (with potential passwords) will be unencrypted +*.pubxml +*.publishproj + +# Microsoft Azure Web App publish settings. Comment the next line if you want to +# checkin your Azure Web App publish settings, but sensitive information contained +# in these scripts will be unencrypted +PublishScripts/ + +# NuGet Packages +*.nupkg +# NuGet Symbol Packages +*.snupkg +# The packages folder can be ignored because of Package Restore +**/[Pp]ackages/* +# except build/, which is used as an MSBuild target. +!**/[Pp]ackages/build/ +# Uncomment if necessary however generally it will be regenerated when needed +#!**/[Pp]ackages/repositories.config +# NuGet v3's project.json files produces more ignorable files +*.nuget.props +*.nuget.targets + +# Microsoft Azure Build Output +csx/ +*.build.csdef + +# Microsoft Azure Emulator +ecf/ +rcf/ + +# Windows Store app package directories and files +AppPackages/ +BundleArtifacts/ +Package.StoreAssociation.xml +_pkginfo.txt +*.appx +*.appxbundle +*.appxupload + +# Visual Studio cache files +# files ending in .cache can be ignored +*.[Cc]ache +# but keep track of directories ending in .cache +!?*.[Cc]ache/ + +# Others +ClientBin/ +~$* +*.dbmdl +*.dbproj.schemaview +*.jfm +*.pfx +*.publishsettings +orleans.codegen.cs + +# Including strong name files can present a security risk +# (https://github.com/github/gitignore/pull/2483#issue-259490424) +#*.snk + +# Since there are multiple workflows, uncomment next line to ignore bower_components +# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) +#bower_components/ + +# RIA/Silverlight projects +Generated_Code/ + +# Backup & report files from converting an old project file +# to a newer Visual Studio version. Backup files are not needed, +# because we have git ;-) +_UpgradeReport_Files/ +Backup*/ +UpgradeLog*.XML +UpgradeLog*.htm +ServiceFabricBackup/ +*.rptproj.bak + +# SQL Server files +*.mdf +*.ldf +*.ndf + +# Business Intelligence projects +*.rdl.data +*.bim.layout +*.bim_*.settings +*.rptproj.rsuser +*- [Bb]ackup.rdl +*- [Bb]ackup ([0-9]).rdl +*- [Bb]ackup ([0-9][0-9]).rdl + +# Microsoft Fakes +FakesAssemblies/ + +# GhostDoc plugin setting file +*.GhostDoc.xml + +# Node.js Tools for Visual Studio +.ntvs_analysis.dat +node_modules/ + +# Visual Studio 6 build log +*.plg + +# Visual Studio 6 workspace options file +*.opt + +# Visual Studio 6 auto-generated workspace file (contains which files were open etc.) +*.vbw + +# Visual Studio LightSwitch build output +**/*.HTMLClient/GeneratedArtifacts +**/*.DesktopClient/GeneratedArtifacts +**/*.DesktopClient/ModelManifest.xml +**/*.Server/GeneratedArtifacts +**/*.Server/ModelManifest.xml +_Pvt_Extensions + +# Paket dependency manager +.paket/paket.exe +paket-files/ + +# FAKE - F# Make +.fake/ + +# CodeRush personal settings +.cr/personal + +# Python Tools for Visual Studio (PTVS) +__pycache__/ +*.pyc + +# Cake - Uncomment if you are using it +# tools/** +# !tools/packages.config + +# Tabs Studio +*.tss + +# Telerik's JustMock configuration file +*.jmconfig + +# BizTalk build output +*.btp.cs +*.btm.cs +*.odx.cs +*.xsd.cs + +# OpenCover UI analysis results +OpenCover/ + +# Azure Stream Analytics local run output +ASALocalRun/ + +# MSBuild Binary and Structured Log +*.binlog + +# NVidia Nsight GPU debugger configuration file +*.nvuser + +# MFractors (Xamarin productivity tool) working folder +.mfractor/ + +# Local History for Visual Studio +.localhistory/ + +# BeatPulse healthcheck temp database +healthchecksdb + +# Backup folder for Package Reference Convert tool in Visual Studio 2017 +MigrationBackup/ + +# End of https://www.gitignore.io/api/vim,phpunit,composer,phpstorm+all,visualstudio,visualstudiocode + +### Composer ### +composer.phar +/server/vendor/ + +*.zip + +/server/error-log/* +!/server/error-log/index.html + +config.php + +*password* \ No newline at end of file diff --git a/server/anagrafica.php b/server/anagrafica.php new file mode 100644 index 0000000..609abb3 --- /dev/null +++ b/server/anagrafica.php @@ -0,0 +1,4 @@ + 'Anagrafica utente', 'dacontrollare' => ucwords(str_replace('_', ' ', urldecode($_GET['utente'])))]); +?> diff --git a/server/assistenza.php b/server/assistenza.php new file mode 100644 index 0000000..b6618a4 --- /dev/null +++ b/server/assistenza.php @@ -0,0 +1,35 @@ +nome(true); +$admin = $utente->admin(); +$phpsessid = $_COOKIE['PHPSESSID']; + +if (isset($_COOKIE['chat']) && $_COOKIE['chat'] == true) { +echo " + +"; +} diff --git a/server/composer.json b/server/composer.json new file mode 100644 index 0000000..a049987 --- /dev/null +++ b/server/composer.json @@ -0,0 +1,21 @@ +{ + "name": "matteo/allerta", + "description": "Un software di allertamento per i vvf", + "type": "project", + "require": { + "cmfcmf/openweathermap-php-api": "dev-master", + "doctrine/lexer": "^1.3@dev", + "egulias/email-validator": "^2.1@dev", + "fzaninotto/faker": "^1.9@dev", + "twig/twig": "3.x-dev", + "tracy/tracy": "^2.7@dev" + }, + "license": "GPL-3.0-or-later", + "authors": [ + { + "name": "Matteo Gheza", + "email": "matteo@matteogheza.it" + } + ], + "minimum-stability": "dev" +} diff --git a/server/config-sample.php b/server/config-sample.php new file mode 100644 index 0000000..0aec325 --- /dev/null +++ b/server/config-sample.php @@ -0,0 +1,37 @@ + 'compilation' +]); +$template = NULL; +function loadtemplate($templatename, $data, $richiedilogin=true){ + global $utente, $twig, $template; + if($richiedilogin){ + $utente->richiedilogin(); + } + $data['distaccamento'] = DISTACCAMENTO; + $data['urlsoftware'] = WEB_URL; + $data['utente'] = $utente->info(); + $data['enable_technical_support'] = ENABLE_TECHNICAL_SUPPORT; + $data['technical_support_key'] = TECHNICAL_SUPPORT_KEY; + $data['technical_support_open'] = isset($_COOKIE["chat"]); + $template = $twig->load($templatename); + echo $template->render($data); +} diff --git a/server/error-log/index.html b/server/error-log/index.html new file mode 100644 index 0000000..3bd10e9 --- /dev/null +++ b/server/error-log/index.html @@ -0,0 +1 @@ +nothing (see this directory in file explorer or delete this file) \ No newline at end of file diff --git a/server/esercitazioni.php b/server/esercitazioni.php new file mode 100644 index 0000000..5135fc7 --- /dev/null +++ b/server/esercitazioni.php @@ -0,0 +1,3 @@ + 'Esercitazioni']); diff --git a/server/grafici.php b/server/grafici.php new file mode 100644 index 0000000..135879f --- /dev/null +++ b/server/grafici.php @@ -0,0 +1,17 @@ + + + + Sito in Manutenzione + + + + +

Pagina in Manutenzione

+

Scusaci per l'incoveniente. Stiamo lavorando per migliorare il servizio.

+

Saremo di nuovo attivi entro breve. Puoi utilizzare il resto del sito

+

il Webmaster

+ + diff --git a/server/index.php b/server/index.php new file mode 100644 index 0000000..2e60cab --- /dev/null +++ b/server/index.php @@ -0,0 +1,151 @@ +autenticato()){ + $tools->redirect("lista.php"); +} +$errore = false; +if(isset($_POST['nome']) & isset($_POST['password'])){ + $login = $utente->login($_POST['nome'], md5($_POST['password'])); + //var_dump($login); exit; + if($login===true){ + $tools->redirect("lista.php"); + } else { + $errore = $login; + } +} +loadtemplate('index.html', ['errore' => $errore, 'titolo' => 'Login', 'distaccamento' => 'VVF Darfo', 'urlsoftware' => '', 'utente' => $utente->info(false)], false); +/* +if(isset($_SESSION['accesso'])){ + if($_SESSION['accesso'] == "loggato"){ + if($_SESSION['admin'] == 1){ + $tools->redirect("lista_admin.php"); + } else { + $tools->redirect("lista.php"); + } + } +} + +if(isset($_POST['nome']) & isset($_POST['password'])){ +$nome = $_POST['nome']; +$password = md5($_POST['password']); +$sql = "SELECT * FROM vigili WHERE nome='$nome' AND password='$password';"; +if ($result=mysqli_query($connessione, $sql)) + { + // Return the number of rows in result set + $rowcount=mysqli_num_rows($result); + if($rowcount > 0){ + $_SESSION['accesso'] = "loggato"; + while ($row = mysqli_fetch_array($result)){ + $_SESSION['admin'] = $row['caposquadra']; + $_SESSION['nome'] = $row['nome']; + } + $connesso = isset($_POST['connesso']) ? $_POST['connesso'] : '0'; + if($connesso == 1){ + $cookie = bin2hex(implode("-", array($_SESSION['admin'], $_SESSION['nome']))); + //$cookie = "ciao"; + setcookie("l53o453g35i34434n", $cookie, time() + 108000); + } + if($_SESSION['admin'] == 1){ + $tools->redirect("lista_admin.php"); + + } else { + $tools->redirect("lista.php"); + } + } else { + $err = << + + +Password non valida + + +HTML; + } + // Free result set + mysqli_free_result($result); + } +} else if(isset($_COOKIE['l53o453g35i34434n'])){ + $cookie = pack("H*",$_COOKIE['l53o453g35i34434n']); + $cookie = explode("-", $cookie); + if(is_array($cookie)){ + $_SESSION['accesso'] = "loggato"; + $_SESSION['admin'] = $cookie[0]; + $_SESSION['nome'] = $cookie[1]; + if($_SESSION['admin'] == 1){ + redirect("lista_admin.php"); + } else { + redirect("lista.php"); + } + } +} +?> + + + + + + + + + + +body() ?> + +
+
+ + VVF


+

+

+
+ +
+
+
+ +

+ + + + +*/ diff --git a/server/interventi.php b/server/interventi.php new file mode 100644 index 0000000..5b17074 --- /dev/null +++ b/server/interventi.php @@ -0,0 +1,4 @@ + 'Interventi', 'distaccamento' => 'VVF Darfo', 'urlsoftware' => '', 'utente' => $utente->info()]); +?> diff --git a/server/lista.php b/server/lista.php new file mode 100644 index 0000000..ba719f4 --- /dev/null +++ b/server/lista.php @@ -0,0 +1,3 @@ + 'Disponibilità']); diff --git a/server/log.php b/server/log.php new file mode 100644 index 0000000..1b5d8f0 --- /dev/null +++ b/server/log.php @@ -0,0 +1,3 @@ + 'Log', 'distaccamento' => 'VVF Darfo', 'urlsoftware' => '', 'utente' => $utente->info()]); diff --git a/server/logout.php b/server/logout.php new file mode 100644 index 0000000..20f701a --- /dev/null +++ b/server/logout.php @@ -0,0 +1,6 @@ +logout(); +$tools->redirect("index.php"); +?> diff --git a/server/minuti_dispo.php b/server/minuti_dispo.php new file mode 100644 index 0000000..486adcf --- /dev/null +++ b/server/minuti_dispo.php @@ -0,0 +1,106 @@ +"; + +include_once 'secure.php'; + +init_class(); + +function resetminuti(){ + global $vigili_tot; + global $database; + $sql = "SELECT * FROM vigili"; // Pesco i dati della tabella e li ordino in base alla disponibilità + $risultato = $database->esegui($sql, true); + $disp = array(); + foreach($risultato as $row){ + $disp[$row['nome']] = $row['minuti_dispo']; + } + print("
" . print_r($disp, true) . "

"); + + + // pre-5.3: + $list = implode(', ', array_map( + create_function('$k,$v', 'return "$k => $v";'), + array_keys($disp), + array_values($disp) + )); + $a1 = implode(" - ", array_keys($disp)); + $a2 = implode(" - ", array_values($disp)); + echo "

" . $list . "


" . $a1 . "


" . $a2 . "


"; + $mese = strftime("%B"); + $anno = strftime("%Y"); + echo $mese . " - " . $anno . "
"; + + + $sql = "INSERT INTO `minuti` (`id`, `mese`, `anno`, `list`, `a1`, `a2`) VALUES (NULL, '$mese', '$anno', '$list', '$a1', '$a2')"; // Pesco i dati della tabella e li ordino in base alla disponibilità + $risultato = $database->esegui($sql); + + foreach($risultato as $row){ + $sql = "UPDATE vigili SET minuti_dispo = '0' WHERE nome ='" . $utente . "'"; + $risultato = $database->esegui($sql); + echo "reset effettuato: " . $utente . "
"; + } + + if($risultato){ + echo << + + +EOT; + } +} + +//Per quando dovrò (forse) reinserire i valori in tabella o generare un array +function array_combine_($keys, $values){ + $result = array(); + foreach ($keys as $i => $k) { + $result[$k][] = $values[$i]; + } + array_walk($result, create_function('&$v', '$v = (count($v) == 1)? array_pop($v): $v;')); + return $result; +} +//print("
" . print_r(array_combine_(explode(" - ", $a1), explode(" - ", $a2)), true) . "

"); + + +$sql = "SELECT * FROM vigili ORDER BY disponibile DESC, caposquadra DESC, interventi ASC, nome ASC"; // Pesco i dati della tabella e li ordino in base alla disponibilità +$risultato = $database->esegui($sql, true); + +$vigili_tot = array(); +$incremento = array(); +$minuti_dispo_old = array(); +foreach($risultato as $row){ + $vigili_tot[] = $row['nome']; + if($row['disponibile'] == "1"){ + $incremento[] = $row['nome']; + $minuti_dispo_old[] = $row['minuti_dispo']; + } +} +print_r($incremento); + +if($start && isset($_POST['cron']) && $_POST['cron'] == "cron-job"){ +if($start && isset($_POST['reset']) && $_POST['reset'] == "cron-job"){ +resetminuti(); +} + +foreach($incremento as $key=>$utente){ + $minuti_dispo = $minuti_dispo_old[$key] + $minuti; + $sql = "UPDATE vigili SET minuti_dispo = '" . $minuti_dispo . "' WHERE nome ='" . $utente . "'"; + $risultato = $database->esegui($sql, true); +} +$sql = "SELECT * FROM vigili ORDER BY disponibile DESC, caposquadra DESC, interventi ASC, nome ASC"; // Pesco i dati della tabella e li ordino in base alla disponibilità +$risultato = $database->esegui($sql, true); +$minuti_dispo = array(); +foreach($risultato as $row){ + if($row['disponibile'] == "1"){ + $minuti_dispo[] = $row['minuti_dispo']; + } +} +echo "
"; +print_r($minuti_dispo); +} diff --git a/server/modifica_intervento.php b/server/modifica_intervento.php new file mode 100644 index 0000000..846ebaa --- /dev/null +++ b/server/modifica_intervento.php @@ -0,0 +1,58 @@ +validazione_form('$post-mod', true, "aggiungi")) { + bdump("per poco..."); + if($tools->validazione_form(['$post-data', '$post-codice', '$post-uscita', '$post-rientro', '$post-capo', '$post-luogo', '$post-note', '$post-tipo', '$post-token'])) { + if($_POST["token"] == $_SESSION['token']){ + bdump("aggiungo intervento"); + $database->aggiungi_intervento($_POST["data"], $_POST["codice"], $_POST["uscita"], $_POST["rientro"], $_POST["capo"], $tools->extract_unique($_POST["autisti"]), $tools->extract_unique($_POST["personale"]), $_POST["luogo"], $_POST["note"], $_POST["tipo"], $tools->extract_unique([$_POST["capo"],$_POST["autisti"],$_POST["personale"]]), $utente->nome()); + } else { + $tools->redirect("nonfareilfurbo.php"); + } + } +} elseif($tools->validazione_form('$post-mod', true, "modifica")) { + bdump("per poco..."); + if($tools->validazione_form(['$post-id', '$post-data', '$post-codice', '$post-uscita', '$post-rientro', '$post-capo', '$post-luogo', '$post-note', '$post-tipo', '$post-token'])) { + if($_POST["token"] == $_SESSION['token']){ + bdump("modifico intervento"); + } else { + $tools->redirect("nonfareilfurbo.php"); + } + } +} elseif($tools->validazione_form('$post-mod', true, "elimina")) { + bdump("rimuovo intervento"); + if($tools->validazione_form(['$post-id', '$post-token'])) { + if($_POST["token"] == $_SESSION['token']){ + bdump("rimuovo intervento"); + } else { + $tools->redirect("nonfareilfurbo.php"); + } + } +} else { + $length = 32; + unset($_SESSION['token']); + $_SESSION['token'] = substr(base_convert(sha1(uniqid(mt_rand())), 16, 36), 0, $length) . "-bfwp64GGbdm"; + // 1 hour = 60 seconds * 60 minutes = 3600 + $_SESSION['token-expire'] = time() + 3600; + $personale = $database->esegui("SELECT * FROM vigili ORDER BY nome ASC", true); // Pesco i dati della tabella e li ordino in base al nome + $tipologie = $database->esegui("SELECT nome FROM tipo ORDER BY nome ASC", true); // Pesco le tipologie della tabella + $modalità = (isset($_GET["aggiungi"])) ? "aggiungi" : ((isset($_GET["modifica"])) ? "modifica" : ((isset($_GET["elimina"])) ? "elimina" : "aggiungi")); + bdump($modalità, "modalità"); + bdump($tipologie, "tipologie"); + bdump($personale, "personale"); + $id = ""; + if(isset($_GET["id"])){ + $id = $_GET["id"]; + bdump($database->esiste("interventi", $id)); + } + if($modalità=="modifica" || $modalità=="elimina"){ + if(empty($id)){ + $tools->redirect("nonfareilfurbo.php"); + } elseif (!$database->esiste("interventi", $id)){ + $tools->redirect("nonfareilfurbo.php"); + } + } + loadtemplate('modifica_intervento.html', ['intervento' => array('id' => $id, 'token' => $_SESSION['token'], 'modalità' => $modalità, 'personale' => $personale, 'tipologie' => $tipologie), 'titolo' => ucfirst($modalità) . ' intervento', 'distaccamento' => 'VVF Darfo', 'urlsoftware' => '', 'utente' => $utente->info()]); + bdump($_SESSION['token'], "token"); +} +?> \ No newline at end of file diff --git a/server/nonfareilfurbo.php b/server/nonfareilfurbo.php new file mode 100644 index 0000000..ee17243 --- /dev/null +++ b/server/nonfareilfurbo.php @@ -0,0 +1,26 @@ + + + + + +
+ + +Possibile attività di hacking del software rilevata + +
+

Abbiamo rilevato un' attività sospetta provenire dal tuo dispositivo o dalla tua rete.
Se non stavi facendo niente di brutto, e ritieni che questo sia un errore, la
preghiamo di contattare l'assistenza.

+ diff --git a/server/offline.html b/server/offline.html new file mode 100644 index 0000000..e69de29 diff --git a/server/online.php b/server/online.php new file mode 100644 index 0000000..9424f86 --- /dev/null +++ b/server/online.php @@ -0,0 +1,41 @@ + +ciao = 0; +function onLine() { + ciao = ciao + 1; + console.log(ciao); + console.log("onLine"); + var xhr = new XMLHttpRequest(); + xhr.open('GET', 'http://62.171.139.86/allerta/online_check.php?utente=$user'); + xhr.onload = function () { + if (xhr.status === 200) { + console.log('Text ' + xhr.responseText); + } else { + console.log('Request failed. Returned status of ' + xhr.status); + } + }; + xhr.send(); +} + +function offLine() { + console.log("offLine"); +} + +function check() { + console.log("dfcghfhdt"); + var i = new Image(); + i.onload = onLine; + i.onerror = offLine; + i.src = 'https://www.google-analytics.com/__utm.gif'; +} + +EOT; +echo($string); diff --git a/server/online_check.php b/server/online_check.php new file mode 100644 index 0000000..0746f1b --- /dev/null +++ b/server/online_check.php @@ -0,0 +1,22 @@ +esegui($sql, true); +var_dump($risultato); +foreach($risultato as $row){ +print("
" . print_r($row, true) . "
"); +} + +if(isset($_GET) && !is_null($_GET['utente'])){ + $sql = "UPDATE vigili SET online = '1', online_time = '$minuti' WHERE nome = '" . urldecode($_GET['utente']) . "'"; + $risultato = $database->esegui($sql, true); + var_dump($risultato); +} +?> diff --git a/server/online_check_cron.php b/server/online_check_cron.php new file mode 100644 index 0000000..243ec5f --- /dev/null +++ b/server/online_check_cron.php @@ -0,0 +1,14 @@ +esegui($sql); +echo $sql; +?> diff --git a/server/profilo.php b/server/profilo.php new file mode 100644 index 0000000..fe942e7 --- /dev/null +++ b/server/profilo.php @@ -0,0 +1,3 @@ + 'Pagina profilo', 'distaccamento' => 'VVF Darfo', 'urlsoftware' => '', 'utente' => $utente->info()]); \ No newline at end of file diff --git a/server/risorse/ajax/ajax_aggiornadispo.php b/server/risorse/ajax/ajax_aggiornadispo.php new file mode 100644 index 0000000..e97e77b --- /dev/null +++ b/server/risorse/ajax/ajax_aggiornadispo.php @@ -0,0 +1,12 @@ +richiedilogin(); +if(isset($_POST["nomeutenteattivato"]) && isset($_POST["nomeutenteattivatore"]) && $_POST["dispo"] == 1) { + $risultato = $database->esegui("UPDATE vigili SET disponibile = 1 WHERE nome = :nome", false, [":nome" => $_POST["nomeutenteattivato"]]); + $utente->log("Attivazione disponibilita'", $_POST["nomeutenteattivato"], $_POST["nomeutenteattivatore"], date("d/m/Y"), date("H:i.s")); +} else if(isset($_POST["nomeutenteattivato"]) && isset($_POST["nomeutenteattivatore"]) && $_POST["dispo"] == 0){ + $risultato = $database->esegui("UPDATE vigili SET disponibile = 0 WHERE nome = :nome", false, [":nome" => $_POST["nomeutenteattivato"]]); + $utente->log("Rimozione disponibilita'", $_POST["nomeutenteattivato"], $_POST["nomeutenteattivatore"], date("d/m/Y"), date("H:i.s")); +} +?> diff --git a/server/risorse/ajax/ajax_anagrafica.php b/server/risorse/ajax/ajax_anagrafica.php new file mode 100644 index 0000000..e33308a --- /dev/null +++ b/server/risorse/ajax/ajax_anagrafica.php @@ -0,0 +1,332 @@ +richiedilogin(); + +$risultato = $database->esegui('SELECT * FROM vigili WHERE id = :id', true, array(":id" => $_GET['utente'])); // Pesco i dati della tabella + +$whitelist = $utente->whitelist(); +?> + + +' . $row['nome'] . "" : $row['nome']; +echo("

Dati anagrafici $nome



"); +echo('VVF


'); +$disp = vero1($row['disponibile'], "", ""); +$caposquadra = vero1($row['caposquadra'], "", ""); +$autista = vero1($row['autista'], ""); +echo("

Nome: $nome


"); +echo("

Disponibilità: {$disp}


"); +echo("

Caposquadra: {$caposquadra}


"); +echo("

Autista: {$autista}


"); +echo("

Numero di telefono : {$row['telefono']}


"); +echo("

Minuti di disponibilità
(Questo mese) : {$row['minuti_dispo']} minuti


"); +echo("

Interventi svolti: {$row['interventi']}


"); +} +?> diff --git a/server/risorse/ajax/ajax_cache.php b/server/risorse/ajax/ajax_cache.php new file mode 100644 index 0000000..f2fb3b6 --- /dev/null +++ b/server/risorse/ajax/ajax_cache.php @@ -0,0 +1,18 @@ +richiedilogin(); + +$vigili_sql = "SELECT `id`, `nome`, `disponibile`, `caposquadra`, `autista`, `telefono`, `interventi`, `esercitazioni`, `online`, `minuti_dispo`, `immagine` FROM `vigili` LIMIT 0 , 30"; +$vigili = $database->esegui($vigili_sql, true); + +$interventi_sql="SELECT * FROM `interventi` ORDER BY `interventi`.`id` DESC LIMIT 0 , 30"; +$interventi = $database->esegui($interventi_sql, true); + +$esercitazioni_sql="SELECT * FROM `esercitazioni` ORDER BY `esercitazioni`.`id` DESC LIMIT 0 , 30"; +$esercitazioni = $database->esegui($esercitazioni_sql, true); + +$elenco = ["vigili" => $vigili, "interventi" => $interventi, "esercitazioni" => $esercitazioni]; + +header("Content-Type: application/json; charset=UTF-8"); +echo(json_encode($elenco)); \ No newline at end of file diff --git a/server/risorse/ajax/ajax_dispo.php b/server/risorse/ajax/ajax_dispo.php new file mode 100644 index 0000000..6ecc28d --- /dev/null +++ b/server/risorse/ajax/ajax_dispo.php @@ -0,0 +1,36 @@ +richiedilogin(); + +function arraynum(){ +global $database; +$risultato = $database->esegui("SELECT * FROM vigili ORDER BY disponibile DESC, caposquadra DESC, interventi ASC, nome ASC", true); // Pesco i dati della tabella e li ordino in base alla disponibilità +$incremento = array(); +$minuti_dispo_old = array(); +foreach($risultato as $row){ + if($row['disponibile'] == "1"){ + $incremento[] = $row['nome']; + $minuti_dispo_old[] = $row['minuti_dispo']; + } +} + +return $incremento; +} + +if(!isset($_GET['nome'])){ +print_r(arraynum()); +} else { + if(isset($_GET['nome'])){ + $arr = arraynum(); + $nome = str_replace("_", " ", $_GET['nome']); + if(in_array($nome, $arr)){ + echo "si"; + } else { + echo "no"; + } + } +} +?> diff --git a/server/risorse/ajax/ajax_esercitazioni.php b/server/risorse/ajax/ajax_esercitazioni.php new file mode 100644 index 0000000..1ae4ca0 --- /dev/null +++ b/server/risorse/ajax/ajax_esercitazioni.php @@ -0,0 +1,108 @@ +richiedilogin(); + +function ancora($content, $id) { +$content = substr($content,0,$limit); +$content = substr($content,0,strrpos($content,' ')); +$content = $content." ...Leggi ancora"; +return $content; +} + +$impostazioni['modifica'] = false; +$impostazioni['elimina'] = false; + +$risultato = $database->esegui("SELECT * FROM esercitazioni ORDER BY data DESC, inizio desc", true); // Pesco i dati della tabella e li ordino in base alla data +?> + + +
+
+
+
+ + + + + + + + + + + + Modifica"; } ?> + Elimina"; } ?> + + + +"; + if($impostazioni['modifica']) { + echo ""; + } + if($impostazioni['elimina']) { + echo ""; + } +} +?> + +
DataNomeOra inizioOra fineCapoPersonaleLuogoNote
" . $row['data'] . "" . $row['nome'] . "" . $row['inizio'] . "" . $row['fine'] . "" . $row['capo'] . "" . $row['personale'] . "" . $row['luogo'] . "" . $row['note'] . "
+
+
+
diff --git a/server/risorse/ajax/ajax_interventi.php b/server/risorse/ajax/ajax_interventi.php new file mode 100644 index 0000000..4f3860a --- /dev/null +++ b/server/risorse/ajax/ajax_interventi.php @@ -0,0 +1,110 @@ +richiedilogin(); + +function ancora($content, $id) { +$content = substr($content,0,$limit); +$content = substr($content,0,strrpos($content,' ')); +$content = $content." ...Leggi ancora"; +return $content; +} + +$impostazioni['modifica'] = false; +$impostazioni['elimina'] = false; + +$risultato = $database->esegui("SELECT * FROM interventi ORDER BY data DESC, uscita desc", true); // Pesco i dati della tabella e li ordino in base alla data +?> + + +
+
+
+
+ + + + + + + + + + + + + + Modifica"; } ?> + Elimina"; } ?> + + + +"; + if($impostazioni['modifica']) { + echo ""; + } + if($impostazioni['elimina']) { + echo ""; + } +} +?> + +
DataCodiceUscitaRientroCaposquadraAutistiPersonaleLuogoNoteTipo
" . $row['data'] . "" . $row['codice'] . "" . $row['uscita'] . "" . $row['rientro'] . "" . $row['capo'] . "" . $row['autisti'] . "" . $row['personale'] . "" . $row['luogo'] . "" . $row['note'] . "" . $row['tipo'] . "
+
+
+
\ No newline at end of file diff --git a/server/risorse/ajax/ajax_lista.php b/server/risorse/ajax/ajax_lista.php new file mode 100644 index 0000000..fcd5335 --- /dev/null +++ b/server/risorse/ajax/ajax_lista.php @@ -0,0 +1,61 @@ +richiedilogin(); + +$risultato = $database->esegui("SELECT * FROM vigili ORDER BY disponibile DESC, caposquadra DESC, interventi ASC, minuti_dispo ASC, nome ASC", true); + +$whitelist = $utente->whitelist(); +?> + + +
+ + + + + "; + } + } + ?> +
NomeDisponibile"; + if ($row['caposquadra'] == 1) {echo " ";} else{echo " ";} + if($row['online'] == 1){ + echo "".$row["nome"].""; + } else { + echo "".$row["nome"].""; + } + if ($row['disponibile'] == 1) {echo "";} else{echo "";}; + echo "
+
diff --git a/server/risorse/ajax/ajax_lista_admin.php b/server/risorse/ajax/ajax_lista_admin.php new file mode 100644 index 0000000..0418993 --- /dev/null +++ b/server/risorse/ajax/ajax_lista_admin.php @@ -0,0 +1,79 @@ +richiedilogin(); + +$risultato = $database->esegui("SELECT * FROM vigili ORDER BY disponibile DESC, caposquadra DESC, interventi ASC, minuti_dispo ASC, nome ASC", true); + +$whitelist = $utente->whitelist(); +?> + + +
+ + + + + + + + + + + nome(), $whitelist)){ + echo " + + + ";} else{echo "";}; + + $interventi = $row['interventi']; + $minuti = $row['minuti_dispo']; + $u = 'anagrafica.php?utente=' . str_replace(' ', '_', urldecode(strtolower($row["id"]))); + echo ""; + } +} + ?> +
NomeDisponibileAutistaChiamaScriviInterventiMinuti DisponibilitàAltro
"; + $nome = $row["nome"]; + $disponibile = $row["disponibile"]; + if ($row['caposquadra'] == 1) {echo " ";} else{echo " ";} + if($row['online'] == 1){ + echo "".$row["nome"].""; + } else { + echo $row["nome"].""; + } + if ($row['disponibile'] == 1) {echo "";} else{echo "";}; + echo ""; + if ($row['autista'] == 1) {echo "";} else{echo "";}; + echo ""; + + if ($row['disponibile'] == 1) {echo " $interventi$minuti

Altri dettagli

+
diff --git a/server/risorse/ajax/ajax_log.php b/server/risorse/ajax/ajax_log.php new file mode 100644 index 0000000..0fde87a --- /dev/null +++ b/server/risorse/ajax/ajax_log.php @@ -0,0 +1,133 @@ +richiedilogin(); +/* +function trovanomi() { +include_once '../../connection.php'; +$sql = "SELECT nome FROM vigili"; // Pesco i dati della tabella +$result = mysqli_query($connessione, $sql); + while($row = $result->fetch_array()) +{ +$rows[] = $row; +} +$nome = array(); +foreach($rows as $row) +{ + $nome[] = $row['nome']; + +} +mysqli_close($connessione); +return $nome; +} + +function checkbox_vigili() { +$whitelist = $utente->whitelist(); +$id = 0; +$checkbox = << + + + "; +return $checkbox; +} +*/ + +$risultato = $database->esegui("SELECT * FROM `log`", true); + +$whitelist = $utente->whitelist(); +?> + +
+ + + + + + + + + + + nome(), $whitelist)){ + echo ""; + + } + } + ?> + +
AzioneInteressatoFatto daOra
" . $row["azione"] . "" . $row["subisce"] . "" . $row["agisce"] ."" . $row['data'] . " - ore " . $row['ora'] . "
+
diff --git a/server/risorse/css/animation.css b/server/risorse/css/animation.css new file mode 100644 index 0000000..ac5a956 --- /dev/null +++ b/server/risorse/css/animation.css @@ -0,0 +1,85 @@ +/* + Animation example, for spinners +*/ +.animate-spin { + -moz-animation: spin 2s infinite linear; + -o-animation: spin 2s infinite linear; + -webkit-animation: spin 2s infinite linear; + animation: spin 2s infinite linear; + display: inline-block; +} +@-moz-keyframes spin { + 0% { + -moz-transform: rotate(0deg); + -o-transform: rotate(0deg); + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + + 100% { + -moz-transform: rotate(359deg); + -o-transform: rotate(359deg); + -webkit-transform: rotate(359deg); + transform: rotate(359deg); + } +} +@-webkit-keyframes spin { + 0% { + -moz-transform: rotate(0deg); + -o-transform: rotate(0deg); + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + + 100% { + -moz-transform: rotate(359deg); + -o-transform: rotate(359deg); + -webkit-transform: rotate(359deg); + transform: rotate(359deg); + } +} +@-o-keyframes spin { + 0% { + -moz-transform: rotate(0deg); + -o-transform: rotate(0deg); + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + + 100% { + -moz-transform: rotate(359deg); + -o-transform: rotate(359deg); + -webkit-transform: rotate(359deg); + transform: rotate(359deg); + } +} +@-ms-keyframes spin { + 0% { + -moz-transform: rotate(0deg); + -o-transform: rotate(0deg); + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + + 100% { + -moz-transform: rotate(359deg); + -o-transform: rotate(359deg); + -webkit-transform: rotate(359deg); + transform: rotate(359deg); + } +} +@keyframes spin { + 0% { + -moz-transform: rotate(0deg); + -o-transform: rotate(0deg); + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + + 100% { + -moz-transform: rotate(359deg); + -o-transform: rotate(359deg); + -webkit-transform: rotate(359deg); + transform: rotate(359deg); + } +} diff --git a/server/risorse/css/aprilFools.css b/server/risorse/css/aprilFools.css new file mode 100644 index 0000000..b585dc0 --- /dev/null +++ b/server/risorse/css/aprilFools.css @@ -0,0 +1,287 @@ +/* + aprilFools.css + Written by Wes Bos + Modified by Nick Karamoff + + I assume no responsibility for angry co-workers or lost productivity + + Put these CSS definitons into your co-workers Custom.css file. + + They will be applied to every website they visit as well as their developer tools. +*/ + + +/* + Turn every website upside down +*/ +body { + transform: rotate(180deg); +} + +/* + blur every website for a split second every 30 seconds +*/ +body { + animation: blur 30s infinite; +} + +/* + Spin every Website +*/ +body { + animation: spin 5s linear infinite; +} + +/* + Flip all images upside down +*/ +img { + transform: rotate(180deg); +} + +/* + COMIC SANS EVERYTHING +*/ + +body, p, body p, body div p { + font-family: 'Comic Sans MS', cursive !important; +} + +/* + Spin all images +*/ +img { + animation: spin 1s linear infinite; +} + +/* + Hide every 2nd paragraph element on a page +*/ +p:nth-child(2) { + display:none !important; +} + +/* + Permanent cursor wait +*/ +html { + cursor:wait !important; +} + +/* + hide the cursor all together +*/ +html { + cursor:none !important; +} + +/* + slowly grow text +*/ +p { + animation: grow 120s ease-in; +} + + +/* Dev Tools */ + +/* + Spin dev tools round and round +*/ +#-webkit-web-inspector { + -webkit-animation: spin 1s linear infinite; +} + + +/* + Flip dev tools upside down +*/ +#-webkit-web-inspector { + -webkit-transform:rotate(180deg); +} + + +/* Hide the close button */ +#-webkit-web-inspector .toolbar-item.close-left { + display:none !important; +} + + +/* Make console text all blurry */ +#-webkit-web-inspector .console-group-messages { + text-shadow: 0 0 3px rgba(0,0,0,.5) !important; +} + +#-webkit-web-inspector .console-error-level .console-message-text, +#-webkit-web-inspector .console-error-level .section .header .title { + text-shadow: 0 0 3px rgba(255,0,0,.5) !important; +} + +#-webkit-web-inspector .console-user-command > .console-message-text { + text-shadow: 0 0 3px rgba(0,128,255,.5) !important; +} + +#-webkit-web-inspector .console-group-messages, +#-webkit-web-inspector .console-user-command > .console-message-text, +#-webkit-web-inspector .console-formatted-null, +#-webkit-web-inspector .console-formatted-undefined, +#-webkit-web-inspector .console-debug-level .console-message-text, +#-webkit-web-inspector .console-error-level .console-message-text, +#-webkit-web-inspector .console-error-level .section .header .title, +#-webkit-web-inspector .console-group-messages .section .header .title, +#-webkit-web-inspector .console-formatted-object, +#-webkit-web-inspector .console-formatted-node, +#-webkit-web-inspector .console-formatted-array, +#-webkit-web-inspector .section .properties .name, +#-webkit-web-inspector .event-properties .name, +#-webkit-web-inspector .console-formatted-object .name, +#-webkit-web-inspector .console-formatted-number, +#-webkit-web-inspector .console-formatted-string, +#-webkit-web-inspector #console-messages a { + color: transparent !important; +} + + +/* HTML PRIDE! */ +html { + animation: rainbow 8s infinite; +} + + +/* + Make every website fall over! +*/ +html, body { + height: 100%; +} + +html { + perspective: 1000; +} + +body { + transform-origin: bottom center; + transform: rotateX(-90deg); + animation: fall 1.5s ease-in; +} + + +/* + Insert a phrase every paragraph +*/ +p:before { + content: "YOLO "; +} + + +/* New tricks by Nick Karamoff */ + +/* + Flip every paragraph upside down +*/ +p { + transform: rotate(180deg); +} + + +/* + Flip every header upside down +*/ +h1, h2, h3, h4, h5, h6 { + transform: rotate(180deg); +} + + +/* + Mirror the whole webpage +*/ +body { + transform: scale(-1, 1); +} + +/* + Transparent paragraphs +*/ +p { + color: transparent; +} + +/* + "Very good design" combo (blue bg, red text, Comic Sans) +*/ +body, p, h1, h2, h3, h4, h5, h6 { + color: red; + background-color: blue; + font-family: "Comic Sans", cursive; +} + +/* + Deactivate all the links +*/ +a { + pointer-events: none; + cursor: default; +} + +/* + Unlinkify links (standart formatting, but still clickable) +*/ +a { + text-decoration: none; + color: inherit; + cursor: default; +} + +/* + Links not allowed +*/ +a { + cursor: not-allowed; +} + +/* + Everything's a link! +*/ +body { + cursor: pointer; +} + + + +/* Animations */ + +/* + Everything that is moving is powered from here, so just copy this whole chunk +*/ + +@keyframes blur { + 0% { filter: blur(0px); } + 49% { filter: blur(0px); } + 50% { filter: blur(1px); } + 51% { filter: blur(0px); } + 100% { filter: blur(0px); } +} + +@-webkit-keyframes spin { + 0% { -webkit-transform: rotate(0deg); } + 100% { -webkit-transform: rotate(360deg); } +} + +@keyframes rainbow { + 100% { filter: hue-rotate(360deg); } +} + +@keyframes spin { + 0% { transform: rotate(0deg); } + 100% { transform: rotate(360deg); } +} + +@keyframes fall { + 0% { transform: none; } + 100% { transform: rotateX(-90deg); } +} + +@keyframes grow { + 0% { font-size: none; } + 100% { font-size: 80pt; } +} diff --git a/server/risorse/css/classic.css b/server/risorse/css/classic.css new file mode 100644 index 0000000..8d16c9e --- /dev/null +++ b/server/risorse/css/classic.css @@ -0,0 +1,4 @@ +.picker,.picker__holder{width:100%;position:absolute}.picker{font-size:16px;text-align:left;line-height:1.2;color:#000;z-index:10000;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:0}.picker__input{cursor:default}.picker__input.picker__input--active{border-color:#0089ec}.picker__holder{overflow-y:auto;-webkit-overflow-scrolling:touch;background:#fff;border:1px solid #aaa;border-top-width:0;border-bottom-width:0;border-radius:0 0 5px 5px;box-sizing:border-box;min-width:176px;max-width:466px;max-height:0;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";filter:alpha(opacity=0);-moz-opacity:0;opacity:0;transform:translateY(-1em) perspective(600px) rotateX(10deg);transition:transform .15s ease-out,opacity .15s ease-out,max-height 0s .15s,border-width 0s .15s}/*! + * Classic picker styling for pickadate.js + * Demo: http://amsul.github.io/pickadate.js + */.picker__frame{padding:1px}.picker__wrap{margin:-1px}.picker--opened .picker__holder{max-height:25em;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";filter:alpha(opacity=100);-moz-opacity:1;opacity:1;border-top-width:1px;border-bottom-width:1px;transform:translateY(0) perspective(600px) rotateX(0);transition:transform .15s ease-out,opacity .15s ease-out,max-height 0s,border-width 0s;box-shadow:0 6px 18px 1px rgba(0,0,0,.12)} \ No newline at end of file diff --git a/server/risorse/css/classic.date.css b/server/risorse/css/classic.date.css new file mode 100644 index 0000000..2664433 --- /dev/null +++ b/server/risorse/css/classic.date.css @@ -0,0 +1 @@ +.picker__footer,.picker__header,.picker__table{text-align:center}.picker__box{padding:0 1em}.picker__header{position:relative;margin-top:.75em}.picker__month,.picker__year{font-weight:500;display:inline-block;margin-left:.25em;margin-right:.25em}.picker__year{color:#999;font-size:.8em;font-style:italic}.picker__select--month,.picker__select--year{border:1px solid #b7b7b7;height:2em;padding:.5em;margin-left:.25em;margin-right:.25em}.picker__select--month{width:35%}.picker__select--year{width:22.5%}.picker__select--month:focus,.picker__select--year:focus{border-color:#0089ec}.picker__nav--next,.picker__nav--prev{position:absolute;padding:.5em 1.25em;width:1em;height:1em;box-sizing:content-box;top:-.25em}.picker__nav--prev{left:-1em;padding-right:1.25em}.picker__nav--next{right:-1em;padding-left:1.25em}@media (min-width:24.5em){.picker__select--month,.picker__select--year{margin-top:-.5em}.picker__nav--next,.picker__nav--prev{top:-.33em}.picker__nav--prev{padding-right:1.5em}.picker__nav--next{padding-left:1.5em}}.picker__nav--next:before,.picker__nav--prev:before{content:" ";border-top:.5em solid transparent;border-bottom:.5em solid transparent;border-right:.75em solid #000;width:0;height:0;display:block;margin:0 auto}.picker__nav--next:before{border-right:0;border-left:.75em solid #000}.picker__nav--next:hover,.picker__nav--prev:hover{cursor:pointer;color:#000;background:#b1dcfb}.picker__nav--disabled,.picker__nav--disabled:before,.picker__nav--disabled:before:hover,.picker__nav--disabled:hover{cursor:default;background:0 0;border-right-color:#f5f5f5;border-left-color:#f5f5f5}.picker__table{border-collapse:collapse;border-spacing:0;table-layout:fixed;font-size:inherit;width:100%;margin-top:.75em;margin-bottom:.5em}@media (min-height:33.875em){.picker__table{margin-bottom:.75em}}.picker__table td{margin:0;padding:0}.picker__weekday{width:14.285714286%;font-size:.75em;padding-bottom:.25em;color:#999;font-weight:500}@media (min-height:33.875em){.picker__weekday{padding-bottom:.5em}}.picker__day{padding:.3125em 0;font-weight:200;border:1px solid transparent}.picker__day--today{position:relative}.picker__day--today:before{content:" ";position:absolute;top:2px;right:2px;width:0;height:0;border-top:.5em solid #0059bc;border-left:.5em solid transparent}.picker__day--disabled:before{border-top-color:#aaa}.picker__day--outfocus{color:#ddd}.picker--focused .picker__day--highlighted,.picker__day--highlighted:hover,.picker__day--infocus:hover,.picker__day--outfocus:hover{cursor:pointer;color:#000;background:#b1dcfb}.picker__day--highlighted{border-color:#0089ec}.picker--focused .picker__day--selected,.picker__day--selected,.picker__day--selected:hover{background:#0089ec;color:#fff}.picker--focused .picker__day--disabled,.picker__day--disabled,.picker__day--disabled:hover{background:#f5f5f5;border-color:#f5f5f5;color:#ddd;cursor:default}.picker__day--highlighted.picker__day--disabled,.picker__day--highlighted.picker__day--disabled:hover{background:#bbb}.picker__button--clear,.picker__button--close,.picker__button--today{border:1px solid #fff;background:#fff;font-size:.8em;padding:.66em 0;font-weight:700;width:33%;display:inline-block;vertical-align:bottom}.picker__button--clear:hover,.picker__button--close:hover,.picker__button--today:hover{cursor:pointer;color:#000;background:#b1dcfb;border-bottom-color:#b1dcfb}.picker__button--clear:focus,.picker__button--close:focus,.picker__button--today:focus{background:#b1dcfb;border-color:#0089ec;outline:0}.picker__button--clear:before,.picker__button--close:before,.picker__button--today:before{position:relative;display:inline-block;height:0}.picker__button--clear:before,.picker__button--today:before{content:" ";margin-right:.45em}.picker__button--today:before{top:-.05em;width:0;border-top:.66em solid #0059bc;border-left:.66em solid transparent}.picker__button--clear:before{top:-.25em;width:.66em;border-top:3px solid #e20}.picker__button--close:before{content:"\D7";top:-.1em;vertical-align:top;font-size:1.1em;margin-right:.35em;color:#777}.picker__button--today[disabled],.picker__button--today[disabled]:hover{background:#f5f5f5;border-color:#f5f5f5;color:#ddd;cursor:default}.picker__button--today[disabled]:before{border-top-color:#aaa} \ No newline at end of file diff --git a/server/risorse/css/classic.time.css b/server/risorse/css/classic.time.css new file mode 100644 index 0000000..2d540eb --- /dev/null +++ b/server/risorse/css/classic.time.css @@ -0,0 +1 @@ +.picker__list{list-style:none;padding:.75em 0 4.2em;margin:0}.picker__list-item{border-bottom:1px solid #ddd;border-top:1px solid #ddd;margin-bottom:-1px;position:relative;background:#fff;padding:.75em 1.25em}.picker__list-item--highlighted,.picker__list-item:hover{border-color:#0089ec;z-index:10}.picker--focused .picker__list-item--highlighted,.picker__list-item--highlighted:hover,.picker__list-item:hover{color:#000;background:#b1dcfb;cursor:pointer}@media (min-height:46.75em){.picker__list-item{padding:.5em 1em}}.picker--focused .picker__list-item--selected,.picker__list-item--selected,.picker__list-item--selected:hover{background:#0089ec;color:#fff;z-index:10}.picker--focused .picker__list-item--disabled,.picker__list-item--disabled,.picker__list-item--disabled:hover{background:#f5f5f5;color:#ddd;cursor:default;border-color:#ddd;z-index:auto}.picker--time .picker__button--clear{display:block;width:80%;margin:1em auto 0;padding:1em 1.25em;background:0 0;border:0;font-weight:500;font-size:.67em;text-align:center;text-transform:uppercase;color:#666}.picker--time .picker__button--clear:focus,.picker--time .picker__button--clear:hover{background:#e20;border-color:#e20;cursor:pointer;color:#fff;outline:0}.picker--time .picker__button--clear:before{top:-.25em;color:#666;font-size:1.25em;font-weight:700}.picker--time .picker__button--clear:focus:before,.picker--time .picker__button--clear:hover:before{color:#fff;border-color:#fff}.picker--time{min-width:256px;max-width:320px}.picker--time .picker__holder{background:#f2f2f2}@media (min-height:40.125em){.picker--time .picker__holder{font-size:.875em}}.picker--time .picker__box{padding:0;position:relative} \ No newline at end of file diff --git a/server/risorse/css/default.css b/server/risorse/css/default.css new file mode 100644 index 0000000..3d3b7b5 --- /dev/null +++ b/server/risorse/css/default.css @@ -0,0 +1,4 @@ +.picker{font-size:16px;text-align:left;line-height:1.2;color:#000;position:absolute;z-index:10000;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:0}.picker__input{cursor:default}.picker__input.picker__input--active{border-color:#0089ec}.picker__holder{width:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;position:fixed;transition:background .15s ease-out,transform 0s .15s;-webkit-backface-visibility:hidden}/*! + * Default mobile-first, responsive styling for pickadate.js + * Demo: http://amsul.github.io/pickadate.js + */.picker__frame,.picker__holder{top:0;bottom:0;left:0;right:0;-ms-transform:translateY(100%);transform:translateY(100%)}.picker__frame{position:absolute;margin:0 auto;min-width:256px;max-width:666px;width:100%;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";filter:alpha(opacity=0);-moz-opacity:0;opacity:0;transition:all .15s ease-out}.picker__wrap{display:table;width:100%;height:100%}@media (min-height:33.875em){.picker__frame{overflow:visible;top:auto;bottom:-100%;max-height:80%}.picker__wrap{display:block}}.picker__box{background:#fff;display:table-cell;vertical-align:middle}@media (min-height:26.5em){.picker__box{font-size:1.25em}}@media (min-height:33.875em){.picker__box{display:block;font-size:1.33em;border:1px solid #777;border-top-color:#898989;border-bottom-width:0;border-radius:5px 5px 0 0;box-shadow:0 12px 36px 16px rgba(0,0,0,.24)}.picker--opened .picker__frame{top:auto;bottom:0}}@media (min-height:40.125em){.picker__frame{margin-bottom:7.5%}.picker__box{font-size:1.5em;border-bottom-width:1px;border-radius:5px}}.picker--opened .picker__holder{-ms-transform:translateY(0);transform:translateY(0);zoom:1;background:rgba(0,0,0,.32);transition:background .15s ease-out}.picker--opened .picker__frame{-ms-transform:translateY(0);transform:translateY(0);-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";filter:alpha(opacity=100);-moz-opacity:1;opacity:1} \ No newline at end of file diff --git a/server/risorse/css/default.date.css b/server/risorse/css/default.date.css new file mode 100644 index 0000000..2664433 --- /dev/null +++ b/server/risorse/css/default.date.css @@ -0,0 +1 @@ +.picker__footer,.picker__header,.picker__table{text-align:center}.picker__box{padding:0 1em}.picker__header{position:relative;margin-top:.75em}.picker__month,.picker__year{font-weight:500;display:inline-block;margin-left:.25em;margin-right:.25em}.picker__year{color:#999;font-size:.8em;font-style:italic}.picker__select--month,.picker__select--year{border:1px solid #b7b7b7;height:2em;padding:.5em;margin-left:.25em;margin-right:.25em}.picker__select--month{width:35%}.picker__select--year{width:22.5%}.picker__select--month:focus,.picker__select--year:focus{border-color:#0089ec}.picker__nav--next,.picker__nav--prev{position:absolute;padding:.5em 1.25em;width:1em;height:1em;box-sizing:content-box;top:-.25em}.picker__nav--prev{left:-1em;padding-right:1.25em}.picker__nav--next{right:-1em;padding-left:1.25em}@media (min-width:24.5em){.picker__select--month,.picker__select--year{margin-top:-.5em}.picker__nav--next,.picker__nav--prev{top:-.33em}.picker__nav--prev{padding-right:1.5em}.picker__nav--next{padding-left:1.5em}}.picker__nav--next:before,.picker__nav--prev:before{content:" ";border-top:.5em solid transparent;border-bottom:.5em solid transparent;border-right:.75em solid #000;width:0;height:0;display:block;margin:0 auto}.picker__nav--next:before{border-right:0;border-left:.75em solid #000}.picker__nav--next:hover,.picker__nav--prev:hover{cursor:pointer;color:#000;background:#b1dcfb}.picker__nav--disabled,.picker__nav--disabled:before,.picker__nav--disabled:before:hover,.picker__nav--disabled:hover{cursor:default;background:0 0;border-right-color:#f5f5f5;border-left-color:#f5f5f5}.picker__table{border-collapse:collapse;border-spacing:0;table-layout:fixed;font-size:inherit;width:100%;margin-top:.75em;margin-bottom:.5em}@media (min-height:33.875em){.picker__table{margin-bottom:.75em}}.picker__table td{margin:0;padding:0}.picker__weekday{width:14.285714286%;font-size:.75em;padding-bottom:.25em;color:#999;font-weight:500}@media (min-height:33.875em){.picker__weekday{padding-bottom:.5em}}.picker__day{padding:.3125em 0;font-weight:200;border:1px solid transparent}.picker__day--today{position:relative}.picker__day--today:before{content:" ";position:absolute;top:2px;right:2px;width:0;height:0;border-top:.5em solid #0059bc;border-left:.5em solid transparent}.picker__day--disabled:before{border-top-color:#aaa}.picker__day--outfocus{color:#ddd}.picker--focused .picker__day--highlighted,.picker__day--highlighted:hover,.picker__day--infocus:hover,.picker__day--outfocus:hover{cursor:pointer;color:#000;background:#b1dcfb}.picker__day--highlighted{border-color:#0089ec}.picker--focused .picker__day--selected,.picker__day--selected,.picker__day--selected:hover{background:#0089ec;color:#fff}.picker--focused .picker__day--disabled,.picker__day--disabled,.picker__day--disabled:hover{background:#f5f5f5;border-color:#f5f5f5;color:#ddd;cursor:default}.picker__day--highlighted.picker__day--disabled,.picker__day--highlighted.picker__day--disabled:hover{background:#bbb}.picker__button--clear,.picker__button--close,.picker__button--today{border:1px solid #fff;background:#fff;font-size:.8em;padding:.66em 0;font-weight:700;width:33%;display:inline-block;vertical-align:bottom}.picker__button--clear:hover,.picker__button--close:hover,.picker__button--today:hover{cursor:pointer;color:#000;background:#b1dcfb;border-bottom-color:#b1dcfb}.picker__button--clear:focus,.picker__button--close:focus,.picker__button--today:focus{background:#b1dcfb;border-color:#0089ec;outline:0}.picker__button--clear:before,.picker__button--close:before,.picker__button--today:before{position:relative;display:inline-block;height:0}.picker__button--clear:before,.picker__button--today:before{content:" ";margin-right:.45em}.picker__button--today:before{top:-.05em;width:0;border-top:.66em solid #0059bc;border-left:.66em solid transparent}.picker__button--clear:before{top:-.25em;width:.66em;border-top:3px solid #e20}.picker__button--close:before{content:"\D7";top:-.1em;vertical-align:top;font-size:1.1em;margin-right:.35em;color:#777}.picker__button--today[disabled],.picker__button--today[disabled]:hover{background:#f5f5f5;border-color:#f5f5f5;color:#ddd;cursor:default}.picker__button--today[disabled]:before{border-top-color:#aaa} \ No newline at end of file diff --git a/server/risorse/css/default.time.css b/server/risorse/css/default.time.css new file mode 100644 index 0000000..85b41e7 --- /dev/null +++ b/server/risorse/css/default.time.css @@ -0,0 +1 @@ +.picker__list{list-style:none;padding:.75em 0 4.2em;margin:0}.picker__list-item{border-bottom:1px solid #ddd;border-top:1px solid #ddd;margin-bottom:-1px;position:relative;background:#fff;padding:.75em 1.25em}.picker__list-item--highlighted,.picker__list-item:hover{border-color:#0089ec;z-index:10}.picker--focused .picker__list-item--highlighted,.picker__list-item--highlighted:hover,.picker__list-item:hover{cursor:pointer;color:#000;background:#b1dcfb}@media (min-height:46.75em){.picker__list-item{padding:.5em 1em}}.picker--focused .picker__list-item--selected,.picker__list-item--selected,.picker__list-item--selected:hover{background:#0089ec;color:#fff;z-index:10}.picker--focused .picker__list-item--disabled,.picker__list-item--disabled,.picker__list-item--disabled:hover{background:#f5f5f5;color:#ddd;cursor:default;border-color:#ddd;z-index:auto}.picker--time .picker__button--clear{display:block;width:80%;margin:1em auto 0;padding:1em 1.25em;background:0 0;border:0;font-weight:500;font-size:.67em;text-align:center;text-transform:uppercase;color:#666}.picker--time .picker__button--clear:focus,.picker--time .picker__button--clear:hover{background:#e20;border-color:#e20;cursor:pointer;color:#fff;outline:0}.picker--time .picker__button--clear:before{top:-.25em;color:#666;font-size:1.25em;font-weight:700}.picker--time .picker__button--clear:focus:before,.picker--time .picker__button--clear:hover:before{color:#fff;border-color:#fff}.picker--time .picker__frame{min-width:256px;max-width:320px}.picker--time .picker__box{font-size:1em;background:#f2f2f2;padding:0}@media (min-height:40.125em){.picker--time .picker__box{margin-bottom:5em}} \ No newline at end of file diff --git a/server/risorse/css/joke.css b/server/risorse/css/joke.css new file mode 100644 index 0000000..553d29e --- /dev/null +++ b/server/risorse/css/joke.css @@ -0,0 +1,285 @@ +/* + aprilFools.css + Written by Wes Bos + Modified by Nick Karamoff + I assume no responsibility for angry co-workers or lost productivity + Put these CSS definitons into your co-workers Custom.css file. + + They will be applied to every website they visit as well as their developer tools. + + + +/* + Turn every website upside down + +body { + transform: rotate(180deg); +} + +/* + blur every website for a split second every 30 seconds + +body { + animation: blur 30s infinite; +} + +/* + Spin every Website + +body { + animation: spin 5s linear infinite; +} + +/* + Flip all images upside down + +img { + transform: rotate(180deg); +} + +/* + COMIC SANS EVERYTHING + + +body, p, body p, body div p { + font-family: 'Comic Sans MS', cursive !important; +} + +/* + Spin all images + +img { + animation: spin 1s linear infinite; +} + +/* + Hide every 2nd paragraph element on a page + +p:nth-child(2) { + display:none !important; +} + +/* + Permanent cursor wait + +html { + cursor:wait !important; +} + +/* + hide the cursor all together + +html { + cursor:none !important; +} + +/* + slowly grow text + +p { + animation: grow 120s ease-in; +} + + + + +/* + Spin dev tools round and round + +#-webkit-web-inspector { + -webkit-animation: spin 1s linear infinite; +} + + +/* + Flip dev tools upside down + +#-webkit-web-inspector { + -webkit-transform:rotate(180deg); +} + + +/* Hide the close button +#-webkit-web-inspector .toolbar-item.close-left { + display:none !important; +} + + +/* Make console text all blurry +#-webkit-web-inspector .console-group-messages { + text-shadow: 0 0 3px rgba(0,0,0,.5) !important; +} + +#-webkit-web-inspector .console-error-level .console-message-text, +#-webkit-web-inspector .console-error-level .section .header .title { + text-shadow: 0 0 3px rgba(255,0,0,.5) !important; +} + +#-webkit-web-inspector .console-user-command > .console-message-text { + text-shadow: 0 0 3px rgba(0,128,255,.5) !important; +} + +#-webkit-web-inspector .console-group-messages, +#-webkit-web-inspector .console-user-command > .console-message-text, +#-webkit-web-inspector .console-formatted-null, +#-webkit-web-inspector .console-formatted-undefined, +#-webkit-web-inspector .console-debug-level .console-message-text, +#-webkit-web-inspector .console-error-level .console-message-text, +#-webkit-web-inspector .console-error-level .section .header .title, +#-webkit-web-inspector .console-group-messages .section .header .title, +#-webkit-web-inspector .console-formatted-object, +#-webkit-web-inspector .console-formatted-node, +#-webkit-web-inspector .console-formatted-array, +#-webkit-web-inspector .section .properties .name, +#-webkit-web-inspector .event-properties .name, +#-webkit-web-inspector .console-formatted-object .name, +#-webkit-web-inspector .console-formatted-number, +#-webkit-web-inspector .console-formatted-string, +#-webkit-web-inspector #console-messages a { + color: transparent !important; +} + + + +html { + animation: rainbow 8s infinite; +} + + +/* + Make every website fall over! + +html, body { + height: 100%; +} + +html { + perspective: 1000; +} + +body { + transform-origin: bottom center; + transform: rotateX(-90deg); + animation: fall 1.5s ease-in; +} + + +/* + Insert a phrase every paragraph + +p:before { + content: "YOLO "; +} + + +/* New tricks by Nick Karamoff */ + +/* + Flip every paragraph upside down + +p { + transform: rotate(180deg); +} + + +/* + Flip every header upside down + +h1, h2, h3, h4, h5, h6 { + transform: rotate(180deg); +} + + +/* + Mirror the whole webpage + +body { + transform: scale(-1, 1); +} + +/* + Transparent paragraphs + +p { + color: transparent; +} + +/* + "Very good design" combo (blue bg, red text, Comic Sans) + +body, p, h1, h2, h3, h4, h5, h6 { + color: red; + background-color: blue; + font-family: "Comic Sans", cursive; +} + +/* + Deactivate all the links + +a { + pointer-events: none; + cursor: default; +} + +/* + Unlinkify links (standart formatting, but still clickable) + +a { + text-decoration: none; + color: inherit; + cursor: default; +} + +/* + Links not allowed + +a { + cursor: not-allowed; +} + +/* + Everything's a link! + +body { + cursor: pointer; +} +*/ + + +/* Animations */ + +/* + Everything that is moving is powered from here, so just copy this whole chunk +*/ + +@keyframes blur { + 0% { filter: blur(0px); } + 49% { filter: blur(0px); } + 50% { filter: blur(1px); } + 51% { filter: blur(0px); } + 100% { filter: blur(0px); } +} + +@-webkit-keyframes spin { + 0% { -webkit-transform: rotate(0deg); } + 100% { -webkit-transform: rotate(360deg); } +} + +@keyframes rainbow { + 100% { filter: hue-rotate(360deg); } +} + +@keyframes spin { + 0% { transform: rotate(0deg); } + 100% { transform: rotate(360deg); } +} + +@keyframes fall { + 0% { transform: none; } + 100% { transform: rotateX(-90deg); } +} + +@keyframes grow { + 0% { font-size: none; } + 100% { font-size: 80pt; } +} diff --git a/server/risorse/css/rtl.css b/server/risorse/css/rtl.css new file mode 100644 index 0000000..0b9d69f --- /dev/null +++ b/server/risorse/css/rtl.css @@ -0,0 +1,3 @@ +/*! + * Styling for RTL (right-to-left) languages using pickadate.js + */.picker{direction:rtl}.picker__nav--next{right:auto;left:-1em}.picker__nav--prev{left:auto;right:-1em}.picker__nav--next:before{border-left:0;border-right:.75em solid #000}.picker__nav--prev:before{border-right:0;border-left:.75em solid #000} \ No newline at end of file diff --git a/server/risorse/css/test-codes.css b/server/risorse/css/test-codes.css new file mode 100644 index 0000000..1bf9038 --- /dev/null +++ b/server/risorse/css/test-codes.css @@ -0,0 +1,3 @@ + +.icon-clock:before { content: '\e800'; } /* '' */ +.icon-hourglass:before { content: '\e801'; } /* '' */ \ No newline at end of file diff --git a/server/risorse/css/test-embedded.css b/server/risorse/css/test-embedded.css new file mode 100644 index 0000000..223df68 --- /dev/null +++ b/server/risorse/css/test-embedded.css @@ -0,0 +1,56 @@ +@font-face { + font-family: 'test'; + src: url('../font/test.eot?5796926'); + src: url('../font/test.eot?5796926#iefix') format('embedded-opentype'), + url('../font/test.svg?5796926#test') format('svg'); + font-weight: normal; + font-style: normal; +} +@font-face { + font-family: 'test'; + src: url('data:application/octet-stream;base64,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') format('woff'), + url('data:application/octet-stream;base64,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') format('truetype'); +} +/* Chrome hack: SVG is rendered more smooth in Windozze. 100% magic, uncomment if you need it. */ +/* Note, that will break hinting! In other OS-es font will be not as sharp as it could be */ +/* +@media screen and (-webkit-min-device-pixel-ratio:0) { + @font-face { + font-family: 'test'; + src: url('../font/test.svg?5796926#test') format('svg'); + } +} +*/ + + [class^="icon-"]:before, [class*=" icon-"]:before { + font-family: "test"; + font-style: normal; + font-weight: normal; + speak: none; + + display: inline-block; + text-decoration: inherit; + width: 1em; + margin-right: .2em; + text-align: center; + /* opacity: .8; */ + + /* For safety - reset parent styles, that can break glyph codes*/ + font-variant: normal; + text-transform: none; + + /* fix buttons height, for twitter bootstrap */ + line-height: 1em; + + /* Animation center compensation - margins should be symmetric */ + /* remove if not needed */ + margin-left: .2em; + + /* you can be more comfortable with increased icons size */ + /* font-size: 120%; */ + + /* Uncomment for 3D effect */ + /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */ +} +.icon-clock:before { content: '\e800'; } /* '' */ +.icon-hourglass:before { content: '\e801'; } /* '' */ \ No newline at end of file diff --git a/server/risorse/css/test-ie7-codes.css b/server/risorse/css/test-ie7-codes.css new file mode 100644 index 0000000..d6962ea --- /dev/null +++ b/server/risorse/css/test-ie7-codes.css @@ -0,0 +1,3 @@ + +.icon-clock { *zoom: expression( this.runtimeStyle['zoom'] = '1', this.innerHTML = ' '); } +.icon-hourglass { *zoom: expression( this.runtimeStyle['zoom'] = '1', this.innerHTML = ' '); } \ No newline at end of file diff --git a/server/risorse/css/test-ie7.css b/server/risorse/css/test-ie7.css new file mode 100644 index 0000000..307892f --- /dev/null +++ b/server/risorse/css/test-ie7.css @@ -0,0 +1,14 @@ +[class^="icon-"], [class*=" icon-"] { + font-family: 'test'; + font-style: normal; + font-weight: normal; + + /* fix buttons height */ + line-height: 1em; + + /* you can be more comfortable with increased icons size */ + /* font-size: 120%; */ +} + +.icon-clock { *zoom: expression( this.runtimeStyle['zoom'] = '1', this.innerHTML = ' '); } +.icon-hourglass { *zoom: expression( this.runtimeStyle['zoom'] = '1', this.innerHTML = ' '); } \ No newline at end of file diff --git a/server/risorse/css/test.css b/server/risorse/css/test.css new file mode 100644 index 0000000..814fc1b --- /dev/null +++ b/server/risorse/css/test.css @@ -0,0 +1,59 @@ +@font-face { + font-family: 'test'; + src: url('../font/test.eot?26673982'); + src: url('../font/test.eot?26673982#iefix') format('embedded-opentype'), + url('../font/test.woff2?26673982') format('woff2'), + url('../font/test.woff?26673982') format('woff'), + url('../font/test.ttf?26673982') format('truetype'), + url('../font/test.svg?26673982#test') format('svg'); + font-weight: normal; + font-style: normal; +} +/* Chrome hack: SVG is rendered more smooth in Windozze. 100% magic, uncomment if you need it. */ +/* Note, that will break hinting! In other OS-es font will be not as sharp as it could be */ +/* +@media screen and (-webkit-min-device-pixel-ratio:0) { + @font-face { + font-family: 'test'; + src: url('../font/test.svg?26673982#test') format('svg'); + } +} +*/ + + [class^="icon-"]:before, [class*=" icon-"]:before { + font-family: "test"; + font-style: normal; + font-weight: normal; + speak: none; + + display: inline-block; + text-decoration: inherit; + width: 1em; + margin-right: .2em; + text-align: center; + /* opacity: .8; */ + + /* For safety - reset parent styles, that can break glyph codes*/ + font-variant: normal; + text-transform: none; + + /* fix buttons height, for twitter bootstrap */ + line-height: 1em; + + /* Animation center compensation - margins should be symmetric */ + /* remove if not needed */ + margin-left: .2em; + + /* you can be more comfortable with increased icons size */ + /* font-size: 120%; */ + + /* Font smoothing. That was taken from TWBS */ + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; + + /* Uncomment for 3D effect */ + /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */ +} + +.icon-clock:before { content: '\e800'; } /* '' */ +.icon-hourglass:before { content: '\e801'; } /* '' */ \ No newline at end of file diff --git a/server/risorse/font/test.eot b/server/risorse/font/test.eot new file mode 100644 index 0000000..516e50a Binary files /dev/null and b/server/risorse/font/test.eot differ diff --git a/server/risorse/font/test.svg b/server/risorse/font/test.svg new file mode 100644 index 0000000..03fb5be --- /dev/null +++ b/server/risorse/font/test.svg @@ -0,0 +1,14 @@ + + + +Copyright (C) 2018 by original authors @ fontello.com + + + + + + + + + + \ No newline at end of file diff --git a/server/risorse/font/test.ttf b/server/risorse/font/test.ttf new file mode 100644 index 0000000..1105419 Binary files /dev/null and b/server/risorse/font/test.ttf differ diff --git a/server/risorse/font/test.woff b/server/risorse/font/test.woff new file mode 100644 index 0000000..b46c0fb Binary files /dev/null and b/server/risorse/font/test.woff differ diff --git a/server/risorse/font/test.woff2 b/server/risorse/font/test.woff2 new file mode 100644 index 0000000..08e87db Binary files /dev/null and b/server/risorse/font/test.woff2 differ diff --git a/server/risorse/images/LoaderIcon.gif b/server/risorse/images/LoaderIcon.gif new file mode 100644 index 0000000..fe378da Binary files /dev/null and b/server/risorse/images/LoaderIcon.gif differ diff --git a/server/risorse/images/cascoNero.png b/server/risorse/images/cascoNero.png new file mode 100644 index 0000000..92a5516 Binary files /dev/null and b/server/risorse/images/cascoNero.png differ diff --git a/server/risorse/images/cascoRosso.png b/server/risorse/images/cascoRosso.png new file mode 100644 index 0000000..8504ec9 Binary files /dev/null and b/server/risorse/images/cascoRosso.png differ diff --git a/server/risorse/images/favicon.ico b/server/risorse/images/favicon.ico new file mode 100644 index 0000000..f24c4dc Binary files /dev/null and b/server/risorse/images/favicon.ico differ diff --git a/server/risorse/images/fiocco.gif b/server/risorse/images/fiocco.gif new file mode 100644 index 0000000..8861daf Binary files /dev/null and b/server/risorse/images/fiocco.gif differ diff --git a/server/risorse/images/flake.png b/server/risorse/images/flake.png new file mode 100644 index 0000000..b8e3acc Binary files /dev/null and b/server/risorse/images/flake.png differ diff --git a/server/risorse/images/logo.jpg b/server/risorse/images/logo.jpg new file mode 100644 index 0000000..e36b0e7 Binary files /dev/null and b/server/risorse/images/logo.jpg differ diff --git a/server/risorse/images/logo_home.png b/server/risorse/images/logo_home.png new file mode 100644 index 0000000..512429b Binary files /dev/null and b/server/risorse/images/logo_home.png differ diff --git a/server/risorse/images/manifest.json b/server/risorse/images/manifest.json new file mode 100644 index 0000000..87892fb --- /dev/null +++ b/server/risorse/images/manifest.json @@ -0,0 +1,52 @@ +{ + "name": "Allerta Vvf Volontari DARFO", + "short_name": "Allerta", + "theme_color": "#ff0000", + "background_color": "#4181b4", + "display": "standalone", + "Scope": "/", + "start_url": "/?utm_source=a2hs", + "icons": [ + { + "src": "images/icons/icon-72x72.png", + "sizes": "72x72", + "type": "image/png" + }, + { + "src": "images/icons/icon-96x96.png", + "sizes": "96x96", + "type": "image/png" + }, + { + "src": "images/icons/icon-128x128.png", + "sizes": "128x128", + "type": "image/png" + }, + { + "src": "images/icons/icon-144x144.png", + "sizes": "144x144", + "type": "image/png" + }, + { + "src": "images/icons/icon-152x152.png", + "sizes": "152x152", + "type": "image/png" + }, + { + "src": "images/icons/icon-192x192.png", + "sizes": "192x192", + "type": "image/png" + }, + { + "src": "images/icons/icon-384x384.png", + "sizes": "384x384", + "type": "image/png" + }, + { + "src": "images/icons/icon-512x512.png", + "sizes": "512x512", + "type": "image/png" + } + ], + "splash_pages": null +} diff --git a/server/risorse/images/manifest_standalone.json b/server/risorse/images/manifest_standalone.json new file mode 100644 index 0000000..007e0f5 --- /dev/null +++ b/server/risorse/images/manifest_standalone.json @@ -0,0 +1,52 @@ +{ + "name": "Allerta Vvf Volontari DARFO", + "short_name": "Allerta", + "theme_color": "#ff0000", + "background_color": "#4181b4", + "display": "standalone", + "Scope": "/", + "start_url": "/?utm_source=a2hs", + "icons": [ + { + "src": "", + "sizes": "72x72", + "type": "image/png" + }, + { + "src": "", + "sizes": "96x96", + "type": "image/png" + }, + { + "src": "", + "sizes": "128x128", + "type": "image/png" + }, + { + "src": "", + "sizes": "144x144", + "type": "image/png" + }, + { + "src": "", + "sizes": "152x152", + "type": "image/png" + }, + { + "src": "", + "sizes": "192x192", + "type": "image/png" + }, + { + "src": "", + "sizes": "384x384", + "type": "image/png" + }, + { + "src": "", + "sizes": "512x512", + "type": "image/png" + } + ], + "splash_pages": null +} diff --git a/server/risorse/images/nonono.gif b/server/risorse/images/nonono.gif new file mode 100644 index 0000000..46b6f2f Binary files /dev/null and b/server/risorse/images/nonono.gif differ diff --git a/server/risorse/images/volante.png b/server/risorse/images/volante.png new file mode 100644 index 0000000..b24f79a Binary files /dev/null and b/server/risorse/images/volante.png differ diff --git a/server/risorse/js/cache.js b/server/risorse/js/cache.js new file mode 100644 index 0000000..d108de2 --- /dev/null +++ b/server/risorse/js/cache.js @@ -0,0 +1,26 @@ +$(document).ready(function(){ + $.get("risorse/ajax/ajax_cache.php", function(data, status){ + console.log(data); + console.log(data.vigili); + console.log(data.interventi); + console.log(data.esercitazioni); + var db = new Dexie("offline"); + console.log(db.tables.length); + if(db.tables.length !== 0){ + db.vigilil.clear(); + db.interventi.clear(); + console.log("cleaned"); + } + db.version(1).stores({ + vigili: '++id,nome,disponibile,caposquadra,autista,telefono,interventi,esercitazioni,online,minuti_dispo,immagine', + interventi: '++id,data,codice,uscita,rientro,capo,autisti,personale,luogo,note,tipo,incrementa,inseritoda' + }); + $.each( data.vigili, function( key, val ) { + db.vigili.put(val); + }); + $.each( data.interventi, function( key, val ) { + db.interventi.put(val); + }); + window.db = db; + }, "json"); +}); \ No newline at end of file diff --git a/server/risorse/js/legacy.js b/server/risorse/js/legacy.js new file mode 100644 index 0000000..406af26 --- /dev/null +++ b/server/risorse/js/legacy.js @@ -0,0 +1,10 @@ +/*! + * Legacy browser support + */ +[].map||(Array.prototype.map=function(a,b){for(var c=this,d=c.length,e=new Array(d),f=0;f>>0;if("function"!=typeof a)throw new TypeError;for(var d=[],e=arguments[1],f=0;f>>0;if(0===c)return-1;var d=0;if(arguments.length>1&&(d=Number(arguments[1]),d!=d?d=0:0!==d&&d!=1/0&&d!=-1/0&&(d=(d>0||-1)*Math.floor(Math.abs(d)))),d>=c)return-1;for(var e=d>=0?d:Math.max(c-Math.abs(d),0);e + * Available under the MIT License + * http://blog.stevenlevithan.com/archives/cross-browser-split + */ +var nativeSplit=String.prototype.split,compliantExecNpcg=void 0===/()??/.exec("")[1];String.prototype.split=function(a,b){var c=this;if("[object RegExp]"!==Object.prototype.toString.call(a))return nativeSplit.call(c,a,b);var d,e,f,g,h=[],i=(a.ignoreCase?"i":"")+(a.multiline?"m":"")+(a.extended?"x":"")+(a.sticky?"y":""),j=0;for(a=new RegExp(a.source,i+"g"),c+="",compliantExecNpcg||(d=new RegExp("^"+a.source+"$(?!\\s)",i)),b=void 0===b?-1>>>0:b>>>0;(e=a.exec(c))&&!((f=e.index+e[0].length)>j&&(h.push(c.slice(j,e.index)),!compliantExecNpcg&&e.length>1&&e[0].replace(d,function(){for(var a=1;a1&&e.index=b));)a.lastIndex===e.index&&a.lastIndex++;return j===c.length?!g&&a.test("")||h.push(""):h.push(c.slice(j)),h.length>b?h.slice(0,b):h}; \ No newline at end of file diff --git a/server/risorse/js/picker.date.js b/server/risorse/js/picker.date.js new file mode 100644 index 0000000..c526307 --- /dev/null +++ b/server/risorse/js/picker.date.js @@ -0,0 +1,5 @@ +/*! + * Date picker for pickadate.js v3.6.4 + * http://amsul.github.io/pickadate.js/date.htm + */ +!function(a){"function"==typeof define&&define.amd?define(["./picker","jquery"],a):"object"==typeof exports?module.exports=a(require("./picker.js"),require("jquery")):a(Picker,jQuery)}(function(a,b){function c(a,b){var c=this,d=a.$node[0],e=d.value,f=a.$node.data("value"),g=f||e,h=f?b.formatSubmit:b.format,i=function(){return d.currentStyle?"rtl"==d.currentStyle.direction:"rtl"==getComputedStyle(a.$root[0]).direction};c.settings=b,c.$node=a.$node,c.queue={min:"measure create",max:"measure create",now:"now create",select:"parse create validate",highlight:"parse navigate create validate",view:"parse create validate viewset",disable:"deactivate",enable:"activate"},c.item={},c.item.clear=null,c.item.disable=(b.disable||[]).slice(0),c.item.enable=-function(a){return!0===a[0]?a.shift():-1}(c.item.disable),c.set("min",b.min).set("max",b.max).set("now"),g?c.set("select",g,{format:h,defaultValue:!0}):c.set("select",null).set("highlight",c.item.now),c.key={40:7,38:-7,39:function(){return i()?-1:1},37:function(){return i()?1:-1},go:function(a){var b=c.item.highlight,d=new Date(b.year,b.month,b.date+a);c.set("highlight",d,{interval:a}),this.render()}},a.on("render",function(){a.$root.find("."+b.klass.selectMonth).on("change",function(){var c=this.value;c&&(a.set("highlight",[a.get("view").year,c,a.get("highlight").date]),a.$root.find("."+b.klass.selectMonth).trigger("focus"))}),a.$root.find("."+b.klass.selectYear).on("change",function(){var c=this.value;c&&(a.set("highlight",[c,a.get("view").month,a.get("highlight").date]),a.$root.find("."+b.klass.selectYear).trigger("focus"))})},1).on("open",function(){var d="";c.disabled(c.get("now"))&&(d=":not(."+b.klass.buttonToday+")"),a.$root.find("button"+d+", select").attr("disabled",!1)},1).on("close",function(){a.$root.find("button, select").attr("disabled",!0)},1)}var d=7,e=a._;c.prototype.set=function(a,b,c){var d=this,e=d.item;return null===b?("clear"==a&&(a="select"),e[a]=b,d):(e["enable"==a?"disable":"flip"==a?"enable":a]=d.queue[a].split(" ").map(function(e){return b=d[e](a,b,c)}).pop(),"select"==a?d.set("highlight",e.select,c):"highlight"==a?d.set("view",e.highlight,c):a.match(/^(flip|min|max|disable|enable)$/)&&(e.select&&d.disabled(e.select)&&d.set("select",e.select,c),e.highlight&&d.disabled(e.highlight)&&d.set("highlight",e.highlight,c)),d)},c.prototype.get=function(a){return this.item[a]},c.prototype.create=function(a,c,d){var f,g=this;return c=void 0===c?a:c,c==-1/0||c==1/0?f=c:b.isPlainObject(c)&&e.isInteger(c.pick)?c=c.obj:b.isArray(c)?(c=new Date(c[0],c[1],c[2]),c=e.isDate(c)?c:g.create().obj):c=e.isInteger(c)||e.isDate(c)?g.normalize(new Date(c),d):g.now(a,c,d),{year:f||c.getFullYear(),month:f||c.getMonth(),date:f||c.getDate(),day:f||c.getDay(),obj:f||c,pick:f||c.getTime()}},c.prototype.createRange=function(a,c){var d=this,f=function(a){return!0===a||b.isArray(a)||e.isDate(a)?d.create(a):a};return e.isInteger(a)||(a=f(a)),e.isInteger(c)||(c=f(c)),e.isInteger(a)&&b.isPlainObject(c)?a=[c.year,c.month,c.date+a]:e.isInteger(c)&&b.isPlainObject(a)&&(c=[a.year,a.month,a.date+c]),{from:f(a),to:f(c)}},c.prototype.withinRange=function(a,b){return a=this.createRange(a.from,a.to),b.pick>=a.from.pick&&b.pick<=a.to.pick},c.prototype.overlapRanges=function(a,b){var c=this;return a=c.createRange(a.from,a.to),b=c.createRange(b.from,b.to),c.withinRange(a,b.from)||c.withinRange(a,b.to)||c.withinRange(b,a.from)||c.withinRange(b,a.to)},c.prototype.now=function(a,b,c){return b=new Date,c&&c.rel&&b.setDate(b.getDate()+c.rel),this.normalize(b,c)},c.prototype.navigate=function(a,c,d){var e,f,g,h,i=b.isArray(c),j=b.isPlainObject(c),k=this.item.view;if(i||j){for(j?(f=c.year,g=c.month,h=c.date):(f=+c[0],g=+c[1],h=+c[2]),d&&d.nav&&k&&k.month!==g&&(f=k.year,g=k.month),e=new Date(f,g+(d&&d.nav?d.nav:0),1),f=e.getFullYear(),g=e.getMonth();new Date(f,g,h).getMonth()!==g;)h-=1;c=[f,g,h]}return c},c.prototype.normalize=function(a){return a.setHours(0,0,0,0),a},c.prototype.measure=function(a,b){var c=this;return e.isInteger(b)?b=c.now(a,b,{rel:b}):b?"string"==typeof b&&(b=c.parse(a,b)):b="min"==a?-1/0:1/0,b},c.prototype.viewset=function(a,b){return this.create([b.year,b.month,1])},c.prototype.validate=function(a,c,d){var f,g,h,i,j=this,k=c,l=d&&d.interval?d.interval:1,m=-1===j.item.enable,n=j.item.min,o=j.item.max,p=m&&j.item.disable.filter(function(a){if(b.isArray(a)){var d=j.create(a).pick;dc.pick&&(g=!0)}return e.isInteger(a)}).length;if((!d||!d.nav&&!d.defaultValue)&&(!m&&j.disabled(c)||m&&j.disabled(c)&&(p||f||g)||!m&&(c.pick<=n.pick||c.pick>=o.pick)))for(m&&!p&&(!g&&l>0||!f&&l<0)&&(l*=-1);j.disabled(c)&&(Math.abs(l)>1&&(c.monthk.month)&&(c=k,l=l>0?1:-1),c.pick<=n.pick?(h=!0,l=1,c=j.create([n.year,n.month,n.date+(c.pick===n.pick?0:-1)])):c.pick>=o.pick&&(i=!0,l=-1,c=j.create([o.year,o.month,o.date+(c.pick===o.pick?0:1)])),!h||!i);)c=j.create([c.year,c.month,c.date+l]);return c},c.prototype.disabled=function(a){var c=this,d=c.item.disable.filter(function(d){return e.isInteger(d)?a.day===(c.settings.firstDay?d:d-1)%7:b.isArray(d)||e.isDate(d)?a.pick===c.create(d).pick:b.isPlainObject(d)?c.withinRange(d,a):void 0});return d=d.length&&!d.filter(function(a){return b.isArray(a)&&"inverted"==a[3]||b.isPlainObject(a)&&a.inverted}).length,-1===c.item.enable?!d:d||a.pickc.item.max.pick},c.prototype.parse=function(a,b,c){var d=this,f={};return b&&"string"==typeof b?(c&&c.format||(c=c||{},c.format=d.settings.format),d.formats.toArray(c.format).map(function(a){var c=d.formats[a],g=c?e.trigger(c,d,[b,f]):a.replace(/^!/,"").length;c&&(f[a]=b.substr(0,g)),b=b.substr(g)}),[f.yyyy||f.yy,+(f.mm||f.m)-1,f.dd||f.d]):b},c.prototype.formats=function(){function a(a,b,c){var d=a.match(/[^\x00-\x7F]+|\w+/)[0];return c.mm||c.m||(c.m=b.indexOf(d)+1),d.length}function b(a){return a.match(/\w+/)[0].length}return{d:function(a,b){return a?e.digits(a):b.date},dd:function(a,b){return a?2:e.lead(b.date)},ddd:function(a,c){return a?b(a):this.settings.weekdaysShort[c.day]},dddd:function(a,c){return a?b(a):this.settings.weekdaysFull[c.day]},m:function(a,b){return a?e.digits(a):b.month+1},mm:function(a,b){return a?2:e.lead(b.month+1)},mmm:function(b,c){var d=this.settings.monthsShort;return b?a(b,d,c):d[c.month]},mmmm:function(b,c){var d=this.settings.monthsFull;return b?a(b,d,c):d[c.month]},yy:function(a,b){return a?2:(""+b.year).slice(2)},yyyy:function(a,b){return a?4:b.year},toArray:function(a){return a.split(/(d{1,4}|m{1,4}|y{4}|yy|!.)/g)},toString:function(a,b){var c=this;return c.formats.toArray(a).map(function(a){return e.trigger(c.formats[a],c,[0,b])||a.replace(/^!/,"")}).join("")}}}(),c.prototype.isDateExact=function(a,c){var d=this;return e.isInteger(a)&&e.isInteger(c)||"boolean"==typeof a&&"boolean"==typeof c?a===c:(e.isDate(a)||b.isArray(a))&&(e.isDate(c)||b.isArray(c))?d.create(a).pick===d.create(c).pick:!(!b.isPlainObject(a)||!b.isPlainObject(c))&&d.isDateExact(a.from,c.from)&&d.isDateExact(a.to,c.to)},c.prototype.isDateOverlap=function(a,c){var d=this,f=d.settings.firstDay?1:0;return e.isInteger(a)&&(e.isDate(c)||b.isArray(c))?(a=a%7+f)===d.create(c).day+1:e.isInteger(c)&&(e.isDate(a)||b.isArray(a))?(c=c%7+f)===d.create(a).day+1:!(!b.isPlainObject(a)||!b.isPlainObject(c))&&d.overlapRanges(a,c)},c.prototype.flipEnable=function(a){var b=this.item;b.enable=a||(-1==b.enable?1:-1)},c.prototype.deactivate=function(a,c){var d=this,f=d.item.disable.slice(0);return"flip"==c?d.flipEnable():!1===c?(d.flipEnable(1),f=[]):!0===c?(d.flipEnable(-1),f=[]):c.map(function(a){for(var c,g=0;g=m.year&&j.month>=m.month||!a&&j.year<=l.year&&j.month<=l.month?" "+c.klass.navDisabled:""),"data-nav="+(a||-1)+" "+e.ariaAttr({role:"button",controls:b.$node[0].id+"_table"})+' title="'+(a?c.labelMonthNext:c.labelMonthPrev)+'"')},p=function(){var d=c.showMonthsShort?c.monthsShort:c.monthsFull;return c.selectMonths?e.node("select",e.group({min:0,max:11,i:1,node:"option",item:function(a){return[d[a],0,"value="+a+(j.month==a?" selected":"")+(j.year==l.year&&am.month?" disabled":"")]}}),c.klass.selectMonth,(a?"":"disabled")+" "+e.ariaAttr({controls:b.$node[0].id+"_table"})+' title="'+c.labelMonthSelect+'"'):e.node("div",d[j.month],c.klass.month)},q=function(){var d=j.year,f=!0===c.selectYears?5:~~(c.selectYears/2);if(f){var g=l.year,h=m.year,i=d-f,k=d+f;if(g>i&&(k+=g-i,i=g),ho?o:n,k=h}return e.node("select",e.group({min:i,max:k,i:1,node:"option",item:function(a){return[a,0,"value="+a+(d==a?" selected":"")]}}),c.klass.selectYear,(a?"":"disabled")+" "+e.ariaAttr({controls:b.$node[0].id+"_table"})+' title="'+c.labelYearSelect+'"')}return e.node("div",d,c.klass.year)};return e.node("div",(c.selectYears?q()+p():p()+q())+o()+o(1),c.klass.header)+e.node("table",n+e.node("tbody",e.group({min:0,max:5,i:1,node:"tr",item:function(a){var f=c.firstDay&&0===b.create([j.year,j.month,1]).day?-7:0;return[e.group({min:d*a-j.day+f+1,max:function(){return this.min+d-1},i:1,node:"td",item:function(a){a=b.create([j.year,j.month,a+(c.firstDay?1:0)]);var d=h&&h.pick==a.pick,f=i&&i.pick==a.pick,n=k&&b.disabled(a)||a.pickm.pick,o=e.trigger(b.formats.toString,b,[c.format,a]);return[e.node("div",a.date,function(b){return b.push(j.month==a.month?c.klass.infocus:c.klass.outfocus),g.pick==a.pick&&b.push(c.klass.now),d&&b.push(c.klass.selected),f&&b.push(c.klass.highlighted),n&&b.push(c.klass.disabled),b.join(" ")}([c.klass.day]),"data-pick="+a.pick+" "+e.ariaAttr({role:"gridcell",label:o,selected:!(!d||b.$node.val()!==o)||null,activedescendant:!!f||null,disabled:!!n||null})),"",e.ariaAttr({role:"presentation"})]}})]}})),c.klass.table,'id="'+b.$node[0].id+'_table" '+e.ariaAttr({role:"grid",controls:b.$node[0].id,readonly:!0}))+e.node("div",e.node("button",c.today,c.klass.buttonToday,"type=button data-pick="+g.pick+(a&&!b.disabled(g)?"":" disabled")+" "+e.ariaAttr({controls:b.$node[0].id}))+e.node("button",c.clear,c.klass.buttonClear,"type=button data-clear=1"+(a?"":" disabled")+" "+e.ariaAttr({controls:b.$node[0].id}))+e.node("button",c.close,c.klass.buttonClose,"type=button data-close=true "+(a?"":" disabled")+" "+e.ariaAttr({controls:b.$node[0].id})),c.klass.footer)},c.defaults=function(a){return{labelMonthNext:"Next month",labelMonthPrev:"Previous month",labelMonthSelect:"Select a month",labelYearSelect:"Select a year",monthsFull:["January","February","March","April","May","June","July","August","September","October","November","December"],monthsShort:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],weekdaysFull:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],weekdaysShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],today:"Today",clear:"Clear",close:"Close",closeOnSelect:!0,closeOnClear:!0,updateInput:!0,format:"d mmmm, yyyy",klass:{table:a+"table",header:a+"header",navPrev:a+"nav--prev",navNext:a+"nav--next",navDisabled:a+"nav--disabled",month:a+"month",year:a+"year",selectMonth:a+"select--month",selectYear:a+"select--year",weekdays:a+"weekday",day:a+"day",disabled:a+"day--disabled",selected:a+"day--selected",highlighted:a+"day--highlighted",now:a+"day--today",infocus:a+"day--infocus",outfocus:a+"day--outfocus",footer:a+"footer",buttonClear:a+"button--clear",buttonToday:a+"button--today",buttonClose:a+"button--close"}}}(a.klasses().picker+"__"),a.extend("pickadate",c)}); \ No newline at end of file diff --git a/server/risorse/js/picker.js b/server/risorse/js/picker.js new file mode 100644 index 0000000..eaa2de3 --- /dev/null +++ b/server/risorse/js/picker.js @@ -0,0 +1,7 @@ +/*! + * pickadate.js v3.6.4, 2019/05/25 + * By Amsul, http://amsul.ca + * Hosted on http://amsul.github.io/pickadate.js + * Licensed under MIT + */ +!function(a){"function"==typeof define&&define.amd?define("picker",["jquery"],a):"object"==typeof exports?module.exports=a(require("jquery")):"object"==typeof window?window.Picker=a(jQuery):this.Picker=a(jQuery)}(function(a){function b(g,h,j,l){function n(){return b._.node("div",b._.node("div",b._.node("div",b._.node("div",B.component.nodes(w.open),y.box),y.wrap),y.frame),y.holder,'tabindex="-1"')}function o(){z.data(h,B).addClass(y.input).val(z.data("value")?B.get("select",x.format):g.value).on("focus."+w.id+" click."+w.id,function(a){a.preventDefault(),B.open()}).on("mousedown",function(){w.handlingOpen=!0;var b=function(){setTimeout(function(){a(document).off("mouseup",b),w.handlingOpen=!1},0)};a(document).on("mouseup",b)}),x.editable||z.on("keydown."+w.id,u),f(g,{haspopup:!0,expanded:!1,readonly:!1,owns:g.id+"_root"})}function p(){f(B.$root[0],"hidden",!0)}function q(){B.$holder.on({keydown:u,"focus.toOpen":t,blur:function(){z.removeClass(y.target)},focusin:function(a){B.$root.removeClass(y.focused),a.stopPropagation()},"mousedown click":function(b){var c=e(b,g);c!=B.$holder[0]&&(b.stopPropagation(),"mousedown"!=b.type||a(c).is("input, select, textarea, button, option")||(b.preventDefault(),B.$holder.eq(0).focus()))}}).on("click","[data-pick], [data-nav], [data-clear], [data-close]",function(){var b=a(this),c=b.data(),d=b.hasClass(y.navDisabled)||b.hasClass(y.disabled),e=i();e=e&&(e.type||e.href?e:null),(d||e&&!a.contains(B.$root[0],e))&&B.$holder.eq(0).focus(),!d&&c.nav?B.set("highlight",B.component.item.highlight,{nav:c.nav}):!d&&"pick"in c?(B.set("select",c.pick),x.closeOnSelect&&B.close(!0)):c.clear?(B.clear(),x.closeOnClear&&B.close(!0)):c.close&&B.close(!0)})}function r(){var b;!0===x.hiddenName?(b=g.name,g.name=""):(b=["string"==typeof x.hiddenPrefix?x.hiddenPrefix:"","string"==typeof x.hiddenSuffix?x.hiddenSuffix:"_submit"],b=b[0]+g.name+b[1]),B._hidden=a('")[0],z.on("change."+w.id,function(){B._hidden.value=g.value?B.get("select",x.formatSubmit):""})}function s(){v&&m?B.$holder.find("."+y.frame).one("transitionend",function(){B.$holder.eq(0).focus()}):setTimeout(function(){B.$holder.eq(0).focus()},0)}function t(a){a.stopPropagation(),z.addClass(y.target),B.$root.addClass(y.focused),B.open()}function u(a){var b=a.keyCode,c=/^(8|46)$/.test(b);if(27==b)return B.close(!0),!1;(32==b||c||!w.open&&B.component.key[b])&&(a.preventDefault(),a.stopPropagation(),c?B.clear().close():B.open())}if(!g)return b;var v=!1,w={id:g.id||"P"+Math.abs(~~(Math.random()*new Date)),handlingOpen:!1},x=j?a.extend(!0,{},j.defaults,l):l||{},y=a.extend({},b.klasses(),x.klass),z=a(g),A=function(){return this.start()},B=A.prototype={constructor:A,$node:z,start:function(){return w&&w.start?B:(w.methods={},w.start=!0,w.open=!1,w.type=g.type,g.autofocus=g==i(),g.readOnly=!x.editable,g.id=g.id||w.id,"text"!=g.type&&(g.type="text"),B.component=new j(B,x),B.$root=a('
'),p(),B.$holder=a(n()).appendTo(B.$root),q(),x.formatSubmit&&r(),o(),x.containerHidden?a(x.containerHidden).append(B._hidden):z.after(B._hidden),x.container?a(x.container).append(B.$root):z.after(B.$root),B.on({start:B.component.onStart,render:B.component.onRender,stop:B.component.onStop,open:B.component.onOpen,close:B.component.onClose,set:B.component.onSet}).on({start:x.onStart,render:x.onRender,stop:x.onStop,open:x.onOpen,close:x.onClose,set:x.onSet}),v=c(B.$holder[0]),g.autofocus&&B.open(),B.trigger("start").trigger("render"))},render:function(b){return b?(B.$holder=a(n()),q(),B.$root.html(B.$holder)):B.$root.find("."+y.box).html(B.component.nodes(w.open)),B.trigger("render")},stop:function(){return w.start?(B.close(),B._hidden&&B._hidden.parentNode.removeChild(B._hidden),B.$root.remove(),z.removeClass(y.input).removeData(h),setTimeout(function(){z.off("."+w.id)},0),g.type=w.type,g.readOnly=!1,B.trigger("stop"),w.methods={},w.start=!1,B):B},open:function(c){return w.open?B:(z.addClass(y.active),f(g,"expanded",!0),setTimeout(function(){B.$root.addClass(y.opened),f(B.$root[0],"hidden",!1)},0),!1!==c&&(w.open=!0,v&&a("body").css("overflow","hidden").css("padding-right","+="+d()),s(),k.on("click."+w.id+" focusin."+w.id,function(a){if(!w.handlingOpen){var b=e(a,g);a.isSimulated||b==g||b==document||3==a.which||B.close(b===B.$holder[0])}}).on("keydown."+w.id,function(c){var d=c.keyCode,f=B.component.key[d],h=e(c,g);27==d?B.close(!0):h!=B.$holder[0]||!f&&13!=d?a.contains(B.$root[0],h)&&13==d&&(c.preventDefault(),h.click()):(c.preventDefault(),f?b._.trigger(B.component.key.go,B,[b._.trigger(f)]):B.$root.find("."+y.highlighted).hasClass(y.disabled)||(B.set("select",B.component.item.highlight),x.closeOnSelect&&B.close(!0)))})),B.trigger("open"))},close:function(b){return b&&(x.editable?g.focus():(B.$holder.off("focus.toOpen").focus(),setTimeout(function(){B.$holder.on("focus.toOpen",t)},0))),z.removeClass(y.active),f(g,"expanded",!1),setTimeout(function(){B.$root.removeClass(y.opened+" "+y.focused),f(B.$root[0],"hidden",!0)},0),w.open?(w.open=!1,v&&a("body").css("overflow","").css("padding-right","-="+d()),k.off("."+w.id),B.trigger("close")):B},clear:function(a){return B.set("clear",null,a)},set:function(b,c,d){var e,f,g=a.isPlainObject(b),h=g?b:{};if(d=g&&a.isPlainObject(c)?c:d||{},b){g||(h[b]=c);for(e in h)f=h[e],e in B.component.item&&(void 0===f&&(f=null),B.component.set(e,f,d)),"select"!=e&&"clear"!=e||!x.updateInput||z.val("clear"==e?"":B.get(e,x.format)).trigger("change");B.render()}return d.muted?B:B.trigger("set",h)},get:function(a,c){if(a=a||"value",null!=w[a])return w[a];if("valueSubmit"==a){if(B._hidden)return B._hidden.value;a="value"}if("value"==a)return g.value;if(a in B.component.item){if("string"==typeof c){var d=B.component.get(a);return d?b._.trigger(B.component.formats.toString,B.component,[c,d]):""}return B.component.get(a)}},on:function(b,c,d){var e,f,g=a.isPlainObject(b),h=g?b:{};if(b){g||(h[b]=c);for(e in h)f=h[e],d&&(e="_"+e),w.methods[e]=w.methods[e]||[],w.methods[e].push(f)}return B},off:function(){var a,b,c=arguments;for(a=0,namesCount=c.length;a').appendTo("body"),c=b[0].offsetWidth;b.css("overflow","scroll");var d=a('
').appendTo(b),e=d[0].offsetWidth;return b.remove(),c-e}function e(a,b){var c=[];return a.path&&(c=a.path),a.originalEvent&&a.originalEvent.path&&(c=a.originalEvent.path),c&&c.length>0?b&&c.indexOf(b)>=0?b:c[0]:a.target}function f(b,c,d){if(a.isPlainObject(c))for(var e in c)g(b,e,c[e]);else g(b,c,d)}function g(a,b,c){a.setAttribute(("role"==b?"":"aria-")+b,c)}function h(b,c){a.isPlainObject(b)||(b={attribute:c}),c="";for(var d in b){var e=("role"==d?"":"aria-")+d;c+=null==b[d]?"":e+'="'+b[d]+'"'}return c}function i(){try{return document.activeElement}catch(a){}}var j=a(window),k=a(document),l=a(document.documentElement),m=null!=document.documentElement.style.transition;return b.klasses=function(a){return a=a||"picker",{picker:a,opened:a+"--opened",focused:a+"--focused",input:a+"__input",active:a+"__input--active",target:a+"__input--target",holder:a+"__holder",frame:a+"__frame",wrap:a+"__wrap",box:a+"__box"}},b._={group:function(a){for(var c,d="",e=b._.trigger(a.min,a);e<=b._.trigger(a.max,a,[e]);e+=a.i)c=b._.trigger(a.item,a,[e]),d+=b._.node(a.node,c[0],c[1],c[2]);return d},node:function(b,c,d,e){return c?(c=a.isArray(c)?c.join(""):c,d=d?' class="'+d+'"':"",e=e?" "+e:"","<"+b+d+e+">"+c+""):""},lead:function(a){return(a<10?"0":"")+a},trigger:function(a,b,c){return"function"==typeof a?a.apply(b,c||[]):a},digits:function(a){return/\d/.test(a[1])?2:1},isDate:function(a){return{}.toString.call(a).indexOf("Date")>-1&&this.isInteger(a.getDate())},isInteger:function(a){return{}.toString.call(a).indexOf("Number")>-1&&a%1==0},ariaAttr:h},b.extend=function(c,d){a.fn[c]=function(e,f){var g=this.data(c);return"picker"==e?g:g&&"string"==typeof e?b._.trigger(g[e],g,[f]):this.each(function(){a(this).data(c)||new b(this,c,d,e)})},a.fn[c].defaults=d.defaults},b}); \ No newline at end of file diff --git a/server/risorse/js/picker.time.js b/server/risorse/js/picker.time.js new file mode 100644 index 0000000..4c06602 --- /dev/null +++ b/server/risorse/js/picker.time.js @@ -0,0 +1,5 @@ +/*! + * Time picker for pickadate.js v3.6.4 + * http://amsul.github.io/pickadate.js/time.htm + */ +!function(a){"function"==typeof define&&define.amd?define(["./picker","jquery"],a):"object"==typeof exports?module.exports=a(require("./picker.js"),require("jquery")):a(Picker,jQuery)}(function(a,b){function c(a,b){var c=this,d=a.$node[0].value,e=a.$node.data("value"),f=e||d,g=e?b.formatSubmit:b.format;c.settings=b,c.$node=a.$node,c.queue={interval:"i",min:"measure create",max:"measure create",now:"now create",select:"parse create validate",highlight:"parse create validate",view:"parse create validate",disable:"deactivate",enable:"activate"},c.item={},c.item.clear=null,c.item.interval=b.interval||30,c.item.disable=(b.disable||[]).slice(0),c.item.enable=-function(a){return!0===a[0]?a.shift():-1}(c.item.disable),c.set("min",b.min).set("max",b.max).set("now"),f?c.set("select",f,{format:g}):c.set("select",null).set("highlight",c.item.now),c.key={40:1,38:-1,39:1,37:-1,go:function(a){c.set("highlight",c.item.highlight.pick+a*c.item.interval,{interval:a*c.item.interval}),this.render()}},a.on("render",function(){var c=a.$root.children(),d=c.find("."+b.klass.viewset),e=function(a){return["webkit","moz","ms","o",""].map(function(b){return(b?"-"+b+"-":"")+a})},f=function(a,b){e("transform").map(function(c){a.css(c,b)}),e("transition").map(function(c){a.css(c,b)})};d.length&&(f(c,"none"),c[0].scrollTop=~~d.position().top-2*d[0].clientHeight,f(c,""))},1).on("open",function(){a.$root.find("button").attr("disabled",!1)},1).on("close",function(){a.$root.find("button").attr("disabled",!0)},1)}var d=24,e=60,f=12,g=d*e,h=a._;c.prototype.set=function(a,b,c){var d=this,e=d.item;return null===b?("clear"==a&&(a="select"),e[a]=b,d):(e["enable"==a?"disable":"flip"==a?"enable":a]=d.queue[a].split(" ").map(function(e){return b=d[e](a,b,c)}).pop(),"select"==a?d.set("highlight",e.select,c):"highlight"==a?d.set("view",e.highlight,c):"interval"==a?d.set("min",e.min,c).set("max",e.max,c):a.match(/^(flip|min|max|disable|enable)$/)&&(e.select&&d.disabled(e.select)&&d.set("select",b,c),e.highlight&&d.disabled(e.highlight)&&d.set("highlight",b,c),"min"==a&&d.set("max",e.max,c)),d)},c.prototype.get=function(a){return this.item[a]},c.prototype.create=function(a,c,f){var i=this;return c=void 0===c?a:c,h.isDate(c)&&(c=[c.getHours(),c.getMinutes()]),b.isPlainObject(c)&&h.isInteger(c.pick)?c=c.pick:b.isArray(c)?c=+c[0]*e+ +c[1]:h.isInteger(c)||(c=i.now(a,c,f)),"max"==a&&c=a.from.pick&&b.pick<=a.to.pick},c.prototype.overlapRanges=function(a,b){var c=this;return a=c.createRange(a.from,a.to),b=c.createRange(b.from,b.to),c.withinRange(a,b.from)||c.withinRange(a,b.to)||c.withinRange(b,a.from)||c.withinRange(b,a.to)},c.prototype.now=function(a,b){var c,d=this.item.interval,f=new Date,g=f.getHours()*e+f.getMinutes(),i=h.isInteger(b);return g-=g%d,c=b<0&&d*b+g<=-d,g+="min"==a&&c?0:d,i&&(g+=d*(c&&"max"!=a?b+1:b)),g},c.prototype.normalize=function(a,b){var c=this.item.interval,d=this.item.min&&this.item.min.pick||0;return b-="min"==a?0:(b-d)%c},c.prototype.measure=function(a,c,f){var g=this;return c||(c="min"==a?[0,0]:[d-1,e-1]),"string"==typeof c?c=g.parse(a,c):!0===c||h.isInteger(c)?c=g.now(a,c,f):b.isPlainObject(c)&&h.isInteger(c.pick)&&(c=g.normalize(a,c.pick,f)),c},c.prototype.validate=function(a,b,c){var d=this,e=c&&c.interval?c.interval:d.item.interval;return d.disabled(b)&&(b=d.shift(b,e)),b=d.scope(b),d.disabled(b)&&(b=d.shift(b,-1*e)),b},c.prototype.disabled=function(a){var c=this,d=c.item.disable.filter(function(d){return h.isInteger(d)?a.hour==d:b.isArray(d)||h.isDate(d)?a.pick==c.create(d).pick:b.isPlainObject(d)?c.withinRange(d,a):void 0});return d=d.length&&!d.filter(function(a){return b.isArray(a)&&"inverted"==a[2]||b.isPlainObject(a)&&a.inverted}).length,-1===c.item.enable?!d:d||a.pickc.item.max.pick},c.prototype.shift=function(a,b){var c=this,d=c.item.min.pick,e=c.item.max.pick;for(b=b||c.item.interval;c.disabled(a)&&(a=c.create(a.pick+=b),!(a.pick<=d||a.pick>=e)););return a},c.prototype.scope=function(a){var b=this.item.min.pick,c=this.item.max.pick;return this.create(a.pick>c?c:a.pickb.time%g?"a.m.":"p.m."},A:function(a,b){return a?2:g/2>b.time%g?"AM":"PM"},toArray:function(a){return a.split(/(h{1,2}|H{1,2}|i|a|A|!.)/g)},toString:function(a,b){var c=this;return c.formats.toArray(a).map(function(a){return h.trigger(c.formats[a],c,[0,b])||a.replace(/^!/,"")}).join("")}},c.prototype.isTimeExact=function(a,c){var d=this;return h.isInteger(a)&&h.isInteger(c)||"boolean"==typeof a&&"boolean"==typeof c?a===c:(h.isDate(a)||b.isArray(a))&&(h.isDate(c)||b.isArray(c))?d.create(a).pick===d.create(c).pick:!(!b.isPlainObject(a)||!b.isPlainObject(c))&&(d.isTimeExact(a.from,c.from)&&d.isTimeExact(a.to,c.to))},c.prototype.isTimeOverlap=function(a,c){var d=this;return h.isInteger(a)&&(h.isDate(c)||b.isArray(c))?a===d.create(c).hour:h.isInteger(c)&&(h.isDate(a)||b.isArray(a))?c===d.create(a).hour:!(!b.isPlainObject(a)||!b.isPlainObject(c))&&d.overlapRanges(a,c)},c.prototype.flipEnable=function(a){var b=this.item;b.enable=a||(-1==b.enable?1:-1)},c.prototype.deactivate=function(a,c){var d=this,e=d.item.disable.slice(0);return"flip"==c?d.flipEnable():!1===c?(d.flipEnable(1),e=[]):!0===c?(d.flipEnable(-1),e=[]):c.map(function(a){for(var c,f=0;f0?b:this.item.interval},c.prototype.nodes=function(a){var b=this,c=b.settings,d=b.item.select,e=b.item.highlight,f=b.item.view,g=b.item.disable;return h.node("ul",h.group({min:b.item.min.pick,max:b.item.max.pick,i:b.item.interval,node:"li",item:function(a){a=b.create(a);var i=a.pick,j=d&&d.pick==i,k=e&&e.pick==i,l=g&&b.disabled(a),m=h.trigger(b.formats.toString,b,[c.format,a]);return[h.trigger(b.formats.toString,b,[h.trigger(c.formatLabel,b,[a])||c.format,a]),function(a){return j&&a.push(c.klass.selected),k&&a.push(c.klass.highlighted),f&&f.pick==i&&a.push(c.klass.viewset),l&&a.push(c.klass.disabled),a.join(" ")}([c.klass.listItem]),"data-pick="+a.pick+" "+h.ariaAttr({role:"option",label:m,selected:!(!j||b.$node.val()!==m)||null,activedescendant:!!k||null,disabled:!!l||null})]}})+h.node("li",h.node("button",c.clear,c.klass.buttonClear,"type=button data-clear=1"+(a?"":" disabled")+" "+h.ariaAttr({controls:b.$node[0].id})),"",h.ariaAttr({role:"presentation"})),c.klass.list,h.ariaAttr({role:"listbox",controls:b.$node[0].id}))},c.defaults=function(a){return{clear:"Clear",format:"h:i A",interval:30,closeOnSelect:!0,closeOnClear:!0,updateInput:!0,klass:{picker:a+" "+a+"--time",holder:a+"__holder",list:a+"__list",listItem:a+"__list-item",disabled:a+"__list-item--disabled",selected:a+"__list-item--selected",highlighted:a+"__list-item--highlighted",viewset:a+"__list-item--viewset",now:a+"__list-item--now",buttonClear:a+"__button--clear"}}}(a.klasses().picker),a.extend("pickatime",c)}); \ No newline at end of file diff --git a/server/risorse/js/snowfall.jquery.js b/server/risorse/js/snowfall.jquery.js new file mode 100644 index 0000000..6ce1169 --- /dev/null +++ b/server/risorse/js/snowfall.jquery.js @@ -0,0 +1,376 @@ +/* Snowfall jquery plugin + + ==================================================================== + LICENSE + ==================================================================== + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. + ==================================================================== + + Version 1.51 Dec 2nd 2012 + // fixed bug where snow collection didn't happen if a valid doctype was declared. + + Version 1.5 Oct 5th 2011 + Added collecting snow! Uses the canvas element to collect snow. In order to initialize snow collection use the following + + $(document).snowfall({collection : 'element'}); + + element = any valid jquery selector. + + The plugin then creates a canvas above every element that matches the selector, and collects the snow. If there are a varrying amount of elements the + flakes get assigned a random one on start they will collide. + + Version 1.4 Dec 8th 2010 + Fixed issues (I hope) with scroll bars flickering due to snow going over the edge of the screen. + Added round snowflakes via css, will not work for any version of IE. - Thanks to Luke Barker of http://www.infinite-eye.com/ + Added shadows as an option via css again will not work with IE. The idea behind shadows, is to show flakes on lighter colored web sites - Thanks Yutt + + Version 1.3.1 Nov 25th 2010 + Updated script that caused flakes not to show at all if plugin was initialized with no options, also added the fixes that Han Bongers suggested + + Developed by Jason Brown for any bugs or questions email me at loktar69@hotmail + info on the plugin is located on Somethinghitme.com + + values for snow options are + + flakeCount, + flakeColor, + flakeIndex, + minSize, + maxSize, + minSpeed, + maxSpeed, + round, true or false, makes the snowflakes rounded if the browser supports it. + shadow true or false, gives the snowflakes a shadow if the browser supports it. + + Example Usage : + $(document).snowfall({flakeCount : 100, maxSpeed : 10}); + + -or- + + $('#element').snowfall({flakeCount : 800, maxSpeed : 5, maxSize : 5}); + + -or with defaults- + + $(document).snowfall(); + + - To clear - + $('#element').snowfall('clear'); +*/ + +// requestAnimationFrame polyfill from https://github.com/darius/requestAnimationFrame +if (!Date.now) + Date.now = function() { return new Date().getTime(); }; + +(function() { + 'use strict'; + + var vendors = ['webkit', 'moz']; + for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) { + var vp = vendors[i]; + window.requestAnimationFrame = window[vp+'RequestAnimationFrame']; + window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame'] + || window[vp+'CancelRequestAnimationFrame']); + } + if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) // iOS6 is buggy + || !window.requestAnimationFrame || !window.cancelAnimationFrame) { + var lastTime = 0; + window.requestAnimationFrame = function(callback) { + var now = Date.now(); + var nextTime = Math.max(lastTime + 16, now); + return setTimeout(function() { callback(lastTime = nextTime); }, + nextTime - now); + }; + window.cancelAnimationFrame = clearTimeout; + } +}()); + +(function($){ + $.snowfall = function(element, options){ + var flakes = [], + defaults = { + flakeCount : 35, + flakeColor : '#ffffff', + flakePosition: 'absolute', + flakeIndex: 999999, + minSize : 1, + maxSize : 2, + minSpeed : 1, + maxSpeed : 5, + round : false, + shadow : false, + collection : false, + collectionHeight : 40, + deviceorientation : false + }, + options = $.extend(defaults, options), + random = function random(min, max){ + return Math.round(min + Math.random()*(max-min)); + }; + + $(element).data("snowfall", this); + + // Snow flake object + function Flake(_x, _y, _size, _speed){ + // Flake properties + this.x = _x; + this.y = _y; + this.size = _size; + this.speed = _speed; + this.step = 0; + this.stepSize = random(1,10) / 100; + + if(options.collection){ + this.target = canvasCollection[random(0,canvasCollection.length-1)]; + } + + var flakeMarkup = null; + + if(options.image){ + flakeMarkup = document.createElement("img"); + flakeMarkup.src = options.image; + }else{ + flakeMarkup = document.createElement("div"); + $(flakeMarkup).css({'background' : options.flakeColor}); + } + + $(flakeMarkup).attr({ + 'class': 'snowfall-flakes', + }).css({ + 'width' : this.size, + 'height' : this.size, + 'position' : options.flakePosition, + 'top' : this.y, + 'left' : this.x, + 'fontSize' : 0, + 'zIndex' : options.flakeIndex + }); + + if($(element).get(0).tagName === $(document).get(0).tagName){ + $('body').append($(flakeMarkup)); + element = $('body'); + }else{ + $(element).append($(flakeMarkup)); + } + + this.element = flakeMarkup; + + // Update function, used to update the snow flakes, and checks current snowflake against bounds + this.update = function(){ + this.y += this.speed; + + if(this.y > (elHeight) - (this.size + 6)){ + this.reset(); + } + + this.element.style.top = this.y + 'px'; + this.element.style.left = this.x + 'px'; + + this.step += this.stepSize; + + if (doRatio === false) { + this.x += Math.cos(this.step); + } else { + this.x += (doRatio + Math.cos(this.step)); + } + + // Pileup check + if(options.collection){ + if(this.x > this.target.x && this.x < this.target.width + this.target.x && this.y > this.target.y && this.y < this.target.height + this.target.y){ + var ctx = this.target.element.getContext("2d"), + curX = this.x - this.target.x, + curY = this.y - this.target.y, + colData = this.target.colData; + + if(colData[parseInt(curX)][parseInt(curY+this.speed+this.size)] !== undefined || curY+this.speed+this.size > this.target.height){ + if(curY+this.speed+this.size > this.target.height){ + while(curY+this.speed+this.size > this.target.height && this.speed > 0){ + this.speed *= .5; + } + + ctx.fillStyle = defaults.flakeColor; + + if(colData[parseInt(curX)][parseInt(curY+this.speed+this.size)] == undefined){ + colData[parseInt(curX)][parseInt(curY+this.speed+this.size)] = 1; + ctx.fillRect(curX, (curY)+this.speed+this.size, this.size, this.size); + }else{ + colData[parseInt(curX)][parseInt(curY+this.speed)] = 1; + ctx.fillRect(curX, curY+this.speed, this.size, this.size); + } + this.reset(); + }else{ + // flow to the sides + this.speed = 1; + this.stepSize = 0; + + if(parseInt(curX)+1 < this.target.width && colData[parseInt(curX)+1][parseInt(curY)+1] == undefined ){ + // go left + this.x++; + }else if(parseInt(curX)-1 > 0 && colData[parseInt(curX)-1][parseInt(curY)+1] == undefined ){ + // go right + this.x--; + }else{ + //stop + ctx.fillStyle = defaults.flakeColor; + ctx.fillRect(curX, curY, this.size, this.size); + colData[parseInt(curX)][parseInt(curY)] = 1; + this.reset(); + } + } + } + } + } + + if(this.x + this.size > (elWidth) - widthOffset || this.x < widthOffset){ + this.reset(); + } + } + + // Resets the snowflake once it reaches one of the bounds set + this.reset = function(){ + this.y = 0; + this.x = random(widthOffset, elWidth - widthOffset); + this.stepSize = random(1,10) / 100; + this.size = random((options.minSize * 100), (options.maxSize * 100)) / 100; + this.element.style.width = this.size + 'px'; + this.element.style.height = this.size + 'px'; + this.speed = random(options.minSpeed, options.maxSpeed); + } + } + + // local vars + var i = 0, + elHeight = $(element).height(), + elWidth = $(element).width(), + widthOffset = 0, + snowTimeout = 0; + + // Collection Piece ****************************** + if(options.collection !== false){ + var testElem = document.createElement('canvas'); + if(!!(testElem.getContext && testElem.getContext('2d'))){ + var canvasCollection = [], + elements = $(options.collection), + collectionHeight = options.collectionHeight; + + for(var i =0; i < elements.length; i++){ + var bounds = elements[i].getBoundingClientRect(), + $canvas = $('', + { + 'class' : 'snowfall-canvas' + }), + collisionData = []; + + if(bounds.top-collectionHeight > 0){ + $('body').append($canvas); + + $canvas.css({ + 'position' : options.flakePosition, + 'left' : bounds.left + 'px', + 'top' : bounds.top-collectionHeight + 'px' + }) + .prop({ + width: bounds.width, + height: collectionHeight + }); + + for(var w = 0; w < bounds.width; w++){ + collisionData[w] = []; + } + + canvasCollection.push({ + element : $canvas.get(0), + x : bounds.left, + y : bounds.top-collectionHeight, + width : bounds.width, + height: collectionHeight, + colData : collisionData + }); + } + } + }else{ + // Canvas element isnt supported + options.collection = false; + } + } + // ************************************************ + + // This will reduce the horizontal scroll bar from displaying, when the effect is applied to the whole page + if($(element).get(0).tagName === $(document).get(0).tagName){ + widthOffset = 25; + } + + // Bind the window resize event so we can get the innerHeight again + $(window).bind("resize", function(){ + elHeight = $(element)[0].clientHeight; + elWidth = $(element)[0].offsetWidth; + }); + + + // initialize the flakes + for(i = 0; i < options.flakeCount; i+=1){ + flakes.push(new Flake(random(widthOffset,elWidth - widthOffset), random(0, elHeight), random((options.minSize * 100), (options.maxSize * 100)) / 100, random(options.minSpeed, options.maxSpeed))); + } + + // This adds the style to make the snowflakes round via border radius property + if(options.round){ + $('.snowfall-flakes').css({'-moz-border-radius' : options.maxSize, '-webkit-border-radius' : options.maxSize, 'border-radius' : options.maxSize}); + } + + // This adds shadows just below the snowflake so they pop a bit on lighter colored web pages + if(options.shadow){ + $('.snowfall-flakes').css({'-moz-box-shadow' : '1px 1px 1px #555', '-webkit-box-shadow' : '1px 1px 1px #555', 'box-shadow' : '1px 1px 1px #555'}); + } + + // On newer Macbooks Snowflakes will fall based on deviceorientation + var doRatio = false; + if (options.deviceorientation) { + $(window).bind('deviceorientation', function(event) { + doRatio = event.originalEvent.gamma * 0.1; + }); + } + + // this controls flow of the updating snow + function snow(){ + for( i = 0; i < flakes.length; i += 1){ + flakes[i].update(); + } + + snowTimeout = requestAnimationFrame(function(){snow()}); + } + + snow(); + + // clears the snowflakes + this.clear = function(){ + $('.snowfall-canvas').remove(); + $(element).children('.snowfall-flakes').remove(); + cancelAnimationFrame(snowTimeout); + } + }; + + // Initialize the options and the plugin + $.fn.snowfall = function(options){ + if(typeof(options) == "object" || options == undefined){ + return this.each(function(i){ + (new $.snowfall(this, options)); + }); + }else if (typeof(options) == "string") { + return this.each(function(i){ + var snow = $(this).data('snowfall'); + if(snow){ + snow.clear(); + } + }); + } + }; +})(jQuery); diff --git a/server/risorse/js/snowfall.js b/server/risorse/js/snowfall.js new file mode 100644 index 0000000..e431c0e --- /dev/null +++ b/server/risorse/js/snowfall.js @@ -0,0 +1,283 @@ +/* Snowfall pure js + ==================================================================== + LICENSE + ==================================================================== + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. + ==================================================================== + + 1.0 + Wanted to rewrite my snow plugin to use pure JS so you werent necessarily tied to using a framework. + Does not include a selector engine or anything, just pass elements to it using standard JS selectors. + + Does not clear snow currently. Collection portion removed just for ease of testing will add back in next version + + Theres a few ways to call the snow you could do it the following way by directly passing the selector, + + snowFall.snow(document.getElementsByTagName("body"), {options}); + + or you could save the selector results to a variable, and then call it + + var elements = document.getElementsByClassName('yourclass'); + snowFall.snow(elements, {options}); + + Options are all the same as the plugin except clear, and collection + + values for snow options are + + flakeCount, + flakeColor, + flakeIndex, + flakePosition, + minSize, + maxSize, + minSpeed, + maxSpeed, + round, true or false, makes the snowflakes rounded if the browser supports it. + shadow true or false, gives the snowflakes a shadow if the browser supports it. + +*/ + +// requestAnimationFrame polyfill from https://github.com/darius/requestAnimationFrame +if (!Date.now) + Date.now = function() { return new Date().getTime(); }; + +(function() { + 'use strict'; + + var vendors = ['webkit', 'moz']; + for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) { + var vp = vendors[i]; + window.requestAnimationFrame = window[vp+'RequestAnimationFrame']; + window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame'] + || window[vp+'CancelRequestAnimationFrame']); + } + if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) // iOS6 is buggy + || !window.requestAnimationFrame || !window.cancelAnimationFrame) { + var lastTime = 0; + window.requestAnimationFrame = function(callback) { + var now = Date.now(); + var nextTime = Math.max(lastTime + 16, now); + return setTimeout(function() { callback(lastTime = nextTime); }, + nextTime - now); + }; + window.cancelAnimationFrame = clearTimeout; + } +}()); + +var snowFall = (function(){ + function jSnow(){ + // local methods + var defaults = { + flakeCount : 35, + flakeColor : '#ffffff', + flakeIndex: 999999, + flakePosition: 'absolute', + minSize : 1, + maxSize : 2, + minSpeed : 1, + maxSpeed : 5, + round : false, + shadow : false, + collection : false, + image : false, + collectionHeight : 40 + }, + flakes = [], + element = {}, + elHeight = 0, + elWidth = 0, + widthOffset = 0, + snowTimeout = 0, + // For extending the default object with properties + extend = function(obj, extObj){ + for(var i in extObj){ + if(obj.hasOwnProperty(i)){ + obj[i] = extObj[i]; + } + } + }, + // For setting CSS3 transform styles + transform = function (el, styles){ + el.style.webkitTransform = styles; + el.style.MozTransform = styles; + el.style.msTransform = styles; + el.style.OTransform = styles; + el.style.transform = styles; + }, + // random between range + random = function random(min, max){ + return Math.round(min + Math.random()*(max-min)); + }, + // Set multiple styles at once. + setStyle = function(element, props) + { + for (var property in props){ + element.style[property] = props[property] + ((property == 'width' || property == 'height') ? 'px' : ''); + } + }, + // snowflake + flake = function(_el, _size, _speed) + { + // Flake properties + this.x = random(widthOffset, elWidth - widthOffset); + this.y = random(0, elHeight); + this.size = _size; + this.speed = _speed; + this.step = 0; + this.stepSize = random(1,10) / 100; + + if(defaults.collection){ + this.target = canvasCollection[random(0,canvasCollection.length-1)]; + } + + var flakeObj = null; + + if(defaults.image){ + flakeObj = new Image(); + flakeObj.src = defaults.image; + }else{ + flakeObj = document.createElement('div'); + setStyle(flakeObj, {'background' : defaults.flakeColor}); + } + + flakeObj.className = 'snowfall-flakes'; + setStyle(flakeObj, {'width' : this.size, 'height' : this.size, 'position' : defaults.flakePosition, 'top' : 0, 'left' : 0, 'will-change': 'transform', 'fontSize' : 0, 'zIndex' : defaults.flakeIndex}); + + // This adds the style to make the snowflakes round via border radius property + if(defaults.round){ + setStyle(flakeObj,{'-moz-border-radius' : ~~(defaults.maxSize) + 'px', '-webkit-border-radius' : ~~(defaults.maxSize) + 'px', 'borderRadius' : ~~(defaults.maxSize) + 'px'}); + } + + // This adds shadows just below the snowflake so they pop a bit on lighter colored web pages + if(defaults.shadow){ + setStyle(flakeObj,{'-moz-box-shadow' : '1px 1px 1px #555', '-webkit-box-shadow' : '1px 1px 1px #555', 'boxShadow' : '1px 1px 1px #555'}); + } + + if(_el.tagName === document.body.tagName){ + document.body.appendChild(flakeObj); + }else{ + _el.appendChild(flakeObj); + } + + + this.element = flakeObj; + + // Update function, used to update the snow flakes, and checks current snowflake against bounds + this.update = function(){ + this.y += this.speed; + + if(this.y > elHeight - (this.size + 6)){ + this.reset(); + } + + transform(this.element, 'translateY('+this.y+'px) translateX('+this.x+'px)'); + + this.step += this.stepSize; + this.x += Math.cos(this.step); + + if(this.x + this.size > elWidth - widthOffset || this.x < widthOffset){ + this.reset(); + } + } + + // Resets the snowflake once it reaches one of the bounds set + this.reset = function(){ + this.y = 0; + this.x = random(widthOffset, elWidth - widthOffset); + this.stepSize = random(1,10) / 100; + this.size = random((defaults.minSize * 100), (defaults.maxSize * 100)) / 100; + this.element.style.width = this.size + 'px'; + this.element.style.height = this.size + 'px'; + this.speed = random(defaults.minSpeed, defaults.maxSpeed); + } + }, + // this controls flow of the updating snow + animateSnow = function(){ + for(var i = 0; i < flakes.length; i += 1){ + flakes[i].update(); + } + snowTimeout = requestAnimationFrame(function(){animateSnow()}); + } + return{ + snow : function(_element, _options){ + extend(defaults, _options); + + //init the element vars + element = _element; + elHeight = element.offsetHeight; + elWidth = element.offsetWidth; + + element.snow = this; + + // if this is the body the offset is a little different + if(element.tagName.toLowerCase() === 'body'){ + widthOffset = 25; + } + + // Bind the window resize event so we can get the innerHeight again + window.addEventListener('resize', function(){ + elHeight = element.clientHeight; + elWidth = element.offsetWidth; + }, true); + + // initialize the flakes + for(i = 0; i < defaults.flakeCount; i+=1){ + flakes.push(new flake(element, random((defaults.minSize * 100), (defaults.maxSize * 100)) / 100, random(defaults.minSpeed, defaults.maxSpeed))); + } + // start the snow + animateSnow(); + }, + clear : function(){ + var flakeChildren = null; + + if(!element.getElementsByClassName){ + flakeChildren = element.querySelectorAll('.snowfall-flakes'); + }else{ + flakeChildren = element.getElementsByClassName('snowfall-flakes'); + } + + var flakeChilLen = flakeChildren.length; + while(flakeChilLen--){ + if(flakeChildren[flakeChilLen].parentNode === element){ + element.removeChild(flakeChildren[flakeChilLen]); + } + } + + cancelAnimationFrame(snowTimeout); + } + } + }; + return{ + snow : function(elements, options){ + if(typeof(options) == 'string'){ + if(elements.length > 0){ + for(var i = 0; i < elements.length; i++){ + if(elements[i].snow){ + elements[i].snow.clear(); + } + } + }else{ + elements.snow.clear(); + } + }else{ + if(elements.length > 0){ + for(var i = 0; i < elements.length; i++){ + new jSnow().snow(elements[i], options); + } + }else{ + new jSnow().snow(elements, options); + } + } + } + } +})(); diff --git a/server/risorse/js/themes/classic.css b/server/risorse/js/themes/classic.css new file mode 100644 index 0000000..8d16c9e --- /dev/null +++ b/server/risorse/js/themes/classic.css @@ -0,0 +1,4 @@ +.picker,.picker__holder{width:100%;position:absolute}.picker{font-size:16px;text-align:left;line-height:1.2;color:#000;z-index:10000;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:0}.picker__input{cursor:default}.picker__input.picker__input--active{border-color:#0089ec}.picker__holder{overflow-y:auto;-webkit-overflow-scrolling:touch;background:#fff;border:1px solid #aaa;border-top-width:0;border-bottom-width:0;border-radius:0 0 5px 5px;box-sizing:border-box;min-width:176px;max-width:466px;max-height:0;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";filter:alpha(opacity=0);-moz-opacity:0;opacity:0;transform:translateY(-1em) perspective(600px) rotateX(10deg);transition:transform .15s ease-out,opacity .15s ease-out,max-height 0s .15s,border-width 0s .15s}/*! + * Classic picker styling for pickadate.js + * Demo: http://amsul.github.io/pickadate.js + */.picker__frame{padding:1px}.picker__wrap{margin:-1px}.picker--opened .picker__holder{max-height:25em;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";filter:alpha(opacity=100);-moz-opacity:1;opacity:1;border-top-width:1px;border-bottom-width:1px;transform:translateY(0) perspective(600px) rotateX(0);transition:transform .15s ease-out,opacity .15s ease-out,max-height 0s,border-width 0s;box-shadow:0 6px 18px 1px rgba(0,0,0,.12)} \ No newline at end of file diff --git a/server/risorse/js/themes/classic.date.css b/server/risorse/js/themes/classic.date.css new file mode 100644 index 0000000..2664433 --- /dev/null +++ b/server/risorse/js/themes/classic.date.css @@ -0,0 +1 @@ +.picker__footer,.picker__header,.picker__table{text-align:center}.picker__box{padding:0 1em}.picker__header{position:relative;margin-top:.75em}.picker__month,.picker__year{font-weight:500;display:inline-block;margin-left:.25em;margin-right:.25em}.picker__year{color:#999;font-size:.8em;font-style:italic}.picker__select--month,.picker__select--year{border:1px solid #b7b7b7;height:2em;padding:.5em;margin-left:.25em;margin-right:.25em}.picker__select--month{width:35%}.picker__select--year{width:22.5%}.picker__select--month:focus,.picker__select--year:focus{border-color:#0089ec}.picker__nav--next,.picker__nav--prev{position:absolute;padding:.5em 1.25em;width:1em;height:1em;box-sizing:content-box;top:-.25em}.picker__nav--prev{left:-1em;padding-right:1.25em}.picker__nav--next{right:-1em;padding-left:1.25em}@media (min-width:24.5em){.picker__select--month,.picker__select--year{margin-top:-.5em}.picker__nav--next,.picker__nav--prev{top:-.33em}.picker__nav--prev{padding-right:1.5em}.picker__nav--next{padding-left:1.5em}}.picker__nav--next:before,.picker__nav--prev:before{content:" ";border-top:.5em solid transparent;border-bottom:.5em solid transparent;border-right:.75em solid #000;width:0;height:0;display:block;margin:0 auto}.picker__nav--next:before{border-right:0;border-left:.75em solid #000}.picker__nav--next:hover,.picker__nav--prev:hover{cursor:pointer;color:#000;background:#b1dcfb}.picker__nav--disabled,.picker__nav--disabled:before,.picker__nav--disabled:before:hover,.picker__nav--disabled:hover{cursor:default;background:0 0;border-right-color:#f5f5f5;border-left-color:#f5f5f5}.picker__table{border-collapse:collapse;border-spacing:0;table-layout:fixed;font-size:inherit;width:100%;margin-top:.75em;margin-bottom:.5em}@media (min-height:33.875em){.picker__table{margin-bottom:.75em}}.picker__table td{margin:0;padding:0}.picker__weekday{width:14.285714286%;font-size:.75em;padding-bottom:.25em;color:#999;font-weight:500}@media (min-height:33.875em){.picker__weekday{padding-bottom:.5em}}.picker__day{padding:.3125em 0;font-weight:200;border:1px solid transparent}.picker__day--today{position:relative}.picker__day--today:before{content:" ";position:absolute;top:2px;right:2px;width:0;height:0;border-top:.5em solid #0059bc;border-left:.5em solid transparent}.picker__day--disabled:before{border-top-color:#aaa}.picker__day--outfocus{color:#ddd}.picker--focused .picker__day--highlighted,.picker__day--highlighted:hover,.picker__day--infocus:hover,.picker__day--outfocus:hover{cursor:pointer;color:#000;background:#b1dcfb}.picker__day--highlighted{border-color:#0089ec}.picker--focused .picker__day--selected,.picker__day--selected,.picker__day--selected:hover{background:#0089ec;color:#fff}.picker--focused .picker__day--disabled,.picker__day--disabled,.picker__day--disabled:hover{background:#f5f5f5;border-color:#f5f5f5;color:#ddd;cursor:default}.picker__day--highlighted.picker__day--disabled,.picker__day--highlighted.picker__day--disabled:hover{background:#bbb}.picker__button--clear,.picker__button--close,.picker__button--today{border:1px solid #fff;background:#fff;font-size:.8em;padding:.66em 0;font-weight:700;width:33%;display:inline-block;vertical-align:bottom}.picker__button--clear:hover,.picker__button--close:hover,.picker__button--today:hover{cursor:pointer;color:#000;background:#b1dcfb;border-bottom-color:#b1dcfb}.picker__button--clear:focus,.picker__button--close:focus,.picker__button--today:focus{background:#b1dcfb;border-color:#0089ec;outline:0}.picker__button--clear:before,.picker__button--close:before,.picker__button--today:before{position:relative;display:inline-block;height:0}.picker__button--clear:before,.picker__button--today:before{content:" ";margin-right:.45em}.picker__button--today:before{top:-.05em;width:0;border-top:.66em solid #0059bc;border-left:.66em solid transparent}.picker__button--clear:before{top:-.25em;width:.66em;border-top:3px solid #e20}.picker__button--close:before{content:"\D7";top:-.1em;vertical-align:top;font-size:1.1em;margin-right:.35em;color:#777}.picker__button--today[disabled],.picker__button--today[disabled]:hover{background:#f5f5f5;border-color:#f5f5f5;color:#ddd;cursor:default}.picker__button--today[disabled]:before{border-top-color:#aaa} \ No newline at end of file diff --git a/server/risorse/js/themes/classic.time.css b/server/risorse/js/themes/classic.time.css new file mode 100644 index 0000000..2d540eb --- /dev/null +++ b/server/risorse/js/themes/classic.time.css @@ -0,0 +1 @@ +.picker__list{list-style:none;padding:.75em 0 4.2em;margin:0}.picker__list-item{border-bottom:1px solid #ddd;border-top:1px solid #ddd;margin-bottom:-1px;position:relative;background:#fff;padding:.75em 1.25em}.picker__list-item--highlighted,.picker__list-item:hover{border-color:#0089ec;z-index:10}.picker--focused .picker__list-item--highlighted,.picker__list-item--highlighted:hover,.picker__list-item:hover{color:#000;background:#b1dcfb;cursor:pointer}@media (min-height:46.75em){.picker__list-item{padding:.5em 1em}}.picker--focused .picker__list-item--selected,.picker__list-item--selected,.picker__list-item--selected:hover{background:#0089ec;color:#fff;z-index:10}.picker--focused .picker__list-item--disabled,.picker__list-item--disabled,.picker__list-item--disabled:hover{background:#f5f5f5;color:#ddd;cursor:default;border-color:#ddd;z-index:auto}.picker--time .picker__button--clear{display:block;width:80%;margin:1em auto 0;padding:1em 1.25em;background:0 0;border:0;font-weight:500;font-size:.67em;text-align:center;text-transform:uppercase;color:#666}.picker--time .picker__button--clear:focus,.picker--time .picker__button--clear:hover{background:#e20;border-color:#e20;cursor:pointer;color:#fff;outline:0}.picker--time .picker__button--clear:before{top:-.25em;color:#666;font-size:1.25em;font-weight:700}.picker--time .picker__button--clear:focus:before,.picker--time .picker__button--clear:hover:before{color:#fff;border-color:#fff}.picker--time{min-width:256px;max-width:320px}.picker--time .picker__holder{background:#f2f2f2}@media (min-height:40.125em){.picker--time .picker__holder{font-size:.875em}}.picker--time .picker__box{padding:0;position:relative} \ No newline at end of file diff --git a/server/risorse/js/themes/default.css b/server/risorse/js/themes/default.css new file mode 100644 index 0000000..3d3b7b5 --- /dev/null +++ b/server/risorse/js/themes/default.css @@ -0,0 +1,4 @@ +.picker{font-size:16px;text-align:left;line-height:1.2;color:#000;position:absolute;z-index:10000;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:0}.picker__input{cursor:default}.picker__input.picker__input--active{border-color:#0089ec}.picker__holder{width:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;position:fixed;transition:background .15s ease-out,transform 0s .15s;-webkit-backface-visibility:hidden}/*! + * Default mobile-first, responsive styling for pickadate.js + * Demo: http://amsul.github.io/pickadate.js + */.picker__frame,.picker__holder{top:0;bottom:0;left:0;right:0;-ms-transform:translateY(100%);transform:translateY(100%)}.picker__frame{position:absolute;margin:0 auto;min-width:256px;max-width:666px;width:100%;-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";filter:alpha(opacity=0);-moz-opacity:0;opacity:0;transition:all .15s ease-out}.picker__wrap{display:table;width:100%;height:100%}@media (min-height:33.875em){.picker__frame{overflow:visible;top:auto;bottom:-100%;max-height:80%}.picker__wrap{display:block}}.picker__box{background:#fff;display:table-cell;vertical-align:middle}@media (min-height:26.5em){.picker__box{font-size:1.25em}}@media (min-height:33.875em){.picker__box{display:block;font-size:1.33em;border:1px solid #777;border-top-color:#898989;border-bottom-width:0;border-radius:5px 5px 0 0;box-shadow:0 12px 36px 16px rgba(0,0,0,.24)}.picker--opened .picker__frame{top:auto;bottom:0}}@media (min-height:40.125em){.picker__frame{margin-bottom:7.5%}.picker__box{font-size:1.5em;border-bottom-width:1px;border-radius:5px}}.picker--opened .picker__holder{-ms-transform:translateY(0);transform:translateY(0);zoom:1;background:rgba(0,0,0,.32);transition:background .15s ease-out}.picker--opened .picker__frame{-ms-transform:translateY(0);transform:translateY(0);-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";filter:alpha(opacity=100);-moz-opacity:1;opacity:1} \ No newline at end of file diff --git a/server/risorse/js/themes/default.date.css b/server/risorse/js/themes/default.date.css new file mode 100644 index 0000000..2664433 --- /dev/null +++ b/server/risorse/js/themes/default.date.css @@ -0,0 +1 @@ +.picker__footer,.picker__header,.picker__table{text-align:center}.picker__box{padding:0 1em}.picker__header{position:relative;margin-top:.75em}.picker__month,.picker__year{font-weight:500;display:inline-block;margin-left:.25em;margin-right:.25em}.picker__year{color:#999;font-size:.8em;font-style:italic}.picker__select--month,.picker__select--year{border:1px solid #b7b7b7;height:2em;padding:.5em;margin-left:.25em;margin-right:.25em}.picker__select--month{width:35%}.picker__select--year{width:22.5%}.picker__select--month:focus,.picker__select--year:focus{border-color:#0089ec}.picker__nav--next,.picker__nav--prev{position:absolute;padding:.5em 1.25em;width:1em;height:1em;box-sizing:content-box;top:-.25em}.picker__nav--prev{left:-1em;padding-right:1.25em}.picker__nav--next{right:-1em;padding-left:1.25em}@media (min-width:24.5em){.picker__select--month,.picker__select--year{margin-top:-.5em}.picker__nav--next,.picker__nav--prev{top:-.33em}.picker__nav--prev{padding-right:1.5em}.picker__nav--next{padding-left:1.5em}}.picker__nav--next:before,.picker__nav--prev:before{content:" ";border-top:.5em solid transparent;border-bottom:.5em solid transparent;border-right:.75em solid #000;width:0;height:0;display:block;margin:0 auto}.picker__nav--next:before{border-right:0;border-left:.75em solid #000}.picker__nav--next:hover,.picker__nav--prev:hover{cursor:pointer;color:#000;background:#b1dcfb}.picker__nav--disabled,.picker__nav--disabled:before,.picker__nav--disabled:before:hover,.picker__nav--disabled:hover{cursor:default;background:0 0;border-right-color:#f5f5f5;border-left-color:#f5f5f5}.picker__table{border-collapse:collapse;border-spacing:0;table-layout:fixed;font-size:inherit;width:100%;margin-top:.75em;margin-bottom:.5em}@media (min-height:33.875em){.picker__table{margin-bottom:.75em}}.picker__table td{margin:0;padding:0}.picker__weekday{width:14.285714286%;font-size:.75em;padding-bottom:.25em;color:#999;font-weight:500}@media (min-height:33.875em){.picker__weekday{padding-bottom:.5em}}.picker__day{padding:.3125em 0;font-weight:200;border:1px solid transparent}.picker__day--today{position:relative}.picker__day--today:before{content:" ";position:absolute;top:2px;right:2px;width:0;height:0;border-top:.5em solid #0059bc;border-left:.5em solid transparent}.picker__day--disabled:before{border-top-color:#aaa}.picker__day--outfocus{color:#ddd}.picker--focused .picker__day--highlighted,.picker__day--highlighted:hover,.picker__day--infocus:hover,.picker__day--outfocus:hover{cursor:pointer;color:#000;background:#b1dcfb}.picker__day--highlighted{border-color:#0089ec}.picker--focused .picker__day--selected,.picker__day--selected,.picker__day--selected:hover{background:#0089ec;color:#fff}.picker--focused .picker__day--disabled,.picker__day--disabled,.picker__day--disabled:hover{background:#f5f5f5;border-color:#f5f5f5;color:#ddd;cursor:default}.picker__day--highlighted.picker__day--disabled,.picker__day--highlighted.picker__day--disabled:hover{background:#bbb}.picker__button--clear,.picker__button--close,.picker__button--today{border:1px solid #fff;background:#fff;font-size:.8em;padding:.66em 0;font-weight:700;width:33%;display:inline-block;vertical-align:bottom}.picker__button--clear:hover,.picker__button--close:hover,.picker__button--today:hover{cursor:pointer;color:#000;background:#b1dcfb;border-bottom-color:#b1dcfb}.picker__button--clear:focus,.picker__button--close:focus,.picker__button--today:focus{background:#b1dcfb;border-color:#0089ec;outline:0}.picker__button--clear:before,.picker__button--close:before,.picker__button--today:before{position:relative;display:inline-block;height:0}.picker__button--clear:before,.picker__button--today:before{content:" ";margin-right:.45em}.picker__button--today:before{top:-.05em;width:0;border-top:.66em solid #0059bc;border-left:.66em solid transparent}.picker__button--clear:before{top:-.25em;width:.66em;border-top:3px solid #e20}.picker__button--close:before{content:"\D7";top:-.1em;vertical-align:top;font-size:1.1em;margin-right:.35em;color:#777}.picker__button--today[disabled],.picker__button--today[disabled]:hover{background:#f5f5f5;border-color:#f5f5f5;color:#ddd;cursor:default}.picker__button--today[disabled]:before{border-top-color:#aaa} \ No newline at end of file diff --git a/server/risorse/js/themes/default.time.css b/server/risorse/js/themes/default.time.css new file mode 100644 index 0000000..85b41e7 --- /dev/null +++ b/server/risorse/js/themes/default.time.css @@ -0,0 +1 @@ +.picker__list{list-style:none;padding:.75em 0 4.2em;margin:0}.picker__list-item{border-bottom:1px solid #ddd;border-top:1px solid #ddd;margin-bottom:-1px;position:relative;background:#fff;padding:.75em 1.25em}.picker__list-item--highlighted,.picker__list-item:hover{border-color:#0089ec;z-index:10}.picker--focused .picker__list-item--highlighted,.picker__list-item--highlighted:hover,.picker__list-item:hover{cursor:pointer;color:#000;background:#b1dcfb}@media (min-height:46.75em){.picker__list-item{padding:.5em 1em}}.picker--focused .picker__list-item--selected,.picker__list-item--selected,.picker__list-item--selected:hover{background:#0089ec;color:#fff;z-index:10}.picker--focused .picker__list-item--disabled,.picker__list-item--disabled,.picker__list-item--disabled:hover{background:#f5f5f5;color:#ddd;cursor:default;border-color:#ddd;z-index:auto}.picker--time .picker__button--clear{display:block;width:80%;margin:1em auto 0;padding:1em 1.25em;background:0 0;border:0;font-weight:500;font-size:.67em;text-align:center;text-transform:uppercase;color:#666}.picker--time .picker__button--clear:focus,.picker--time .picker__button--clear:hover{background:#e20;border-color:#e20;cursor:pointer;color:#fff;outline:0}.picker--time .picker__button--clear:before{top:-.25em;color:#666;font-size:1.25em;font-weight:700}.picker--time .picker__button--clear:focus:before,.picker--time .picker__button--clear:hover:before{color:#fff;border-color:#fff}.picker--time .picker__frame{min-width:256px;max-width:320px}.picker--time .picker__box{font-size:1em;background:#f2f2f2;padding:0}@media (min-height:40.125em){.picker--time .picker__box{margin-bottom:5em}} \ No newline at end of file diff --git a/server/risorse/js/themes/rtl.css b/server/risorse/js/themes/rtl.css new file mode 100644 index 0000000..0b9d69f --- /dev/null +++ b/server/risorse/js/themes/rtl.css @@ -0,0 +1,3 @@ +/*! + * Styling for RTL (right-to-left) languages using pickadate.js + */.picker{direction:rtl}.picker__nav--next{right:auto;left:-1em}.picker__nav--prev{left:auto;right:-1em}.picker__nav--next:before{border-left:0;border-right:.75em solid #000}.picker__nav--prev:before{border-right:0;border-left:.75em solid #000} \ No newline at end of file diff --git a/server/risorse/js/translations/ar.js b/server/risorse/js/translations/ar.js new file mode 100644 index 0000000..7f2be0f --- /dev/null +++ b/server/risorse/js/translations/ar.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["يناير","فبراير","مارس","ابريل","مايو","يونيو","يوليو","اغسطس","سبتمبر","اكتوبر","نوفمبر","ديسمبر"],monthsShort:["يناير","فبراير","مارس","ابريل","مايو","يونيو","يوليو","اغسطس","سبتمبر","اكتوبر","نوفمبر","ديسمبر"],weekdaysFull:["الاحد","الاثنين","الثلاثاء","الاربعاء","الخميس","الجمعة","السبت"],weekdaysShort:["الاحد","الاثنين","الثلاثاء","الاربعاء","الخميس","الجمعة","السبت"],today:"اليوم",clear:"مسح",format:"yyyy mmmm dd",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"مسح"}); \ No newline at end of file diff --git a/server/risorse/js/translations/bg_BG.js b/server/risorse/js/translations/bg_BG.js new file mode 100644 index 0000000..9bcdde2 --- /dev/null +++ b/server/risorse/js/translations/bg_BG.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["януари","февруари","март","април","май","юни","юли","август","септември","октомври","ноември","декември"],monthsShort:["янр","фев","мар","апр","май","юни","юли","авг","сеп","окт","ное","дек"],weekdaysFull:["неделя","понеделник","вторник","сряда","четвъртък","петък","събота"],weekdaysShort:["нд","пн","вт","ср","чт","пт","сб"],today:"днес",clear:"изтривам",firstDay:1,format:"d mmmm yyyy г.",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"изтривам"}); \ No newline at end of file diff --git a/server/risorse/js/translations/bs_BA.js b/server/risorse/js/translations/bs_BA.js new file mode 100644 index 0000000..5316da5 --- /dev/null +++ b/server/risorse/js/translations/bs_BA.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["januar","februar","mart","april","maj","juni","juli","august","septembar","oktobar","novembar","decembar"],monthsShort:["jan","feb","mar","apr","maj","jun","jul","aug","sep","okt","nov","dec"],weekdaysFull:["nedjelja","ponedjeljak","utorak","srijeda","cetvrtak","petak","subota"],weekdaysShort:["ne","po","ut","sr","če","pe","su"],today:"danas",clear:"izbrisati",firstDay:1,format:"dd. mmmm yyyy.",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"izbrisati"}); \ No newline at end of file diff --git a/server/risorse/js/translations/ca_ES.js b/server/risorse/js/translations/ca_ES.js new file mode 100644 index 0000000..26baa53 --- /dev/null +++ b/server/risorse/js/translations/ca_ES.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Gener","Febrer","Març","Abril","Maig","juny","Juliol","Agost","Setembre","Octubre","Novembre","Desembre"],monthsShort:["Gen","Feb","Mar","Abr","Mai","Jun","Jul","Ago","Set","Oct","Nov","Des"],weekdaysFull:["diumenge","dilluns","dimarts","dimecres","dijous","divendres","dissabte"],weekdaysShort:["diu","dil","dim","dmc","dij","div","dis"],today:"avui",clear:"esborra",close:"tanca",firstDay:1,format:"dddd d !de mmmm !de yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"esborra"}); \ No newline at end of file diff --git a/server/risorse/js/translations/cs_CZ.js b/server/risorse/js/translations/cs_CZ.js new file mode 100644 index 0000000..00053bb --- /dev/null +++ b/server/risorse/js/translations/cs_CZ.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["leden","únor","březen","duben","květen","červen","červenec","srpen","září","říjen","listopad","prosinec"],monthsShort:["led","úno","bře","dub","kvě","čer","čvc","srp","zář","říj","lis","pro"],weekdaysFull:["neděle","pondělí","úterý","středa","čtvrtek","pátek","sobota"],weekdaysShort:["ne","po","út","st","čt","pá","so"],today:"dnes",clear:"vymazat",firstDay:1,format:"d. mmmm yyyy",formatSubmit:"yyyy/mm/dd",close:"zavřít"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"vymazat"}); \ No newline at end of file diff --git a/server/risorse/js/translations/da_DK.js b/server/risorse/js/translations/da_DK.js new file mode 100644 index 0000000..d83e9cb --- /dev/null +++ b/server/risorse/js/translations/da_DK.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["januar","februar","marts","april","maj","juni","juli","august","september","oktober","november","december"],monthsShort:["jan","feb","mar","apr","maj","jun","jul","aug","sep","okt","nov","dec"],weekdaysFull:["søndag","mandag","tirsdag","onsdag","torsdag","fredag","lørdag"],weekdaysShort:["søn","man","tir","ons","tor","fre","lør"],today:"i dag",clear:"slet",close:"luk",firstDay:1,format:"d. mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"slet"}); \ No newline at end of file diff --git a/server/risorse/js/translations/de_DE.js b/server/risorse/js/translations/de_DE.js new file mode 100644 index 0000000..4e07b28 --- /dev/null +++ b/server/risorse/js/translations/de_DE.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Januar","Februar","März","April","Mai","Juni","Juli","August","September","Oktober","November","Dezember"],monthsShort:["Jan","Feb","Mär","Apr","Mai","Jun","Jul","Aug","Sep","Okt","Nov","Dez"],weekdaysFull:["Sonntag","Montag","Dienstag","Mittwoch","Donnerstag","Freitag","Samstag"],weekdaysShort:["So","Mo","Di","Mi","Do","Fr","Sa"],today:"Heute",clear:"Löschen",close:"Schließen",firstDay:1,format:"dddd, dd. mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Löschen",format:"H:i"}); \ No newline at end of file diff --git a/server/risorse/js/translations/el_GR.js b/server/risorse/js/translations/el_GR.js new file mode 100644 index 0000000..06605f9 --- /dev/null +++ b/server/risorse/js/translations/el_GR.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Ιανουάριος","Φεβρουάριος","Μάρτιος","Απρίλιος","Μάιος","Ιούνιος","Ιούλιος","Αύγουστος","Σεπτέμβριος","Οκτώβριος","Νοέμβριος","Δεκέμβριος"],monthsShort:["Ιαν","Φεβ","Μαρ","Απρ","Μαι","Ιουν","Ιουλ","Αυγ","Σεπ","Οκτ","Νοε","Δεκ"],weekdaysFull:["Κυριακή","Δευτέρα","Τρίτη","Τετάρτη","Πέμπτη","Παρασκευή","Σάββατο"],weekdaysShort:["Κυρ","Δευ","Τρι","Τετ","Πεμ","Παρ","Σαβ"],today:"σήμερα",clear:"Διαγραφή",firstDay:1,format:"d mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Διαγραφή"}); \ No newline at end of file diff --git a/server/risorse/js/translations/es_ES.js b/server/risorse/js/translations/es_ES.js new file mode 100644 index 0000000..98eb363 --- /dev/null +++ b/server/risorse/js/translations/es_ES.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Enero","Febrero","Marzo","Abril","Mayo","Junio","Julio","Agosto","Septiembre","Octubre","Noviembre","Diciembre"],monthsShort:["ene","feb","mar","abr","may","jun","jul","ago","sep","oct","nov","dic"],weekdaysFull:["Domingo","Lunes","Martes","Miércoles","Jueves","Viernes","Sábado"],weekdaysShort:["dom","lun","mar","mié","jue","vie","sáb"],today:"Hoy",clear:"Borrar",close:"Cerrar",firstDay:1,format:"dddd d !de mmmm !de yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Borrar"}); \ No newline at end of file diff --git a/server/risorse/js/translations/et_EE.js b/server/risorse/js/translations/et_EE.js new file mode 100644 index 0000000..73ccd74 --- /dev/null +++ b/server/risorse/js/translations/et_EE.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["jaanuar","veebruar","märts","aprill","mai","juuni","juuli","august","september","oktoober","november","detsember"],monthsShort:["jaan","veebr","märts","apr","mai","juuni","juuli","aug","sept","okt","nov","dets"],weekdaysFull:["pühapäev","esmaspäev","teisipäev","kolmapäev","neljapäev","reede","laupäev"],weekdaysShort:["püh","esm","tei","kol","nel","ree","lau"],today:"täna",clear:"kustuta",firstDay:1,format:"d. mmmm yyyy. a",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"kustuta"}); \ No newline at end of file diff --git a/server/risorse/js/translations/eu_ES.js b/server/risorse/js/translations/eu_ES.js new file mode 100644 index 0000000..95370e1 --- /dev/null +++ b/server/risorse/js/translations/eu_ES.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["urtarrila","otsaila","martxoa","apirila","maiatza","ekaina","uztaila","abuztua","iraila","urria","azaroa","abendua"],monthsShort:["urt","ots","mar","api","mai","eka","uzt","abu","ira","urr","aza","abe"],weekdaysFull:["igandea","astelehena","asteartea","asteazkena","osteguna","ostirala","larunbata"],weekdaysShort:["ig.","al.","ar.","az.","og.","or.","lr."],today:"gaur",clear:"garbitu",firstDay:1,format:"dddd, yyyy(e)ko mmmmren da",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"garbitu"}); \ No newline at end of file diff --git a/server/risorse/js/translations/fa_IR.js b/server/risorse/js/translations/fa_IR.js new file mode 100644 index 0000000..8010c78 --- /dev/null +++ b/server/risorse/js/translations/fa_IR.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["ژانویه","فوریه","مارس","آوریل","مه","ژوئن","ژوئیه","اوت","سپتامبر","اکتبر","نوامبر","دسامبر"],monthsShort:["ژانویه","فوریه","مارس","آوریل","مه","ژوئن","ژوئیه","اوت","سپتامبر","اکتبر","نوامبر","دسامبر"],weekdaysFull:["یکشنبه","دوشنبه","سه شنبه","چهارشنبه","پنجشنبه","جمعه","شنبه"],weekdaysShort:["یکشنبه","دوشنبه","سه شنبه","چهارشنبه","پنجشنبه","جمعه","شنبه"],today:"امروز",clear:"پاک کردن",close:"بستن",format:"yyyy mmmm dd",formatSubmit:"yyyy/mm/dd",labelMonthNext:"ماه بعدی",labelMonthPrev:"ماه قبلی"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"پاک کردن"}); \ No newline at end of file diff --git a/server/risorse/js/translations/fi_FI.js b/server/risorse/js/translations/fi_FI.js new file mode 100644 index 0000000..77d14cf --- /dev/null +++ b/server/risorse/js/translations/fi_FI.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["tammikuu","helmikuu","maaliskuu","huhtikuu","toukokuu","kesäkuu","heinäkuu","elokuu","syyskuu","lokakuu","marraskuu","joulukuu"],monthsShort:["tammi","helmi","maalis","huhti","touko","kesä","heinä","elo","syys","loka","marras","joulu"],weekdaysFull:["sunnuntai","maanantai","tiistai","keskiviikko","torstai","perjantai","lauantai"],weekdaysShort:["su","ma","ti","ke","to","pe","la"],today:"tänään",clear:"tyhjennä",firstDay:1,format:"d.m.yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"tyhjennä"}); \ No newline at end of file diff --git a/server/risorse/js/translations/fr_FR.js b/server/risorse/js/translations/fr_FR.js new file mode 100644 index 0000000..b20cab7 --- /dev/null +++ b/server/risorse/js/translations/fr_FR.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Janvier","Février","Mars","Avril","Mai","Juin","Juillet","Août","Septembre","Octobre","Novembre","Décembre"],monthsShort:["Jan","Fev","Mar","Avr","Mai","Juin","Juil","Aou","Sep","Oct","Nov","Dec"],weekdaysFull:["Dimanche","Lundi","Mardi","Mercredi","Jeudi","Vendredi","Samedi"],weekdaysShort:["Dim","Lun","Mar","Mer","Jeu","Ven","Sam"],today:"Aujourd'hui",clear:"Effacer",close:"Fermer",firstDay:1,format:"dd mmmm yyyy",formatSubmit:"yyyy/mm/dd",labelMonthNext:"Mois suivant",labelMonthPrev:"Mois précédent",labelMonthSelect:"Sélectionner un mois",labelYearSelect:"Sélectionner une année"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Effacer",format:"H:i"}); \ No newline at end of file diff --git a/server/risorse/js/translations/ge_GEO.js b/server/risorse/js/translations/ge_GEO.js new file mode 100644 index 0000000..2ec1a5d --- /dev/null +++ b/server/risorse/js/translations/ge_GEO.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["იანვარი","თებერვალი","მარტი","აპრილი","მაისი","ივნისი","ივლისი","აგვისტო","სექტემბერი","ოქტომბერი","ნოემბერი","დეკემბერი"],monthsShort:["იან","თებ","მარტ","აპრ","მაი","ივნ","ივლ","აგვ","სექტ","ოქტ","ნოემ","დეკ"],weekdaysFull:["კვირა","ორშაბათი","სამშაბათი","ოთხშაბათი","ხუშაბათი","პარასკევი","შაბათი"],weekdaysShort:["კვ","ორ","სამ","ოთხ","ხუთ","პარ","შაბ"],today:"დღეს",clear:"გასუფთავება",firstDay:1,format:"d mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"გასუფთავება"}); \ No newline at end of file diff --git a/server/risorse/js/translations/gl_ES.js b/server/risorse/js/translations/gl_ES.js new file mode 100644 index 0000000..1d87803 --- /dev/null +++ b/server/risorse/js/translations/gl_ES.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Xaneiro","Febreiro","Marzo","Abril","Maio","Xuño","Xullo","Agosto","Setembro","Outubro","Novembro","Decembro"],monthsShort:["xan","feb","mar","abr","mai","xun","xul","ago","sep","out","nov","dec"],weekdaysFull:["domingo","luns","martes","mércores","xoves","venres","sábado"],weekdaysShort:["dom","lun","mar","mér","xov","ven","sab"],today:"hoxe",clear:"borrar",firstDay:1,format:"dddd d !de mmmm !de yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"borrar"}); \ No newline at end of file diff --git a/server/risorse/js/translations/he_IL.js b/server/risorse/js/translations/he_IL.js new file mode 100644 index 0000000..d00f5b3 --- /dev/null +++ b/server/risorse/js/translations/he_IL.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["ינואר","פברואר","מרץ","אפריל","מאי","יוני","יולי","אוגוסט","ספטמבר","אוקטובר","נובמבר","דצמבר"],monthsShort:["ינו","פבר","מרץ","אפר","מאי","יונ","יול","אוג","ספט","אוק","נוב","דצמ"],weekdaysFull:["יום ראשון","יום שני","יום שלישי","יום רביעי","יום חמישי","יום ששי","יום שבת"],weekdaysShort:["א","ב","ג","ד","ה","ו","ש"],today:"היום",clear:"למחוק",format:"yyyy mmmmב d dddd",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"למחוק"}); \ No newline at end of file diff --git a/server/risorse/js/translations/hi_IN.js b/server/risorse/js/translations/hi_IN.js new file mode 100644 index 0000000..d731287 --- /dev/null +++ b/server/risorse/js/translations/hi_IN.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["जनवरी","फरवरी","मार्च","अप्रैल","मई","जून","जुलाई","अगस्त","सितम्बर","अक्टूबर","नवम्बर","दिसम्बर"],monthsShort:["जन","फर","मार्च","अप्रैल","मई","जून","जु","अग","सित","अक्टू","नव","दिस"],weekdaysFull:["रविवार","सोमवार","मंगलवार","बुधवार","गुरुवार","शुक्रवार","शनिवार"],weekdaysShort:["रवि","सोम","मंगल","बुध","गुरु","शुक्र","शनि"],today:"आज की तारीख चयन करें",clear:"चुनी हुई तारीख को मिटाएँ",close:"विंडो बंद करे",firstDay:1,format:"dd/mm/yyyy",formatSubmit:"yyyy/mm/dd",labelMonthNext:"अगले माह का चयन करें",labelMonthPrev:"पिछले माह का चयन करें",labelMonthSelect:"किसि एक महीने का चयन करें",labelYearSelect:"किसि एक वर्ष का चयन करें"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"चुनी हुई तारीख को मिटाएँ"}); \ No newline at end of file diff --git a/server/risorse/js/translations/hr_HR.js b/server/risorse/js/translations/hr_HR.js new file mode 100644 index 0000000..6e29c7f --- /dev/null +++ b/server/risorse/js/translations/hr_HR.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["siječanj","veljača","ožujak","travanj","svibanj","lipanj","srpanj","kolovoz","rujan","listopad","studeni","prosinac"],monthsShort:["sij","velj","ožu","tra","svi","lip","srp","kol","ruj","lis","stu","pro"],weekdaysFull:["nedjelja","ponedjeljak","utorak","srijeda","četvrtak","petak","subota"],weekdaysShort:["ned","pon","uto","sri","čet","pet","sub"],today:"Danas",clear:"Izbriši",close:"Zatvori",firstDay:1,format:"d. mmmm yyyy.",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Izbriši"}); \ No newline at end of file diff --git a/server/risorse/js/translations/hu_HU.js b/server/risorse/js/translations/hu_HU.js new file mode 100644 index 0000000..8cca4be --- /dev/null +++ b/server/risorse/js/translations/hu_HU.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["január","február","március","április","május","június","július","augusztus","szeptember","október","november","december"],monthsShort:["jan","febr","márc","ápr","máj","jún","júl","aug","szept","okt","nov","dec"],weekdaysFull:["vasárnap","hétfő","kedd","szerda","csütörtök","péntek","szombat"],weekdaysShort:["V","H","K","Sze","CS","P","Szo"],today:"Ma",clear:"Törlés",close:"Bezárás",firstDay:1,format:"yyyy. mmmm dd.",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Törlés"}); \ No newline at end of file diff --git a/server/risorse/js/translations/id_ID.js b/server/risorse/js/translations/id_ID.js new file mode 100644 index 0000000..9333a42 --- /dev/null +++ b/server/risorse/js/translations/id_ID.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Januari","Februari","Maret","April","Mei","Juni","Juli","Agustus","September","Oktober","November","Desember"],monthsShort:["Jan","Feb","Mar","Apr","Mei","Jun","Jul","Agu","Sep","Okt","Nov","Des"],weekdaysFull:["Minggu","Senin","Selasa","Rabu","Kamis","Jumat","Sabtu"],weekdaysShort:["Min","Sen","Sel","Rab","Kam","Jum","Sab"],today:"hari ini",clear:"menghapus",firstDay:1,format:"d mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"menghapus"}); \ No newline at end of file diff --git a/server/risorse/js/translations/is_IS.js b/server/risorse/js/translations/is_IS.js new file mode 100644 index 0000000..a324705 --- /dev/null +++ b/server/risorse/js/translations/is_IS.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["janúar","febrúar","mars","apríl","maí","júní","júlí","ágúst","september","október","nóvember","desember"],monthsShort:["jan","feb","mar","apr","maí","jún","júl","ágú","sep","okt","nóv","des"],weekdaysFull:["sunnudagur","mánudagur","þriðjudagur","miðvikudagur","fimmtudagur","föstudagur","laugardagur"],weekdaysShort:["sun","mán","þri","mið","fim","fös","lau"],today:"Í dag",clear:"Hreinsa",firstDay:1,format:"dd. mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Hreinsa"}); \ No newline at end of file diff --git a/server/risorse/js/translations/it_IT.js b/server/risorse/js/translations/it_IT.js new file mode 100644 index 0000000..19dd26f --- /dev/null +++ b/server/risorse/js/translations/it_IT.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["gennaio","febbraio","marzo","aprile","maggio","giugno","luglio","agosto","settembre","ottobre","novembre","dicembre"],monthsShort:["gen","feb","mar","apr","mag","giu","lug","ago","set","ott","nov","dic"],weekdaysFull:["domenica","lunedì","martedì","mercoledì","giovedì","venerdì","sabato"],weekdaysShort:["dom","lun","mar","mer","gio","ven","sab"],today:"Oggi",clear:"Cancella",close:"Chiudi",firstDay:1,format:"dddd d mmmm yyyy",formatSubmit:"yyyy/mm/dd",labelMonthNext:"Mese successivo",labelMonthPrev:"Mese precedente",labelMonthSelect:"Seleziona un mese",labelYearSelect:"Seleziona un anno"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Cancella",format:"HH:i",formatSubmit:"HH:i"}); \ No newline at end of file diff --git a/server/risorse/js/translations/ja_JP.js b/server/risorse/js/translations/ja_JP.js new file mode 100644 index 0000000..25c9bbe --- /dev/null +++ b/server/risorse/js/translations/ja_JP.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],monthsShort:["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],weekdaysFull:["日曜日","月曜日","火曜日","水曜日","木曜日","金曜日","土曜日"],weekdaysShort:["日","月","火","水","木","金","土"],today:"今日",clear:"消去",close:"閉じる",firstDay:1,format:"yyyy年mm月dd日",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"消去"}); \ No newline at end of file diff --git a/server/risorse/js/translations/km_KH.js b/server/risorse/js/translations/km_KH.js new file mode 100644 index 0000000..d2f5322 --- /dev/null +++ b/server/risorse/js/translations/km_KH.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["មករា","កុម្ភៈ","មីនា","មេសា","ឧសភា","មិថុនា","កក្កដា","សីហា","កញ្ញា","តុលា","វិច្ឆិកា","ធ្នូ"],monthsShort:["មក.","កុ.","មី.","មេ.","ឧស.","មិថុ.","កក្ក.","សី.","កញ.","តុ.","វិច្ឆ.","ធ."],weekdaysFull:["អាទិត្យ","ចន្ទ","អង្គារ","ពុធ","ព្រហស្បតិ៍","សុក្រ","សៅរ៍"],weekdaysShort:["អា.","ច.","អ.","ព.","ព្រ.","សុ.","ស."],today:"ថ្ងៃនេះ",clear:"លុប",close:"បិទ",labelMonthNext:"ខែបន្ទាប់",labelMonthPrev:"ខែមុន",labelMonthSelect:"ជ្រើសរើសខែ",labelYearSelect:"ជ្រើសរើសឆ្នាំ",firstDay:1,showMonthsShort:!1,showWeekdaysFull:!0,format:"ថ្ងៃទី d ខែmmmm ឆ្នាំ yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"លុប"}); \ No newline at end of file diff --git a/server/risorse/js/translations/ko_KR.js b/server/risorse/js/translations/ko_KR.js new file mode 100644 index 0000000..c7d428d --- /dev/null +++ b/server/risorse/js/translations/ko_KR.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["1월","2월","3월","4월","5월","6월","7월","8월","9월","10월","11월","12월"],monthsShort:["1월","2월","3월","4월","5월","6월","7월","8월","9월","10월","11월","12월"],weekdaysFull:["일요일","월요일","화요일","수요일","목요일","금요일","토요일"],weekdaysShort:["일","월","화","수","목","금","토"],today:"오늘",clear:"취소",firstDay:1,format:"yyyy 년 mm 월 dd 일",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"취소"}); \ No newline at end of file diff --git a/server/risorse/js/translations/lt_LT.js b/server/risorse/js/translations/lt_LT.js new file mode 100644 index 0000000..348f9cb --- /dev/null +++ b/server/risorse/js/translations/lt_LT.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{labelMonthNext:"Sekantis mėnuo",labelMonthPrev:"Ankstesnis mėnuo",labelMonthSelect:"Pasirinkite mėnesį",labelYearSelect:"Pasirinkite metus",monthsFull:["Sausis","Vasaris","Kovas","Balandis","Gegužė","Birželis","Liepa","Rugpjūtis","Rugsėjis","Spalis","Lapkritis","Gruodis"],monthsShort:["Sau","Vas","Kov","Bal","Geg","Bir","Lie","Rgp","Rgs","Spa","Lap","Grd"],weekdaysFull:["Sekmadienis","Pirmadienis","Antradienis","Trečiadienis","Ketvirtadienis","Penktadienis","Šeštadienis"],weekdaysShort:["Sk","Pr","An","Tr","Kt","Pn","Št"],today:"Šiandien",clear:"Išvalyti",close:"Uždaryti",firstDay:1,format:"yyyy-mm-dd",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Išvalyti",format:"HH:i"}); \ No newline at end of file diff --git a/server/risorse/js/translations/lv_LV.js b/server/risorse/js/translations/lv_LV.js new file mode 100644 index 0000000..4f3bfd1 --- /dev/null +++ b/server/risorse/js/translations/lv_LV.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Janvāris","Februāris","Marts","Aprīlis","Maijs","Jūnijs","Jūlijs","Augusts","Septembris","Oktobris","Novembris","Decembris"],monthsShort:["Jan","Feb","Mar","Apr","Mai","Jūn","Jūl","Aug","Sep","Okt","Nov","Dec"],weekdaysFull:["Svētdiena","Pirmdiena","Otrdiena","Trešdiena","Ceturtdiena","Piektdiena","Sestdiena"],weekdaysShort:["Sv","P","O","T","C","Pk","S"],today:"Šodiena",clear:"Dzēst",close:"Aizvērt",firstDay:1,format:"yyyy.mm.dd. dddd",formatSubmit:"yyyy/mm/dd",labelMonthNext:"Nākamais mēnesis",labelMonthPrev:"Iepriekšējais mēnesis",labelMonthSelect:"Izvēlēties mēnesi",labelYearSelect:"Izvēlēties gadu"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Dzēst"}); \ No newline at end of file diff --git a/server/risorse/js/translations/nb_NO.js b/server/risorse/js/translations/nb_NO.js new file mode 100644 index 0000000..1c88146 --- /dev/null +++ b/server/risorse/js/translations/nb_NO.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["januar","februar","mars","april","mai","juni","juli","august","september","oktober","november","desember"],monthsShort:["jan","feb","mar","apr","mai","jun","jul","aug","sep","okt","nov","des"],weekdaysFull:["søndag","mandag","tirsdag","onsdag","torsdag","fredag","lørdag"],weekdaysShort:["søn","man","tir","ons","tor","fre","lør"],today:"i dag",clear:"nullstill",close:"lukk",firstDay:1,format:"dd. mmm. yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"nullstill"}); \ No newline at end of file diff --git a/server/risorse/js/translations/ne_NP.js b/server/risorse/js/translations/ne_NP.js new file mode 100644 index 0000000..e391f2b --- /dev/null +++ b/server/risorse/js/translations/ne_NP.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["जनवरी","फेब्रुअरी","मार्च","अप्रिल","मे","जुन","जुलाई","अगस्त","सेप्टेम्बर","अक्टोबर","नोवेम्बर","डिसेम्बर"],monthsShort:["जन","फेब्रु","मार्च","अप्रिल","मे","जुन","जुल","अग","सेप्टे","अक्टो","नोभे","डिसे"],weekdaysFull:["सोमबार","मङ्लबार","बुधबार","बिहीबार","शुक्रबार","शनिबार","आईतबार"],weekdaysShort:["सोम","मंगल्","बुध","बिही","शुक्र","शनि","आईत"],numbers:["०","१","२","३","४","५","६","७","८","९"],today:"आज",clear:"मेटाउनुहोस्",format:"dddd, dd mmmm, yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"मेटाउनुहोस्"}); \ No newline at end of file diff --git a/server/risorse/js/translations/nl_NL.js b/server/risorse/js/translations/nl_NL.js new file mode 100644 index 0000000..144511f --- /dev/null +++ b/server/risorse/js/translations/nl_NL.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["januari","februari","maart","april","mei","juni","juli","augustus","september","oktober","november","december"],monthsShort:["jan","feb","mrt","apr","mei","jun","jul","aug","sep","okt","nov","dec"],weekdaysFull:["zondag","maandag","dinsdag","woensdag","donderdag","vrijdag","zaterdag"],weekdaysShort:["zo","ma","di","wo","do","vr","za"],today:"vandaag",clear:"wissen",close:"sluiten",firstDay:1,format:"dddd d mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"wissen"}); \ No newline at end of file diff --git a/server/risorse/js/translations/no_NO.js b/server/risorse/js/translations/no_NO.js new file mode 100644 index 0000000..bdcf262 --- /dev/null +++ b/server/risorse/js/translations/no_NO.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["januar","februar","mars","april","mai","juni","juli","august","september","oktober","november","desember"],monthsShort:["jan","feb","mar","apr","mai","jun","jul","aug","sep","okt","nov","des"],weekdaysFull:["søndag","mandag","tirsdag","onsdag","torsdag","fredag","lørdag"],weekdaysShort:["søn","man","tir","ons","tor","fre","lør"],today:"i dag",clear:"nullstill",firstDay:1,format:"dd. mmm. yyyy",formatSubmit:"yyyy/mm/dd"}); \ No newline at end of file diff --git a/server/risorse/js/translations/pl_PL.js b/server/risorse/js/translations/pl_PL.js new file mode 100644 index 0000000..2afdecf --- /dev/null +++ b/server/risorse/js/translations/pl_PL.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["styczeń","luty","marzec","kwiecień","maj","czerwiec","lipiec","sierpień","wrzesień","październik","listopad","grudzień"],monthsShort:["sty","lut","mar","kwi","maj","cze","lip","sie","wrz","paź","lis","gru"],weekdaysFull:["niedziela","poniedziałek","wtorek","środa","czwartek","piątek","sobota"],weekdaysShort:["niedz.","pn.","wt.","śr.","cz.","pt.","sob."],today:"Dzisiaj",clear:"Usuń",close:"Zamknij",firstDay:1,format:"d mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"usunąć"}); \ No newline at end of file diff --git a/server/risorse/js/translations/pt_BR.js b/server/risorse/js/translations/pt_BR.js new file mode 100644 index 0000000..31bd211 --- /dev/null +++ b/server/risorse/js/translations/pt_BR.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["janeiro","fevereiro","março","abril","maio","junho","julho","agosto","setembro","outubro","novembro","dezembro"],monthsShort:["jan","fev","mar","abr","mai","jun","jul","ago","set","out","nov","dez"],weekdaysFull:["domingo","segunda-feira","terça-feira","quarta-feira","quinta-feira","sexta-feira","sábado"],weekdaysShort:["dom","seg","ter","qua","qui","sex","sab"],today:"hoje",clear:"limpar",close:"fechar",format:"dddd, d !de mmmm !de yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"limpar"}); \ No newline at end of file diff --git a/server/risorse/js/translations/pt_PT.js b/server/risorse/js/translations/pt_PT.js new file mode 100644 index 0000000..46e39ff --- /dev/null +++ b/server/risorse/js/translations/pt_PT.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Janeiro","Fevereiro","Março","Abril","Maio","Junho","Julho","Agosto","Setembro","Outubro","Novembro","Dezembro"],monthsShort:["jan","fev","mar","abr","mai","jun","jul","ago","set","out","nov","dez"],weekdaysFull:["Domingo","Segunda","Terça","Quarta","Quinta","Sexta","Sábado"],weekdaysShort:["dom","seg","ter","qua","qui","sex","sab"],today:"Hoje",clear:"Limpar",close:"Fechar",format:"d !de mmmm !de yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Limpar"}); \ No newline at end of file diff --git a/server/risorse/js/translations/ro_RO.js b/server/risorse/js/translations/ro_RO.js new file mode 100644 index 0000000..7c52076 --- /dev/null +++ b/server/risorse/js/translations/ro_RO.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["ianuarie","februarie","martie","aprilie","mai","iunie","iulie","august","septembrie","octombrie","noiembrie","decembrie"],monthsShort:["ian","feb","mar","apr","mai","iun","iul","aug","sep","oct","noi","dec"],weekdaysFull:["duminică","luni","marţi","miercuri","joi","vineri","sâmbătă"],weekdaysShort:["D","L","Ma","Mi","J","V","S"],today:"azi",clear:"șterge",firstDay:1,format:"dd mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"șterge"}); \ No newline at end of file diff --git a/server/risorse/js/translations/ru_RU.js b/server/risorse/js/translations/ru_RU.js new file mode 100644 index 0000000..59f19fd --- /dev/null +++ b/server/risorse/js/translations/ru_RU.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["января","февраля","марта","апреля","мая","июня","июля","августа","сентября","октября","ноября","декабря"],monthsShort:["янв","фев","мар","апр","май","июн","июл","авг","сен","окт","ноя","дек"],weekdaysFull:["воскресенье","понедельник","вторник","среда","четверг","пятница","суббота"],weekdaysShort:["вс","пн","вт","ср","чт","пт","сб"],today:"сегодня",clear:"удалить",close:"закрыть",firstDay:1,format:"d mmmm yyyy г.",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"удалить"}); \ No newline at end of file diff --git a/server/risorse/js/translations/sk_SK.js b/server/risorse/js/translations/sk_SK.js new file mode 100644 index 0000000..e640f03 --- /dev/null +++ b/server/risorse/js/translations/sk_SK.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["január","február","marec","apríl","máj","jún","júl","august","september","október","november","december"],monthsShort:["jan","feb","mar","apr","máj","jún","júl","aug","sep","okt","nov","dec"],weekdaysFull:["nedeľa","pondelok","utorok","streda","štvrtok","piatok","sobota"],weekdaysShort:["Ne","Po","Ut","St","Št","Pi","So"],today:"dnes",clear:"vymazať",close:"zavrieť",firstDay:1,format:"d. mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"vymazať"}); \ No newline at end of file diff --git a/server/risorse/js/translations/sl_SI.js b/server/risorse/js/translations/sl_SI.js new file mode 100644 index 0000000..8a94db2 --- /dev/null +++ b/server/risorse/js/translations/sl_SI.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["januar","februar","marec","april","maj","junij","julij","avgust","september","oktober","november","december"],monthsShort:["jan","feb","mar","apr","maj","jun","jul","avg","sep","okt","nov","dec"],weekdaysFull:["nedelja","ponedeljek","torek","sreda","četrtek","petek","sobota"],weekdaysShort:["ned","pon","tor","sre","čet","pet","sob"],today:"danes",clear:"izbriši",close:"zapri",firstDay:1,format:"d. mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"izbriši"}); \ No newline at end of file diff --git a/server/risorse/js/translations/sr_RS_cy.js b/server/risorse/js/translations/sr_RS_cy.js new file mode 100644 index 0000000..1d9683a --- /dev/null +++ b/server/risorse/js/translations/sr_RS_cy.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["јануар","фебруар","март","април","мај","јун","јул","август","септембар","октобар","новембар","децембар"],monthsShort:["јан.","феб.","март","апр.","мај","јун","јул","авг.","септ.","окт.","нов.","дец."],weekdaysFull:["недеља","понедељак","уторак","среда","четвртак","петак","субота"],weekdaysShort:["нед.","пон.","ут.","ср.","чет.","пет.","суб."],today:"данас",clear:"избриши",close:"затвори",firstDay:1,format:"d. MMMM yyyy.",formatSubmit:"yyyy/mm/dd",labelMonthNext:"Следећи месец",labelMonthPrev:"Претходни месец",labelMonthSelect:"Изаберите месец",labelYearSelect:"Изаберите годину"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"избриши"}); \ No newline at end of file diff --git a/server/risorse/js/translations/sr_RS_lt.js b/server/risorse/js/translations/sr_RS_lt.js new file mode 100644 index 0000000..606cbf3 --- /dev/null +++ b/server/risorse/js/translations/sr_RS_lt.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["januar","februar","mart","april","maj","jun","juli","avgust","septembar","oktobar","novembar","decembar"],monthsShort:["jan.","feb.","mart","apr.","maj","jun","jul","avg.","sept.","okt.","nov.","dec."],weekdaysFull:["nedelja","ponedeljak","utorak","sreda","četvrtak","petak","subota"],weekdaysShort:["ned.","pon.","ut.","sr.","čet.","pet.","sub."],today:"danas",clear:"izbriši",close:"zatvori",firstDay:1,format:"d. MMMM yyyy.",formatSubmit:"yyyy/mm/dd",labelMonthNext:"Sledeći mesec",labelMonthPrev:"Prethodni mesec",labelMonthSelect:"Izaberite mesec",labelYearSelect:"Izaberite godinu"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"izbriši"}); \ No newline at end of file diff --git a/server/risorse/js/translations/sv_SE.js b/server/risorse/js/translations/sv_SE.js new file mode 100644 index 0000000..028870d --- /dev/null +++ b/server/risorse/js/translations/sv_SE.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["januari","februari","mars","april","maj","juni","juli","augusti","september","oktober","november","december"],monthsShort:["jan","feb","mar","apr","maj","jun","jul","aug","sep","okt","nov","dec"],weekdaysFull:["söndag","måndag","tisdag","onsdag","torsdag","fredag","lördag"],weekdaysShort:["sön","mån","tis","ons","tor","fre","lör"],today:"Idag",clear:"Rensa",close:"Stäng",firstDay:1,format:"yyyy-mm-dd",formatSubmit:"yyyy/mm/dd",labelMonthNext:"Nästa månad",labelMonthPrev:"Föregående månad",labelMonthSelect:"Välj månad",labelYearSelect:"Välj år"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Rensa"}); \ No newline at end of file diff --git a/server/risorse/js/translations/th_TH.js b/server/risorse/js/translations/th_TH.js new file mode 100644 index 0000000..2e64bc2 --- /dev/null +++ b/server/risorse/js/translations/th_TH.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["มกราคม","กุมภาพันธ์","มีนาคม","เมษายน","พฤษภาคม","มิถุนายน","กรกฎาคม","สิงหาคม","กันยายน","ตุลาคม","พฤศจิกายน","ธันวาคม"],monthsShort:["ม.ค.","ก.พ.","มี.ค.","เม.ย.","พ.ค.","มิ.ย.","ก.ค.","ส.ค.","ก.ย.","ต.ค.","พ.ย.","ธ.ค."],weekdaysFull:["อาทิตย์","จันทร์","อังคาร","พุธ","พฤหัสบดี","ศุกร์","เสาร์"],weekdaysShort:["อา.","จ.","อ.","พ.","พฤ.","ศ.","ส."],today:"วันนี้",clear:"ลบ",format:"d mmmm yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"ลบ"}); \ No newline at end of file diff --git a/server/risorse/js/translations/tr_TR.js b/server/risorse/js/translations/tr_TR.js new file mode 100644 index 0000000..777dd5c --- /dev/null +++ b/server/risorse/js/translations/tr_TR.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Ocak","Şubat","Mart","Nisan","Mayıs","Haziran","Temmuz","Ağustos","Eylül","Ekim","Kasım","Aralık"],monthsShort:["Oca","Şub","Mar","Nis","May","Haz","Tem","Ağu","Eyl","Eki","Kas","Ara"],weekdaysFull:["Pazar","Pazartesi","Salı","Çarşamba","Perşembe","Cuma","Cumartesi"],weekdaysShort:["Pzr","Pzt","Sal","Çrş","Prş","Cum","Cmt"],today:"Bugün",clear:"Sil",close:"Kapat",firstDay:1,format:"dd mmmm yyyy dddd",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"sil"}); \ No newline at end of file diff --git a/server/risorse/js/translations/uk_UA.js b/server/risorse/js/translations/uk_UA.js new file mode 100644 index 0000000..87b5e2f --- /dev/null +++ b/server/risorse/js/translations/uk_UA.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["січень","лютий","березень","квітень","травень","червень","липень","серпень","вересень","жовтень","листопад","грудень"],monthsShort:["січ","лют","бер","кві","тра","чер","лип","сер","вер","жов","лис","гру"],weekdaysFull:["неділя","понеділок","вівторок","середа","четвер","п‘ятниця","субота"],weekdaysShort:["нд","пн","вт","ср","чт","пт","сб"],today:"сьогодні",clear:"викреслити",firstDay:1,format:"dd mmmm yyyy p.",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"викреслити"}); \ No newline at end of file diff --git a/server/risorse/js/translations/vi_VN.js b/server/risorse/js/translations/vi_VN.js new file mode 100644 index 0000000..f0562c1 --- /dev/null +++ b/server/risorse/js/translations/vi_VN.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["Tháng Một","Tháng Hai","Tháng Ba","Tháng Tư","Tháng Năm","Tháng Sáu","Tháng Bảy","Tháng Tám","Tháng Chín","Tháng Mười","Tháng Mười Một","Tháng Mười Hai"],monthsShort:["Một","Hai","Ba","Tư","Năm","Sáu","Bảy","Tám","Chín","Mười","Mười Một","Mười Hai"],weekdaysFull:["Chủ Nhật","Thứ Hai","Thứ Ba","Thứ Tư","Thứ Năm","Thứ Sáu","Thứ Bảy"],weekdaysShort:["C.Nhật","T.Hai","T.Ba","T.Tư","T.Năm","T.Sáu","T.Bảy"],today:"Hôm Nay",clear:"Xoá",close:"Đóng",firstDay:1,format:"Bạn chọn: dddd, dd mmmm, yyyy",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"Xoá"}); \ No newline at end of file diff --git a/server/risorse/js/translations/zh_CN.js b/server/risorse/js/translations/zh_CN.js new file mode 100644 index 0000000..a721ee5 --- /dev/null +++ b/server/risorse/js/translations/zh_CN.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"],monthsShort:["一","二","三","四","五","六","七","八","九","十","十一","十二"],weekdaysFull:["星期日","星期一","星期二","星期三","星期四","星期五","星期六"],weekdaysShort:["日","一","二","三","四","五","六"],today:"今天",clear:"清除",close:"关闭",firstDay:1,format:"yyyy 年 mm 月 dd 日",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"清除"}); \ No newline at end of file diff --git a/server/risorse/js/translations/zh_TW.js b/server/risorse/js/translations/zh_TW.js new file mode 100644 index 0000000..fc8b0db --- /dev/null +++ b/server/risorse/js/translations/zh_TW.js @@ -0,0 +1 @@ +jQuery.extend(jQuery.fn.pickadate.defaults,{monthsFull:["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"],monthsShort:["一","二","三","四","五","六","七","八","九","十","十一","十二"],weekdaysFull:["星期日","星期一","星期二","星期三","星期四","星期五","星期六"],weekdaysShort:["日","一","二","三","四","五","六"],today:"今天",clear:"清除",close:"關閉",firstDay:1,format:"yyyy 年 mm 月 dd 日",formatSubmit:"yyyy/mm/dd"}),jQuery.extend(jQuery.fn.pickatime.defaults,{clear:"清除"}); \ No newline at end of file diff --git a/server/risorse/musiche/non_hai_detto_la_parola_magica.mp3 b/server/risorse/musiche/non_hai_detto_la_parola_magica.mp3 new file mode 100644 index 0000000..e58ca21 Binary files /dev/null and b/server/risorse/musiche/non_hai_detto_la_parola_magica.mp3 differ diff --git a/server/secure.php b/server/secure.php new file mode 100644 index 0000000..cf7bf38 --- /dev/null +++ b/server/secure.php @@ -0,0 +1,371 @@ +$valore){ + if(!is_array($valore) && isset($valore) && !empty($valore)){ + if(substr($valore, 0, 6) == '$post-'){ + $valore = substr($valore, 6); + if(isset($_POST[$valore])){ + $valore = $_POST[$valore]; + } + } + } + if($continuo){ + if(!is_array($valore)){ + bdump($valore); + bdump("_"); + $validazione = $this->validazione_form($valore, $noempty, $valore); + if(!$validazione){ + $continuo = false; + return false; + } + } + } + } + if($continuo){ + bdump("passato con"); + bdump($data); + return true; + } + } + } else if(isset($data)) { + if(!empty($data)){ + if(!is_null($valore)){ + return $valore == $data; + } else { + bdump("non dovrebbe succedere"); + bdump($data); + return true; + } + } else { + return false; + } + } else { + return false; + } + } + + public function get_ip(){ + if(!empty($_SERVER['HTTP_CLIENT_IP'])){ + $ip = $_SERVER['HTTP_CLIENT_IP']; + }elseif(!empty($_SERVER['HTTP_X_FORWARDED_FOR'])){ + $ip = $_SERVER['HTTP_X_FORWARDED_FOR']; + }else{ + $ip = $_SERVER['REMOTE_ADDR']; + } + if(SERVER_UNDER_CF){ + if(!empty($_SERVER['HTTP_CF_CONNECTING_IP'])){ + $ip = $_SERVER['HTTP_CF_CONNECTING_IP']; + } + } + return $ip; + } + + public function get_page_url(){ + if(!empty($_SERVER["HTTPS"])){ + if($_SERVER["HTTPS"] == "on"){ + $protocol = "https"; + } else { + $protocol = "http"; + } + } else { + $protocol = "http"; + } + $port = ($_SERVER["SERVER_PORT"] == "80") ? "" : (":".$_SERVER["SERVER_PORT"]); + return $protocol . "://" . $_SERVER['SERVER_NAME'] . $port . $_SERVER['REQUEST_URI']; + } + + public function redirect($url){ + if (!headers_sent()){ + header('Location: '.$url); + exit; + } else { + echo ''; + echo ''; + } + } + function extract_unique($data){ + $array2=[]; + foreach($data as $arr){ + if(is_array($arr)){ + $tmp = $this->extract_unique($arr); + foreach($tmp as $temp){ + if(!is_array($temp)){ + if(!in_array($temp, $array2)){ + $array2[] = $temp; + } + } + + } + } else { + if(!in_array($arr, $array2)){ + $array2[] = $arr; + } + } + } + return $array2; + } +} + +class database{ + protected $db_host = DB_HOST; + protected $db_dbname = DB_NAME; + protected $db_username = DB_USER; + protected $db_password = DB_PASSWORD; + public $connessione = null; + public $query = null; + public $stmt = null; + + public function connetti(){ + try { + $this->connessione = new PDO("mysql:host=" . $this->db_host . ";dbname=" . $this->db_dbname, $this->db_username, $this->db_password); + $this->connessione->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); + $this->connessione->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); + } + catch(PDOException $e) + { + exit($e->getMessage()); + } + } + + public function __construct(){ + if(!defined("DATABASE")){ + define("DATABASE", "OK"); + } + $this->connetti(); + } + + public function close(){ + $this->connessione = null; + } + + public function esegui($sql, $fetch=false, $param=null){ + try{ + $this->connessione->beginTransaction(); + $this->stmt = $this->connessione->prepare($sql); + if(!is_null($param)){ + $this->query = $this->stmt->execute($param); + } else { + $this->query = $this->stmt->execute(); + } + bdump($this->query); + $this->connessione->commit(); + if($fetch == true){ + return $this->stmt->fetchAll(PDO::FETCH_ASSOC); + } + $this->stmt->closeCursor(); + } catch (PDOException $e) { + print "Errore!: " . $e->getMessage() . "
"; + $this->connessione->rollBack(); + die(); + } + } + + public function esiste($tabella, $id){ + $risultato = $this->esegui("SELECT :tabella FROM interventi WHERE id = :id;", true, [":tabella" => $tabella, ":id" => $id]); + return !empty($risultato); + } + + public function aggiungi_intervento($data, $codice, $uscita, $rientro, $capo, $autisti, $personale, $luogo, $note, $tipo, $incrementa, $inseritoda){ + $autisti = implode(",", $autisti); + bdump($autisti); + $personale = implode(",", $personale); + bdump($personale); + $incrementa = implode(",", $incrementa); + bdump($incrementa); + $sql = "INSERT INTO `interventi` (`id`, `data`, `codice`, `uscita`, `rientro`, `capo`, `autisti`, `personale`, `luogo`, `note`, `tipo`, `incrementa`, `inseritoda`) VALUES (NULL, :data, :codice, :uscita, :rientro, :capo, :autisti, :personale, :luogo, :note, :tipo, :incrementa, :inseritoda); + UPDATE `vigili` SET `interventi`= interventi + 1 WHERE id IN (:incrementa);"; + $this->esegui($sql, false, [":data" => $data, ":codice" => $codice, "uscita" => $uscita, ":rientro" => $rientro, ":capo" => $capo, ":autisti" => $autisti, ":personale" => $personale, ":luogo" => $luogo, ":note" => $note, ":tipo" => $tipo, ":incrementa" => $incrementa, ":inseritoda" => $inseritoda]); // Non posso eseguire 2 query pdo con salvate le query nella classe dalla classe. Devo eseguirne 1 sola + } +} + +class user{ + private $database = null; + private $tools = null; + + public function __construct($database, $tools){ + $this->database = $database; + $this->tools = $tools; + define("LOGIN", "OK"); + } + + public function autenticato(){ + if(isset($_SESSION['accesso'])){ + return true; + } else { + return false; + } + } + + public function richiedilogin(){ + if(!$this->autenticato()){ + if(INTRUSION_SAVE){ + if(INTRUSION_SAVE_INFO){ + $parametri = [":pagina" => $this->tools->get_page_url(), ":ip" => $this->tools->get_ip(), ":data" => date("d/m/Y"), ":ora" => date("H:i.s"), ":servervar" => json_encode($_SERVER)]; + } else { + $parametri = [":pagina" => $this->tools->get_page_url(), ":ip" => "redacted", ":data" => date("d/m/Y"), ":ora" => date("H:i.s"), ":servervar" => json_encode(["redacted" => "true"])]; + } + $sql = "INSERT INTO `intrusioni` (`id`, `pagina`, `data`, `ora`, `ip`, `servervar`) VALUES (NULL, :pagina, :data, :ora, :ip, :servervar)"; + $this->database->esegui($sql, false, $parametri); + } + $this->tools->redirect(WEB_URL); + } + } + + public function admin(){ + if(isset($_SESSION['admin'])){ + if($_SESSION['admin'] == 1){ + return true; + } else { + return false; + } + } else { + return false; + } + } + public function nome($replace=false){ + if(isset($_SESSION['nome'])){ + if($replace){ + return str_replace(" ", "_", $_SESSION['nome']); + } else { + return $_SESSION['nome']; + } + } else { + return "non autenticato"; + } + } + + public function nome_by_id($id){ + $vigile = $this->database->esegui("SELECT nome FROM vigili WHERE id = :id;", true, [":id" => $id]); + if(empty($vigile)){ + return false; + } else { + return $vigile[0]["nome"]; + } + } + + public function disponibile($nome){ + $vigile = $this->database->esegui("SELECT disponibile FROM vigili WHERE nome = :nome;", true, [":nome" => $nome]); + if(empty($vigile)){ + return false; + } else { + return $vigile[0]["disponibile"]; + } + } + + public function whitelist($array = true, $str = ", "){ + $array_data = array("test", "test2", "test3"); + if($array){ + return $array_data; + } else if(!$array){ + return implode((string) $str, $array_data); + } + } + public function info(){ + return array("nome" => $this->nome(), "admin" => $this->admin(), "codice" => "TODO", "tester" => $this->tester()); + } + + public function tester($nome="questo"){ + if($nome=="questo"){ + $nome = $this->nome(); + } + if(in_array($nome, $this->whitelist())){ + return true; + } else { + return false; + } + } + + public function dev($nome="questo"){ + if($nome=="questo"){ + $nome = $this->nome(); + } + if(in_array($nome, $this->whitelist())){ + return true; + } else { + return false; + } + } + + public function login($nome, $password, $twofa=null){ + if(!empty($nome)){ + if(!empty($password)){ + $vigili = $this->database->esegui("SELECT * FROM vigili WHERE nome = :nome AND password = :password;", true, [":nome" => $nome, ":password" => $password]); + if(!empty($vigili)){ + $_SESSION["accesso"] = "autenticato"; + $_SESSION["nome"] = $vigili[0]["nome"]; + $_SESSION["admin"] = $vigili[0]["caposquadra"]; + return true; + //return $vigili; + } else { + return ["status" => "errore", "codice" => 003, "spiegazione" => "Dati di login non corretti"]; + } + } else { + return ["status" => "errore", "codice" => 002]; + } + } else { + return ["status" => "errore", "codice" => 001]; + } + } + public function log($azione, $subisce, $agisce, $data, $ora){ + $parametri = [":azione" => $azione, ":subisce" => $subisce, ":agisce" => $agisce, ":data" => $data, ":ora" => $ora]; + $sql = "INSERT INTO `log` (`id`, `azione`, `subisce`, `agisce`, `data`, `ora`) VALUES (NULL, :azione, :subisce, :agisce, :data, :ora)"; + $this->database->esegui($sql, false, $parametri); + } + + public function lista($tutti=false){ + $vigili = $this->database->esegui("SELECT * FROM vigili;", true); + } + + public function logout(){ + unset($_SESSION["accesso"]); + unset($_SESSION["nome"]); + unset($_SESSION["admin"]); + } +} + +function init_class(){ + global $utente, $tools, $database; + if(!isset($utente) && !isset($tools) && !isset($database)){ + $tools = new tools(); + $database = new database(); + $utente = new user($database, $tools); + } + if($utente->dev()){ + Debugger::enable(Debugger::DEVELOPMENT, __DIR__ . '/error-log'); + } else { + Debugger::enable(Debugger::PRODUCTION, __DIR__ . '/error-log'); + } +} \ No newline at end of file diff --git a/server/templates/anagrafica.html b/server/templates/anagrafica.html new file mode 100644 index 0000000..a6fe49d --- /dev/null +++ b/server/templates/anagrafica.html @@ -0,0 +1,40 @@ +{% extends "base.html" %} + +{% block content %} +
+
+
+ + + +{% endblock %} diff --git a/server/templates/base.html b/server/templates/base.html new file mode 100644 index 0000000..10a513c --- /dev/null +++ b/server/templates/base.html @@ -0,0 +1,367 @@ + + + + {% block head %} + {{ titolo }} - ALLERTA sistema gestionale {{ distaccamento }} + + + + + + + + + + {% if enable_technical_support and technical_support_open %} + + + + {% endif %} + + + + + {% endblock %} + + + + + + + {% block menu %} + + + + {% endblock %} + +
{% block content %}{% endblock %}
+ + + +
+
+
Copyright © Matteo
+

Applicativo realizzato per {{ distaccamento }}

+
+
+ + + \ No newline at end of file diff --git a/server/templates/disponibile.html b/server/templates/disponibile.html new file mode 100644 index 0000000..e69de29 diff --git a/server/templates/esercitazioni.html b/server/templates/esercitazioni.html new file mode 100644 index 0000000..d85683b --- /dev/null +++ b/server/templates/esercitazioni.html @@ -0,0 +1,39 @@ +{% extends "base.html" %} + +{% block content %} +
+ VVF +
+

+ Aggiungi esercitazione +

+
+
+ +
+
+{% endblock %} diff --git a/server/templates/index.html b/server/templates/index.html new file mode 100644 index 0000000..4ce6a54 --- /dev/null +++ b/server/templates/index.html @@ -0,0 +1,47 @@ +{% extends "base.html" %} + +{% block menu %} +{% endblock %} + +{% block content %} +{% if errore %} +
+ + +{{ errore.spiegazione }} + +
+{% endif %} +
+
+ VVF


+

+

+
+ +
+
+
+ +

+ +
+{% endblock %} diff --git a/server/templates/interventi.html b/server/templates/interventi.html new file mode 100644 index 0000000..1312e0c --- /dev/null +++ b/server/templates/interventi.html @@ -0,0 +1,39 @@ +{% extends "base.html" %} + +{% block content %} +
+ VVF +
+

+ Aggiungi intervento +

+
+
+ +
+
+{% endblock %} diff --git a/server/templates/lista.html b/server/templates/lista.html new file mode 100644 index 0000000..e47eed9 --- /dev/null +++ b/server/templates/lista.html @@ -0,0 +1,109 @@ +{% extends "base.html" %} + +{% block content %} +
+
+

Sei disponibile in caso di allerta?

+ + + +
+ +
+
+ VVF +
+
+
+{% if utente.admin == false %} + +{% elseif utente.admin == true %} + +{% endif %} + +
+
+{% endblock %} \ No newline at end of file diff --git a/server/templates/log.html b/server/templates/log.html new file mode 100644 index 0000000..1ba3ca7 --- /dev/null +++ b/server/templates/log.html @@ -0,0 +1,35 @@ +{% extends "base.html" %} + +{% block content %} +
+ VVF +
+
+ +
+
+{% endblock %} diff --git a/server/templates/modifica_intervento.html b/server/templates/modifica_intervento.html new file mode 100644 index 0000000..da0b809 --- /dev/null +++ b/server/templates/modifica_intervento.html @@ -0,0 +1,437 @@ + + + + + + + + + + + + + + + + + +{% if intervento.modalità == "aggiungi" %} +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ +
+ {% for vigile in intervento.personale %} +
+ +
+ {% endfor %} + +
+ +
+ {% for vigile in intervento.personale %} + {% if vigile.autista == 1 %} +
+ +
+ {% endif %} + {% endfor %} +
+ +
+ {% for vigile in intervento.personale %} +
+ +
+ {% endfor %} +
+ + +
+
+
+ +
+
+ +
+ +
+ + + +
+
+ +{% endif %} +{% if intervento.modalità == "modifica" %} +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ +
+ {% for vigile in intervento.personale %} +
+ +
+ {% endfor %} + +
+ +
+ {% for vigile in intervento.personale %} + {% if vigile.autista == 1 %} +
+ +
+ {% endif %} + {% endfor %} +
+ +
+ {% for vigile in intervento.personale %} +
+ +
+ {% endfor %} +
+ + +
+
+
+ +
+
+ +
+ +
+ + + + +
+
+ +{% endif %} +{% if intervento.modalità == "elimina" %} + +
+

Sei sicuro di voler eliminare l' intervento?

+
+ + + + +
+ +
+{% endif %} + + \ No newline at end of file diff --git a/server/templates/profilo.html b/server/templates/profilo.html new file mode 100644 index 0000000..e69de29