@tricoteuses/senat 1.1.1 → 1.3.1
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/README.md +53 -15
- package/lib/aggregates.d.ts +4 -6
- package/lib/aggregates.mjs +908 -780
- package/lib/aggregates.ts +8 -122
- package/lib/data/legislatures.json +38 -0
- package/lib/databases.d.ts +9 -0
- package/lib/databases.js +41 -11
- package/lib/databases.mjs +32 -1
- package/lib/databases.ts +40 -1
- package/lib/fields.mjs +64 -18
- package/lib/index.d.ts +5 -6
- package/lib/index.js +8 -99
- package/lib/index.mjs +4 -6
- package/lib/index.ts +9 -26
- package/lib/inserters.d.ts +0 -4
- package/lib/inserters.mjs +461 -337
- package/lib/inserters.ts +0 -24
- package/lib/legislatures.json +38 -0
- package/lib/loaders.d.ts +64 -0
- package/lib/loaders.js +682 -0
- package/lib/loaders.mjs +158 -0
- package/lib/loaders.ts +271 -0
- package/lib/model/ameli.d.ts +105 -4
- package/lib/model/ameli.js +20 -160
- package/lib/model/ameli.mjs +84 -57
- package/lib/model/ameli.ts +94 -80
- package/lib/model/debats.d.ts +0 -4
- package/lib/model/debats.js +1 -122
- package/lib/model/debats.mjs +1 -43
- package/lib/model/debats.ts +0 -68
- package/lib/model/dosleg.d.ts +227 -29
- package/lib/model/dosleg.js +92 -832
- package/lib/model/dosleg.mjs +196 -337
- package/lib/model/dosleg.ts +213 -531
- package/lib/model/index.d.ts +4 -5
- package/lib/model/index.js +14 -15
- package/lib/model/index.mjs +4 -5
- package/lib/model/index.ts +8 -5
- package/lib/model/questions.d.ts +88 -2
- package/lib/model/questions.js +40 -45
- package/lib/model/questions.mjs +71 -8
- package/lib/model/questions.ts +90 -11
- package/lib/model/sens.d.ts +524 -2
- package/lib/model/sens.js +172 -49
- package/lib/model/sens.mjs +415 -9
- package/lib/model/sens.ts +514 -16
- package/lib/model/texte.d.ts +7 -0
- package/lib/model/texte.js +321 -0
- package/lib/model/texte.mjs +208 -0
- package/lib/model/texte.ts +229 -0
- package/lib/model/util.d.ts +7 -1
- package/lib/model/util.js +37 -53
- package/lib/model/util.mjs +19 -10
- package/lib/model/util.ts +30 -14
- package/lib/raw_types/ameli.d.ts +912 -538
- package/lib/raw_types/ameli.js +1 -39
- package/lib/raw_types/ameli.mjs +4 -1
- package/lib/raw_types/ameli.ts +947 -597
- package/lib/raw_types/debats.d.ts +204 -124
- package/lib/raw_types/debats.js +1 -18
- package/lib/raw_types/debats.mjs +4 -1
- package/lib/raw_types/debats.ts +218 -141
- package/lib/raw_types/dosleg.d.ts +3533 -2024
- package/lib/raw_types/dosleg.js +1 -92
- package/lib/raw_types/dosleg.mjs +4 -1
- package/lib/raw_types/dosleg.ts +3621 -2189
- package/lib/raw_types/questions.d.ts +404 -220
- package/lib/raw_types/questions.js +1 -18
- package/lib/raw_types/questions.mjs +4 -1
- package/lib/raw_types/questions.ts +404 -226
- package/lib/raw_types/sens.d.ts +4391 -2706
- package/lib/raw_types/sens.js +1 -108
- package/lib/raw_types/sens.mjs +4 -1
- package/lib/raw_types/sens.ts +4495 -2903
- package/lib/raw_types_kysely/ameli.d.ts +6 -0
- package/lib/raw_types_kysely/ameli.mjs +7 -0
- package/lib/raw_types_kysely/ameli.ts +6 -0
- package/lib/raw_types_kysely/debats.d.ts +6 -0
- package/lib/raw_types_kysely/debats.mjs +7 -0
- package/lib/raw_types_kysely/debats.ts +6 -0
- package/lib/raw_types_kysely/dosleg.d.ts +6 -0
- package/lib/raw_types_kysely/dosleg.mjs +7 -0
- package/lib/raw_types_kysely/dosleg.ts +6 -0
- package/lib/raw_types_kysely/questions.d.ts +6 -0
- package/lib/raw_types_kysely/questions.mjs +7 -0
- package/lib/raw_types_kysely/questions.ts +6 -0
- package/lib/raw_types_kysely/sens.d.ts +6 -0
- package/lib/raw_types_kysely/sens.mjs +7 -0
- package/lib/raw_types_kysely/sens.ts +6 -0
- package/lib/raw_types_kysely/texte.d.ts +45 -0
- package/lib/raw_types_kysely/texte.mjs +7 -0
- package/lib/raw_types_kysely/texte.ts +53 -0
- package/lib/raw_types_schemats/ameli.d.ts +541 -0
- package/lib/raw_types_schemats/ameli.js +45 -0
- package/lib/raw_types_schemats/ameli.mjs +2 -0
- package/lib/raw_types_schemats/ameli.ts +601 -0
- package/lib/raw_types_schemats/debats.d.ts +127 -0
- package/lib/raw_types_schemats/debats.js +24 -0
- package/lib/raw_types_schemats/debats.mjs +2 -0
- package/lib/raw_types_schemats/debats.ts +145 -0
- package/lib/raw_types_schemats/dosleg.d.ts +2029 -0
- package/lib/raw_types_schemats/dosleg.js +98 -0
- package/lib/raw_types_schemats/dosleg.mjs +2 -0
- package/lib/raw_types_schemats/dosleg.ts +2195 -0
- package/lib/raw_types_schemats/questions.d.ts +233 -0
- package/lib/raw_types_schemats/questions.js +24 -0
- package/lib/raw_types_schemats/questions.mjs +2 -0
- package/lib/raw_types_schemats/questions.ts +251 -0
- package/lib/raw_types_schemats/sens.d.ts +2709 -0
- package/lib/raw_types_schemats/sens.js +114 -0
- package/lib/raw_types_schemats/sens.mjs +2 -0
- package/lib/raw_types_schemats/sens.ts +2907 -0
- package/lib/scripts/convert_data.js +574 -215
- package/lib/scripts/convert_data.mjs +134 -99
- package/lib/scripts/convert_data.ts +173 -112
- package/lib/scripts/datautil.d.ts +5 -0
- package/lib/scripts/datautil.js +64 -0
- package/lib/scripts/datautil.mjs +16 -0
- package/lib/scripts/datautil.ts +19 -0
- package/lib/scripts/parse_textes.js +132 -0
- package/lib/scripts/parse_textes.mjs +46 -0
- package/lib/scripts/parse_textes.ts +65 -0
- package/lib/scripts/retrieve_documents.d.ts +1 -0
- package/lib/scripts/retrieve_documents.js +521 -0
- package/lib/scripts/retrieve_documents.mjs +249 -0
- package/lib/scripts/retrieve_documents.ts +298 -0
- package/lib/scripts/retrieve_open_data.js +77 -69
- package/lib/scripts/retrieve_open_data.mjs +48 -49
- package/lib/scripts/retrieve_open_data.ts +74 -58
- package/lib/scripts/retrieve_senateurs_photos.js +45 -63
- package/lib/scripts/retrieve_senateurs_photos.mjs +4 -21
- package/lib/scripts/retrieve_senateurs_photos.ts +6 -29
- package/lib/scripts/retrieve_textes.mjs +325 -74
- package/lib/scripts/retrieve_textes.ts +111 -63
- package/lib/scripts/shared/cli_helpers.d.ts +44 -0
- package/lib/scripts/shared/cli_helpers.js +35 -0
- package/lib/scripts/shared/cli_helpers.ts +36 -0
- package/lib/scripts/shared/util.d.ts +3 -0
- package/lib/scripts/shared/util.js +102 -0
- package/lib/scripts/shared/util.ts +33 -0
- package/lib/src/aggregates.d.ts +52 -0
- package/lib/src/aggregates.mjs +726 -0
- package/lib/src/config.d.ts +2 -0
- package/lib/src/config.mjs +16 -0
- package/lib/src/databases.d.ts +18 -0
- package/lib/src/databases.mjs +55 -0
- package/lib/src/datasets.d.ts +28 -0
- package/lib/src/datasets.mjs +78 -0
- package/lib/src/fields.d.ts +10 -0
- package/lib/src/fields.mjs +22 -0
- package/lib/src/index.d.ts +8 -0
- package/lib/src/index.mjs +7 -0
- package/lib/src/inserters.d.ts +98 -0
- package/lib/src/inserters.mjs +360 -0
- package/lib/src/loaders.d.ts +36 -0
- package/lib/src/loaders.mjs +107 -0
- package/lib/src/model/ameli.d.ts +4 -0
- package/lib/src/model/ameli.js +57 -0
- package/lib/src/model/debats.d.ts +4 -0
- package/lib/src/model/debats.js +43 -0
- package/lib/src/model/dosleg.d.ts +197 -0
- package/lib/src/model/dosleg.js +169 -0
- package/lib/src/model/index.d.ts +4 -0
- package/lib/src/model/index.js +4 -0
- package/lib/src/model/questions.d.ts +89 -0
- package/lib/src/model/questions.js +76 -0
- package/lib/src/model/sens.d.ts +390 -0
- package/lib/src/model/sens.js +339 -0
- package/lib/src/model/texte.d.ts +7 -0
- package/lib/src/model/texte.js +183 -0
- package/lib/src/raw_types_kysely/ameli.d.ts +915 -0
- package/lib/src/raw_types_kysely/ameli.js +5 -0
- package/lib/src/raw_types_kysely/debats.d.ts +207 -0
- package/lib/src/raw_types_kysely/debats.js +5 -0
- package/lib/src/raw_types_kysely/dosleg.d.ts +3532 -0
- package/lib/src/raw_types_kysely/dosleg.js +5 -0
- package/lib/src/raw_types_kysely/questions.d.ts +414 -0
- package/lib/src/raw_types_kysely/questions.js +5 -0
- package/lib/src/raw_types_kysely/sens.d.ts +4394 -0
- package/lib/src/raw_types_kysely/sens.js +5 -0
- package/lib/src/raw_types_schemats/ameli.d.ts +541 -0
- package/lib/src/raw_types_schemats/ameli.js +2 -0
- package/lib/src/raw_types_schemats/debats.d.ts +127 -0
- package/lib/src/raw_types_schemats/debats.js +2 -0
- package/lib/src/raw_types_schemats/dosleg.d.ts +2027 -0
- package/lib/src/raw_types_schemats/dosleg.js +2 -0
- package/lib/src/raw_types_schemats/questions.d.ts +231 -0
- package/lib/src/raw_types_schemats/questions.js +2 -0
- package/lib/src/raw_types_schemats/sens.d.ts +2709 -0
- package/lib/src/raw_types_schemats/sens.js +2 -0
- package/lib/src/scripts/convert_data.d.ts +1 -0
- package/lib/src/scripts/convert_data.js +95 -0
- package/lib/src/scripts/datautil.d.ts +5 -0
- package/lib/src/scripts/datautil.js +16 -0
- package/lib/src/scripts/parse_textes.d.ts +1 -0
- package/lib/src/scripts/parse_textes.js +47 -0
- package/lib/src/scripts/retrieve_documents.d.ts +1 -0
- package/lib/src/scripts/retrieve_documents.js +258 -0
- package/lib/src/scripts/retrieve_open_data.d.ts +1 -0
- package/lib/src/scripts/retrieve_open_data.js +214 -0
- package/lib/src/scripts/retrieve_senateurs_photos.d.ts +1 -0
- package/lib/src/scripts/retrieve_senateurs_photos.js +147 -0
- package/lib/src/scripts/shared/cli_helpers.d.ts +44 -0
- package/lib/src/scripts/shared/cli_helpers.js +32 -0
- package/lib/src/scripts/shared/util.d.ts +3 -0
- package/lib/src/scripts/shared/util.js +28 -0
- package/lib/src/strings.d.ts +1 -0
- package/lib/src/strings.mjs +18 -0
- package/lib/src/types/ameli.d.ts +10 -0
- package/lib/src/types/ameli.js +13 -0
- package/lib/src/types/debats.d.ts +4 -0
- package/lib/src/types/debats.js +2 -0
- package/lib/src/types/dosleg.d.ts +98 -0
- package/lib/src/types/dosleg.js +151 -0
- package/lib/src/types/questions.d.ts +2 -0
- package/lib/src/types/questions.js +1 -0
- package/lib/src/types/sens.d.ts +10 -0
- package/lib/src/types/sens.js +1 -0
- package/lib/src/types/sessions.d.ts +42 -0
- package/lib/src/types/sessions.js +43 -0
- package/lib/src/types/texte.d.ts +61 -0
- package/lib/src/types/texte.js +16 -0
- package/lib/src/validators/config.d.ts +1 -0
- package/lib/src/validators/config.js +54 -0
- package/lib/src/validators/senat.d.ts +0 -0
- package/lib/src/validators/senat.js +24 -0
- package/lib/types/ameli.d.ts +1 -1
- package/lib/types/ameli.js +2 -2
- package/lib/types/ameli.ts +1 -1
- package/lib/types/debats.d.ts +1 -1
- package/lib/types/debats.js +2 -2
- package/lib/types/debats.ts +1 -1
- package/lib/types/dosleg.d.ts +2 -2
- package/lib/types/dosleg.js +2 -2
- package/lib/types/dosleg.ts +2 -2
- package/lib/types/questions.d.ts +1 -1
- package/lib/types/questions.js +2 -2
- package/lib/types/questions.ts +1 -1
- package/lib/types/sens.d.ts +1 -3
- package/lib/types/sens.js +2 -5
- package/lib/types/sens.mjs +1 -23
- package/lib/types/sens.ts +1 -25
- package/lib/types/sessions.d.ts +42 -0
- package/lib/types/sessions.js +51 -0
- package/lib/types/sessions.mjs +43 -0
- package/lib/types/sessions.ts +42 -0
- package/lib/types/texte.d.ts +65 -0
- package/lib/types/texte.js +24 -0
- package/lib/types/texte.mjs +16 -0
- package/lib/types/texte.ts +76 -0
- package/package.json +35 -10
- package/lib/aggregates.js +0 -1122
- package/lib/fields.js +0 -68
- package/lib/inserters.js +0 -518
- package/lib/scripts/fix_db.js +0 -144
- package/lib/scripts/fix_db.mjs +0 -64
- package/lib/scripts/fix_db.ts +0 -75
- package/lib/scripts/retrieve_textes.js +0 -179
- /package/lib/scripts/{fix_db.d.ts → parse_textes.d.ts} +0 -0
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
import { JSDOM } from "jsdom";
|
|
2
|
+
import { AKN_WORKFLOW_IDENTIFICATION_STRUCTURE_REGEXP, AKN_IDENTIFICATION_STRUCTURE_REGEXP } from "../scripts/datautil";
|
|
3
|
+
import { DivisionType, } from "../types/texte";
|
|
4
|
+
function buildWorklow(metaElement) {
|
|
5
|
+
const stepElements = metaElement.querySelectorAll("workflow step");
|
|
6
|
+
const steps = [];
|
|
7
|
+
for (const stepElement of stepElements) {
|
|
8
|
+
const identification = stepElement.getAttribute("href") ?? "";
|
|
9
|
+
const identificationParts = AKN_WORKFLOW_IDENTIFICATION_STRUCTURE_REGEXP.exec(identification)?.groups;
|
|
10
|
+
steps.push({
|
|
11
|
+
eId: stepElement.getAttribute("eId"),
|
|
12
|
+
date: stepElement.getAttribute("date") ? new Date(stepElement.getAttribute("date") ?? "") : null,
|
|
13
|
+
type: identificationParts?.type || null,
|
|
14
|
+
session: identificationParts?.session || null,
|
|
15
|
+
numero: identificationParts?.numTexte || null,
|
|
16
|
+
version: identificationParts?.version ? identificationParts.version : null,
|
|
17
|
+
outcome: stepElement.getAttribute("outcome"),
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
return steps;
|
|
21
|
+
}
|
|
22
|
+
function buildDivision(node, index) {
|
|
23
|
+
const eId = node.getAttribute("eId");
|
|
24
|
+
const tag = node.nodeName;
|
|
25
|
+
const level = DivisionType[tag];
|
|
26
|
+
const titleNode = node.querySelector("num");
|
|
27
|
+
const subtitleNode = node.querySelector("heading");
|
|
28
|
+
const headings = [
|
|
29
|
+
...(titleNode ? [{
|
|
30
|
+
text: titleNode.textContent?.trim() ?? null,
|
|
31
|
+
html: titleNode.innerHTML?.trim() ?? null,
|
|
32
|
+
}] : []),
|
|
33
|
+
...(subtitleNode ? [{
|
|
34
|
+
text: subtitleNode.textContent?.trim() ?? null,
|
|
35
|
+
html: subtitleNode.innerHTML?.trim() ?? null,
|
|
36
|
+
}] : []),
|
|
37
|
+
];
|
|
38
|
+
const division = {
|
|
39
|
+
index,
|
|
40
|
+
eId,
|
|
41
|
+
tag,
|
|
42
|
+
level,
|
|
43
|
+
headings,
|
|
44
|
+
};
|
|
45
|
+
if (tag === "article") {
|
|
46
|
+
division.alineas = [];
|
|
47
|
+
}
|
|
48
|
+
return division;
|
|
49
|
+
}
|
|
50
|
+
function buildAlinea(contentNode, alineaNode) {
|
|
51
|
+
const eId = alineaNode.getAttribute("eId");
|
|
52
|
+
const heading = {
|
|
53
|
+
text: alineaNode.querySelector("num")?.textContent ?? null,
|
|
54
|
+
};
|
|
55
|
+
const pastille = alineaNode.getAttribute("data:pastille") ?? null;
|
|
56
|
+
return {
|
|
57
|
+
eId,
|
|
58
|
+
heading,
|
|
59
|
+
text: contentNode.textContent?.trim() ?? null,
|
|
60
|
+
html: contentNode.innerHTML?.trim() ?? null,
|
|
61
|
+
pastille,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
function buildEmptyArticle(index) {
|
|
65
|
+
return {
|
|
66
|
+
index: index,
|
|
67
|
+
eId: "",
|
|
68
|
+
tag: "article",
|
|
69
|
+
level: DivisionType["article"],
|
|
70
|
+
headings: [],
|
|
71
|
+
alineas: [],
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
function flattenTexte(texteContentRoot) {
|
|
75
|
+
const divisions = [];
|
|
76
|
+
let divisionIndex = 0;
|
|
77
|
+
const iter = (node) => {
|
|
78
|
+
if (node.nodeName === "content") {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
switch (node.nodeName) {
|
|
82
|
+
case "tome":
|
|
83
|
+
case "part":
|
|
84
|
+
case "book":
|
|
85
|
+
case "title":
|
|
86
|
+
case "subtitle":
|
|
87
|
+
case "chapter":
|
|
88
|
+
case "section":
|
|
89
|
+
case "subsection":
|
|
90
|
+
case "paragraph":
|
|
91
|
+
case "article":
|
|
92
|
+
divisions.push(buildDivision(node, divisionIndex++));
|
|
93
|
+
break;
|
|
94
|
+
}
|
|
95
|
+
if (node.nodeName === "alinea") {
|
|
96
|
+
Array.from(node.childNodes)
|
|
97
|
+
// Find direct content children programmatically
|
|
98
|
+
// because `:scope` selector does not work
|
|
99
|
+
// https://github.com/jsdom/jsdom/issues/2998
|
|
100
|
+
.filter((alineaChildNode) => alineaChildNode.nodeName === "content")
|
|
101
|
+
.forEach((alineaContentNode) => {
|
|
102
|
+
// Hypothesis: alineas should always be enclosed in articles
|
|
103
|
+
let lastArticle = divisions.findLast(division => division.tag === "article");
|
|
104
|
+
if (!lastArticle) {
|
|
105
|
+
lastArticle = buildEmptyArticle(divisionIndex++);
|
|
106
|
+
divisions.push(lastArticle);
|
|
107
|
+
}
|
|
108
|
+
lastArticle.alineas.push(buildAlinea(alineaContentNode, node));
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
if (node.hasChildNodes()) {
|
|
112
|
+
node.childNodes.forEach((childNode) => iter(childNode));
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
iter(texteContentRoot);
|
|
116
|
+
return divisions;
|
|
117
|
+
}
|
|
118
|
+
export function transformTexte(document) {
|
|
119
|
+
const metaElement = document.querySelector("meta");
|
|
120
|
+
const preambleElement = document.querySelector("preamble");
|
|
121
|
+
const identification = metaElement?.querySelector("FRBRExpression FRBRuri")?.getAttribute("value") ?? "";
|
|
122
|
+
const identificationParts = AKN_IDENTIFICATION_STRUCTURE_REGEXP.exec(identification)?.groups;
|
|
123
|
+
const bodyElement = document.querySelector("body");
|
|
124
|
+
const datePresentation = metaElement?.querySelector("FRBRdate[name='#presentation']")?.getAttribute("date");
|
|
125
|
+
const dateDepot = metaElement?.querySelector("FRBRdate[name='#depot']")?.getAttribute("date");
|
|
126
|
+
const datePublicationXml = metaElement?.querySelector("FRBRdate[name='#publication-xml']")?.getAttribute("date");
|
|
127
|
+
return {
|
|
128
|
+
titre: preambleElement?.querySelector("docTitle")?.textContent || null,
|
|
129
|
+
titreCourt: metaElement?.querySelector("FRBRalias[name='intitule-court']")
|
|
130
|
+
?.getAttribute("value") || null,
|
|
131
|
+
signetDossier: metaElement?.querySelector("FRBRalias[name='signet-dossier-legislatif-senat']")
|
|
132
|
+
?.getAttribute("value") || null,
|
|
133
|
+
urlDossierSenat: metaElement?.querySelector("FRBRalias[name='url-senat']")?.getAttribute("value") || null,
|
|
134
|
+
urlDossierAssemblee: metaElement?.querySelector("FRBRalias[name='url-AN']")?.getAttribute("value") || null,
|
|
135
|
+
type: identificationParts?.type || null,
|
|
136
|
+
session: identificationParts?.session || null,
|
|
137
|
+
numero: identificationParts?.numTexte ? parseInt(identificationParts.numTexte) : null,
|
|
138
|
+
datePresentation: datePresentation ? new Date(datePresentation) : null,
|
|
139
|
+
dateDepot: dateDepot ? new Date(dateDepot) : null,
|
|
140
|
+
datePublicationXml: datePublicationXml ? new Date(datePublicationXml) : null,
|
|
141
|
+
version: identificationParts?.version ? identificationParts.version : null,
|
|
142
|
+
workflow: metaElement ? buildWorklow(metaElement) : [],
|
|
143
|
+
divisions: bodyElement ? flattenTexte(bodyElement) : [],
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
export function transformExposeDesMotifs(document) {
|
|
147
|
+
const sectionElements = document.querySelectorAll("section");
|
|
148
|
+
const exposeDesMotifsRegexp = new RegExp("EXPOS.{1,2}[\\n\\s]DES[\\n\\s]MOTIFS");
|
|
149
|
+
for (const sectionElement of sectionElements) {
|
|
150
|
+
const firstParagraph = sectionElement.querySelector("p:first-of-type");
|
|
151
|
+
const secondParagraph = sectionElement.querySelector("p:nth-of-type(2)");
|
|
152
|
+
if (!firstParagraph) {
|
|
153
|
+
continue;
|
|
154
|
+
}
|
|
155
|
+
const firstParagraphContent = firstParagraph.textContent;
|
|
156
|
+
const secondParagraphContent = secondParagraph?.textContent;
|
|
157
|
+
if (!firstParagraphContent || !exposeDesMotifsRegexp.test(firstParagraphContent.toUpperCase())) {
|
|
158
|
+
if (!secondParagraphContent || !exposeDesMotifsRegexp.test(secondParagraphContent.toUpperCase())) {
|
|
159
|
+
continue;
|
|
160
|
+
}
|
|
161
|
+
else {
|
|
162
|
+
sectionElement.removeChild(secondParagraph);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
sectionElement.removeChild(firstParagraph);
|
|
166
|
+
return {
|
|
167
|
+
text: sectionElement.textContent?.trim() ?? null,
|
|
168
|
+
html: sectionElement.innerHTML?.trim() ?? null,
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
return null;
|
|
172
|
+
}
|
|
173
|
+
export function parseTexte(texteXml) {
|
|
174
|
+
try {
|
|
175
|
+
const { document } = (new JSDOM(texteXml, {
|
|
176
|
+
contentType: "text/xml",
|
|
177
|
+
})).window;
|
|
178
|
+
return transformTexte(document);
|
|
179
|
+
}
|
|
180
|
+
catch (error) {
|
|
181
|
+
console.error(`Could not parse texte with error ${error}`);
|
|
182
|
+
}
|
|
183
|
+
return null;
|
|
184
|
+
}
|
|
185
|
+
// Prevent from memory leak
|
|
186
|
+
// https://github.com/jsdom/jsdom/issues/2583#issuecomment-559520814
|
|
187
|
+
export async function parseTexteFromFile(xmlFilePath) {
|
|
188
|
+
try {
|
|
189
|
+
const { document } = (await JSDOM.fromFile(xmlFilePath, { contentType: "text/xml" })).window;
|
|
190
|
+
return transformTexte(document);
|
|
191
|
+
}
|
|
192
|
+
catch (error) {
|
|
193
|
+
console.error(`Could not parse texte with error ${error}`);
|
|
194
|
+
}
|
|
195
|
+
return null;
|
|
196
|
+
}
|
|
197
|
+
export function parseExposeDesMotifs(exposeDesMotifsHtml) {
|
|
198
|
+
const { document } = (new JSDOM(exposeDesMotifsHtml, {
|
|
199
|
+
contentType: "text/html",
|
|
200
|
+
})).window;
|
|
201
|
+
return transformExposeDesMotifs(document);
|
|
202
|
+
}
|
|
203
|
+
// Prevent from memory leak
|
|
204
|
+
// https://github.com/jsdom/jsdom/issues/2583#issuecomment-559520814
|
|
205
|
+
export async function parseExposeDesMotifsFromFile(htmlFilePath) {
|
|
206
|
+
const { document } = (await JSDOM.fromFile(htmlFilePath, { contentType: "text/html" })).window;
|
|
207
|
+
return transformExposeDesMotifs(document);
|
|
208
|
+
}
|
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
import { JSDOM } from "jsdom"
|
|
2
|
+
|
|
3
|
+
import { AKN_WORKFLOW_IDENTIFICATION_STRUCTURE_REGEXP, AKN_IDENTIFICATION_STRUCTURE_REGEXP } from "../scripts/datautil"
|
|
4
|
+
import {
|
|
5
|
+
Alinea,
|
|
6
|
+
Article,
|
|
7
|
+
Division,
|
|
8
|
+
DivisionContent,
|
|
9
|
+
DivisionTag,
|
|
10
|
+
DivisionType, ExposeDesMotifs,
|
|
11
|
+
FlatTexte, Step,
|
|
12
|
+
Version,
|
|
13
|
+
} from "../types/texte"
|
|
14
|
+
|
|
15
|
+
function buildWorklow (metaElement: HTMLMetaElement): Step[] {
|
|
16
|
+
const stepElements = metaElement.querySelectorAll("workflow step")
|
|
17
|
+
const steps: Step[] = []
|
|
18
|
+
for (const stepElement of stepElements) {
|
|
19
|
+
const identification = stepElement.getAttribute("href") ?? ""
|
|
20
|
+
const identificationParts = AKN_WORKFLOW_IDENTIFICATION_STRUCTURE_REGEXP.exec(identification)?.groups
|
|
21
|
+
steps.push({
|
|
22
|
+
eId: stepElement.getAttribute("eId")!,
|
|
23
|
+
date: stepElement.getAttribute("date") ? new Date(stepElement.getAttribute("date") ?? "") : null,
|
|
24
|
+
type: identificationParts?.type || null,
|
|
25
|
+
session: identificationParts?.session || null,
|
|
26
|
+
numero: identificationParts?.numTexte || null,
|
|
27
|
+
version: identificationParts?.version ? identificationParts.version as Version : null,
|
|
28
|
+
outcome: stepElement.getAttribute("outcome"),
|
|
29
|
+
})
|
|
30
|
+
}
|
|
31
|
+
return steps
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
function buildDivision (node: Node, index: number): Division {
|
|
35
|
+
const eId = (node as Element).getAttribute("eId")!
|
|
36
|
+
const tag = node.nodeName as DivisionTag
|
|
37
|
+
const level = DivisionType[tag]
|
|
38
|
+
const titleNode = (node as Element).querySelector("num")
|
|
39
|
+
const subtitleNode = (node as Element).querySelector("heading")
|
|
40
|
+
const headings: DivisionContent[] = [
|
|
41
|
+
...(titleNode ? [{
|
|
42
|
+
text: titleNode.textContent?.trim() ?? null,
|
|
43
|
+
html: titleNode.innerHTML?.trim() ?? null,
|
|
44
|
+
}] : []),
|
|
45
|
+
...(subtitleNode ? [{
|
|
46
|
+
text: subtitleNode.textContent?.trim() ?? null,
|
|
47
|
+
html: subtitleNode.innerHTML?.trim() ?? null,
|
|
48
|
+
}] : []),
|
|
49
|
+
]
|
|
50
|
+
const division = {
|
|
51
|
+
index,
|
|
52
|
+
eId,
|
|
53
|
+
tag,
|
|
54
|
+
level,
|
|
55
|
+
headings,
|
|
56
|
+
}
|
|
57
|
+
if (tag === "article") {
|
|
58
|
+
(division as Article).alineas = []
|
|
59
|
+
}
|
|
60
|
+
return division
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
function buildAlinea (contentNode: Node, alineaNode: Node): Alinea {
|
|
64
|
+
const eId = (alineaNode as Element).getAttribute("eId")!
|
|
65
|
+
const heading = {
|
|
66
|
+
text: (alineaNode as Element).querySelector("num")?.textContent ?? null,
|
|
67
|
+
}
|
|
68
|
+
const pastille = (alineaNode as Element).getAttribute("data:pastille") ?? null
|
|
69
|
+
return {
|
|
70
|
+
eId,
|
|
71
|
+
heading,
|
|
72
|
+
text: (contentNode as Element).textContent?.trim() ?? null,
|
|
73
|
+
html: (contentNode as Element).innerHTML?.trim() ?? null,
|
|
74
|
+
pastille,
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
function buildEmptyArticle (index: number): Article {
|
|
79
|
+
return {
|
|
80
|
+
index: index,
|
|
81
|
+
eId: "",
|
|
82
|
+
tag: "article",
|
|
83
|
+
level: DivisionType["article"],
|
|
84
|
+
headings: [],
|
|
85
|
+
alineas: [],
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
function flattenTexte (texteContentRoot: Node): Division[] {
|
|
90
|
+
const divisions: Division[] = []
|
|
91
|
+
let divisionIndex = 0
|
|
92
|
+
const iter = (node: Node) => {
|
|
93
|
+
if (node.nodeName === "content") {
|
|
94
|
+
return
|
|
95
|
+
}
|
|
96
|
+
switch (node.nodeName) {
|
|
97
|
+
case "tome":
|
|
98
|
+
case "part":
|
|
99
|
+
case "book":
|
|
100
|
+
case "title":
|
|
101
|
+
case "subtitle":
|
|
102
|
+
case "chapter":
|
|
103
|
+
case "section":
|
|
104
|
+
case "subsection":
|
|
105
|
+
case "paragraph":
|
|
106
|
+
case "article":
|
|
107
|
+
divisions.push(buildDivision(node, divisionIndex++))
|
|
108
|
+
break
|
|
109
|
+
}
|
|
110
|
+
if (node.nodeName === "alinea") {
|
|
111
|
+
Array.from(node.childNodes)
|
|
112
|
+
// Find direct content children programmatically
|
|
113
|
+
// because `:scope` selector does not work
|
|
114
|
+
// https://github.com/jsdom/jsdom/issues/2998
|
|
115
|
+
.filter((alineaChildNode: Node) => alineaChildNode.nodeName === "content")
|
|
116
|
+
.forEach((alineaContentNode: Node) => {
|
|
117
|
+
// Hypothesis: alineas should always be enclosed in articles
|
|
118
|
+
let lastArticle = divisions.findLast(division => division.tag === "article") as Article
|
|
119
|
+
if (!lastArticle) {
|
|
120
|
+
lastArticle = buildEmptyArticle(divisionIndex++)
|
|
121
|
+
divisions.push(lastArticle)
|
|
122
|
+
}
|
|
123
|
+
lastArticle.alineas.push(buildAlinea(alineaContentNode, node))
|
|
124
|
+
})
|
|
125
|
+
}
|
|
126
|
+
if (node.hasChildNodes()) {
|
|
127
|
+
node.childNodes.forEach((childNode: Node) => iter(childNode))
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
iter(texteContentRoot)
|
|
131
|
+
return divisions
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
export function transformTexte (document: Document): FlatTexte | null {
|
|
135
|
+
const metaElement = document.querySelector("meta")
|
|
136
|
+
const preambleElement = document.querySelector("preamble")
|
|
137
|
+
const identification = metaElement?.querySelector("FRBRExpression FRBRuri")?.getAttribute("value") ?? ""
|
|
138
|
+
const identificationParts = AKN_IDENTIFICATION_STRUCTURE_REGEXP.exec(identification)?.groups
|
|
139
|
+
const bodyElement = document.querySelector("body")
|
|
140
|
+
const datePresentation = metaElement?.querySelector("FRBRdate[name='#presentation']")?.getAttribute("date")
|
|
141
|
+
const dateDepot = metaElement?.querySelector("FRBRdate[name='#depot']")?.getAttribute("date")
|
|
142
|
+
const datePublicationXml = metaElement?.querySelector("FRBRdate[name='#publication-xml']")?.getAttribute("date")
|
|
143
|
+
return {
|
|
144
|
+
titre: preambleElement?.querySelector("docTitle")?.textContent || null,
|
|
145
|
+
titreCourt: metaElement?.querySelector("FRBRalias[name='intitule-court']")
|
|
146
|
+
?.getAttribute("value") || null,
|
|
147
|
+
signetDossier:
|
|
148
|
+
metaElement?.querySelector("FRBRalias[name='signet-dossier-legislatif-senat']")
|
|
149
|
+
?.getAttribute("value") || null,
|
|
150
|
+
urlDossierSenat: metaElement?.querySelector("FRBRalias[name='url-senat']")?.getAttribute("value") || null,
|
|
151
|
+
urlDossierAssemblee: metaElement?.querySelector("FRBRalias[name='url-AN']")?.getAttribute("value") || null,
|
|
152
|
+
type: identificationParts?.type || null,
|
|
153
|
+
session: identificationParts?.session || null,
|
|
154
|
+
numero: identificationParts?.numTexte ? parseInt(identificationParts.numTexte) : null,
|
|
155
|
+
datePresentation: datePresentation ? new Date(datePresentation) : null,
|
|
156
|
+
dateDepot: dateDepot ? new Date(dateDepot) : null,
|
|
157
|
+
datePublicationXml: datePublicationXml ? new Date(datePublicationXml) : null,
|
|
158
|
+
version: identificationParts?.version ? identificationParts.version as Version : null,
|
|
159
|
+
workflow: metaElement ? buildWorklow(metaElement) : [],
|
|
160
|
+
divisions: bodyElement ? flattenTexte(bodyElement) : [],
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
export function transformExposeDesMotifs (document: Document): ExposeDesMotifs | null {
|
|
165
|
+
const sectionElements = document.querySelectorAll("section")
|
|
166
|
+
const exposeDesMotifsRegexp = new RegExp("EXPOS.{1,2}[\\n\\s]DES[\\n\\s]MOTIFS")
|
|
167
|
+
for (const sectionElement of sectionElements) {
|
|
168
|
+
const firstParagraph = sectionElement.querySelector("p:first-of-type")
|
|
169
|
+
const secondParagraph = sectionElement.querySelector("p:nth-of-type(2)")
|
|
170
|
+
if (!firstParagraph) {
|
|
171
|
+
continue
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
const firstParagraphContent = firstParagraph.textContent
|
|
175
|
+
const secondParagraphContent = secondParagraph?.textContent
|
|
176
|
+
if (!firstParagraphContent || !exposeDesMotifsRegexp.test(firstParagraphContent.toUpperCase())) {
|
|
177
|
+
if (!secondParagraphContent || !exposeDesMotifsRegexp.test(secondParagraphContent.toUpperCase())) {
|
|
178
|
+
continue
|
|
179
|
+
} else {
|
|
180
|
+
sectionElement.removeChild(secondParagraph)
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
sectionElement.removeChild(firstParagraph)
|
|
185
|
+
return {
|
|
186
|
+
text: sectionElement.textContent?.trim() ?? null,
|
|
187
|
+
html: sectionElement.innerHTML?.trim() ?? null,
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
return null
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
export function parseTexte (texteXml: string): FlatTexte | null {
|
|
194
|
+
try {
|
|
195
|
+
const { document } = (new JSDOM(texteXml, {
|
|
196
|
+
contentType: "text/xml",
|
|
197
|
+
})).window
|
|
198
|
+
return transformTexte(document)
|
|
199
|
+
} catch (error: any) {
|
|
200
|
+
console.error(`Could not parse texte with error ${error}`)
|
|
201
|
+
}
|
|
202
|
+
return null
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
// Prevent from memory leak
|
|
206
|
+
// https://github.com/jsdom/jsdom/issues/2583#issuecomment-559520814
|
|
207
|
+
export async function parseTexteFromFile (xmlFilePath: string): Promise<FlatTexte | null> {
|
|
208
|
+
try {
|
|
209
|
+
const { document } = (await JSDOM.fromFile(xmlFilePath, { contentType: "text/xml" })).window
|
|
210
|
+
return transformTexte(document)
|
|
211
|
+
} catch (error: any) {
|
|
212
|
+
console.error(`Could not parse texte with error ${error}`)
|
|
213
|
+
}
|
|
214
|
+
return null
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
export function parseExposeDesMotifs (exposeDesMotifsHtml: string): ExposeDesMotifs | null {
|
|
218
|
+
const { document } = (new JSDOM(exposeDesMotifsHtml, {
|
|
219
|
+
contentType: "text/html",
|
|
220
|
+
})).window
|
|
221
|
+
return transformExposeDesMotifs(document)
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
// Prevent from memory leak
|
|
225
|
+
// https://github.com/jsdom/jsdom/issues/2583#issuecomment-559520814
|
|
226
|
+
export async function parseExposeDesMotifsFromFile (htmlFilePath: string): Promise<ExposeDesMotifs | null> {
|
|
227
|
+
const { document } = (await JSDOM.fromFile(htmlFilePath, { contentType: "text/html" })).window
|
|
228
|
+
return transformExposeDesMotifs(document)
|
|
229
|
+
}
|
package/lib/model/util.d.ts
CHANGED
|
@@ -1 +1,7 @@
|
|
|
1
|
-
|
|
1
|
+
import { Expression } from "kysely";
|
|
2
|
+
export declare function concat(...exprs: Expression<number | string | null | undefined>[]): import("kysely").RawBuilder<string>;
|
|
3
|
+
export declare function expandToRows(expr: Expression<string | null | undefined>, regexp: Expression<string>): import("kysely").RawBuilder<unknown>;
|
|
4
|
+
export declare function removeSubstring(expr: Expression<string | null | undefined>, pattern: Expression<string>): import("kysely").RawBuilder<string>;
|
|
5
|
+
export declare function replace(expr: Expression<string | null | undefined>, pattern: Expression<string>, replacement: Expression<string>): import("kysely").RawBuilder<string>;
|
|
6
|
+
export declare function rtrim(expr: Expression<string | null | undefined>): import("kysely").RawBuilder<string>;
|
|
7
|
+
export declare function toDateString(expr: Expression<Date | null | undefined>): import("kysely").RawBuilder<string>;
|
package/lib/model/util.js
CHANGED
|
@@ -1,60 +1,44 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
require("core-js/modules/es.symbol.js");
|
|
5
|
-
require("core-js/modules/es.symbol.description.js");
|
|
6
|
-
require("core-js/modules/es.symbol.async-iterator.js");
|
|
7
|
-
require("core-js/modules/es.symbol.iterator.js");
|
|
8
|
-
require("core-js/modules/es.symbol.to-string-tag.js");
|
|
9
|
-
require("core-js/modules/es.array.for-each.js");
|
|
10
|
-
require("core-js/modules/es.array.iterator.js");
|
|
11
|
-
require("core-js/modules/es.array.reverse.js");
|
|
3
|
+
require("core-js/modules/es.array.concat.js");
|
|
12
4
|
require("core-js/modules/es.array.slice.js");
|
|
13
|
-
require("core-js/modules/es.
|
|
14
|
-
require("core-js/modules/es.json.to-string-tag.js");
|
|
15
|
-
require("core-js/modules/es.math.to-string-tag.js");
|
|
16
|
-
require("core-js/modules/es.object.create.js");
|
|
5
|
+
require("core-js/modules/es.object.define-properties.js");
|
|
17
6
|
require("core-js/modules/es.object.define-property.js");
|
|
18
|
-
require("core-js/modules/es.object.
|
|
19
|
-
require("core-js/modules/es.
|
|
20
|
-
require("core-js/modules/es.string.
|
|
21
|
-
require("core-js/modules/web.dom-collections.for-each.js");
|
|
22
|
-
require("core-js/modules/web.dom-collections.iterator.js");
|
|
7
|
+
require("core-js/modules/es.object.freeze.js");
|
|
8
|
+
require("core-js/modules/es.regexp.exec.js");
|
|
9
|
+
require("core-js/modules/es.string.replace.js");
|
|
23
10
|
Object.defineProperty(exports, "__esModule", {
|
|
24
11
|
value: true
|
|
25
12
|
});
|
|
26
|
-
exports.
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
var
|
|
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
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGF0YWJhc2VzIiwicmVxdWlyZSIsIl9yZWdlbmVyYXRvclJ1bnRpbWUiLCJlIiwidCIsInIiLCJPYmplY3QiLCJwcm90b3R5cGUiLCJuIiwiaGFzT3duUHJvcGVydHkiLCJvIiwiZGVmaW5lUHJvcGVydHkiLCJ2YWx1ZSIsImkiLCJTeW1ib2wiLCJhIiwiaXRlcmF0b3IiLCJjIiwiYXN5bmNJdGVyYXRvciIsInUiLCJ0b1N0cmluZ1RhZyIsImRlZmluZSIsImVudW1lcmFibGUiLCJjb25maWd1cmFibGUiLCJ3cml0YWJsZSIsIndyYXAiLCJHZW5lcmF0b3IiLCJjcmVhdGUiLCJDb250ZXh0IiwibWFrZUludm9rZU1ldGhvZCIsInRyeUNhdGNoIiwidHlwZSIsImFyZyIsImNhbGwiLCJoIiwibCIsImYiLCJzIiwieSIsIkdlbmVyYXRvckZ1bmN0aW9uIiwiR2VuZXJhdG9yRnVuY3Rpb25Qcm90b3R5cGUiLCJwIiwiZCIsImdldFByb3RvdHlwZU9mIiwidiIsInZhbHVlcyIsImciLCJkZWZpbmVJdGVyYXRvck1ldGhvZHMiLCJmb3JFYWNoIiwiX2ludm9rZSIsIkFzeW5jSXRlcmF0b3IiLCJpbnZva2UiLCJfdHlwZW9mIiwicmVzb2x2ZSIsIl9fYXdhaXQiLCJ0aGVuIiwiY2FsbEludm9rZVdpdGhNZXRob2RBbmRBcmciLCJFcnJvciIsImRvbmUiLCJtZXRob2QiLCJkZWxlZ2F0ZSIsIm1heWJlSW52b2tlRGVsZWdhdGUiLCJzZW50IiwiX3NlbnQiLCJkaXNwYXRjaEV4Y2VwdGlvbiIsImFicnVwdCIsIlR5cGVFcnJvciIsInJlc3VsdE5hbWUiLCJuZXh0IiwibmV4dExvYyIsInB1c2hUcnlFbnRyeSIsInRyeUxvYyIsImNhdGNoTG9jIiwiZmluYWxseUxvYyIsImFmdGVyTG9jIiwidHJ5RW50cmllcyIsInB1c2giLCJyZXNldFRyeUVudHJ5IiwiY29tcGxldGlvbiIsInJlc2V0IiwiaXNOYU4iLCJsZW5ndGgiLCJkaXNwbGF5TmFtZSIsImlzR2VuZXJhdG9yRnVuY3Rpb24iLCJjb25zdHJ1Y3RvciIsIm5hbWUiLCJtYXJrIiwic2V0UHJvdG90eXBlT2YiLCJfX3Byb3RvX18iLCJhd3JhcCIsImFzeW5jIiwiUHJvbWlzZSIsImtleXMiLCJyZXZlcnNlIiwicG9wIiwicHJldiIsImNoYXJBdCIsInNsaWNlIiwic3RvcCIsInJ2YWwiLCJoYW5kbGUiLCJjb21wbGV0ZSIsImZpbmlzaCIsIl9jYXRjaCIsImRlbGVnYXRlWWllbGQiLCJhc3luY0dlbmVyYXRvclN0ZXAiLCJfYXN5bmNUb0dlbmVyYXRvciIsImFyZ3VtZW50cyIsImFwcGx5IiwiX25leHQiLCJfdGhyb3ciLCJnZXRUYWJsZXMiLCJleHBvcnRzIiwiX3JlZiIsIl9jYWxsZWUiLCJkYk5hbWUiLCJzY2hlbWEiLCJfYXJncyIsIl9jYWxsZWUkIiwiX2NvbnRleHQiLCJ1bmRlZmluZWQiLCJkYkJ5TmFtZSIsIm1hcCIsInJvdyIsInRhYmxlX25hbWUiLCJfeCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tb2RlbC91dGlsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGRiQnlOYW1lIH0gZnJvbSAnLi4vZGF0YWJhc2VzJ1xuXG5leHBvcnQgY29uc3QgZ2V0VGFibGVzID0gYXN5bmMgKGRiTmFtZTogc3RyaW5nLCBzY2hlbWEgPSBcInB1YmxpY1wiKTogUHJvbWlzZTxzdHJpbmdbXT4gPT4ge1xuICByZXR1cm4gKFxuICAgIGF3YWl0IGRiQnlOYW1lW2RiTmFtZV0ubWFwKFxuICAgICAgYFxuICAgICAgU0VMRUNUIHRhYmxlX25hbWVcbiAgICAgIEZST00gaW5mb3JtYXRpb25fc2NoZW1hLnRhYmxlc1xuICAgICAgV0hFUkUgdGFibGVfc2NoZW1hID0gJDxzY2hlbWE+XG4gICAgYCwge1xuICAgICAgICBzY2hlbWFcbiAgICAgIH0sXG4gICAgICAgIChyb3c6IHsgdGFibGVfbmFtZTogc3RyaW5nIH0pID0+IHJvdy50YWJsZV9uYW1lXG4gICAgKVxuICApXG59XG4iXSwibWFwcGluZ3MiOiI7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
|
|
13
|
+
exports.concat = concat;
|
|
14
|
+
exports.expandToRows = expandToRows;
|
|
15
|
+
exports.removeSubstring = removeSubstring;
|
|
16
|
+
exports.replace = replace;
|
|
17
|
+
exports.rtrim = rtrim;
|
|
18
|
+
exports.toDateString = toDateString;
|
|
19
|
+
require("core-js/modules/es.array.join.js");
|
|
20
|
+
var _kysely = require("kysely");
|
|
21
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
|
|
22
|
+
function _taggedTemplateLiteral(e, t) { return t || (t = e.slice(0)), Object.freeze(Object.defineProperties(e, { raw: { value: Object.freeze(t) } })); }
|
|
23
|
+
function concat() {
|
|
24
|
+
for (var _len = arguments.length, exprs = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
25
|
+
exprs[_key] = arguments[_key];
|
|
26
|
+
}
|
|
27
|
+
return _kysely.sql.join(exprs, (0, _kysely.sql)(_templateObject || (_templateObject = _taggedTemplateLiteral(["||"])))).$castTo();
|
|
28
|
+
}
|
|
29
|
+
function expandToRows(expr, regexp) {
|
|
30
|
+
return (0, _kysely.sql)(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["unnest(regexp_matches(", ", ", ", 'g'))"])), expr, regexp);
|
|
31
|
+
}
|
|
32
|
+
function removeSubstring(expr, pattern) {
|
|
33
|
+
return replace(expr, pattern, _kysely.sql.val(""));
|
|
34
|
+
}
|
|
35
|
+
function replace(expr, pattern, replacement) {
|
|
36
|
+
return (0, _kysely.sql)(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["replace(", ", ", ", ", ")"])), expr, pattern, replacement);
|
|
37
|
+
}
|
|
38
|
+
function rtrim(expr) {
|
|
39
|
+
return (0, _kysely.sql)(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["rtrim(", ")"])), expr);
|
|
40
|
+
}
|
|
41
|
+
function toDateString(expr) {
|
|
42
|
+
return (0, _kysely.sql)(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["to_char(", ", 'yyyy-MM-dd')"])), expr);
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfa3lzZWx5IiwicmVxdWlyZSIsIl90ZW1wbGF0ZU9iamVjdCIsIl90ZW1wbGF0ZU9iamVjdDIiLCJfdGVtcGxhdGVPYmplY3QzIiwiX3RlbXBsYXRlT2JqZWN0NCIsIl90ZW1wbGF0ZU9iamVjdDUiLCJfdGFnZ2VkVGVtcGxhdGVMaXRlcmFsIiwiZSIsInQiLCJzbGljZSIsIk9iamVjdCIsImZyZWV6ZSIsImRlZmluZVByb3BlcnRpZXMiLCJyYXciLCJ2YWx1ZSIsImNvbmNhdCIsIl9sZW4iLCJhcmd1bWVudHMiLCJsZW5ndGgiLCJleHBycyIsIkFycmF5IiwiX2tleSIsInNxbCIsImpvaW4iLCIkY2FzdFRvIiwiZXhwYW5kVG9Sb3dzIiwiZXhwciIsInJlZ2V4cCIsInJlbW92ZVN1YnN0cmluZyIsInBhdHRlcm4iLCJyZXBsYWNlIiwidmFsIiwicmVwbGFjZW1lbnQiLCJydHJpbSIsInRvRGF0ZVN0cmluZyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tb2RlbC91dGlsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV4cHJlc3Npb24sIHNxbCB9IGZyb20gXCJreXNlbHlcIlxuXG5leHBvcnQgZnVuY3Rpb24gY29uY2F0ICguLi5leHByczogRXhwcmVzc2lvbjxudW1iZXIgfCBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkPltdKSB7XG4gIHJldHVybiBzcWwuam9pbihleHBycywgc3FsYHx8YCkuJGNhc3RUbzxzdHJpbmc+KClcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGV4cGFuZFRvUm93cyAoZXhwcjogRXhwcmVzc2lvbjxzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkPiwgcmVnZXhwOiBFeHByZXNzaW9uPHN0cmluZz4pIHtcbiAgcmV0dXJuIHNxbGB1bm5lc3QocmVnZXhwX21hdGNoZXMoJHtleHByfSwgJHtyZWdleHB9LCAnZycpKWBcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlbW92ZVN1YnN0cmluZyAoXG4gIGV4cHI6IEV4cHJlc3Npb248c3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZD4sXG4gIHBhdHRlcm46IEV4cHJlc3Npb248c3RyaW5nPlxuKSB7XG4gIHJldHVybiByZXBsYWNlKGV4cHIsIHBhdHRlcm4sIHNxbC52YWwoXCJcIikpXG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZXBsYWNlIChcbiAgZXhwcjogRXhwcmVzc2lvbjxzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkPixcbiAgcGF0dGVybjogRXhwcmVzc2lvbjxzdHJpbmc+LFxuICByZXBsYWNlbWVudDogRXhwcmVzc2lvbjxzdHJpbmc+XG4pIHtcbiAgcmV0dXJuIHNxbDxzdHJpbmc+YHJlcGxhY2UoJHtleHByfSwgJHtwYXR0ZXJufSwgJHtyZXBsYWNlbWVudH0pYFxufVxuXG5leHBvcnQgZnVuY3Rpb24gcnRyaW0gKGV4cHI6IEV4cHJlc3Npb248c3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZD4pIHtcbiAgcmV0dXJuIHNxbDxzdHJpbmc+YHJ0cmltKCR7ZXhwcn0pYFxufVxuXG5leHBvcnQgZnVuY3Rpb24gdG9EYXRlU3RyaW5nIChleHByOiBFeHByZXNzaW9uPERhdGUgfCBudWxsIHwgdW5kZWZpbmVkPikge1xuICByZXR1cm4gc3FsPHN0cmluZz5gdG9fY2hhcigke2V4cHJ9LCAneXl5eS1NTS1kZCcpYFxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsSUFBQUEsT0FBQSxHQUFBQyxPQUFBO0FBQXdDLElBQUFDLGVBQUEsRUFBQUMsZ0JBQUEsRUFBQUMsZ0JBQUEsRUFBQUMsZ0JBQUEsRUFBQUMsZ0JBQUE7QUFBQSxTQUFBQyx1QkFBQUMsQ0FBQSxFQUFBQyxDQUFBLFdBQUFBLENBQUEsS0FBQUEsQ0FBQSxHQUFBRCxDQUFBLENBQUFFLEtBQUEsTUFBQUMsTUFBQSxDQUFBQyxNQUFBLENBQUFELE1BQUEsQ0FBQUUsZ0JBQUEsQ0FBQUwsQ0FBQSxJQUFBTSxHQUFBLElBQUFDLEtBQUEsRUFBQUosTUFBQSxDQUFBQyxNQUFBLENBQUFILENBQUE7QUFFakMsU0FBU08sTUFBTUEsQ0FBQSxFQUE4RDtFQUFBLFNBQUFDLElBQUEsR0FBQUMsU0FBQSxDQUFBQyxNQUFBLEVBQXpEQyxLQUFLLE9BQUFDLEtBQUEsQ0FBQUosSUFBQSxHQUFBSyxJQUFBLE1BQUFBLElBQUEsR0FBQUwsSUFBQSxFQUFBSyxJQUFBO0lBQUxGLEtBQUssQ0FBQUUsSUFBQSxJQUFBSixTQUFBLENBQUFJLElBQUE7RUFBQTtFQUM5QixPQUFPQyxXQUFHLENBQUNDLElBQUksQ0FBQ0osS0FBSyxNQUFFRyxXQUFHLEVBQUFyQixlQUFBLEtBQUFBLGVBQUEsR0FBQUssc0JBQUEsVUFBSSxDQUFDLENBQUNrQixPQUFPLENBQVMsQ0FBQztBQUNuRDtBQUVPLFNBQVNDLFlBQVlBLENBQUVDLElBQTJDLEVBQUVDLE1BQTBCLEVBQUU7RUFDckcsV0FBT0wsV0FBRyxFQUFBcEIsZ0JBQUEsS0FBQUEsZ0JBQUEsR0FBQUksc0JBQUEsZ0RBQXlCb0IsSUFBSSxFQUFLQyxNQUFNO0FBQ3BEO0FBRU8sU0FBU0MsZUFBZUEsQ0FDN0JGLElBQTJDLEVBQzNDRyxPQUEyQixFQUMzQjtFQUNBLE9BQU9DLE9BQU8sQ0FBQ0osSUFBSSxFQUFFRyxPQUFPLEVBQUVQLFdBQUcsQ0FBQ1MsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBQzVDO0FBRU8sU0FBU0QsT0FBT0EsQ0FDckJKLElBQTJDLEVBQzNDRyxPQUEyQixFQUMzQkcsV0FBK0IsRUFDL0I7RUFDQSxXQUFPVixXQUFHLEVBQUFuQixnQkFBQSxLQUFBQSxnQkFBQSxHQUFBRyxzQkFBQSxrQ0FBbUJvQixJQUFJLEVBQUtHLE9BQU8sRUFBS0csV0FBVztBQUMvRDtBQUVPLFNBQVNDLEtBQUtBLENBQUVQLElBQTJDLEVBQUU7RUFDbEUsV0FBT0osV0FBRyxFQUFBbEIsZ0JBQUEsS0FBQUEsZ0JBQUEsR0FBQUUsc0JBQUEsb0JBQWlCb0IsSUFBSTtBQUNqQztBQUVPLFNBQVNRLFlBQVlBLENBQUVSLElBQXlDLEVBQUU7RUFDdkUsV0FBT0osV0FBRyxFQUFBakIsZ0JBQUEsS0FBQUEsZ0JBQUEsR0FBQUMsc0JBQUEsb0NBQW1Cb0IsSUFBSTtBQUNuQyIsImlnbm9yZUxpc3QiOltdfQ==
|
package/lib/model/util.mjs
CHANGED
|
@@ -1,10 +1,19 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export
|
|
3
|
-
return (
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
}
|
|
1
|
+
import { sql } from "kysely";
|
|
2
|
+
export function concat(...exprs) {
|
|
3
|
+
return sql.join(exprs, sql `||`).$castTo();
|
|
4
|
+
}
|
|
5
|
+
export function expandToRows(expr, regexp) {
|
|
6
|
+
return sql `unnest(regexp_matches(${expr}, ${regexp}, 'g'))`;
|
|
7
|
+
}
|
|
8
|
+
export function removeSubstring(expr, pattern) {
|
|
9
|
+
return replace(expr, pattern, sql.val(""));
|
|
10
|
+
}
|
|
11
|
+
export function replace(expr, pattern, replacement) {
|
|
12
|
+
return sql `replace(${expr}, ${pattern}, ${replacement})`;
|
|
13
|
+
}
|
|
14
|
+
export function rtrim(expr) {
|
|
15
|
+
return sql `rtrim(${expr})`;
|
|
16
|
+
}
|
|
17
|
+
export function toDateString(expr) {
|
|
18
|
+
return sql `to_char(${expr}, 'yyyy-MM-dd')`;
|
|
19
|
+
}
|