-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.php
146 lines (138 loc) · 6.41 KB
/
index.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
<?php
ini_set("memory_limit", "500M");
error_reporting(0);
require_once ("functions/functions.php");
require_once ("functions/pattern.php");
require_once ("functions/patab.php");
require_once ("functions/get_corpus.php");
require_once ("functions/get_needle.php");
require_once ("functions/search.php");
require_once ("functions/db.php");
require_once ("functions/statify.php");
require_once ("functions/plays.php");
require_once ("functions/json.php");
require_once ("functions/get_filters.php");
require_once ("functions/doPost.php");
$bdd = connect();
$lang = (isset($_GET["lang"]) and $_GET["lang"] == "en") ? "en" : "fr";
include ("lang/" . $lang . ".php");
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<script type="text/javascript" src="js/jquery-2.2.3.min.js"></script>
<script type="text/javascript" src="js/jquery.hoverIntent.js"></script>
<script type="text/javascript" src="js/jquery-ui-1.11.4/jquery-ui.min.js"></script>
<script type="text/javascript" src="js/tipsy/src/javascripts/jquery.tipsy.js"></script>
<script type="text/javascript" src="js/fancybox/source/jquery.fancybox.js"></script>
<script type="text/javascript" src="js/TableFilter/dist/tablefilter/tablefilter.js"></script>
<script type="text/javascript" src="js/export.js"></script>
<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
<script type="text/javascript" src="js/main.js"></script>
<link rel="stylesheet" href="js/fancybox/source/jquery.fancybox.css" type="text/css" />
<link rel="stylesheet" href="js/tipsy/src/stylesheets/tipsy.css" type="text/css" />
<link rel="stylesheet" href="css/font-awesome/css/font-awesome.css" type="text/css" />
<link rel="stylesheet" href="js/jquery-ui-1.11.4/themes/smoothness/jquery-ui.css">
<link rel="stylesheet" type="text/css" href="css/style.css">
<link rel="icon" type="image/x-icon" href="img/favicon.ico">
<title>Moteur d'analyse dramaturgique</title>
</head>
<body>
<script type="text/javascript">document.body.style.display = "none";</script>
<div class="res">
<?php
//filtres : (xpath)
//created ≠ lustrum (je ne peux pas prendre en compte created parce que les tableaux s'affichent par lustres) : le dire dans la documentation
//liste des valeurs de champs : si j'ai un trou dans lustrum dans mon corpus (dans statify ?). Pour l'instant ça va, mais avec l'Allemagne ?
//faut-il virer A//B des stats A/B ?
//index pour les filtres => Fred ?
//comparateur : graphe camembert, temps d'exécution, lier les tableaux (pb de l'ancre : fait planter le graph)
//résultats groupé : si count patterns>1, agréger les résultats (comment statify ?)
//lien sur le motif et rappel (dans la même page ou une page différente)
//nombre total
//pas de résultat
//colonnes genre (dans le tableau)
//colonne lustre (dans le tableau)
//dans ce cas, il resterait occurrences, auteur, xpath
//lignes genres (dans les graphes)
//un graphique pour tous les motifs (mais dans ce cas je ne peux pas faire une ligne par genre)
//Quelle utilité ?
include ("tpl/header.tpl.php");
include ("html/corpus.html");
include ("tpl/form.tpl.php");
if (isset($_GET["post"])) {
$fields = array(
"code" => array(
"title" => "Résultats par pièce",
"head" => "Titre"
) ,
"author" => array(
"title" => "Résultats par auteur",
"head" => "Auteur"
) ,
"genre" => array(
"title" => "Résultats par genre",
"head" => "Genre"
) ,
"lustrum" => array(
"title" => "Résultats par année",
"head" => "Année"
) ,
);
foreach ($_GET["xpath"] as $key => $xpath) {
if (!$xpath) {
continue;
}
$fields[$key] = array(
"title" => $xpath,
"type" => "xpath",
);
}
$group = (isset($_GET["group"])) ? 1 : 0;
$confidents = (isset($_GET["ignore_confident"])) ? 1 : 0;
$filters = array();
if ($_GET["filters"]["from"]) {
$filters["from"] = "created >= '" . $_GET["filters"]["from"] . "'";
}
if ($_GET["filters"]["to"]) {
$filters["to"] = "created <= '" . $_GET["filters"]["to"] . "'";
}
foreach ($fields as $key => $field) {
if (($key != "author") AND ($key != "genre") AND ($key != "code")) {
continue;
}
if (isset($_GET["filters"][$key])) {
if(!($_GET["filters"][$key][0])){continue;}
$array = array();
foreach ($_GET["filters"][$key] as $filter) {
$array[] = $key . " = '" . $filter . "'";
}
$filters[$key] = "(";
$filters[$key].= implode(" OR ", $array);
$filters[$key].= ")";
}
}
$filter_play = ($filters) ? " WHERE " . implode(" AND ", $filters) : "";
$filter = ($filters) ? " AND play_id IN (SELECT id FROM play " . $filter_play . ")" : "";
$all_results = doPost($bdd, $fields, $group, $confidents, $filter, $filter_play);
include("tpl/table_summary.tpl.php");
foreach($all_results as $needle=>$all_result){
$needletr = strtr($needle, "/", "_");
$results = $all_result["results"];
$results_n = $all_result["count"];
$proportion = $all_result["proportion"];
$length = $all_result["length"];
$plays = $all_result["plays"];
foreach ($fields as $key => $field) {
$xpath = isset($field["type"]) ? $field : false;
$table_results[$key] = statify($results, $key, $length, $group, $confidents, $xpath, $plays, $bdd, $filter, $filter_play);
}
$json = json($table_results["lustrum"]);
include("tpl/pattern.tpl.php");
}
}
?>
</div>
</body>
</html>