@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
package/lib/model/ameli.js
CHANGED
|
@@ -1,167 +1,27 @@
|
|
|
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.from.js");
|
|
11
|
-
require("core-js/modules/es.array.is-array.js");
|
|
12
|
-
require("core-js/modules/es.array.iterator.js");
|
|
13
|
-
require("core-js/modules/es.array.reverse.js");
|
|
14
|
-
require("core-js/modules/es.array.slice.js");
|
|
15
|
-
require("core-js/modules/es.date.to-string.js");
|
|
16
|
-
require("core-js/modules/es.function.name.js");
|
|
17
|
-
require("core-js/modules/es.json.to-string-tag.js");
|
|
18
|
-
require("core-js/modules/es.math.to-string-tag.js");
|
|
19
|
-
require("core-js/modules/es.object.create.js");
|
|
3
|
+
require("core-js/modules/es.array.concat.js");
|
|
20
4
|
require("core-js/modules/es.object.define-property.js");
|
|
21
|
-
require("core-js/modules/es.object.get-prototype-of.js");
|
|
22
|
-
require("core-js/modules/es.object.set-prototype-of.js");
|
|
23
|
-
require("core-js/modules/es.regexp.exec.js");
|
|
24
|
-
require("core-js/modules/es.regexp.to-string.js");
|
|
25
|
-
require("core-js/modules/es.string.iterator.js");
|
|
26
|
-
require("core-js/modules/web.dom-collections.for-each.js");
|
|
27
|
-
require("core-js/modules/web.dom-collections.iterator.js");
|
|
28
5
|
Object.defineProperty(exports, "__esModule", {
|
|
29
6
|
value: true
|
|
30
7
|
});
|
|
31
|
-
exports.
|
|
32
|
-
require("
|
|
33
|
-
require("core-js/modules/es.object.to-string.js");
|
|
34
|
-
require("core-js/modules/es.parse-int.js");
|
|
35
|
-
require("core-js/modules/es.promise.js");
|
|
36
|
-
var _ameli = require("../types/ameli");
|
|
8
|
+
exports.findAll = findAll;
|
|
9
|
+
var _postgres = require("kysely/helpers/postgres");
|
|
37
10
|
var _databases = require("../databases");
|
|
38
|
-
var
|
|
39
|
-
function
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
case 2:
|
|
56
|
-
_context.next = 4;
|
|
57
|
-
return _databases.dbByName.ameli.any("\n SELECT *\n FROM ses\n WHERE ann IN ($<ids:list>)\n ", {
|
|
58
|
-
ids: ids
|
|
59
|
-
});
|
|
60
|
-
case 4:
|
|
61
|
-
return _context.abrupt("return", _context.sent.map(function (ses) {
|
|
62
|
-
return (0, _fields.parseIntFields)(_ameli.sesFieldsToParseInt, (0, _fields.trimFieldsRight)(_ameli.sesFieldsToTrim, ses));
|
|
63
|
-
}));
|
|
64
|
-
case 5:
|
|
65
|
-
case "end":
|
|
66
|
-
return _context.stop();
|
|
67
|
-
}
|
|
68
|
-
}, _callee);
|
|
69
|
-
}));
|
|
70
|
-
return function getSessFromAnns(_x) {
|
|
71
|
-
return _ref.apply(this, arguments);
|
|
72
|
-
};
|
|
73
|
-
}();
|
|
74
|
-
var getSubsFromTxtids = exports.getSubsFromTxtids = /*#__PURE__*/function () {
|
|
75
|
-
var _ref2 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee2(ids) {
|
|
76
|
-
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
77
|
-
while (1) switch (_context2.prev = _context2.next) {
|
|
78
|
-
case 0:
|
|
79
|
-
if (!(ids.length === 0)) {
|
|
80
|
-
_context2.next = 2;
|
|
81
|
-
break;
|
|
82
|
-
}
|
|
83
|
-
return _context2.abrupt("return", []);
|
|
84
|
-
case 2:
|
|
85
|
-
_context2.next = 4;
|
|
86
|
-
return _databases.dbByName.ameli.any("\n SELECT *\n FROM sub\n WHERE txtid IN($<ids:list>)\n ", {
|
|
87
|
-
ids: ids
|
|
88
|
-
});
|
|
89
|
-
case 4:
|
|
90
|
-
return _context2.abrupt("return", _context2.sent.map(function (sub) {
|
|
91
|
-
return (0, _fields.parseIntFields)(_ameli.subFieldsToParseInt, (0, _fields.trimFieldsRight)(_ameli.subFieldsToTrim, sub));
|
|
92
|
-
}));
|
|
93
|
-
case 5:
|
|
94
|
-
case "end":
|
|
95
|
-
return _context2.stop();
|
|
96
|
-
}
|
|
97
|
-
}, _callee2);
|
|
98
|
-
}));
|
|
99
|
-
return function getSubsFromTxtids(_x2) {
|
|
100
|
-
return _ref2.apply(this, arguments);
|
|
101
|
-
};
|
|
102
|
-
}();
|
|
103
|
-
var getTxtsAmeliBySesannNumJoins = exports.getTxtsAmeliBySesannNumJoins = /*#__PURE__*/function () {
|
|
104
|
-
var _ref3 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee3(ids) {
|
|
105
|
-
var txtsAmelis, _iterator, _step, id, idSplit, sesann, num, txtAmeli;
|
|
106
|
-
return _regeneratorRuntime().wrap(function _callee3$(_context3) {
|
|
107
|
-
while (1) switch (_context3.prev = _context3.next) {
|
|
108
|
-
case 0:
|
|
109
|
-
if (!(ids.length === 0)) {
|
|
110
|
-
_context3.next = 2;
|
|
111
|
-
break;
|
|
112
|
-
}
|
|
113
|
-
return _context3.abrupt("return", []);
|
|
114
|
-
case 2:
|
|
115
|
-
txtsAmelis = [];
|
|
116
|
-
_iterator = _createForOfIteratorHelper(ids);
|
|
117
|
-
_context3.prev = 4;
|
|
118
|
-
_iterator.s();
|
|
119
|
-
case 6:
|
|
120
|
-
if ((_step = _iterator.n()).done) {
|
|
121
|
-
_context3.next = 20;
|
|
122
|
-
break;
|
|
123
|
-
}
|
|
124
|
-
id = _step.value;
|
|
125
|
-
idSplit = id.split(" ");
|
|
126
|
-
sesann = parseInt(idSplit[0]);
|
|
127
|
-
num = idSplit[1];
|
|
128
|
-
_context3.t0 = _fields.trimFieldsRight;
|
|
129
|
-
_context3.t1 = _ameli.txtAmeliFieldsToTrim;
|
|
130
|
-
_context3.next = 15;
|
|
131
|
-
return _databases.dbByName.ameli.oneOrNone("\n SELECT *\n FROM txt_ameli\n WHERE\n sesinsid in (\n SELECT id\n FROM ses\n WHERE ann = $<sesann>\n ) AND\n num = $<num>\n LIMIT 1\n ", {
|
|
132
|
-
num: num,
|
|
133
|
-
sesann: sesann
|
|
134
|
-
});
|
|
135
|
-
case 15:
|
|
136
|
-
_context3.t2 = _context3.sent;
|
|
137
|
-
txtAmeli = (0, _context3.t0)(_context3.t1, _context3.t2);
|
|
138
|
-
if (txtAmeli !== null) {
|
|
139
|
-
txtsAmelis.push(txtAmeli);
|
|
140
|
-
}
|
|
141
|
-
case 18:
|
|
142
|
-
_context3.next = 6;
|
|
143
|
-
break;
|
|
144
|
-
case 20:
|
|
145
|
-
_context3.next = 25;
|
|
146
|
-
break;
|
|
147
|
-
case 22:
|
|
148
|
-
_context3.prev = 22;
|
|
149
|
-
_context3.t3 = _context3["catch"](4);
|
|
150
|
-
_iterator.e(_context3.t3);
|
|
151
|
-
case 25:
|
|
152
|
-
_context3.prev = 25;
|
|
153
|
-
_iterator.f();
|
|
154
|
-
return _context3.finish(25);
|
|
155
|
-
case 28:
|
|
156
|
-
return _context3.abrupt("return", txtsAmelis);
|
|
157
|
-
case 29:
|
|
158
|
-
case "end":
|
|
159
|
-
return _context3.stop();
|
|
160
|
-
}
|
|
161
|
-
}, _callee3, null, [[4, 22, 25, 28]]);
|
|
162
|
-
}));
|
|
163
|
-
return function getTxtsAmeliBySesannNumJoins(_x3) {
|
|
164
|
-
return _ref3.apply(this, arguments);
|
|
165
|
-
};
|
|
166
|
-
}();
|
|
167
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfYW1lbGkiLCJyZXF1aXJlIiwiX2RhdGFiYXNlcyIsIl9maWVsZHMiLCJfY3JlYXRlRm9yT2ZJdGVyYXRvckhlbHBlciIsInIiLCJlIiwidCIsIlN5bWJvbCIsIml0ZXJhdG9yIiwiQXJyYXkiLCJpc0FycmF5IiwiX3Vuc3VwcG9ydGVkSXRlcmFibGVUb0FycmF5IiwibGVuZ3RoIiwiX24iLCJGIiwicyIsIm4iLCJkb25lIiwidmFsdWUiLCJmIiwiVHlwZUVycm9yIiwibyIsImEiLCJ1IiwiY2FsbCIsIm5leHQiLCJfYXJyYXlMaWtlVG9BcnJheSIsInRvU3RyaW5nIiwic2xpY2UiLCJjb25zdHJ1Y3RvciIsIm5hbWUiLCJmcm9tIiwidGVzdCIsIl9yZWdlbmVyYXRvclJ1bnRpbWUiLCJPYmplY3QiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImRlZmluZVByb3BlcnR5IiwiaSIsImMiLCJhc3luY0l0ZXJhdG9yIiwidG9TdHJpbmdUYWciLCJkZWZpbmUiLCJlbnVtZXJhYmxlIiwiY29uZmlndXJhYmxlIiwid3JpdGFibGUiLCJ3cmFwIiwiR2VuZXJhdG9yIiwiY3JlYXRlIiwiQ29udGV4dCIsIm1ha2VJbnZva2VNZXRob2QiLCJ0cnlDYXRjaCIsInR5cGUiLCJhcmciLCJoIiwibCIsInkiLCJHZW5lcmF0b3JGdW5jdGlvbiIsIkdlbmVyYXRvckZ1bmN0aW9uUHJvdG90eXBlIiwicCIsImQiLCJnZXRQcm90b3R5cGVPZiIsInYiLCJ2YWx1ZXMiLCJnIiwiZGVmaW5lSXRlcmF0b3JNZXRob2RzIiwiZm9yRWFjaCIsIl9pbnZva2UiLCJBc3luY0l0ZXJhdG9yIiwiaW52b2tlIiwiX3R5cGVvZiIsInJlc29sdmUiLCJfX2F3YWl0IiwidGhlbiIsImNhbGxJbnZva2VXaXRoTWV0aG9kQW5kQXJnIiwiRXJyb3IiLCJtZXRob2QiLCJkZWxlZ2F0ZSIsIm1heWJlSW52b2tlRGVsZWdhdGUiLCJzZW50IiwiX3NlbnQiLCJkaXNwYXRjaEV4Y2VwdGlvbiIsImFicnVwdCIsInJlc3VsdE5hbWUiLCJuZXh0TG9jIiwicHVzaFRyeUVudHJ5IiwidHJ5TG9jIiwiY2F0Y2hMb2MiLCJmaW5hbGx5TG9jIiwiYWZ0ZXJMb2MiLCJ0cnlFbnRyaWVzIiwicHVzaCIsInJlc2V0VHJ5RW50cnkiLCJjb21wbGV0aW9uIiwicmVzZXQiLCJpc05hTiIsImRpc3BsYXlOYW1lIiwiaXNHZW5lcmF0b3JGdW5jdGlvbiIsIm1hcmsiLCJzZXRQcm90b3R5cGVPZiIsIl9fcHJvdG9fXyIsImF3cmFwIiwiYXN5bmMiLCJQcm9taXNlIiwia2V5cyIsInJldmVyc2UiLCJwb3AiLCJwcmV2IiwiY2hhckF0Iiwic3RvcCIsInJ2YWwiLCJoYW5kbGUiLCJjb21wbGV0ZSIsImZpbmlzaCIsIl9jYXRjaCIsImRlbGVnYXRlWWllbGQiLCJhc3luY0dlbmVyYXRvclN0ZXAiLCJfYXN5bmNUb0dlbmVyYXRvciIsImFyZ3VtZW50cyIsImFwcGx5IiwiX25leHQiLCJfdGhyb3ciLCJnZXRTZXNzRnJvbUFubnMiLCJleHBvcnRzIiwiX3JlZiIsIl9jYWxsZWUiLCJpZHMiLCJfY2FsbGVlJCIsIl9jb250ZXh0IiwiZGJCeU5hbWUiLCJhbWVsaSIsImFueSIsIm1hcCIsInNlcyIsInBhcnNlSW50RmllbGRzIiwic2VzRmllbGRzVG9QYXJzZUludCIsInRyaW1GaWVsZHNSaWdodCIsInNlc0ZpZWxkc1RvVHJpbSIsIl94IiwiZ2V0U3Vic0Zyb21UeHRpZHMiLCJfcmVmMiIsIl9jYWxsZWUyIiwiX2NhbGxlZTIkIiwiX2NvbnRleHQyIiwic3ViIiwic3ViRmllbGRzVG9QYXJzZUludCIsInN1YkZpZWxkc1RvVHJpbSIsIl94MiIsImdldFR4dHNBbWVsaUJ5U2VzYW5uTnVtSm9pbnMiLCJfcmVmMyIsIl9jYWxsZWUzIiwidHh0c0FtZWxpcyIsIl9pdGVyYXRvciIsIl9zdGVwIiwiaWQiLCJpZFNwbGl0Iiwic2VzYW5uIiwibnVtIiwidHh0QW1lbGkiLCJfY2FsbGVlMyQiLCJfY29udGV4dDMiLCJzcGxpdCIsInBhcnNlSW50IiwidDAiLCJ0MSIsInR4dEFtZWxpRmllbGRzVG9UcmltIiwib25lT3JOb25lIiwidDIiLCJ0MyIsIl94MyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tb2RlbC9hbWVsaS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBTZXMsIHNlc0ZpZWxkc1RvUGFyc2VJbnQsIHNlc0ZpZWxkc1RvVHJpbSxcbiAgU3ViLCBzdWJGaWVsZHNUb1BhcnNlSW50LCBzdWJGaWVsZHNUb1RyaW0sXG4gIFR4dEFtZWxpLCB0eHRBbWVsaUZpZWxkc1RvVHJpbVxufSBmcm9tICcuLi90eXBlcy9hbWVsaSdcbmltcG9ydCB7IGRiQnlOYW1lIH0gZnJvbSBcIi4uL2RhdGFiYXNlc1wiXG5pbXBvcnQgeyBwYXJzZUludEZpZWxkcywgdHJpbUZpZWxkc1JpZ2h0IH0gZnJvbSAnLi4vZmllbGRzJ1xuXG5leHBvcnQgY29uc3QgZ2V0U2Vzc0Zyb21Bbm5zID0gYXN5bmMgKGlkczogc3RyaW5nW10pOiBQcm9taXNlPFNlc1tdPiA9PiB7XG4gIGlmIChpZHMubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuIFtdXG4gIH1cbiAgcmV0dXJuIChcbiAgICBhd2FpdCBkYkJ5TmFtZS5hbWVsaS5hbnkoXG4gICAgICBgXG4gICAgICBTRUxFQ1QgKlxuICAgICAgRlJPTSBzZXNcbiAgICAgIFdIRVJFIGFubiBJTiAoJDxpZHM6bGlzdD4pXG4gICAgYCxcbiAgICAgIHtcbiAgICAgICAgaWRzLFxuICAgICAgfSxcbiAgICApXG4gICkubWFwKChzZXM6IFNlcykgPT5cbiAgICBwYXJzZUludEZpZWxkcyhzZXNGaWVsZHNUb1BhcnNlSW50LCB0cmltRmllbGRzUmlnaHQoc2VzRmllbGRzVG9UcmltLCBzZXMpKSxcbiAgKVxufVxuXG5leHBvcnQgY29uc3QgZ2V0U3Vic0Zyb21UeHRpZHMgPSBhc3luYyAoaWRzOiBzdHJpbmdbXSk6IFByb21pc2U8U3ViW10+ID0+IHtcbiAgaWYgKGlkcy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm4gW11cbiAgfVxuICByZXR1cm4gKFxuICAgIGF3YWl0IGRiQnlOYW1lLmFtZWxpLmFueShcbiAgICAgIGBcbiAgICAgIFNFTEVDVCAqXG4gICAgICBGUk9NIHN1YlxuICAgICAgV0hFUkUgdHh0aWQgSU4oJDxpZHM6bGlzdD4pXG4gICAgYCxcbiAgICAgIHtcbiAgICAgICAgaWRzLFxuICAgICAgfSxcbiAgICApXG4gICkubWFwKChzdWI6IFN1YikgPT5cbiAgICBwYXJzZUludEZpZWxkcyhzdWJGaWVsZHNUb1BhcnNlSW50LCB0cmltRmllbGRzUmlnaHQoc3ViRmllbGRzVG9UcmltLCBzdWIpKSxcbiAgKVxufVxuXG5leHBvcnQgY29uc3QgZ2V0VHh0c0FtZWxpQnlTZXNhbm5OdW1Kb2lucyA9IGFzeW5jIChcbiAgaWRzOiBzdHJpbmdbXSxcbik6IFByb21pc2U8VHh0QW1lbGlbXT4gPT4ge1xuICBpZiAoaWRzLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiBbXVxuICB9XG4gIGNvbnN0IHR4dHNBbWVsaXMgPSBbXVxuICBmb3IgKGNvbnN0IGlkIG9mIGlkcykge1xuICAgIGNvbnN0IGlkU3BsaXQgPSBpZC5zcGxpdChcIiBcIilcbiAgICBjb25zdCBzZXNhbm4gPSBwYXJzZUludChpZFNwbGl0WzBdKVxuICAgIGNvbnN0IG51bSA9IGlkU3BsaXRbMV1cbiAgICBjb25zdCB0eHRBbWVsaSA9IHRyaW1GaWVsZHNSaWdodChcbiAgICAgIHR4dEFtZWxpRmllbGRzVG9UcmltLFxuICAgICAgYXdhaXQgZGJCeU5hbWUuYW1lbGkub25lT3JOb25lKFxuICAgICAgICBgXG4gICAgICAgICAgU0VMRUNUICpcbiAgICAgICAgICBGUk9NIHR4dF9hbWVsaVxuICAgICAgICAgIFdIRVJFXG4gICAgICAgICAgICBzZXNpbnNpZCBpbiAoXG4gICAgICAgICAgICAgIFNFTEVDVCBpZFxuICAgICAgICAgICAgICBGUk9NIHNlc1xuICAgICAgICAgICAgICBXSEVSRSBhbm4gPSAkPHNlc2Fubj5cbiAgICAgICAgICAgICkgQU5EXG4gICAgICAgICAgICBudW0gPSAkPG51bT5cbiAgICAgICAgICBMSU1JVCAxXG4gICAgICAgIGAsXG4gICAgICAgIHtcbiAgICAgICAgICBudW0sXG4gICAgICAgICAgc2VzYW5uLFxuICAgICAgICB9LFxuICAgICAgKSxcbiAgICApIGFzIFR4dEFtZWxpXG4gICAgaWYgKHR4dEFtZWxpICE9PSBudWxsKSB7XG4gICAgICB0eHRzQW1lbGlzLnB1c2godHh0QW1lbGkpXG4gICAgfVxuICB9XG4gIHJldHVybiB0eHRzQW1lbGlzXG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxPQUFBO0FBS0EsSUFBQUMsVUFBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsT0FBQSxHQUFBRixPQUFBO0FBQTJELFNBQUFHLDJCQUFBQyxDQUFBLEVBQUFDLENBQUEsUUFBQUMsQ0FBQSx5QkFBQUMsTUFBQSxJQUFBSCxDQUFBLENBQUFHLE1BQUEsQ0FBQUMsUUFBQSxLQUFBSixDQUFBLHFCQUFBRSxDQUFBLFFBQUFHLEtBQUEsQ0FBQUMsT0FBQSxDQUFBTixDQUFBLE1BQUFFLENBQUEsR0FBQUssMkJBQUEsQ0FBQVAsQ0FBQSxNQUFBQyxDQUFBLElBQUFELENBQUEsdUJBQUFBLENBQUEsQ0FBQVEsTUFBQSxJQUFBTixDQUFBLEtBQUFGLENBQUEsR0FBQUUsQ0FBQSxPQUFBTyxFQUFBLE1BQUFDLENBQUEsWUFBQUEsRUFBQSxlQUFBQyxDQUFBLEVBQUFELENBQUEsRUFBQUUsQ0FBQSxXQUFBQSxFQUFBLFdBQUFILEVBQUEsSUFBQVQsQ0FBQSxDQUFBUSxNQUFBLEtBQUFLLElBQUEsV0FBQUEsSUFBQSxNQUFBQyxLQUFBLEVBQUFkLENBQUEsQ0FBQVMsRUFBQSxVQUFBUixDQUFBLFdBQUFBLEVBQUFELENBQUEsVUFBQUEsQ0FBQSxLQUFBZSxDQUFBLEVBQUFMLENBQUEsZ0JBQUFNLFNBQUEsaUpBQUFDLENB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QUQsU0FBQSxDQUFBeEksQ0FBQSxJQUFBQyxJQUFBO1lBQUErSSxTQUFBLENBQUF2SSxJQUFBO1lBQUE7VUFBQTtVQUFUaUksRUFBRSxHQUFBRCxLQUFBLENBQUF2SSxLQUFBO1VBQ0x5SSxPQUFPLEdBQUdELEVBQUUsQ0FBQ08sS0FBSyxDQUFDLEdBQUcsQ0FBQztVQUN2QkwsTUFBTSxHQUFHTSxRQUFRLENBQUNQLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztVQUM3QkUsR0FBRyxHQUFHRixPQUFPLENBQUMsQ0FBQyxDQUFDO1VBQUFLLFNBQUEsQ0FBQUcsRUFBQSxHQUNMM0IsdUJBQWU7VUFBQXdCLFNBQUEsQ0FBQUksRUFBQSxHQUM5QkMsMkJBQW9CO1VBQUFMLFNBQUEsQ0FBQXZJLElBQUE7VUFBQSxPQUNkd0csbUJBQVEsQ0FBQ0MsS0FBSyxDQUFDb0MsU0FBUywrUEFhNUI7WUFDRVQsR0FBRyxFQUFIQSxHQUFHO1lBQ0hELE1BQU0sRUFBTkE7VUFDRixDQUNGLENBQUM7UUFBQTtVQUFBSSxTQUFBLENBQUFPLEVBQUEsR0FBQVAsU0FBQSxDQUFBakYsSUFBQTtVQW5CRytFLFFBQVEsT0FBQUUsU0FBQSxDQUFBRyxFQUFBLEVBQUFILFNBQUEsQ0FBQUksRUFBQSxFQUFBSixTQUFBLENBQUFPLEVBQUE7VUFxQmQsSUFBSVQsUUFBUSxLQUFLLElBQUksRUFBRTtZQUNyQlAsVUFBVSxDQUFDNUQsSUFBSSxDQUFDbUUsUUFBUSxDQUFDO1VBQzNCO1FBQUM7VUFBQUUsU0FBQSxDQUFBdkksSUFBQTtVQUFBO1FBQUE7VUFBQXVJLFNBQUEsQ0FBQXZJLElBQUE7VUFBQTtRQUFBO1VBQUF1SSxTQUFBLENBQUFyRCxJQUFBO1VBQUFxRCxTQUFBLENBQUFRLEVBQUEsR0FBQVIsU0FBQTtVQUFBUixTQUFBLENBQUFuSixDQUFBLENBQUEySixTQUFBLENBQUFRLEVBQUE7UUFBQTtVQUFBUixTQUFBLENBQUFyRCxJQUFBO1VBQUE2QyxTQUFBLENBQUFySSxDQUFBO1VBQUEsT0FBQTZJLFNBQUEsQ0FBQS9DLE1BQUE7UUFBQTtVQUFBLE9BQUErQyxTQUFBLENBQUE5RSxNQUFBLFdBRUlxRSxVQUFVO1FBQUE7UUFBQTtVQUFBLE9BQUFTLFNBQUEsQ0FBQW5ELElBQUE7TUFBQTtJQUFBLEdBQUF5QyxRQUFBO0VBQUEsQ0FDbEI7RUFBQSxnQkFyQ1lGLDRCQUE0QkEsQ0FBQXFCLEdBQUE7SUFBQSxPQUFBcEIsS0FBQSxDQUFBOUIsS0FBQSxPQUFBRCxTQUFBO0VBQUE7QUFBQSxHQXFDeEMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
11
|
+
var _util = require("./util");
|
|
12
|
+
function auteurs(amendementId) {
|
|
13
|
+
return (0, _postgres.jsonArrayFrom)(_databases.dbAmeli.selectFrom("amdsen").leftJoin("sen_ameli", "amdsen.senid", "sen_ameli.entid").where("amdsen.amdid", "=", amendementId).select(["amdsen.prenomuse as prenom", "amdsen.nomuse as nom", "sen_ameli.mat as matricule"]).orderBy("amdsen.rng asc"));
|
|
14
|
+
}
|
|
15
|
+
var findAllQuery = _databases.dbAmeli.selectFrom("amd").leftJoin("sub", "amd.subid", "sub.id").leftJoin("typsub", "sub.typid", "typsub.id").leftJoin("txt_ameli", "amd.txtid", "txt_ameli.id").leftJoin("ses", "txt_ameli.sesdepid", "ses.id").leftJoin("nat", "txt_ameli.natid", "nat.id").leftJoin("lec_ameli", "txt_ameli.lecid", "lec_ameli.id").leftJoin("avicom", "amd.avcid", "avicom.id").leftJoin("avigvt", "amd.avgid", "avigvt.id").leftJoin("sor", "amd.sorid", "sor.id").leftJoin("irr", "amd.irrid", "irr.id").leftJoin("grppol_ameli", "amd.nomentid", "grppol_ameli.entid").leftJoin("com_ameli", "amd.nomentid", "com_ameli.entid").leftJoin("cab", "amd.nomentid", "cab.entid").select(function (_ref) {
|
|
16
|
+
var eb = _ref.eb,
|
|
17
|
+
ref = _ref.ref,
|
|
18
|
+
val = _ref.val;
|
|
19
|
+
return ["ses.ann as session", "txt_ameli.doslegsignet as signet_dossier_legislatif", "nat.libcourt as nature_texte", "txt_ameli.numabs as numero_texte", "txt_ameli.int as intitule_texte", "lec_ameli.lib as lecture", eb["case"]().when("amd.typ", "=", "A").then(val("Amendement")).when("amd.typ", "=", "M").then(val("Motion")).when("amd.typ", "=", "S").then(val("Sous-amendement"))["else"]("'").end().as("nature"), "amd.id as id", "amd.amdperid as parent_id", "amd.num as numero", "amd.numabs as numero_absolu", "amd.ord as ordre", "sub.lib as subdivision_libelle", "sub.lic as subdivision_libelle_court", "typsub.lib as subdivision_type", "amd.alinea as alinea", (0, _util.toDateString)(ref("amd.datdep")).as("date_depot"), eb["case"]().when("amd.etaid", "=", 8).then(val("Cet amendement a été retiré avant séance."))["else"](ref("amd.dis")).end().as("dispositif"), "amd.obj as objet", "amd.etaid as etat_id", "avicom.lib as avis_commission", "avigvt.lib as avis_gouvernement", eb.fn.coalesce("sor.lib", "irr.libirr").as("sort"), "amd.rev as revision", (0, _util.concat)(val("https://www.senat.fr/amendements/"), ref("ses.lil"), val("/"), ref("txt_ameli.numabs"), val("/Amdt_"), ref("amd.numabs"), val(".html")).as("url"), "grppol_ameli.lilcou as au_nom_de_groupe_politique", "com_ameli.lil as au_nom_de_commission", eb["case"]().when("cab.entid", "is not", null).then(true)["else"](false).end().as("auteur_est_gouvernement")];
|
|
20
|
+
}).select(function (_ref2) {
|
|
21
|
+
var ref = _ref2.ref;
|
|
22
|
+
return [auteurs(ref("amd.id")).as("auteurs")];
|
|
23
|
+
});
|
|
24
|
+
function findAll() {
|
|
25
|
+
return findAllQuery.stream();
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcG9zdGdyZXMiLCJyZXF1aXJlIiwiX2RhdGFiYXNlcyIsIl91dGlsIiwiYXV0ZXVycyIsImFtZW5kZW1lbnRJZCIsImpzb25BcnJheUZyb20iLCJkYkFtZWxpIiwic2VsZWN0RnJvbSIsImxlZnRKb2luIiwid2hlcmUiLCJzZWxlY3QiLCJvcmRlckJ5IiwiZmluZEFsbFF1ZXJ5IiwiX3JlZiIsImViIiwicmVmIiwidmFsIiwid2hlbiIsInRoZW4iLCJlbmQiLCJhcyIsInRvRGF0ZVN0cmluZyIsImZuIiwiY29hbGVzY2UiLCJjb25jYXQiLCJfcmVmMiIsImZpbmRBbGwiLCJzdHJlYW0iXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kZWwvYW1lbGkudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXhwcmVzc2lvbiwgSW5mZXJSZXN1bHQgfSBmcm9tIFwia3lzZWx5XCJcbmltcG9ydCB7IGpzb25BcnJheUZyb20gfSBmcm9tIFwia3lzZWx5L2hlbHBlcnMvcG9zdGdyZXNcIlxuaW1wb3J0IHsgZGJBbWVsaSB9IGZyb20gXCIuLi9kYXRhYmFzZXNcIlxuaW1wb3J0IHsgY29uY2F0LCB0b0RhdGVTdHJpbmcgfSBmcm9tIFwiLi91dGlsXCJcblxuZnVuY3Rpb24gYXV0ZXVycyAoYW1lbmRlbWVudElkOiBFeHByZXNzaW9uPG51bWJlcj4pIHtcbiAgcmV0dXJuIGpzb25BcnJheUZyb20oXG4gICAgZGJBbWVsaS5zZWxlY3RGcm9tKFwiYW1kc2VuXCIpXG4gICAgICAubGVmdEpvaW4oXCJzZW5fYW1lbGlcIiwgXCJhbWRzZW4uc2VuaWRcIiwgXCJzZW5fYW1lbGkuZW50aWRcIilcbiAgICAgIC53aGVyZShcImFtZHNlbi5hbWRpZFwiLCBcIj1cIiwgYW1lbmRlbWVudElkKVxuICAgICAgLnNlbGVjdChbXG4gICAgICAgIFwiYW1kc2VuLnByZW5vbXVzZSBhcyBwcmVub21cIixcbiAgICAgICAgXCJhbWRzZW4ubm9tdXNlIGFzIG5vbVwiLFxuICAgICAgICBcInNlbl9hbWVsaS5tYXQgYXMgbWF0cmljdWxlXCIsXG4gICAgICBdKVxuICAgICAgLm9yZGVyQnkoXCJhbWRzZW4ucm5nIGFzY1wiKSxcbiAgKVxufVxuXG5jb25zdCBmaW5kQWxsUXVlcnkgPSBkYkFtZWxpXG4gIC5zZWxlY3RGcm9tKFwiYW1kXCIpXG4gIC5sZWZ0Sm9pbihcInN1YlwiLCBcImFtZC5zdWJpZFwiLCBcInN1Yi5pZFwiKVxuICAubGVmdEpvaW4oXCJ0eXBzdWJcIiwgXCJzdWIudHlwaWRcIiwgXCJ0eXBzdWIuaWRcIilcbiAgLmxlZnRKb2luKFwidHh0X2FtZWxpXCIsIFwiYW1kLnR4dGlkXCIsIFwidHh0X2FtZWxpLmlkXCIpXG4gIC5sZWZ0Sm9pbihcInNlc1wiLCBcInR4dF9hbWVsaS5zZXNkZXBpZFwiLCBcInNlcy5pZFwiKVxuICAubGVmdEpvaW4oXCJuYXRcIiwgXCJ0eHRfYW1lbGkubmF0aWRcIiwgXCJuYXQuaWRcIilcbiAgLmxlZnRKb2luKFwibGVjX2FtZWxpXCIsIFwidHh0X2FtZWxpLmxlY2lkXCIsIFwibGVjX2FtZWxpLmlkXCIpXG4gIC5sZWZ0Sm9pbihcImF2aWNvbVwiLCBcImFtZC5hdmNpZFwiLCBcImF2aWNvbS5pZFwiKVxuICAubGVmdEpvaW4oXCJhdmlndnRcIiwgXCJhbWQuYXZnaWRcIiwgXCJhdmlndnQuaWRcIilcbiAgLmxlZnRKb2luKFwic29yXCIsIFwiYW1kLnNvcmlkXCIsIFwic29yLmlkXCIpXG4gIC5sZWZ0Sm9pbihcImlyclwiLCBcImFtZC5pcnJpZFwiLCBcImlyci5pZFwiKVxuICAubGVmdEpvaW4oXCJncnBwb2xfYW1lbGlcIiwgXCJhbWQubm9tZW50aWRcIiwgXCJncnBwb2xfYW1lbGkuZW50aWRcIilcbiAgLmxlZnRKb2luKFwiY29tX2FtZWxpXCIsIFwiYW1kLm5vbWVudGlkXCIsIFwiY29tX2FtZWxpLmVudGlkXCIpXG4gIC5sZWZ0Sm9pbihcImNhYlwiLCBcImFtZC5ub21lbnRpZFwiLCBcImNhYi5lbnRpZFwiKVxuICAuc2VsZWN0KCh7IGViLCByZWYsIHZhbCB9KSA9PiBbXG4gICAgXCJzZXMuYW5uIGFzIHNlc3Npb25cIixcbiAgICBcInR4dF9hbWVsaS5kb3NsZWdzaWduZXQgYXMgc2lnbmV0X2Rvc3NpZXJfbGVnaXNsYXRpZlwiLFxuICAgIFwibmF0LmxpYmNvdXJ0IGFzIG5hdHVyZV90ZXh0ZVwiLFxuICAgIFwidHh0X2FtZWxpLm51bWFicyBhcyBudW1lcm9fdGV4dGVcIixcbiAgICBcInR4dF9hbWVsaS5pbnQgYXMgaW50aXR1bGVfdGV4dGVcIixcbiAgICBcImxlY19hbWVsaS5saWIgYXMgbGVjdHVyZVwiLFxuICAgIGViLmNhc2UoKVxuICAgICAgLndoZW4oXCJhbWQudHlwXCIsIFwiPVwiLCBcIkFcIilcbiAgICAgIC50aGVuKHZhbChcIkFtZW5kZW1lbnRcIikpXG4gICAgICAud2hlbihcImFtZC50eXBcIiwgXCI9XCIsIFwiTVwiKVxuICAgICAgLnRoZW4odmFsKFwiTW90aW9uXCIpKVxuICAgICAgLndoZW4oXCJhbWQudHlwXCIsIFwiPVwiLCBcIlNcIilcbiAgICAgIC50aGVuKHZhbChcIlNvdXMtYW1lbmRlbWVudFwiKSlcbiAgICAgIC5lbHNlKFwiJ1wiKVxuICAgICAgLmVuZCgpXG4gICAgICAuYXMoXCJuYXR1cmVcIiksXG4gICAgXCJhbWQuaWQgYXMgaWRcIixcbiAgICBcImFtZC5hbWRwZXJpZCBhcyBwYXJlbnRfaWRcIixcbiAgICBcImFtZC5udW0gYXMgbnVtZXJvXCIsXG4gICAgXCJhbWQubnVtYWJzIGFzIG51bWVyb19hYnNvbHVcIixcbiAgICBcImFtZC5vcmQgYXMgb3JkcmVcIixcbiAgICBcInN1Yi5saWIgYXMgc3ViZGl2aXNpb25fbGliZWxsZVwiLFxuICAgIFwic3ViLmxpYyBhcyBzdWJkaXZpc2lvbl9saWJlbGxlX2NvdXJ0XCIsXG4gICAgXCJ0eXBzdWIubGliIGFzIHN1YmRpdmlzaW9uX3R5cGVcIixcbiAgICBcImFtZC5hbGluZWEgYXMgYWxpbmVhXCIsXG4gICAgdG9EYXRlU3RyaW5nKHJlZihcImFtZC5kYXRkZXBcIikpLmFzKFwiZGF0ZV9kZXBvdFwiKSxcbiAgICBlYi5jYXNlKClcbiAgICAgIC53aGVuKFwiYW1kLmV0YWlkXCIsIFwiPVwiLCA4KVxuICAgICAgLnRoZW4odmFsKFwiQ2V0IGFtZW5kZW1lbnQgYSDDqXTDqSByZXRpcsOpIGF2YW50IHPDqWFuY2UuXCIpKVxuICAgICAgLmVsc2UocmVmKFwiYW1kLmRpc1wiKSlcbiAgICAgIC5lbmQoKVxuICAgICAgLmFzKFwiZGlzcG9zaXRpZlwiKSxcbiAgICBcImFtZC5vYmogYXMgb2JqZXRcIixcbiAgICBcImFtZC5ldGFpZCBhcyBldGF0X2lkXCIsXG4gICAgXCJhdmljb20ubGliIGFzIGF2aXNfY29tbWlzc2lvblwiLFxuICAgIFwiYXZpZ3Z0LmxpYiBhcyBhdmlzX2dvdXZlcm5lbWVudFwiLFxuICAgIGViLmZuLmNvYWxlc2NlKFwic29yLmxpYlwiLCBcImlyci5saWJpcnJcIikuYXMoXCJzb3J0XCIpLFxuICAgIFwiYW1kLnJldiBhcyByZXZpc2lvblwiLFxuICAgIGNvbmNhdChcbiAgICAgIHZhbChcImh0dHBzOi8vd3d3LnNlbmF0LmZyL2FtZW5kZW1lbnRzL1wiKSxcbiAgICAgIHJlZihcInNlcy5saWxcIiksXG4gICAgICB2YWwoXCIvXCIpLFxuICAgICAgcmVmKFwidHh0X2FtZWxpLm51bWFic1wiKSxcbiAgICAgIHZhbChcIi9BbWR0X1wiKSxcbiAgICAgIHJlZihcImFtZC5udW1hYnNcIiksXG4gICAgICB2YWwoXCIuaHRtbFwiKVxuICAgICkuYXMoXCJ1cmxcIiksXG4gICAgXCJncnBwb2xfYW1lbGkubGlsY291IGFzIGF1X25vbV9kZV9ncm91cGVfcG9saXRpcXVlXCIsXG4gICAgXCJjb21fYW1lbGkubGlsIGFzIGF1X25vbV9kZV9jb21taXNzaW9uXCIsXG4gICAgZWIuY2FzZSgpXG4gICAgICAud2hlbihcImNhYi5lbnRpZFwiLCBcImlzIG5vdFwiLCBudWxsKVxuICAgICAgLnRoZW4odHJ1ZSlcbiAgICAgIC5lbHNlKGZhbHNlKVxuICAgICAgLmVuZCgpXG4gICAgICAuYXMoXCJhdXRldXJfZXN0X2dvdXZlcm5lbWVudFwiKSxcbiAgXSlcbiAgLnNlbGVjdCgoeyByZWYgfSkgPT4gW1xuICAgIGF1dGV1cnMocmVmKFwiYW1kLmlkXCIpKS5hcyhcImF1dGV1cnNcIiksXG4gIF0pXG5cbmV4cG9ydCB0eXBlIEFtZW5kZW1lbnRSZXN1bHQgPSBJbmZlclJlc3VsdDx0eXBlb2YgZmluZEFsbFF1ZXJ5PlswXVxuXG5leHBvcnQgZnVuY3Rpb24gZmluZEFsbCAoKSB7XG4gIHJldHVybiBmaW5kQWxsUXVlcnkuc3RyZWFtKClcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFDQSxJQUFBQSxTQUFBLEdBQUFDLE9BQUE7QUFDQSxJQUFBQyxVQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxLQUFBLEdBQUFGLE9BQUE7QUFFQSxTQUFTRyxPQUFPQSxDQUFFQyxZQUFnQyxFQUFFO0VBQ2xELE9BQU8sSUFBQUMsdUJBQWEsRUFDbEJDLGtCQUFPLENBQUNDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FDekJDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsY0FBYyxFQUFFLGlCQUFpQixDQUFDLENBQ3hEQyxLQUFLLENBQUMsY0FBYyxFQUFFLEdBQUcsRUFBRUwsWUFBWSxDQUFDLENBQ3hDTSxNQUFNLENBQUMsQ0FDTiw0QkFBNEIsRUFDNUIsc0JBQXNCLEVBQ3RCLDRCQUE0QixDQUM3QixDQUFDLENBQ0RDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FDN0IsQ0FBQztBQUNIO0FBRUEsSUFBTUMsWUFBWSxHQUFHTixrQkFBTyxDQUN6QkMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUNqQkMsUUFBUSxDQUFDLEtBQUssRUFBRSxXQUFXLEVBQUUsUUFBUSxDQUFDLENBQ3RDQSxRQUFRLENBQUMsUUFBUSxFQUFFLFdBQVcsRUFBRSxXQUFXLENBQUMsQ0FDNUNBLFFBQVEsQ0FBQyxXQUFXLEVBQUUsV0FBVyxFQUFFLGNBQWMsQ0FBQyxDQUNsREEs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
|
package/lib/model/ameli.mjs
CHANGED
|
@@ -1,57 +1,84 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
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
|
-
|
|
1
|
+
import { jsonArrayFrom } from "kysely/helpers/postgres";
|
|
2
|
+
import { dbAmeli } from "../databases";
|
|
3
|
+
import { concat, toDateString } from "./util";
|
|
4
|
+
function auteurs(amendementId) {
|
|
5
|
+
return jsonArrayFrom(dbAmeli.selectFrom("amdsen")
|
|
6
|
+
.leftJoin("sen_ameli", "amdsen.senid", "sen_ameli.entid")
|
|
7
|
+
.where("amdsen.amdid", "=", amendementId)
|
|
8
|
+
.select([
|
|
9
|
+
"amdsen.prenomuse as prenom",
|
|
10
|
+
"amdsen.nomuse as nom",
|
|
11
|
+
"sen_ameli.mat as matricule",
|
|
12
|
+
])
|
|
13
|
+
.orderBy("amdsen.rng asc"));
|
|
14
|
+
}
|
|
15
|
+
const findAllQuery = dbAmeli
|
|
16
|
+
.selectFrom("amd")
|
|
17
|
+
.leftJoin("sub", "amd.subid", "sub.id")
|
|
18
|
+
.leftJoin("typsub", "sub.typid", "typsub.id")
|
|
19
|
+
.leftJoin("txt_ameli", "amd.txtid", "txt_ameli.id")
|
|
20
|
+
.leftJoin("ses", "txt_ameli.sesdepid", "ses.id")
|
|
21
|
+
.leftJoin("nat", "txt_ameli.natid", "nat.id")
|
|
22
|
+
.leftJoin("lec_ameli", "txt_ameli.lecid", "lec_ameli.id")
|
|
23
|
+
.leftJoin("avicom", "amd.avcid", "avicom.id")
|
|
24
|
+
.leftJoin("avigvt", "amd.avgid", "avigvt.id")
|
|
25
|
+
.leftJoin("sor", "amd.sorid", "sor.id")
|
|
26
|
+
.leftJoin("irr", "amd.irrid", "irr.id")
|
|
27
|
+
.leftJoin("grppol_ameli", "amd.nomentid", "grppol_ameli.entid")
|
|
28
|
+
.leftJoin("com_ameli", "amd.nomentid", "com_ameli.entid")
|
|
29
|
+
.leftJoin("cab", "amd.nomentid", "cab.entid")
|
|
30
|
+
.select(({ eb, ref, val }) => [
|
|
31
|
+
"ses.ann as session",
|
|
32
|
+
"txt_ameli.doslegsignet as signet_dossier_legislatif",
|
|
33
|
+
"nat.libcourt as nature_texte",
|
|
34
|
+
"txt_ameli.numabs as numero_texte",
|
|
35
|
+
"txt_ameli.int as intitule_texte",
|
|
36
|
+
"lec_ameli.lib as lecture",
|
|
37
|
+
eb.case()
|
|
38
|
+
.when("amd.typ", "=", "A")
|
|
39
|
+
.then(val("Amendement"))
|
|
40
|
+
.when("amd.typ", "=", "M")
|
|
41
|
+
.then(val("Motion"))
|
|
42
|
+
.when("amd.typ", "=", "S")
|
|
43
|
+
.then(val("Sous-amendement"))
|
|
44
|
+
.else("'")
|
|
45
|
+
.end()
|
|
46
|
+
.as("nature"),
|
|
47
|
+
"amd.id as id",
|
|
48
|
+
"amd.amdperid as parent_id",
|
|
49
|
+
"amd.num as numero",
|
|
50
|
+
"amd.numabs as numero_absolu",
|
|
51
|
+
"amd.ord as ordre",
|
|
52
|
+
"sub.lib as subdivision_libelle",
|
|
53
|
+
"sub.lic as subdivision_libelle_court",
|
|
54
|
+
"typsub.lib as subdivision_type",
|
|
55
|
+
"amd.alinea as alinea",
|
|
56
|
+
toDateString(ref("amd.datdep")).as("date_depot"),
|
|
57
|
+
eb.case()
|
|
58
|
+
.when("amd.etaid", "=", 8)
|
|
59
|
+
.then(val("Cet amendement a été retiré avant séance."))
|
|
60
|
+
.else(ref("amd.dis"))
|
|
61
|
+
.end()
|
|
62
|
+
.as("dispositif"),
|
|
63
|
+
"amd.obj as objet",
|
|
64
|
+
"amd.etaid as etat_id",
|
|
65
|
+
"avicom.lib as avis_commission",
|
|
66
|
+
"avigvt.lib as avis_gouvernement",
|
|
67
|
+
eb.fn.coalesce("sor.lib", "irr.libirr").as("sort"),
|
|
68
|
+
"amd.rev as revision",
|
|
69
|
+
concat(val("https://www.senat.fr/amendements/"), ref("ses.lil"), val("/"), ref("txt_ameli.numabs"), val("/Amdt_"), ref("amd.numabs"), val(".html")).as("url"),
|
|
70
|
+
"grppol_ameli.lilcou as au_nom_de_groupe_politique",
|
|
71
|
+
"com_ameli.lil as au_nom_de_commission",
|
|
72
|
+
eb.case()
|
|
73
|
+
.when("cab.entid", "is not", null)
|
|
74
|
+
.then(true)
|
|
75
|
+
.else(false)
|
|
76
|
+
.end()
|
|
77
|
+
.as("auteur_est_gouvernement"),
|
|
78
|
+
])
|
|
79
|
+
.select(({ ref }) => [
|
|
80
|
+
auteurs(ref("amd.id")).as("auteurs"),
|
|
81
|
+
]);
|
|
82
|
+
export function findAll() {
|
|
83
|
+
return findAllQuery.stream();
|
|
84
|
+
}
|
package/lib/model/ameli.ts
CHANGED
|
@@ -1,86 +1,100 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
} from '../types/ameli'
|
|
6
|
-
import { dbByName } from "../databases"
|
|
7
|
-
import { parseIntFields, trimFieldsRight } from '../fields'
|
|
1
|
+
import { Expression, InferResult } from "kysely"
|
|
2
|
+
import { jsonArrayFrom } from "kysely/helpers/postgres"
|
|
3
|
+
import { dbAmeli } from "../databases"
|
|
4
|
+
import { concat, toDateString } from "./util"
|
|
8
5
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
{
|
|
21
|
-
ids,
|
|
22
|
-
},
|
|
23
|
-
)
|
|
24
|
-
).map((ses: Ses) =>
|
|
25
|
-
parseIntFields(sesFieldsToParseInt, trimFieldsRight(sesFieldsToTrim, ses)),
|
|
6
|
+
function auteurs (amendementId: Expression<number>) {
|
|
7
|
+
return jsonArrayFrom(
|
|
8
|
+
dbAmeli.selectFrom("amdsen")
|
|
9
|
+
.leftJoin("sen_ameli", "amdsen.senid", "sen_ameli.entid")
|
|
10
|
+
.where("amdsen.amdid", "=", amendementId)
|
|
11
|
+
.select([
|
|
12
|
+
"amdsen.prenomuse as prenom",
|
|
13
|
+
"amdsen.nomuse as nom",
|
|
14
|
+
"sen_ameli.mat as matricule",
|
|
15
|
+
])
|
|
16
|
+
.orderBy("amdsen.rng asc"),
|
|
26
17
|
)
|
|
27
18
|
}
|
|
28
19
|
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
20
|
+
const findAllQuery = dbAmeli
|
|
21
|
+
.selectFrom("amd")
|
|
22
|
+
.leftJoin("sub", "amd.subid", "sub.id")
|
|
23
|
+
.leftJoin("typsub", "sub.typid", "typsub.id")
|
|
24
|
+
.leftJoin("txt_ameli", "amd.txtid", "txt_ameli.id")
|
|
25
|
+
.leftJoin("ses", "txt_ameli.sesdepid", "ses.id")
|
|
26
|
+
.leftJoin("nat", "txt_ameli.natid", "nat.id")
|
|
27
|
+
.leftJoin("lec_ameli", "txt_ameli.lecid", "lec_ameli.id")
|
|
28
|
+
.leftJoin("avicom", "amd.avcid", "avicom.id")
|
|
29
|
+
.leftJoin("avigvt", "amd.avgid", "avigvt.id")
|
|
30
|
+
.leftJoin("sor", "amd.sorid", "sor.id")
|
|
31
|
+
.leftJoin("irr", "amd.irrid", "irr.id")
|
|
32
|
+
.leftJoin("grppol_ameli", "amd.nomentid", "grppol_ameli.entid")
|
|
33
|
+
.leftJoin("com_ameli", "amd.nomentid", "com_ameli.entid")
|
|
34
|
+
.leftJoin("cab", "amd.nomentid", "cab.entid")
|
|
35
|
+
.select(({ eb, ref, val }) => [
|
|
36
|
+
"ses.ann as session",
|
|
37
|
+
"txt_ameli.doslegsignet as signet_dossier_legislatif",
|
|
38
|
+
"nat.libcourt as nature_texte",
|
|
39
|
+
"txt_ameli.numabs as numero_texte",
|
|
40
|
+
"txt_ameli.int as intitule_texte",
|
|
41
|
+
"lec_ameli.lib as lecture",
|
|
42
|
+
eb.case()
|
|
43
|
+
.when("amd.typ", "=", "A")
|
|
44
|
+
.then(val("Amendement"))
|
|
45
|
+
.when("amd.typ", "=", "M")
|
|
46
|
+
.then(val("Motion"))
|
|
47
|
+
.when("amd.typ", "=", "S")
|
|
48
|
+
.then(val("Sous-amendement"))
|
|
49
|
+
.else("'")
|
|
50
|
+
.end()
|
|
51
|
+
.as("nature"),
|
|
52
|
+
"amd.id as id",
|
|
53
|
+
"amd.amdperid as parent_id",
|
|
54
|
+
"amd.num as numero",
|
|
55
|
+
"amd.numabs as numero_absolu",
|
|
56
|
+
"amd.ord as ordre",
|
|
57
|
+
"sub.lib as subdivision_libelle",
|
|
58
|
+
"sub.lic as subdivision_libelle_court",
|
|
59
|
+
"typsub.lib as subdivision_type",
|
|
60
|
+
"amd.alinea as alinea",
|
|
61
|
+
toDateString(ref("amd.datdep")).as("date_depot"),
|
|
62
|
+
eb.case()
|
|
63
|
+
.when("amd.etaid", "=", 8)
|
|
64
|
+
.then(val("Cet amendement a été retiré avant séance."))
|
|
65
|
+
.else(ref("amd.dis"))
|
|
66
|
+
.end()
|
|
67
|
+
.as("dispositif"),
|
|
68
|
+
"amd.obj as objet",
|
|
69
|
+
"amd.etaid as etat_id",
|
|
70
|
+
"avicom.lib as avis_commission",
|
|
71
|
+
"avigvt.lib as avis_gouvernement",
|
|
72
|
+
eb.fn.coalesce("sor.lib", "irr.libirr").as("sort"),
|
|
73
|
+
"amd.rev as revision",
|
|
74
|
+
concat(
|
|
75
|
+
val("https://www.senat.fr/amendements/"),
|
|
76
|
+
ref("ses.lil"),
|
|
77
|
+
val("/"),
|
|
78
|
+
ref("txt_ameli.numabs"),
|
|
79
|
+
val("/Amdt_"),
|
|
80
|
+
ref("amd.numabs"),
|
|
81
|
+
val(".html")
|
|
82
|
+
).as("url"),
|
|
83
|
+
"grppol_ameli.lilcou as au_nom_de_groupe_politique",
|
|
84
|
+
"com_ameli.lil as au_nom_de_commission",
|
|
85
|
+
eb.case()
|
|
86
|
+
.when("cab.entid", "is not", null)
|
|
87
|
+
.then(true)
|
|
88
|
+
.else(false)
|
|
89
|
+
.end()
|
|
90
|
+
.as("auteur_est_gouvernement"),
|
|
91
|
+
])
|
|
92
|
+
.select(({ ref }) => [
|
|
93
|
+
auteurs(ref("amd.id")).as("auteurs"),
|
|
94
|
+
])
|
|
95
|
+
|
|
96
|
+
export type AmendementResult = InferResult<typeof findAllQuery>[0]
|
|
48
97
|
|
|
49
|
-
export
|
|
50
|
-
|
|
51
|
-
): Promise<TxtAmeli[]> => {
|
|
52
|
-
if (ids.length === 0) {
|
|
53
|
-
return []
|
|
54
|
-
}
|
|
55
|
-
const txtsAmelis = []
|
|
56
|
-
for (const id of ids) {
|
|
57
|
-
const idSplit = id.split(" ")
|
|
58
|
-
const sesann = parseInt(idSplit[0])
|
|
59
|
-
const num = idSplit[1]
|
|
60
|
-
const txtAmeli = trimFieldsRight(
|
|
61
|
-
txtAmeliFieldsToTrim,
|
|
62
|
-
await dbByName.ameli.oneOrNone(
|
|
63
|
-
`
|
|
64
|
-
SELECT *
|
|
65
|
-
FROM txt_ameli
|
|
66
|
-
WHERE
|
|
67
|
-
sesinsid in (
|
|
68
|
-
SELECT id
|
|
69
|
-
FROM ses
|
|
70
|
-
WHERE ann = $<sesann>
|
|
71
|
-
) AND
|
|
72
|
-
num = $<num>
|
|
73
|
-
LIMIT 1
|
|
74
|
-
`,
|
|
75
|
-
{
|
|
76
|
-
num,
|
|
77
|
-
sesann,
|
|
78
|
-
},
|
|
79
|
-
),
|
|
80
|
-
) as TxtAmeli
|
|
81
|
-
if (txtAmeli !== null) {
|
|
82
|
-
txtsAmelis.push(txtAmeli)
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
return txtsAmelis
|
|
98
|
+
export function findAll () {
|
|
99
|
+
return findAllQuery.stream()
|
|
86
100
|
}
|
package/lib/model/debats.d.ts
CHANGED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { Debat, LecAssDeb } from '../types/debats';
|
|
2
|
-
export declare const getDebats: (ids: string[]) => Promise<Debat[]>;
|
|
3
|
-
export declare const getDebatsFromLecassidts: (ids: string[]) => Promise<Debat[]>;
|
|
4
|
-
export declare const getLecAssDebsFromDatseas: (ids: string[]) => Promise<LecAssDeb[]>;
|