@tricoteuses/senat 3.1.0 → 3.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/src/loaders.d.ts +3 -3
- package/lib/src/loaders.js +1 -1
- package/lib/src/model/agenda.d.ts +1 -1
- package/lib/src/model/commission.d.ts +2 -2
- package/lib/src/model/seance.d.ts +1 -1
- package/lib/src/types/ameli.d.ts +4 -1761
- package/lib/src/types/ameli.js +1 -1074
- package/lib/src/types/debats.d.ts +2 -380
- package/lib/src/types/debats.js +1 -266
- package/lib/src/types/dosleg.d.ts +69 -2953
- package/lib/src/types/dosleg.js +1 -2005
- package/lib/src/types/questions.d.ts +2 -699
- package/lib/src/types/questions.js +1 -493
- package/lib/src/types/sens.d.ts +7 -7842
- package/lib/src/types/sens.js +1 -4691
- package/lib/src/utils/nvs-parsing.d.ts +1 -1
- package/lib/src/utils/nvs-parsing.js +9 -1
- package/lib/src/videos/pipeline.d.ts +3 -3
- package/lib/src/videos/pipeline.js +2 -2
- package/package.json +1 -1
- package/lib/add-js-extensions-v2.d.ts +0 -1
- package/lib/add-js-extensions-v2.js +0 -23
- package/lib/add-js-extensions.d.ts +0 -1
- package/lib/add-js-extensions.js +0 -17
- package/lib/aggregates.d.ts +0 -52
- package/lib/aggregates.js +0 -930
- package/lib/aggregates.mjs +0 -713
- package/lib/aggregates.ts +0 -833
- package/lib/config.d.ts +0 -10
- package/lib/config.js +0 -16
- package/lib/config.mjs +0 -16
- package/lib/config.ts +0 -26
- package/lib/databases.d.ts +0 -2
- package/lib/databases.js +0 -26
- package/lib/databases.mjs +0 -57
- package/lib/databases.ts +0 -71
- package/lib/datasets.d.ts +0 -34
- package/lib/datasets.js +0 -233
- package/lib/datasets.mjs +0 -78
- package/lib/datasets.ts +0 -118
- package/lib/fields.d.ts +0 -10
- package/lib/fields.js +0 -68
- package/lib/fields.mjs +0 -22
- package/lib/fields.ts +0 -29
- package/lib/git.d.ts +0 -26
- package/lib/git.js +0 -167
- package/lib/index.d.ts +0 -13
- package/lib/index.js +0 -1
- package/lib/index.mjs +0 -7
- package/lib/index.ts +0 -64
- package/lib/inserters.d.ts +0 -98
- package/lib/inserters.js +0 -500
- package/lib/inserters.mjs +0 -360
- package/lib/inserters.ts +0 -521
- package/lib/legislatures.json +0 -38
- package/lib/loaders.d.ts +0 -58
- package/lib/loaders.js +0 -286
- package/lib/loaders.mjs +0 -158
- package/lib/loaders.ts +0 -271
- package/lib/model/agenda.d.ts +0 -6
- package/lib/model/agenda.js +0 -148
- package/lib/model/ameli.d.ts +0 -51
- package/lib/model/ameli.js +0 -149
- package/lib/model/ameli.mjs +0 -84
- package/lib/model/ameli.ts +0 -100
- package/lib/model/commission.d.ts +0 -18
- package/lib/model/commission.js +0 -269
- package/lib/model/debats.d.ts +0 -67
- package/lib/model/debats.js +0 -95
- package/lib/model/debats.mjs +0 -43
- package/lib/model/debats.ts +0 -68
- package/lib/model/documents.d.ts +0 -12
- package/lib/model/documents.js +0 -151
- package/lib/model/dosleg.d.ts +0 -7
- package/lib/model/dosleg.js +0 -326
- package/lib/model/dosleg.mjs +0 -196
- package/lib/model/dosleg.ts +0 -240
- package/lib/model/index.d.ts +0 -7
- package/lib/model/index.js +0 -7
- package/lib/model/index.mjs +0 -5
- package/lib/model/index.ts +0 -15
- package/lib/model/questions.d.ts +0 -45
- package/lib/model/questions.js +0 -89
- package/lib/model/questions.mjs +0 -71
- package/lib/model/questions.ts +0 -93
- package/lib/model/scrutins.d.ts +0 -13
- package/lib/model/scrutins.js +0 -114
- package/lib/model/seance.d.ts +0 -3
- package/lib/model/seance.js +0 -267
- package/lib/model/sens.d.ts +0 -146
- package/lib/model/sens.js +0 -454
- package/lib/model/sens.mjs +0 -415
- package/lib/model/sens.ts +0 -516
- package/lib/model/texte.d.ts +0 -7
- package/lib/model/texte.js +0 -256
- package/lib/model/texte.mjs +0 -208
- package/lib/model/texte.ts +0 -229
- package/lib/model/util.d.ts +0 -9
- package/lib/model/util.js +0 -38
- package/lib/model/util.mjs +0 -19
- package/lib/model/util.ts +0 -32
- package/lib/parsers/texte.d.ts +0 -7
- package/lib/parsers/texte.js +0 -228
- package/lib/raw_types/ameli.d.ts +0 -914
- package/lib/raw_types/ameli.js +0 -5
- package/lib/raw_types/ameli.mjs +0 -163
- package/lib/raw_types/debats.d.ts +0 -207
- package/lib/raw_types/debats.js +0 -5
- package/lib/raw_types/debats.mjs +0 -58
- package/lib/raw_types/dosleg.d.ts +0 -1619
- package/lib/raw_types/dosleg.js +0 -5
- package/lib/raw_types/dosleg.mjs +0 -438
- package/lib/raw_types/questions.d.ts +0 -419
- package/lib/raw_types/questions.js +0 -5
- package/lib/raw_types/questions.mjs +0 -11
- package/lib/raw_types/senat.d.ts +0 -11368
- package/lib/raw_types/senat.js +0 -5
- package/lib/raw_types/sens.d.ts +0 -8248
- package/lib/raw_types/sens.js +0 -5
- package/lib/raw_types/sens.mjs +0 -508
- package/lib/raw_types_kysely/ameli.d.ts +0 -915
- package/lib/raw_types_kysely/ameli.js +0 -7
- package/lib/raw_types_kysely/ameli.mjs +0 -5
- package/lib/raw_types_kysely/ameli.ts +0 -951
- package/lib/raw_types_kysely/debats.d.ts +0 -207
- package/lib/raw_types_kysely/debats.js +0 -7
- package/lib/raw_types_kysely/debats.mjs +0 -5
- package/lib/raw_types_kysely/debats.ts +0 -222
- package/lib/raw_types_kysely/dosleg.d.ts +0 -3532
- package/lib/raw_types_kysely/dosleg.js +0 -7
- package/lib/raw_types_kysely/dosleg.mjs +0 -5
- package/lib/raw_types_kysely/dosleg.ts +0 -3621
- package/lib/raw_types_kysely/questions.d.ts +0 -414
- package/lib/raw_types_kysely/questions.js +0 -7
- package/lib/raw_types_kysely/questions.mjs +0 -5
- package/lib/raw_types_kysely/questions.ts +0 -426
- package/lib/raw_types_kysely/sens.d.ts +0 -4394
- package/lib/raw_types_kysely/sens.js +0 -7
- package/lib/raw_types_kysely/sens.mjs +0 -5
- package/lib/raw_types_kysely/sens.ts +0 -4499
- package/lib/raw_types_schemats/ameli.d.ts +0 -539
- package/lib/raw_types_schemats/ameli.js +0 -2
- package/lib/raw_types_schemats/ameli.mjs +0 -2
- package/lib/raw_types_schemats/ameli.ts +0 -601
- package/lib/raw_types_schemats/debats.d.ts +0 -127
- package/lib/raw_types_schemats/debats.js +0 -2
- package/lib/raw_types_schemats/debats.mjs +0 -2
- package/lib/raw_types_schemats/debats.ts +0 -145
- package/lib/raw_types_schemats/dosleg.d.ts +0 -977
- package/lib/raw_types_schemats/dosleg.js +0 -2
- package/lib/raw_types_schemats/dosleg.mjs +0 -2
- package/lib/raw_types_schemats/dosleg.ts +0 -2193
- package/lib/raw_types_schemats/questions.d.ts +0 -235
- package/lib/raw_types_schemats/questions.js +0 -2
- package/lib/raw_types_schemats/questions.mjs +0 -2
- package/lib/raw_types_schemats/questions.ts +0 -249
- package/lib/raw_types_schemats/sens.d.ts +0 -6915
- package/lib/raw_types_schemats/sens.js +0 -2
- package/lib/raw_types_schemats/sens.mjs +0 -2
- package/lib/raw_types_schemats/sens.ts +0 -2907
- package/lib/scripts/convert_data.d.ts +0 -1
- package/lib/scripts/convert_data.js +0 -354
- package/lib/scripts/convert_data.mjs +0 -181
- package/lib/scripts/convert_data.ts +0 -243
- package/lib/scripts/data-download.d.ts +0 -1
- package/lib/scripts/data-download.js +0 -12
- package/lib/scripts/datautil.d.ts +0 -8
- package/lib/scripts/datautil.js +0 -34
- package/lib/scripts/datautil.mjs +0 -16
- package/lib/scripts/datautil.ts +0 -19
- package/lib/scripts/images/transparent_150x192.jpg +0 -0
- package/lib/scripts/images/transparent_155x225.jpg +0 -0
- package/lib/scripts/parse_textes.d.ts +0 -1
- package/lib/scripts/parse_textes.js +0 -44
- package/lib/scripts/parse_textes.mjs +0 -46
- package/lib/scripts/parse_textes.ts +0 -65
- package/lib/scripts/retrieve_agenda.d.ts +0 -1
- package/lib/scripts/retrieve_agenda.js +0 -132
- package/lib/scripts/retrieve_cr_commission.d.ts +0 -1
- package/lib/scripts/retrieve_cr_commission.js +0 -364
- package/lib/scripts/retrieve_cr_seance.d.ts +0 -6
- package/lib/scripts/retrieve_cr_seance.js +0 -347
- package/lib/scripts/retrieve_documents.d.ts +0 -3
- package/lib/scripts/retrieve_documents.js +0 -219
- package/lib/scripts/retrieve_documents.mjs +0 -249
- package/lib/scripts/retrieve_documents.ts +0 -298
- package/lib/scripts/retrieve_open_data.d.ts +0 -1
- package/lib/scripts/retrieve_open_data.js +0 -315
- package/lib/scripts/retrieve_open_data.mjs +0 -217
- package/lib/scripts/retrieve_open_data.ts +0 -268
- package/lib/scripts/retrieve_senateurs_photos.d.ts +0 -1
- package/lib/scripts/retrieve_senateurs_photos.js +0 -147
- package/lib/scripts/retrieve_senateurs_photos.mjs +0 -147
- package/lib/scripts/retrieve_senateurs_photos.ts +0 -177
- package/lib/scripts/retrieve_videos.d.ts +0 -1
- package/lib/scripts/retrieve_videos.js +0 -461
- package/lib/scripts/shared/cli_helpers.d.ts +0 -95
- package/lib/scripts/shared/cli_helpers.js +0 -91
- package/lib/scripts/shared/cli_helpers.ts +0 -36
- package/lib/scripts/shared/util.d.ts +0 -4
- package/lib/scripts/shared/util.js +0 -35
- package/lib/scripts/shared/util.ts +0 -33
- package/lib/scripts/test_iter_load.d.ts +0 -1
- package/lib/scripts/test_iter_load.js +0 -12
- package/lib/src/ameli.d.ts +0 -66
- package/lib/src/ameli.js +0 -1
- package/lib/src/databases.d.ts +0 -3
- package/lib/src/databases.js +0 -26
- package/lib/src/db_types/ameli.d.ts +0 -1762
- package/lib/src/db_types/ameli.js +0 -1074
- package/lib/src/db_types/debats.d.ts +0 -380
- package/lib/src/db_types/debats.js +0 -266
- package/lib/src/db_types/dosleg.d.ts +0 -2954
- package/lib/src/db_types/dosleg.js +0 -2005
- package/lib/src/db_types/questions.d.ts +0 -699
- package/lib/src/db_types/questions.js +0 -493
- package/lib/src/db_types/sens.d.ts +0 -7843
- package/lib/src/db_types/sens.js +0 -4691
- package/lib/src/debats.d.ts +0 -38
- package/lib/src/debats.js +0 -1
- package/lib/src/dosleg.d.ts +0 -142
- package/lib/src/dosleg.js +0 -193
- package/lib/src/model/ameli_postgres.d.ts +0 -67
- package/lib/src/model/ameli_postgres.js +0 -150
- package/lib/src/other_types/questions.d.ts +0 -2
- package/lib/src/other_types/questions.js +0 -1
- package/lib/src/questions.d.ts +0 -53
- package/lib/src/questions.js +0 -1
- package/lib/src/raw_types/senat.d.ts +0 -11372
- package/lib/src/raw_types/senat.js +0 -5
- package/lib/src/rich_types/agenda.d.ts +0 -45
- package/lib/src/rich_types/agenda.js +0 -1
- package/lib/src/rich_types/compte_rendu.d.ts +0 -83
- package/lib/src/rich_types/compte_rendu.js +0 -1
- package/lib/src/rich_types/sessions.d.ts +0 -6
- package/lib/src/rich_types/sessions.js +0 -19
- package/lib/src/rich_types/texte.d.ts +0 -72
- package/lib/src/rich_types/texte.js +0 -15
- package/lib/src/scripts/test_iter_load.d.ts +0 -1
- package/lib/src/scripts/test_iter_load.js +0 -12
- package/lib/src/sens.d.ts +0 -104
- package/lib/src/sens.js +0 -1
- package/lib/strings.d.ts +0 -1
- package/lib/strings.js +0 -18
- package/lib/strings.mjs +0 -18
- package/lib/strings.ts +0 -26
- package/lib/tsconfig.tsbuildinfo +0 -1
- package/lib/types/agenda.d.ts +0 -44
- package/lib/types/agenda.js +0 -1
- package/lib/types/ameli.d.ts +0 -5
- package/lib/types/ameli.js +0 -1
- package/lib/types/ameli.mjs +0 -13
- package/lib/types/ameli.ts +0 -21
- package/lib/types/compte_rendu.d.ts +0 -83
- package/lib/types/compte_rendu.js +0 -1
- package/lib/types/debats.d.ts +0 -2
- package/lib/types/debats.js +0 -1
- package/lib/types/debats.mjs +0 -2
- package/lib/types/debats.ts +0 -6
- package/lib/types/dosleg.d.ts +0 -70
- package/lib/types/dosleg.js +0 -1
- package/lib/types/dosleg.mjs +0 -151
- package/lib/types/dosleg.ts +0 -284
- package/lib/types/questions.d.ts +0 -2
- package/lib/types/questions.js +0 -1
- package/lib/types/questions.mjs +0 -1
- package/lib/types/questions.ts +0 -3
- package/lib/types/sens.d.ts +0 -10
- package/lib/types/sens.js +0 -1
- package/lib/types/sens.mjs +0 -1
- package/lib/types/sens.ts +0 -12
- package/lib/types/sessions.d.ts +0 -5
- package/lib/types/sessions.js +0 -84
- package/lib/types/sessions.mjs +0 -43
- package/lib/types/sessions.ts +0 -42
- package/lib/types/texte.d.ts +0 -74
- package/lib/types/texte.js +0 -16
- package/lib/types/texte.mjs +0 -16
- package/lib/types/texte.ts +0 -76
- package/lib/typings/windows-1252.d.js +0 -2
- package/lib/typings/windows-1252.d.mjs +0 -2
- package/lib/typings/windows-1252.d.ts +0 -11
- package/lib/utils/cr_spliting.d.ts +0 -28
- package/lib/utils/cr_spliting.js +0 -265
- package/lib/utils/date.d.ts +0 -10
- package/lib/utils/date.js +0 -100
- package/lib/utils/nvs-timecode.d.ts +0 -7
- package/lib/utils/nvs-timecode.js +0 -79
- package/lib/utils/reunion_grouping.d.ts +0 -9
- package/lib/utils/reunion_grouping.js +0 -361
- package/lib/utils/reunion_odj_building.d.ts +0 -5
- package/lib/utils/reunion_odj_building.js +0 -154
- package/lib/utils/reunion_parsing.d.ts +0 -23
- package/lib/utils/reunion_parsing.js +0 -209
- package/lib/utils/scoring.d.ts +0 -14
- package/lib/utils/scoring.js +0 -147
- package/lib/utils/string_cleaning.d.ts +0 -7
- package/lib/utils/string_cleaning.js +0 -57
- package/lib/validators/config.d.ts +0 -9
- package/lib/validators/config.js +0 -10
- package/lib/validators/config.mjs +0 -54
- package/lib/validators/config.ts +0 -79
- package/lib/validators/senat.d.ts +0 -0
- package/lib/validators/senat.js +0 -28
- package/lib/validators/senat.mjs +0 -24
- package/lib/validators/senat.ts +0 -26
package/lib/utils/date.js
DELETED
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import { DateTime } from "luxon";
|
|
2
|
-
export function yyyymmddFromPath(xmlFilePath) {
|
|
3
|
-
return xmlFilePath.replace(/^.*?(\d{8}).*$/i, "$1");
|
|
4
|
-
}
|
|
5
|
-
export function parseYYYYMMDD(yyyymmdd) {
|
|
6
|
-
if (!/^\d{8}$/.test(yyyymmdd))
|
|
7
|
-
return null;
|
|
8
|
-
const y = Number(yyyymmdd.slice(0, 4));
|
|
9
|
-
const m = Number(yyyymmdd.slice(4, 6)) - 1;
|
|
10
|
-
const d = Number(yyyymmdd.slice(6, 8));
|
|
11
|
-
const dt = new Date(y, m, d);
|
|
12
|
-
return Number.isFinite(dt.getTime()) ? dt : null;
|
|
13
|
-
}
|
|
14
|
-
export function frDateToISO(s) {
|
|
15
|
-
if (!s)
|
|
16
|
-
return;
|
|
17
|
-
const months = {
|
|
18
|
-
janvier: 1,
|
|
19
|
-
février: 2,
|
|
20
|
-
fevrier: 2,
|
|
21
|
-
mars: 3,
|
|
22
|
-
avril: 4,
|
|
23
|
-
mai: 5,
|
|
24
|
-
juin: 6,
|
|
25
|
-
juillet: 7,
|
|
26
|
-
août: 8,
|
|
27
|
-
aout: 8,
|
|
28
|
-
septembre: 9,
|
|
29
|
-
octobre: 10,
|
|
30
|
-
novembre: 11,
|
|
31
|
-
décembre: 12,
|
|
32
|
-
decembre: 12,
|
|
33
|
-
};
|
|
34
|
-
const cleaned = s
|
|
35
|
-
.trim()
|
|
36
|
-
.replace(/\u00A0/g, " ")
|
|
37
|
-
.replace(/ +/g, " ");
|
|
38
|
-
const m = cleaned.match(/^(\d{1,2})(?:er)?\s+([a-zéèêîïôûùç]+)\s+(\d{4})$/i);
|
|
39
|
-
if (!m)
|
|
40
|
-
return;
|
|
41
|
-
const d = String(parseInt(m[1], 10)).padStart(2, "0");
|
|
42
|
-
const mon = months[m[2].toLowerCase()];
|
|
43
|
-
if (!mon)
|
|
44
|
-
return;
|
|
45
|
-
const y = m[3];
|
|
46
|
-
return `${y}-${String(mon).padStart(2, "0")}-${d}`;
|
|
47
|
-
}
|
|
48
|
-
export function hourShortToStartTime(hourShort) {
|
|
49
|
-
if (!hourShort || hourShort === "NA")
|
|
50
|
-
return null;
|
|
51
|
-
if (!/^\d{4}$/.test(hourShort))
|
|
52
|
-
return null;
|
|
53
|
-
const hh = hourShort.slice(0, 2);
|
|
54
|
-
const mm = hourShort.slice(2, 4);
|
|
55
|
-
return `${hh}:${mm}`;
|
|
56
|
-
}
|
|
57
|
-
export function epochToParisDateTime(epochSec) {
|
|
58
|
-
if (!Number.isFinite(epochSec))
|
|
59
|
-
return null;
|
|
60
|
-
const dUtc = new Date(epochSec * 1000);
|
|
61
|
-
// Offset heuristic (same logique que parisOffsetForDate)
|
|
62
|
-
const m = dUtc.getUTCMonth() + 1; // 1..12
|
|
63
|
-
const offsetHours = m >= 4 && m <= 10 ? 2 : 1;
|
|
64
|
-
const offsetStr = offsetHours === 2 ? "+02:00" : "+01:00";
|
|
65
|
-
// Applique l'offset pour obtenir la date/heure locales Paris
|
|
66
|
-
const localMs = dUtc.getTime() + offsetHours * 3600 * 1000;
|
|
67
|
-
const dl = new Date(localMs);
|
|
68
|
-
const yyyy = String(dl.getUTCFullYear());
|
|
69
|
-
const mm = String(dl.getUTCMonth() + 1).padStart(2, "0");
|
|
70
|
-
const dd = String(dl.getUTCDate()).padStart(2, "0");
|
|
71
|
-
const hh = String(dl.getUTCHours()).padStart(2, "0");
|
|
72
|
-
const mi = String(dl.getUTCMinutes()).padStart(2, "0");
|
|
73
|
-
const ss = String(dl.getUTCSeconds()).padStart(2, "0");
|
|
74
|
-
const ms = String(dl.getUTCMilliseconds()).padStart(3, "0");
|
|
75
|
-
return {
|
|
76
|
-
date: `${yyyy}-${mm}-${dd}`,
|
|
77
|
-
startTime: `${hh}:${mi}:${ss}.${ms}${offsetStr}`,
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
export function toTargetEpoch(time, date) {
|
|
81
|
-
if (!time)
|
|
82
|
-
return null;
|
|
83
|
-
let dtLocal;
|
|
84
|
-
if (time.includes("T")) {
|
|
85
|
-
dtLocal = DateTime.fromISO(time, { zone: "Europe/Paris" });
|
|
86
|
-
}
|
|
87
|
-
else if (date) {
|
|
88
|
-
dtLocal = DateTime.fromISO(`${date}T${time}`, { zone: "Europe/Paris" });
|
|
89
|
-
}
|
|
90
|
-
else {
|
|
91
|
-
return null;
|
|
92
|
-
}
|
|
93
|
-
if (!dtLocal.isValid)
|
|
94
|
-
return null;
|
|
95
|
-
return Math.floor(dtLocal.toUTC().toSeconds());
|
|
96
|
-
}
|
|
97
|
-
export function toFRDate(dateYYYYMMDD) {
|
|
98
|
-
const [y, m, d] = dateYYYYMMDD.split("-");
|
|
99
|
-
return `${d}/${m}/${y}`; // DD/MM/YYYY
|
|
100
|
-
}
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import { XMLParser } from "fast-xml-parser";
|
|
2
|
-
import { dice, normalize } from "./scoring";
|
|
3
|
-
import { decodeHtmlEntities } from "./string_cleaning";
|
|
4
|
-
const CHAPTER_MATCH_THRESHOLD = 0.5;
|
|
5
|
-
const xmlParser = new XMLParser({
|
|
6
|
-
ignoreAttributes: false,
|
|
7
|
-
attributeNamePrefix: "@_",
|
|
8
|
-
});
|
|
9
|
-
function getTimecodeForChapterId(finalPlayerNvs, chapterId) {
|
|
10
|
-
const xml = xmlParser.parse(finalPlayerNvs);
|
|
11
|
-
const synchros = xml?.player?.synchro;
|
|
12
|
-
if (!synchros)
|
|
13
|
-
return null;
|
|
14
|
-
const synchsArray = Array.isArray(synchros) ? synchros : [synchros];
|
|
15
|
-
const match = synchsArray.find((s) => String(s["@_id"]) === String(chapterId));
|
|
16
|
-
if (!match)
|
|
17
|
-
return null;
|
|
18
|
-
const rawTimecode = match["@_timecode"];
|
|
19
|
-
if (rawTimecode == null)
|
|
20
|
-
return null;
|
|
21
|
-
const ms = Number(rawTimecode);
|
|
22
|
-
if (Number.isNaN(ms))
|
|
23
|
-
return null;
|
|
24
|
-
return Math.floor(ms / 1000);
|
|
25
|
-
}
|
|
26
|
-
function toArray(v) {
|
|
27
|
-
if (!v)
|
|
28
|
-
return [];
|
|
29
|
-
return Array.isArray(v) ? v : [v];
|
|
30
|
-
}
|
|
31
|
-
function getLevel1Chapters(dataNvs) {
|
|
32
|
-
const xml = xmlParser.parse(dataNvs);
|
|
33
|
-
const root = xml?.data?.chapters?.chapter ?? xml?.chapters?.chapter;
|
|
34
|
-
const roots = toArray(root);
|
|
35
|
-
return roots
|
|
36
|
-
.map((ch, i) => {
|
|
37
|
-
const id = ch?.id ?? ch?.["@_id"];
|
|
38
|
-
const labelRaw = ch?.label ?? ch?.["@_label"] ?? "";
|
|
39
|
-
return {
|
|
40
|
-
id: String(id),
|
|
41
|
-
label: decodeHtmlEntities(String(labelRaw)).trim(),
|
|
42
|
-
index: i,
|
|
43
|
-
};
|
|
44
|
-
})
|
|
45
|
-
.filter((c) => c.id && c.label);
|
|
46
|
-
}
|
|
47
|
-
function pickBestLevel1ChapterForAgenda(chapters, agendaTitle) {
|
|
48
|
-
const q = normalize(agendaTitle);
|
|
49
|
-
let best = null;
|
|
50
|
-
for (const ch of chapters) {
|
|
51
|
-
const s = dice(q, ch.label);
|
|
52
|
-
if (!best || s > best.score)
|
|
53
|
-
best = { chapter: ch, score: s };
|
|
54
|
-
}
|
|
55
|
-
if (!best || best.score < CHAPTER_MATCH_THRESHOLD)
|
|
56
|
-
return { chapter: chapters[0], score: 0 };
|
|
57
|
-
return best;
|
|
58
|
-
}
|
|
59
|
-
export function getAgendaSegmentTimecodes(dataNvs, finalPlayerNvs, agendaTitleOrObjet) {
|
|
60
|
-
const l1 = getLevel1Chapters(dataNvs);
|
|
61
|
-
if (!l1.length)
|
|
62
|
-
return null;
|
|
63
|
-
const best = pickBestLevel1ChapterForAgenda(l1, agendaTitleOrObjet);
|
|
64
|
-
if (!best)
|
|
65
|
-
return null;
|
|
66
|
-
const chapter = best.chapter;
|
|
67
|
-
const next = l1[chapter.index + 1] ?? null;
|
|
68
|
-
const start = getTimecodeForChapterId(finalPlayerNvs, chapter.id);
|
|
69
|
-
if (start == null)
|
|
70
|
-
return null;
|
|
71
|
-
const end = next ? getTimecodeForChapterId(finalPlayerNvs, next.id) : null;
|
|
72
|
-
return {
|
|
73
|
-
start,
|
|
74
|
-
end,
|
|
75
|
-
chapterId: chapter.id,
|
|
76
|
-
nextChapterId: next?.id ?? null,
|
|
77
|
-
score: best.score,
|
|
78
|
-
};
|
|
79
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { AgendaEvent, GroupedReunion, TimeSlot } from "../types/agenda";
|
|
2
|
-
type KnownType = "SP" | "COM" | "MC" | "OD" | "ID";
|
|
3
|
-
export declare function groupNonSPByTypeOrganeHour(events: AgendaEvent[]): Record<"IDC" | "IDM" | "IDO" | "IDI", GroupedReunion[]>;
|
|
4
|
-
export declare function groupSeancePubliqueBySlot(events: AgendaEvent[]): Record<TimeSlot, GroupedReunion[]>;
|
|
5
|
-
export declare function makeTypeGroupUid(dateISO: string, kind: KnownType, agendaEventId: string, organe?: string | null): string;
|
|
6
|
-
export declare function makeGroupUid(date: string, slot: TimeSlot): string;
|
|
7
|
-
export declare function formatYYYYMMDD(dateYYYYMMDD: string): string;
|
|
8
|
-
export declare function makeReunionUid(agenda: AgendaEvent): string;
|
|
9
|
-
export {};
|
|
@@ -1,361 +0,0 @@
|
|
|
1
|
-
import { DateTime } from "luxon";
|
|
2
|
-
import { norm } from "../model/util";
|
|
3
|
-
const PARIS = "Europe/Paris";
|
|
4
|
-
const STOPWORDS = new Set([
|
|
5
|
-
"de",
|
|
6
|
-
"du",
|
|
7
|
-
"des",
|
|
8
|
-
"la",
|
|
9
|
-
"le",
|
|
10
|
-
"les",
|
|
11
|
-
"l",
|
|
12
|
-
"d",
|
|
13
|
-
"et",
|
|
14
|
-
"en",
|
|
15
|
-
"au",
|
|
16
|
-
"aux",
|
|
17
|
-
"pour",
|
|
18
|
-
"sur",
|
|
19
|
-
"sous",
|
|
20
|
-
"à",
|
|
21
|
-
"a",
|
|
22
|
-
"aux",
|
|
23
|
-
]);
|
|
24
|
-
export function groupNonSPByTypeOrganeHour(events) {
|
|
25
|
-
const out = { IDC: [], IDM: [], IDO: [], IDI: [] };
|
|
26
|
-
if (!events?.length)
|
|
27
|
-
return out;
|
|
28
|
-
const nonSP = events.filter((e) => !isSeancePublique(e?.type));
|
|
29
|
-
if (nonSP.length === 0)
|
|
30
|
-
return out;
|
|
31
|
-
for (const e of nonSP) {
|
|
32
|
-
const kind = classifyAgendaType(e?.type);
|
|
33
|
-
if (!kind || kind === "SP")
|
|
34
|
-
continue;
|
|
35
|
-
const { startISO, endISO } = deriveTimesForEvent(e);
|
|
36
|
-
const startTime = startISO ?? e.startTime ?? null;
|
|
37
|
-
const endTime = endISO ?? e.endTime ?? null;
|
|
38
|
-
const uid = makeTypeGroupUid(e.date, kind, e.id, e.organe ?? null);
|
|
39
|
-
const suffix = (kind === "COM" ? "IDC" : kind === "MC" ? "IDM" : kind === "OD" ? "IDO" : "IDI");
|
|
40
|
-
const group = {
|
|
41
|
-
uid,
|
|
42
|
-
chambre: "SN",
|
|
43
|
-
date: e.date,
|
|
44
|
-
type: e.type || "",
|
|
45
|
-
organe: e.organe || undefined,
|
|
46
|
-
startTime,
|
|
47
|
-
endTime,
|
|
48
|
-
captationVideo: e.captationVideo === true,
|
|
49
|
-
titre: e.titre,
|
|
50
|
-
objet: e.objet || "",
|
|
51
|
-
events: [e],
|
|
52
|
-
};
|
|
53
|
-
out[suffix].push(group);
|
|
54
|
-
}
|
|
55
|
-
for (const k of Object.keys(out)) {
|
|
56
|
-
out[k].sort((a, b) => {
|
|
57
|
-
const da = DateTime.fromISO(`${a.date}T${a.startTime || "00:00:00.000+02:00"}`, { zone: PARIS }).toMillis();
|
|
58
|
-
const db = DateTime.fromISO(`${b.date}T${b.startTime || "00:00:00.000+02:00"}`, { zone: PARIS }).toMillis();
|
|
59
|
-
return da - db || (a.organe || "").localeCompare(b.organe || "");
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
return out;
|
|
63
|
-
}
|
|
64
|
-
export function groupSeancePubliqueBySlot(events) {
|
|
65
|
-
// Résultat à la manière de groupNonSPByTypeOrganeHour : objet de listes, ici indexé par créneau
|
|
66
|
-
const out = {};
|
|
67
|
-
const ensureBucket = (slot) => (out[slot] ??= []);
|
|
68
|
-
if (!events?.length)
|
|
69
|
-
return out;
|
|
70
|
-
const sp = events.filter((e) => isSeancePublique(e?.type));
|
|
71
|
-
if (sp.length === 0)
|
|
72
|
-
return out;
|
|
73
|
-
// Regroupement par date
|
|
74
|
-
const byDate = new Map();
|
|
75
|
-
for (const e of sp) {
|
|
76
|
-
const d = norm(e.date);
|
|
77
|
-
if (!d)
|
|
78
|
-
continue;
|
|
79
|
-
if (!byDate.has(d))
|
|
80
|
-
byDate.set(d, []);
|
|
81
|
-
byDate.get(d).push(e);
|
|
82
|
-
}
|
|
83
|
-
// Pour chaque date : enrichir, bucketiser par slot, puis pousser dans out[slot]
|
|
84
|
-
for (const [date, dayEvents] of byDate) {
|
|
85
|
-
const enriched = dayEvents.map((e) => {
|
|
86
|
-
const { startISO, endISO, slot } = deriveTimesForEvent(e);
|
|
87
|
-
return { ev: e, startISO, endISO, slot };
|
|
88
|
-
});
|
|
89
|
-
// tri par heure de début connue
|
|
90
|
-
enriched.sort((a, b) => {
|
|
91
|
-
const da = a.startISO ? (parseISO(a.startISO)?.toMillis() ?? Number.MAX_SAFE_INTEGER) : Number.MAX_SAFE_INTEGER;
|
|
92
|
-
const db = b.startISO ? (parseISO(b.startISO)?.toMillis() ?? Number.MAX_SAFE_INTEGER) : Number.MAX_SAFE_INTEGER;
|
|
93
|
-
return da - db;
|
|
94
|
-
});
|
|
95
|
-
// Bucket par slot (en déduisant le slot UNKNOWN via l'heure si possible)
|
|
96
|
-
const bySlot = new Map();
|
|
97
|
-
for (const it of enriched) {
|
|
98
|
-
let s = it.slot;
|
|
99
|
-
if (s === "UNKNOWN" && it.startISO) {
|
|
100
|
-
const dt = parseISO(it.startISO);
|
|
101
|
-
if (dt)
|
|
102
|
-
s = slotOf(dt);
|
|
103
|
-
}
|
|
104
|
-
if (s === "UNKNOWN")
|
|
105
|
-
continue; // on écarte les inconnus résiduels (option : créer un bucket "UNKNOWN")
|
|
106
|
-
if (!bySlot.has(s))
|
|
107
|
-
bySlot.set(s, []);
|
|
108
|
-
bySlot.get(s).push(it);
|
|
109
|
-
}
|
|
110
|
-
// Construire les GroupedReunion et les pousser dans out[slot]
|
|
111
|
-
for (const [slot, list] of bySlot) {
|
|
112
|
-
const sorted = list.slice().sort((a, b) => {
|
|
113
|
-
const da = a.startISO ? (parseISO(a.startISO)?.toMillis() ?? Number.MAX_SAFE_INTEGER) : Number.MAX_SAFE_INTEGER;
|
|
114
|
-
const db = b.startISO ? (parseISO(b.startISO)?.toMillis() ?? Number.MAX_SAFE_INTEGER) : Number.MAX_SAFE_INTEGER;
|
|
115
|
-
return da - db;
|
|
116
|
-
});
|
|
117
|
-
const startTime = sorted.find((x) => !!x.startISO)?.startISO ?? null;
|
|
118
|
-
const endTime = sorted.reduce((acc, x) => {
|
|
119
|
-
const de = x.endISO ? parseISO(x.endISO)?.toMillis() : null;
|
|
120
|
-
const accMs = acc ? parseISO(acc)?.toMillis() : null;
|
|
121
|
-
if (de != null && (accMs == null || de > accMs))
|
|
122
|
-
return x.endISO;
|
|
123
|
-
return acc;
|
|
124
|
-
}, null);
|
|
125
|
-
const titres = sorted.map((x) => x.ev.titre || "").filter(Boolean);
|
|
126
|
-
const captationVideo = sorted.some((x) => x.ev.captationVideo === true);
|
|
127
|
-
ensureBucket(slot).push({
|
|
128
|
-
uid: makeGroupUid(date, slot),
|
|
129
|
-
chambre: "SN",
|
|
130
|
-
date,
|
|
131
|
-
slot,
|
|
132
|
-
type: "Séance publique",
|
|
133
|
-
startTime,
|
|
134
|
-
endTime,
|
|
135
|
-
captationVideo,
|
|
136
|
-
organe: "Séance publique",
|
|
137
|
-
titre: compactTitleList(titres, 5),
|
|
138
|
-
objet: joinObjets(sorted.map((x) => x.ev)),
|
|
139
|
-
events: sorted.map((x) => x.ev),
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
// Tri interne de chaque créneau (cohérent avec groupNonSPByTypeOrganeHour)
|
|
144
|
-
for (const s of Object.keys(out)) {
|
|
145
|
-
out[s].sort((a, b) => {
|
|
146
|
-
const da = DateTime.fromISO(`${a.date}T${a.startTime || "00:00:00.000+02:00"}`, { zone: PARIS }).toMillis();
|
|
147
|
-
const db = DateTime.fromISO(`${b.date}T${b.startTime || "00:00:00.000+02:00"}`, { zone: PARIS }).toMillis();
|
|
148
|
-
// puis par nom de slot pour stabilité (facultatif)
|
|
149
|
-
return da - db || (a.slot || "UNKNOWN").localeCompare(b.slot || "UNKNOWN");
|
|
150
|
-
});
|
|
151
|
-
}
|
|
152
|
-
return out;
|
|
153
|
-
}
|
|
154
|
-
function normalizeNoAccents(s) {
|
|
155
|
-
return (s || "")
|
|
156
|
-
.trim()
|
|
157
|
-
.normalize("NFKD")
|
|
158
|
-
.replace(/[\u0300-\u036f]/g, "");
|
|
159
|
-
}
|
|
160
|
-
function isSeancePublique(typeLabel) {
|
|
161
|
-
const s = normalizeNoAccents(typeLabel || "").toLowerCase();
|
|
162
|
-
return /\bseance\b.*\bpublique\b/.test(s);
|
|
163
|
-
}
|
|
164
|
-
function classifyAgendaType(typeLabel) {
|
|
165
|
-
const s = normalizeNoAccents(typeLabel || "").toLowerCase();
|
|
166
|
-
if (/\bseance\b.*\bpublique\b/.test(s))
|
|
167
|
-
return "SP";
|
|
168
|
-
if (/\bcommissions\b/.test(s))
|
|
169
|
-
return "COM";
|
|
170
|
-
if (/\bmission\b.*\bcontrole\b/.test(s))
|
|
171
|
-
return "MC";
|
|
172
|
-
if (/\boffices\b|\bdelegations\b/.test(s))
|
|
173
|
-
return "OD";
|
|
174
|
-
if (/\instances\b|\decisionelles\b/.test(s))
|
|
175
|
-
return "ID";
|
|
176
|
-
return null;
|
|
177
|
-
}
|
|
178
|
-
function typeToSuffixStrict(kind) {
|
|
179
|
-
switch (kind) {
|
|
180
|
-
case "SP":
|
|
181
|
-
return "IDS";
|
|
182
|
-
case "COM":
|
|
183
|
-
return "IDC";
|
|
184
|
-
case "MC":
|
|
185
|
-
return "IDM";
|
|
186
|
-
case "OD":
|
|
187
|
-
return "IDO";
|
|
188
|
-
case "ID":
|
|
189
|
-
return "IDI";
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
function hourShortFromISO(iso) {
|
|
193
|
-
if (!iso)
|
|
194
|
-
return null;
|
|
195
|
-
const dt = parseISO(iso);
|
|
196
|
-
if (!dt)
|
|
197
|
-
return null;
|
|
198
|
-
const z = DateTime.fromISO(iso, { zone: PARIS });
|
|
199
|
-
const H = String(z.hour);
|
|
200
|
-
const mm = String(z.minute).padStart(2, "0");
|
|
201
|
-
return `${H}${mm}`;
|
|
202
|
-
}
|
|
203
|
-
function hourShortFromOriginal(s) {
|
|
204
|
-
if (!s)
|
|
205
|
-
return null;
|
|
206
|
-
const clean = normalizeNoAccents(s).toLowerCase();
|
|
207
|
-
const m = clean.match(/(\d{1,2})\s*[h:]\s*(\d{2})/);
|
|
208
|
-
if (m) {
|
|
209
|
-
const H = String(parseInt(m[1], 10));
|
|
210
|
-
const mm = m[2].padStart(2, "0");
|
|
211
|
-
return `${H}${mm}`;
|
|
212
|
-
}
|
|
213
|
-
const m2 = clean.match(/(\d{1,2})\s*h\b/);
|
|
214
|
-
if (m2)
|
|
215
|
-
return `${parseInt(m2[1], 10)}00`;
|
|
216
|
-
return null;
|
|
217
|
-
}
|
|
218
|
-
function organeInitials(input, maxLen = 8) {
|
|
219
|
-
if (!input)
|
|
220
|
-
return "";
|
|
221
|
-
const clean = normalizeNoAccents(input)
|
|
222
|
-
.replace(/['’]/g, " ")
|
|
223
|
-
.replace(/[^A-Za-z0-9\s]/g, " ")
|
|
224
|
-
.replace(/\s+/g, " ")
|
|
225
|
-
.trim();
|
|
226
|
-
if (!clean)
|
|
227
|
-
return "";
|
|
228
|
-
const parts = clean.split(" ");
|
|
229
|
-
const letters = [];
|
|
230
|
-
for (const raw of parts) {
|
|
231
|
-
const w = raw.toLowerCase();
|
|
232
|
-
if (!w)
|
|
233
|
-
continue;
|
|
234
|
-
if (STOPWORDS.has(w))
|
|
235
|
-
continue;
|
|
236
|
-
// Take two first letter if alphanumeric
|
|
237
|
-
const two = raw.slice(0, 2);
|
|
238
|
-
if (/[A-Za-z0-9]/.test(two))
|
|
239
|
-
letters.push(two.toUpperCase());
|
|
240
|
-
}
|
|
241
|
-
const out = letters.join("");
|
|
242
|
-
return out.slice(0, maxLen);
|
|
243
|
-
}
|
|
244
|
-
export function makeTypeGroupUid(dateISO, kind, agendaEventId, organe) {
|
|
245
|
-
const ymd = dateISO ? formatYYYYMMDD(dateISO) : "00000000";
|
|
246
|
-
const suffix = typeToSuffixStrict(kind);
|
|
247
|
-
const org = organe ? organeInitials(organe) : "";
|
|
248
|
-
let base = `RUSN${ymd}${suffix}${org ? org : ""}${agendaEventId}`;
|
|
249
|
-
return base;
|
|
250
|
-
}
|
|
251
|
-
function parseISO(isoLike) {
|
|
252
|
-
if (!isoLike)
|
|
253
|
-
return null;
|
|
254
|
-
const dt = DateTime.fromISO(isoLike, { zone: PARIS });
|
|
255
|
-
return dt.isValid ? dt : null;
|
|
256
|
-
}
|
|
257
|
-
function slotOf(dt) {
|
|
258
|
-
if (!dt)
|
|
259
|
-
return "UNKNOWN";
|
|
260
|
-
const h = dt.hour + dt.minute / 60;
|
|
261
|
-
if (h < 12.5)
|
|
262
|
-
return "MATIN";
|
|
263
|
-
if (h < 19.0)
|
|
264
|
-
return "APRES-MIDI";
|
|
265
|
-
return "SOIR";
|
|
266
|
-
}
|
|
267
|
-
function trimWords(s, max = 40) {
|
|
268
|
-
const words = norm(s).split(/\s+/).filter(Boolean);
|
|
269
|
-
return words.length <= max ? words.join(" ") : words.slice(0, max).join(" ");
|
|
270
|
-
}
|
|
271
|
-
function compactTitleList(titres, maxTitles = 5) {
|
|
272
|
-
const uniq = Array.from(new Set(titres.map((t) => norm(t)).filter(Boolean)));
|
|
273
|
-
return uniq.slice(0, maxTitles).join(" · ") || "(sans titre)";
|
|
274
|
-
}
|
|
275
|
-
export function makeGroupUid(date, slot) {
|
|
276
|
-
const ymd = date ? formatYYYYMMDD(date) : "00000000";
|
|
277
|
-
return `RUSN${ymd}IDS-${slot}`;
|
|
278
|
-
}
|
|
279
|
-
export function formatYYYYMMDD(dateYYYYMMDD) {
|
|
280
|
-
const [y, m, d] = dateYYYYMMDD.split("-");
|
|
281
|
-
return `${y}${m}${d}`;
|
|
282
|
-
}
|
|
283
|
-
export function makeReunionUid(agenda) {
|
|
284
|
-
const ymd = agenda.date ? formatYYYYMMDD(agenda.date) : "00000000";
|
|
285
|
-
return `${ymd}-${agenda.id}`;
|
|
286
|
-
}
|
|
287
|
-
function joinObjets(events) {
|
|
288
|
-
const objets = events
|
|
289
|
-
.map((e) => (e.objet || "").trim())
|
|
290
|
-
.filter(Boolean)
|
|
291
|
-
.map((s) => trimWords(s, 40));
|
|
292
|
-
if (objets.length === 0)
|
|
293
|
-
return "";
|
|
294
|
-
return objets.join(" · ");
|
|
295
|
-
}
|
|
296
|
-
// Extract hours/minutes from French text like "à 10 h 30", "de 10 h à 12 h", etc.
|
|
297
|
-
function parseTimeOriginalFR(timeOriginal) {
|
|
298
|
-
if (!timeOriginal)
|
|
299
|
-
return { start: null, end: null };
|
|
300
|
-
const txt = (timeOriginal || "")
|
|
301
|
-
.replace(/\u00A0/g, " ") // nbsp → space
|
|
302
|
-
.replace(/\s+/g, " ") // espaces multiples
|
|
303
|
-
.toLowerCase()
|
|
304
|
-
.trim();
|
|
305
|
-
// 1) "de 10 h 30 à 12 heures", "de 10h30 à 12h", "de 9 h à 11 h 15", etc.
|
|
306
|
-
const reRange = /\bde\s+(\d{1,2})\s*(?:h|:)?\s*(\d{1,2})?\s*(?:heures?)?\s*à\s*(\d{1,2})\s*(?:h|:)?\s*(\d{1,2})?\s*(?:heures?)?/i;
|
|
307
|
-
const mRange = txt.match(reRange);
|
|
308
|
-
if (mRange) {
|
|
309
|
-
const h1 = clampHour(+mRange[1]), m1 = clampMinute(mRange[2] ? +mRange[2] : 0);
|
|
310
|
-
const h2 = clampHour(+mRange[3]), m2 = clampMinute(mRange[4] ? +mRange[4] : 0);
|
|
311
|
-
return { start: toIsoTime(h1, m1), end: toIsoTime(h2, m2) };
|
|
312
|
-
}
|
|
313
|
-
// 2) "à 10 h 30", "à 10h", "A 10h30", "A 9 heures", etc.
|
|
314
|
-
const reAt = /\b(?:a|à)\s*(\d{1,2})\s*(?:h|:)?\s*(\d{1,2})?\s*(?:heures?)?/i;
|
|
315
|
-
const mAt = txt.match(reAt);
|
|
316
|
-
if (mAt) {
|
|
317
|
-
const h = clampHour(+mAt[1]), m = clampMinute(mAt[2] ? +mAt[2] : 0);
|
|
318
|
-
return { start: toIsoTime(h, m), end: null };
|
|
319
|
-
}
|
|
320
|
-
// 3) "10 h 30", "15h", "9 heures" sans 'à' / 'de ... à ...'
|
|
321
|
-
const reBare = /\b(\d{1,2})\s*(?:h|:)?\s*(\d{1,2})?\s*(?:heures?)?\b/;
|
|
322
|
-
const mBare = txt.match(reBare);
|
|
323
|
-
if (mBare) {
|
|
324
|
-
const h = clampHour(+mBare[1]), m = clampMinute(mBare[2] ? +mBare[2] : 0);
|
|
325
|
-
return { start: toIsoTime(h, m), end: null };
|
|
326
|
-
}
|
|
327
|
-
return { start: null, end: null };
|
|
328
|
-
}
|
|
329
|
-
function clampHour(h) {
|
|
330
|
-
return Math.max(0, Math.min(23, h));
|
|
331
|
-
}
|
|
332
|
-
function clampMinute(m) {
|
|
333
|
-
return Math.max(0, Math.min(59, m));
|
|
334
|
-
}
|
|
335
|
-
function toIsoTime(h, m) {
|
|
336
|
-
return `${String(h).padStart(2, "0")}:${String(m).padStart(2, "0")}:00.000+02:00`;
|
|
337
|
-
}
|
|
338
|
-
function slotFromTimesOrText(startISO, timeOriginal) {
|
|
339
|
-
if (startISO) {
|
|
340
|
-
const dt = parseISO(startISO);
|
|
341
|
-
if (dt)
|
|
342
|
-
return slotOf(dt);
|
|
343
|
-
}
|
|
344
|
-
const t = (timeOriginal || "").toLowerCase();
|
|
345
|
-
if (/\b(apr(?:è|e)s[-\s]?midi)\b/.test(t))
|
|
346
|
-
return "APRES-MIDI";
|
|
347
|
-
if (/\b(soir(?:ée)?)\b/.test(t))
|
|
348
|
-
return "SOIR";
|
|
349
|
-
if (/\b(matin(?:ée)?)\b/.test(t))
|
|
350
|
-
return "MATIN";
|
|
351
|
-
return "UNKNOWN";
|
|
352
|
-
}
|
|
353
|
-
function deriveTimesForEvent(ev) {
|
|
354
|
-
const directStart = ev.startTime ?? null;
|
|
355
|
-
const directEnd = ev.endTime ?? null;
|
|
356
|
-
const fromText = parseTimeOriginalFR(ev.timeOriginal);
|
|
357
|
-
const startISO = directStart ?? fromText.start ?? null;
|
|
358
|
-
const endISO = directEnd ?? fromText.end ?? null;
|
|
359
|
-
const slot = slotFromTimesOrText(startISO, ev.timeOriginal);
|
|
360
|
-
return { startISO, endISO, slot };
|
|
361
|
-
}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import commandLineArgs from "command-line-args";
|
|
2
|
-
import { DossierLegislatifResult } from "../model/dosleg";
|
|
3
|
-
import { AgendaEvent, ReunionOdj } from "../types/agenda";
|
|
4
|
-
export declare function buildOdj(events: AgendaEvent[], dossierBySenatUrl: Record<string, DossierLegislatifResult>): ReunionOdj | undefined;
|
|
5
|
-
export declare function buildSenatDossierIndex(options: commandLineArgs.CommandLineOptions): Record<string, DossierLegislatifResult>;
|