From 28e4e82a77cd5cedca9f89eb9141edbab4c9467e Mon Sep 17 00:00:00 2001 From: Nick Date: Mon, 26 Aug 2024 10:08:46 -0600 Subject: [PATCH] Resolve #88 & #5 anms exp bld 001 navigation filtering (#123) * 88: Added filtering transcoder log on transcoder log id * 88: Fixed filtering transcoder log on input string and uri * #5: Added active color to selected page indicator * updated pageSizeChange to set page to 1 --------- Co-authored-by: Nicholas Brunner Co-authored-by: linkodm1 --- anms-core/anms/routes/transcoder.py | 19 ++- .../management/builder/transcoder.vue | 153 +++++++++--------- anms-ui/server/components/transcoder.js | 6 +- 3 files changed, 95 insertions(+), 83 deletions(-) diff --git a/anms-core/anms/routes/transcoder.py b/anms-core/anms/routes/transcoder.py index 242864c..7720ef6 100644 --- a/anms-core/anms/routes/transcoder.py +++ b/anms-core/anms/routes/transcoder.py @@ -45,16 +45,19 @@ async def paged_transcoder_log(params: Params = Depends()): return await paginate(session, select(TranscoderLog).order_by(desc(TranscoderLog.transcoder_log_id)), params) -@router.get("/db/search/{query}", status_code=status.HTTP_200_OK, response_model=Page[TL]) +@router.get("/db/search/{query:path}", status_code=status.HTTP_200_OK, response_model=Page[TL]) async def paged_transcoder_log(query: str, params: Params = Depends()): async with get_async_session() as session: - query = '%' + query + '%' - - return await paginate(session, select(TranscoderLog).where(or_( - TranscoderLog.input_string.ilike(query), - TranscoderLog.uri.ilike(query), - TranscoderLog.cbor.ilike(query) - )).order_by(desc(TranscoderLog.transcoder_log_id)), params) + filters = [] + filters.append(TranscoderLog.input_string.ilike(f'%{query}%')) + filters.append(TranscoderLog.uri.ilike(f'%{query}%')) + filters.append(TranscoderLog.cbor.ilike(f'%{query}%')) + if query.isdigit(): + filters.append(TranscoderLog.transcoder_log_id == int(query)) + + return await paginate(session, select(TranscoderLog) + .where(or_(*filters)) + .order_by(desc(TranscoderLog.transcoder_log_id)), params) @router.get("/db/id/{id}", status_code=status.HTTP_200_OK, response_model=TL) async def transcoder_log_by_id(id: str): diff --git a/anms-ui/public/app/components/management/builder/transcoder.vue b/anms-ui/public/app/components/management/builder/transcoder.vue index 6f077d4..7670efc 100644 --- a/anms-ui/public/app/components/management/builder/transcoder.vue +++ b/anms-ui/public/app/components/management/builder/transcoder.vue @@ -2,70 +2,72 @@
+
+

Select CBOR to send to Agents tab

+ + + +
+
+ Items per Page: + +
+ +
+
+ + +
@@ -78,7 +80,7 @@ export default { data() { return { fields: [ - {key:"transcoder_log_id", sortable:true}, {key:"input_string", sortable:true}, {key:"parsed_as", sortable:true}, {key:"cbor", sortable:false}, {key:"ari",sortable:false},{key:"uri", sortable:false}, + { key: "transcoder_log_id", sortable: true }, { key: "input_string", sortable: true }, { key: "parsed_as", sortable: true }, { key: "cbor", sortable: false }, { key: "ari", sortable: false }, { key: "uri", sortable: false }, ], nodeMan: null, node: null, @@ -90,24 +92,24 @@ export default { loading: true, errored: false, pageSizes: [5, 10, 20, 50, 100], - selected:null, - transcoderWorkerId:"", - sortField:"", - sortDesc:false, + selected: null, + transcoderWorkerId: "", + sortField: "", + sortDesc: false, }; }, mounted() { const vm = this; vm.reloadTranscoderLog(); vm.transcoderWorkerId = setInterval(() => { - console.log("Calling schedule transcoder Log refresh in App"); - vm.reloadTranscoderLog(); + console.log("Calling schedule transcoder Log refresh in App"); + vm.reloadTranscoderLog(); }, status_refresh_rate); }, beforeDestroy() { - console.log("Clearing interval with id:", this.transcoderWorkerId); - clearInterval(this.transcoderWorkerId); - }, + console.log("Clearing interval with id:", this.transcoderWorkerId); + clearInterval(this.transcoderWorkerId); + }, computed: { ...mapGetters("transcoder", { currentTranscoderLogs: "currentTranscoderLogs", @@ -139,10 +141,8 @@ export default { handlePageSizeChange(event) { const vm = this; vm.setPageSize(event.target.value); - // vm.setPage(1); - // vm.reloadTranscoderLog(); + handlePageChange(1); }, - handleSearchStringChange(event) { const vm = this; vm.setSearchString(event.target.value); @@ -151,9 +151,14 @@ export default { }; - diff --git a/anms-ui/server/components/transcoder.js b/anms-ui/server/components/transcoder.js index 940591e..6a99407 100644 --- a/anms-ui/server/components/transcoder.js +++ b/anms-ui/server/components/transcoder.js @@ -96,8 +96,12 @@ return next(Boom.badData('Invalid size=' + req.query.size)); } const params = {'page': req.query.page, 'size': req.query.size }; - const url = utils.generateAnmsCoreUrl(['transcoder', 'db', 'search', transcoderQuery], params); + const url = utils.generateAnmsCoreUrl(['transcoder', 'db', 'search', encodeURIComponent(transcoderQuery)], params); + console.log("[getTranscoderPagedBySearch]: url"); + console.log(url); const transcoderLog = await axios.get(url); + console.log("[getTranscoderPagedBySearch]: transcoderLog.data"); + console.log(transcoderLog.data); return res.status(200).json(transcoderLog.data); } catch (err) {