diff --git a/src/lib/ae_events_functions.ts b/src/lib/ae_events_functions.ts index aab0db2a..bdeeef64 100644 --- a/src/lib/ae_events_functions.ts +++ b/src/lib/ae_events_functions.ts @@ -1488,8 +1488,10 @@ function handle_db_save_ae_obj_li__event_file({obj_type, obj_li}) { try { const id_random = await db_events.files.put({ + id: obj.event_file_id_random, id_random: obj.event_file_id_random, event_file_id_random: obj.event_file_id_random, + hosted_file_id_random: obj.hosted_file_id_random, hash_sha256: obj.hash_sha256, // Renamed with alias in FastAPI model @@ -1549,8 +1551,11 @@ function handle_db_save_ae_obj_li__event_session({obj_type, obj_li}) { try { const id_random = await db_events.sessions.put({ - id_random: obj.event_session_id_random, + id: obj.event_session_id_random, + // id_random: obj.event_session_id_random, + event_session_id: obj.event_session_id_random, event_session_id_random: obj.event_session_id_random, + external_id: obj.external_id, code: obj.code, @@ -1690,19 +1695,28 @@ function handle_db_save_ae_obj_li__event_presenter({obj_type, obj_li}) { try { const id_random = await db_events.presenters.put({ - id_random: obj.event_presenter_id_random, + id: obj.event_presenter_id_random, + // id_random: obj.event_presenter_id_random, + event_presenter_id: obj.event_presenter_id_random, event_presenter_id_random: obj.event_presenter_id_random, + external_id: obj.external_id, code: obj.code, // for_type: obj.for_type, // for_id_random: obj.for_id_random, + event_id: obj.event_id_random, event_id_random: obj.event_id_random, + event_session_id: obj.event_session_id_random, event_session_id_random: obj.event_session_id_random, - event_person_id_random: obj.event_person_id_random, + event_presentation_id: obj.event_presentation_id_random, event_presentation_id_random: obj.event_presentation_id_random, + event_person_id: obj.event_person_id_random, + event_person_id_random: obj.event_person_id_random, + person_id: obj.person_id_random, person_id_random: obj.person_id_random, + person_profile_id: obj.person_profile_id_random, person_profile_id_random: obj.person_profile_id_random, // The new table person_profile will be used soon... pronouns: obj.pronouns, @@ -1742,6 +1756,12 @@ function handle_db_save_ae_obj_li__event_presenter({obj_type, obj_li}) { updated_on: obj.updated_on, file_count: obj.file_count, + + person_given_name: obj.person_given_name, + person_family_name: obj.person_family_name, + person_full_name: obj.person_full_name, + person_primary_email: obj.person_primary_email, + person_passcode: obj.person_passcode, }); // console.log(`Put obj with ID: ${obj.event_presenter_id_random} or ${id_random}`); } catch (error) { diff --git a/src/lib/ae_utils.ts b/src/lib/ae_utils.ts index a18535f7..2812e4a3 100644 --- a/src/lib/ae_utils.ts +++ b/src/lib/ae_utils.ts @@ -1,5 +1,9 @@ import dayjs from 'dayjs'; +type key_str = { + [key: string]: string; +}; + type key_val = { [key: string]: any; }; @@ -610,9 +614,6 @@ function count_words(text: string) { } - - - /* Adapted from: To Title Case © 2018 David Gouch | https://github.com/gouch/to-title-case */ // eslint-disable-next-line no-extend-native @@ -660,6 +661,158 @@ function to_title_case (text_string) { } +// Updated 2024-06-19 +export let shorten_string = function shorten_string( + { + string, + max_length=45, + begin_length=15, + end_length=5, + wildcard_length=3 + } : { + string: string, + max_length?: number, + begin_length?: number, + end_length?: number, + wildcard_length?: number + } + ) { + // console.log('*** shorten_filename() ***'); + + if (!string || typeof string != 'string') { + console.log('Invalid string value passed'); + return false; + } + + // NOTE: max_length is not the actual end result length. The actual max will be 45 characters. + // 20 part 1 characters, 5 part 2 characters, 20 part 3 characters + + // let length = string.length; + let char_over = string.length-max_length; + let new_string = null; + let wildcards = char_over; + if (char_over > 0) { + let part1 = string.slice(0, begin_length); + + let part2 = ''; + if (char_over > 5) { + wildcards = 5; + } else { + } + + if (wildcard_length) { + part2 = '.'.repeat(wildcard_length); + } else { + part2 = '.'.repeat(wildcards); + } + + let part3 = string.slice(end_length*-1); + + new_string = part1+part2+part3; + } else { + new_string = string; + } + return new_string; +} + + +// Updated 2024-06-19 +// This function should return a shorted version of a filename if over the max length. It should always contain at least the first character of the original filename and the complete extension. +// Example 1: The Original Long File Name.pdf -> The Orig....pdf +// Example 2: The Original Long File Name.html -> The Ori....html +function shorten_filename( + { + filename, + max_length=20, + slice_end_at=15, + max_end_length=5 + } : { + filename: string, + max_length?: number, + slice_end_at?: number, + max_end_length?: number + } + ) { + // console.log('*** shorten_filename() ***'); + + if (typeof filename !== 'string' || filename.length <= max_length) { + return filename; + } + + let new_filename = null; + let char_over = filename.length - max_length; + let wildcards = char_over - 4; // The number of characters over the max length + if (wildcards < 1) { + return filename; // No point in changing the filename? + } + + let part_1 = filename.slice(0, slice_end_at); + if (wildcards > 3) { + wildcards = 3; + } else { + } + let part_2 = '.'.repeat(wildcards); + let part_3 = filename.slice(max_end_length*-1); + + new_filename = part_1+part_2+part_3; + + return new_filename; +} + + +// Updated 2024-6-19 +function file_extension_icon( + extension: string + ) { + // console.log('*** file_extension_icon() ***'); + + let file_icons: key_str = { + 'file': 'file', + '3gp': 'file-video', + '7z': 'file-archive', + 'aac': 'file-audio', + 'ac3': 'file-audio', + 'aif': 'file-audio', + 'aiff': 'file-audio', + 'avi': 'file-video', + 'bmp': 'file-image', + 'csv': 'file-csv', + 'doc': 'file-word', + 'docx': 'file-word', + 'eps': 'file-image', + 'flac': 'file-audio', + 'gif': 'file-image', + 'htm': 'file-code', + 'html': 'file-code', + 'jpeg': 'file-image', + 'jpg': 'file-image', + 'key': 'file-powerpoint', + 'mkv': 'file-video', + 'mov': 'file-video', + 'mp3': 'file-audio', + 'mp4': 'file-video', + 'odp': 'file-powerpoint', + 'pdf': 'file-pdf', + 'png': 'file-image', + 'ppt': 'file-powerpoint', + 'pptx': 'file-powerpoint', + 'txt': 'file-alt', + 'wav': 'file-audio', + 'webp': 'file-image', + 'xls': 'file-excel', + 'xlsx': 'file-excel', + 'zip': 'file-archive' + }; + + if (file_icons[extension]) { + return file_icons[extension]; + } else { + // return null; + return file_icons['file']; + } +} + + // Updated 2023-08-18 function set_obj_prop_display_name({prop_name, obj_type=null, prefix_w_obj_type=true, prefix_all_w_obj_type=false, replace_underscores=true, title_case=true, override=null}) { console.log('*** set_obj_prop_display_name() ***'); @@ -850,6 +1003,9 @@ export let ae_util = { create_video_element: create_video_element, count_words: count_words, to_title_case: to_title_case, + shorten_string: shorten_string, + shorten_filename: shorten_filename, + file_extension_icon: file_extension_icon, set_obj_prop_display_name: set_obj_prop_display_name, return_obj_type_path: return_obj_type_path, }; diff --git a/src/lib/db_events.ts b/src/lib/db_events.ts index 76d13465..bc83b7a4 100644 --- a/src/lib/db_events.ts +++ b/src/lib/db_events.ts @@ -179,8 +179,10 @@ export interface Exhibit_tracking { } export interface File { + id: string; id_random: string; event_file_id_random: string; + hosted_file_id_random: string; hash_sha256: string; @@ -218,27 +220,35 @@ export interface File { hosted_file_size: number; // In bytes } +// Updated 2024-06-19 export interface Session { - id_random: string; + id: string; + // id_random: string; + event_session_id: string; event_session_id_random: string; - external_id: string; - code: string; + + external_id: null|string; + code: null|string; for_type: string; + for_id: string; for_id_random: string; type_code: string; + event_id: string; event_id_random: string; - event_location_id_random: string; + event_location_id: null|string; + event_location_id_random: null|string; - poc_person_id_random: string; + poc_person_id: null|string; + poc_person_id_random: null|string; name: string; description: null|string; - start_datetime: Date; - end_datetime: Date; + start_datetime: null|Date; + end_datetime: null|Date; passcode: null|string; @@ -259,42 +269,49 @@ export interface Session { updated_on: null|Date; // Additional fields for convenience (database views) - file_count: number; + file_count: null|number; - poc_person_given_name: string; - poc_person_family_name: string; - poc_person_full_name: string; - poc_person_primary_email: string; - poc_person_passcode: string; + poc_person_given_name: null|string; + poc_person_family_name: null|string; + poc_person_full_name: null|string; + poc_person_primary_email: null|string; + poc_person_passcode: null|string; poc_kv_json: null|string; - event_location_code: string; - event_location_name: string; + event_location_code: null|string; + event_location_name: null|string; } // Updated 2024-06-10 export interface Presentation { + id: string; id_random: string; + event_presentation_id: string; event_presentation_id_random: string; - external_id: string; - code: string; + + external_id: null|string; + code: null|string; for_type: string; + for_id: string; for_id_random: string; type_code: string; + event_id: string; event_id_random: string; + event_session_id: string; event_session_id_random: string; - event_abstract_id_random: string; + event_abstract_id: null|string; + event_abstract_id_random: null|string; - abstract_code: string; + abstract_code: null|string; name: string; description: null|string; - start_datetime: Date; - end_datetime: Date; + start_datetime: null|Date; + end_datetime: null|Date; hide_event_launcher: null|boolean; @@ -306,21 +323,36 @@ export interface Presentation { notes: null|string; created_on: Date; updated_on: null|Date; + + // Additional fields for convenience (database views) + // file_count: null|number; + + event_session_code: null|string; + event_session_name: null|string; } // Updated 2024-06-10 export interface Presenter { - id_random: string; + id: string; + // id_random: string; + event_presenter_id: string; event_presenter_id_random: string; + external_id: string; code: string; + event_id: string; event_id_random: string; + event_session_id: string; event_session_id_random: string; - event_person_id_random: string; + event_person_id: null|string; + event_person_id_random: null|string; + event_presentation_id: string; event_presentation_id_random: string; - person_id_random: string; - person_profile_id_random: string; // The new table person_profile will be used soon... + person_id: null|string; + person_id_random: null|string; + person_profile_id: null|string; + person_profile_id_random: null|string; // The new table person_profile will be used soon... pronouns: null|string; informal_name: null|string; @@ -359,9 +391,13 @@ export interface Presenter { updated_on: null|Date; // Additional fields for convenience (database views) - file_count: number; - person_passcode: string; - person_primary_email: string; + file_count: null|number; + + person_given_name: null|string; + person_family_name: null|string; + person_full_name: null|string; + person_primary_email: null|string; + person_passcode: null|string; } @@ -385,7 +421,7 @@ export class MySubClassedDexie extends Dexie { id_random, event_id_random, code, account_id_random, conference, type, - name, summary, description, + name, start_datetime, end_datetime, timezone, location_address_json, mod_abstracts_json, mod_badges_json, mod_exhibits_json, mod_pres_mgmt_json, @@ -414,14 +450,17 @@ export class MySubClassedDexie extends Dexie { enable, hide, priority, sort, group, notes, created_on, updated_on`, sessions: ` - id_random, event_session_id_random, external_id, code, - for_type, for_id_random, type_code, + event_session_id, event_session_id_random, + external_id, code, + for_type, for_id, for_id_random, + type_code, + event_id, event_location_id, + poc_person_id, event_id_random, event_location_id_random, - poc_person_id_random, poc_person_given_name, poc_person_family_name, poc_person_full_name, poc_person_primary_email, poc_kv_json, - name, description, start_datetime, end_datetime, - passcode, + poc_person_id_random, + name, start_datetime, end_datetime, hide_event_launcher, - enable, hide, priority, sort, group, notes, created_on, updated_on`, + enable, hide, priority, sort, group, created_on, updated_on`, files: ` id_random, event_file_id_random, hosted_file_id_random, hash_sha256, @@ -442,12 +481,15 @@ export class MySubClassedDexie extends Dexie { `, presenters: ` - id_random, event_presenter_id_random, external_id, code, + event_presenter_id, event_presenter_id_random, + external_id, code, + event_id, event_session_id, event_person_id, event_presentation_id, event_id_random, event_session_id_random, event_person_id_random, event_presentation_id_random, + person_id, person_profile_id, person_id_random, person_profile_id_random, - pronouns, informal_name, title_names, given_name, middle_name, family_name, designations, - professional_title, full_name, affiliations, email, - biography, agree, comments, passcode, + given_name, family_name, + full_name, affiliations, email, + agree hide_event_launcher, data_json, enable, hide, priority, sort, group, notes, created_on, updated_on diff --git a/src/routes/events_pres_mgmt/event/[slug]/+page.svelte b/src/routes/events_pres_mgmt/event/[slug]/+page.svelte index 8e15f382..6f1bb37f 100644 --- a/src/routes/events_pres_mgmt/event/[slug]/+page.svelte +++ b/src/routes/events_pres_mgmt/event/[slug]/+page.svelte @@ -290,10 +290,12 @@ $: if ($events_trigger == 'load__event_session_obj_li' && $events_slct.event_id)
- Session Name: ${$lq__event_session_obj.name}
- Session ID: ${$lq__event_session_obj.event_session_id_random}
+ Session Name: ${$lq__event_session_obj?.name}
+ Session ID: ${$lq__event_session_obj?.event_session_id_random}
Presentation Name: ${presentation_name}
Presentation ID: ${presentation_id}
Read and Consent Agreement?
@@ -784,11 +806,13 @@ function send_sign_in_poc_email({ $events_sess.pres_mgmt.show_content__presenter_start = event_presenter_obj.event_presenter_id_random; } } - class="btn btn-lg variant-ghost-primary text-lg font-bold min-w-56 hover:variant-filled-primary" + class="btn btn-md variant-ghost-primary hover:variant-filled-primary font-bold min-w-64" title="Person ID: {event_presenter_obj.person_id_random}; Email: {event_presenter_obj.email}" > - - {event_presenter_obj.full_name} + + + {event_presenter_obj.full_name} + @@ -947,10 +971,16 @@ function send_sign_in_poc_email({ class="space-y-2 px-4" > {#each $lq__event_file_obj_li as event_file_obj} - {#if (event_file_obj.event_presentation_id_random == event_presentation_obj.event_presentation_id_random && ($ae_loc.trusted_access || $events_loc.auth__kv.presentation[event_presentation_obj.event_presentation_id_random]))} + {#if ( + event_file_obj.event_presentation_id_random == event_presentation_obj.event_presentation_id_random + && ( + $ae_loc.trusted_access + || $events_loc.auth__kv.presentation[event_presentation_obj.event_presentation_id_random] + || $events_loc.auth__kv.session[$events_slct.event_session_id] // This is the session ID of the person who signed in. + ) + )}