perf(events): implement non-blocking SWR pattern and optimize library loaders

- Refactored 'event_session', 'event_presentation', 'event_file', 'event_location', and 'event_presenter' libraries to follow a Stale-While-Revalidate pattern.
- Implemented non-blocking background refreshes to allow instant UI rendering from IndexedDB cache.
- Parallelized nested collection loads (files, presentations) during background tasks to eliminate UI stalls.
- Standardized ID lookups using specific indices (event_location_id, event_id) for reliable local data retrieval.
- Resolved regression where aggressive ID overwriting caused relationship inconsistencies in background loads.
- Fixed reactive access to live queries in 'session_view.svelte' using proper Svelte 5 prefixing.
This commit is contained in:
Scott Idem
2026-01-30 16:04:28 -05:00
parent 3148375eb3
commit 66affb2a0f
8 changed files with 543 additions and 1832 deletions

View File

@@ -1038,7 +1038,7 @@
{/if}
<!-- Using the loading__session_id_status is kind of a hacky way to determine if the session is still loading or not. -->
{#if $events_slct.event_session_id && $lq__event_session_obj && !$events_sess.launcher.loading__session_id_status}
{#if $events_slct.event_session_id && $lq__event_session_obj}
<Launcher_session_view
bind:slct__event_session_id={$events_slct.event_session_id}
{lq__event_session_obj}

View File

@@ -60,7 +60,7 @@
slct__event_presentation_li: null
});
let hover_timer_wait = 2500;
let hover_timer_wait = 750;
let hover_timer: any = $state(null);
$effect(() => {

View File

@@ -85,23 +85,23 @@
// *** Functions and Logic
$events_sess.pres_mgmt.session__updated_on = null;
$effect(() => {
// && !$events_sess.pres_mgmt.session_qr_url[lq__event_session_obj?.event_session_id] === undefined
// && !$events_sess.pres_mgmt.session_qr_url[$lq__event_session_obj?.event_session_id] === undefined
if (
lq__event_session_obj &&
lq__event_session_obj?.event_session_id &&
$lq__event_session_obj &&
$lq__event_session_obj?.event_session_id &&
$events_loc.pres_mgmt.show_content__session_qr &&
!$events_sess.pres_mgmt.session_qr_url[lq__event_session_obj?.event_session_id]
!$events_sess.pres_mgmt.session_qr_url[$lq__event_session_obj?.event_session_id]
) {
if (log_lvl > 1) {
console.log(`$lq__event_session_obj:`, lq__event_session_obj);
console.log(`$lq__event_session_obj:`, $lq__event_session_obj);
}
$events_sess.pres_mgmt.session_qr_url[lq__event_session_obj?.event_session_id] = true;
$events_sess.pres_mgmt.session_qr_url[$lq__event_session_obj?.event_session_id] = true;
// session_qr_url is a key value of session_id and URL string
// $events_sess.pres_mgmt.session_qr_url[lq__event_session_obj?.event_session_id] = null;
// $events_sess.pres_mgmt.session_qr_url[$lq__event_session_obj?.event_session_id] = null;
if (lq__event_session_obj.updated_on == $events_sess.pres_mgmt.session__updated_on) {
if ($lq__event_session_obj.updated_on == $events_sess.pres_mgmt.session__updated_on) {
if (log_lvl > 1) {
console.log('Updated on is the same.');
}
@@ -110,13 +110,13 @@
console.log('Updated on is different.');
}
// FUTURE USE: Generate a QR code for the object ID.
// ae_promises.generate_qr_code_obj_id = core_func.generate_qr_code({api_cfg: $ae_api, account_id: $slct.account_id, qr_type: 'obj', qr_id: lq__event_session_obj?.event_session_id, obj_type: 'event_session', obj_id: lq__event_session_obj?.event_session_id});
// ae_promises.generate_qr_code_obj_id = core_func.generate_qr_code({api_cfg: $ae_api, account_id: $slct.account_id, qr_type: 'obj', qr_id: $lq__event_session_obj?.event_session_id, obj_type: 'event_session', obj_id: $lq__event_session_obj?.event_session_id});
// Generate a QR code for the URL.
let qr_id_url = `${lq__event_session_obj?.event_session_id}_url`;
let qr_id_url = `${$lq__event_session_obj?.event_session_id}_url`;
// URL for this page (be sure to URL encode it):
let url_str = `${$ae_loc.url_origin}/events/${lq__event_session_obj?.event_id}/session/${lq__event_session_obj?.event_session_id}`;
let url_str = `${$ae_loc.url_origin}/events/${$lq__event_session_obj?.event_id}/session/${$lq__event_session_obj?.event_session_id}`;
url_str = encodeURI(url_str);
ae_promises.generate_qr_code_url = core_func
@@ -134,13 +134,13 @@
}
// Store the URL string in the key value for use in the QR code image src.
$events_sess.pres_mgmt.session_qr_url[
lq__event_session_obj?.event_session_id
$lq__event_session_obj?.event_session_id
] = result;
return result;
});
// console.log(`ae_promises.generate_qr_code_url = `, ae_promises.generate_qr_code_url);
$events_sess.pres_mgmt.session__updated_on = lq__event_session_obj?.updated_on;
$events_sess.pres_mgmt.session__updated_on = $lq__event_session_obj?.updated_on;
}
} else {
// if (log_lvl) {
@@ -157,18 +157,18 @@
{#if $lq__event_session_obj}
<section class="p-2">
<!-- {#if $events_sess.pres_mgmt.session_qr_url[lq__event_session_obj?.event_session_id] && $events_sess.pres_mgmt.session_qr_url[lq__event_session_obj?.event_session_id].length > 10}
<!-- {#if $events_sess.pres_mgmt.session_qr_url[$lq__event_session_obj?.event_session_id] && $events_sess.pres_mgmt.session_qr_url[$lq__event_session_obj?.event_session_id].length > 10}
<img
class="qr_code qr_type_url h-32 w-32 hover:h-48 hover:w-48 outline"
style=""
src={$events_sess.pres_mgmt.session_qr_url[lq__event_session_obj?.event_session_id]}
src={$events_sess.pres_mgmt.session_qr_url[$lq__event_session_obj?.event_session_id]}
alt="URL QR code"
/>
{:else}
No QR URL yet
{/if} -->
{#if $events_sess.pres_mgmt.session_qr_url[lq__event_session_obj?.event_session_id]}
{#if $events_sess.pres_mgmt.session_qr_url[$lq__event_session_obj?.event_session_id]}
<div
class="
float-right m-1 p-1
@@ -178,12 +178,12 @@
group
"
>
{#if $events_sess.pres_mgmt.session_qr_url[lq__event_session_obj?.event_session_id]}
{#if $events_sess.pres_mgmt.session_qr_url[$lq__event_session_obj?.event_session_id]}
<!-- svelte-ignore a11y_click_events_have_key_events -->
<!-- svelte-ignore a11y_no_noninteractive_element_interactions -->
<img
src={$events_sess.pres_mgmt.session_qr_url[
lq__event_session_obj?.event_session_id
$lq__event_session_obj?.event_session_id
]}
onclick={() => {
$events_sess.pres_mgmt.qr_bigger = !$events_sess.pres_mgmt.qr_bigger;
@@ -204,7 +204,7 @@
{/if}
<MyClipboard
value={encodeURI(
`${$ae_loc.url_origin}/events/${lq__event_session_obj?.event_id}/session/${lq__event_session_obj?.event_session_id}`
`${$ae_loc.url_origin}/events/${$lq__event_session_obj?.event_id}/session/${$lq__event_session_obj?.event_session_id}`
)}
btn_text="Copy URL"
btn_title="Copy the session URL to your clipboard"
@@ -228,10 +228,10 @@
<Element_ae_crud
api_cfg={$ae_api}
object_type={'event_session'}
object_id={lq__event_session_obj?.event_session_id}
object_id={$lq__event_session_obj?.event_session_id}
field_name={'name'}
field_type={'text'}
field_value={lq__event_session_obj?.name}
field_value={$lq__event_session_obj?.name}
allow_null={false}
hide_edit_btn={!$ae_loc.trusted_access || !$ae_loc.edit_mode}
outline_element={false}
@@ -245,7 +245,7 @@
events_func
.load_ae_obj_id__event_session({
api_cfg: $ae_api,
event_session_id: lq__event_session_obj?.event_session_id,
event_session_id: $lq__event_session_obj?.event_session_id,
log_lvl: 1
})
.then(function (load_results) {});
@@ -253,7 +253,7 @@
>
<span class="text-sm text-semibold text-surface-600-400">Name/title:</span>
<span class="font-semibold">
{lq__event_session_obj.name}
{$lq__event_session_obj.name}
</span>
</Element_ae_crud>
{/if}
@@ -262,10 +262,10 @@
<Element_ae_crud
api_cfg={$ae_api}
object_type={'event_session'}
object_id={lq__event_session_obj?.event_session_id}
object_id={$lq__event_session_obj?.event_session_id}
field_name={'code'}
field_type={'text'}
field_value={lq__event_session_obj?.code}
field_value={$lq__event_session_obj?.code}
allow_null={false}
hide_edit_btn={!$ae_loc.trusted_access || !$ae_loc.edit_mode}
outline_element={false}
@@ -279,7 +279,7 @@
events_func
.load_ae_obj_id__event_session({
api_cfg: $ae_api,
event_session_id: lq__event_session_obj?.event_session_id,
event_session_id: $lq__event_session_obj?.event_session_id,
log_lvl: 1
})
.then(function (load_results) {});
@@ -292,11 +292,11 @@
border border-yellow-200 dark:border-yellow-800
p-1 rounded-md
"
title="Session code {lq__event_session_obj.code}"
title="Session code {$lq__event_session_obj.code}"
>
<span class="text-sm text-semibold text-surface-600-400">code:</span>
<span class="fas fa-barcode text-surface-600-400"></span>
{lq__event_session_obj.code}
{$lq__event_session_obj.code}
</span>
</Element_ae_crud>
{/if}
@@ -326,10 +326,10 @@
<Element_ae_crud
api_cfg={$ae_api}
object_type={'event_session'}
object_id={lq__event_session_obj?.event_session_id}
object_id={$lq__event_session_obj?.event_session_id}
field_name={'start_datetime'}
field_type={'datetime'}
field_value={lq__event_session_obj.start_datetime}
field_value={$lq__event_session_obj.start_datetime}
allow_null={false}
hide_edit_btn={!$ae_loc.trusted_access || !$ae_loc.edit_mode}
outline_element={false}
@@ -341,15 +341,15 @@
events_func.load_ae_obj_id__event_session({
api_cfg: $ae_api,
event_session_id: lq__event_session_obj?.event_session_id
event_session_id: $lq__event_session_obj?.event_session_id
});
// $events_trigger = 'load__event_session_obj_id';
// $events_trig_kv['event_session_id'] = lq__event_session_obj?.event_session_id;
// $events_trig_kv['event_session_id'] = $lq__event_session_obj?.event_session_id;
}}
>
{ae_util.iso_datetime_formatter(lq__event_session_obj.start_datetime, 'dddd')},
{ae_util.iso_datetime_formatter($lq__event_session_obj.start_datetime, 'dddd')},
{ae_util.iso_datetime_formatter(
lq__event_session_obj.start_datetime,
$lq__event_session_obj.start_datetime,
$events_loc.pres_mgmt.datetime_format
)}
</Element_ae_crud>
@@ -357,10 +357,10 @@
<Element_ae_crud
api_cfg={$ae_api}
object_type={'event_session'}
object_id={lq__event_session_obj?.event_session_id}
object_id={$lq__event_session_obj?.event_session_id}
field_name={'end_datetime'}
field_type={'datetime'}
field_value={lq__event_session_obj.end_datetime}
field_value={$lq__event_session_obj.end_datetime}
allow_null={false}
hide_edit_btn={!$ae_loc.trusted_access || !$ae_loc.edit_mode}
outline_element={false}
@@ -372,14 +372,14 @@
events_func.load_ae_obj_id__event_session({
api_cfg: $ae_api,
event_session_id: lq__event_session_obj?.event_session_id
event_session_id: $lq__event_session_obj?.event_session_id
});
// $events_trigger = 'load__event_session_obj_id';
// $events_trig_kv['event_session_id'] = lq__event_session_obj?.event_session_id;
// $events_trig_kv['event_session_id'] = $lq__event_session_obj?.event_session_id;
}}
>
{ae_util.iso_datetime_formatter(
lq__event_session_obj.end_datetime,
$lq__event_session_obj.end_datetime,
$events_loc.pres_mgmt.time_format
)}
</Element_ae_crud>
@@ -390,22 +390,22 @@
{#if $events_loc.pres_mgmt?.hide__launcher_link_legacy && $events_loc.pres_mgmt?.hide__launcher_link && !$ae_loc.edit_mode}
<span>
{lq__event_session_obj?.event_location_name ?? '-- not set --'}
{$lq__event_session_obj?.event_location_name ?? '-- not set --'}
</span>
{/if}
<!-- Legacy link (Flask) -->
<a
data-sveltekit-preload-data="false"
href="/event/{lq__event_session_obj?.event_id}/launcher/{lq__event_session_obj?.event_location_id}"
href="/event/{$lq__event_session_obj?.event_id}/launcher/{$lq__event_session_obj?.event_location_id}"
class:hidden={$events_loc.pres_mgmt?.hide__launcher_link_legacy &&
!($ae_loc.trusted_access && $ae_loc.edit_mode)}
class="btn btn-sm preset-tonal-secondary hover:preset-filled-secondary-500 transition-all"
title={`Legacy Launcher (Flask): ${lq__event_session_obj?.event_location_name}\n${lq__event_session_obj?.event_location_id}`}
title={`Legacy Launcher (Flask): ${$lq__event_session_obj?.event_location_name}\n${$lq__event_session_obj?.event_location_id}`}
>
<span class="fas fa-paper-plane m-1"></span>
{@html lq__event_session_obj?.event_location_name
? lq__event_session_obj?.event_location_name
{@html $lq__event_session_obj?.event_location_name
? $lq__event_session_obj?.event_location_name
: ae_snip.html__not_set}
</a>
@@ -413,32 +413,32 @@
<a
data-sveltekit-preload-data="false"
data-sveltekit-reload="true"
href="/events/{lq__event_session_obj?.event_id}/launcher/{lq__event_session_obj?.event_location_id}?session_id={lq__event_session_obj?.event_session_id}"
href="/events/{$lq__event_session_obj?.event_id}/launcher/{$lq__event_session_obj?.event_location_id}?session_id={$lq__event_session_obj?.event_session_id}"
class:hidden={$events_loc.pres_mgmt?.hide__launcher_link &&
!($ae_loc.trusted_access && $ae_loc.edit_mode)}
class="btn btn-sm preset-tonal-tertiary hover:preset-filled-secondary-500 group transition-all"
title={`Launcher (Svelte): ${lq__event_session_obj?.event_location_name}\n${lq__event_session_obj?.event_location_id}`}
title={`Launcher (Svelte): ${$lq__event_session_obj?.event_location_name}\n${$lq__event_session_obj?.event_location_id}`}
>
<span class="fas fa-plane"></span>
<span class="hidden group-hover:inline">
{@html lq__event_session_obj.event_location_name
? lq__event_session_obj.event_location_name
{@html $lq__event_session_obj.event_location_name
? $lq__event_session_obj.event_location_name
: ae_snip.html__not_set}
</span>
</a>
<!-- Location details link -->
<a
href="/events/{lq__event_session_obj?.event_id}/location/{lq__event_session_obj?.event_location_id}"
href="/events/{$lq__event_session_obj?.event_id}/location/{$lq__event_session_obj?.event_location_id}"
class:hidden={$events_loc.pres_mgmt?.hide__location_link &&
!($ae_loc.trusted_access && $ae_loc.edit_mode)}
class="btn btn-sm preset-tonal-surface hover:preset-filled-tertiary-500 group transition-all"
title={`Location Details: ${lq__event_session_obj?.event_location_name}\n${lq__event_session_obj?.event_location_id}`}
title={`Location Details: ${$lq__event_session_obj?.event_location_name}\n${$lq__event_session_obj?.event_location_id}`}
>
<span class="fas fa-map-marker-alt m-1"></span>
<span class="hidden group-hover:inline">
{@html lq__event_session_obj?.event_location_name
? lq__event_session_obj?.event_location_name
{@html $lq__event_session_obj?.event_location_name
? $lq__event_session_obj?.event_location_name
: ae_snip.html__not_set}
</span>
</a>
@@ -448,7 +448,7 @@
trigger_patch={ae_triggers.update_event_location}
api_cfg={$ae_api}
object_type={'event_session'}
object_id={lq__event_session_obj?.event_session_id}
object_id={$lq__event_session_obj?.event_session_id}
field_name={'event_location_id_random'}
field_type={'select'}
field_value={ae_tmp.event_location_id_random}
@@ -466,7 +466,7 @@
events_func
.load_ae_obj_id__event_session({
api_cfg: $ae_api,
event_session_id: lq__event_session_obj?.event_session_id,
event_session_id: $lq__event_session_obj?.event_session_id,
log_lvl: 1
})
.then(function (load_results) {
@@ -513,7 +513,7 @@
.load_ae_obj_li__event_location({
api_cfg: $ae_api,
for_obj_type: 'event',
for_obj_id: lq__event_session_obj?.event_id,
for_obj_id: $lq__event_session_obj?.event_id,
params: params,
log_lvl: log_lvl
})
@@ -550,7 +550,7 @@
.finally(function () {
console.log(`Finally...`);
ae_tmp.event_location_id =
lq__event_session_obj?.event_location_id;
$lq__event_session_obj?.event_location_id;
ae_tmp.show__edit_event_location = true;
});
}}
@@ -567,20 +567,20 @@
<span class="text-sm text-semibold text-surface-600-400">
{$events_loc.pres_mgmt?.label__session_poc_name}:
</span>
{#if lq__event_session_obj?.poc_person_id}
{#if $lq__event_session_obj?.poc_person_id}
{#if $ae_loc.manager_access}
<a
href="/core/person/{lq__event_session_obj.poc_person_id}"
href="/core/person/{$lq__event_session_obj.poc_person_id}"
class="text-blue-500 hover:text-blue-800 hover:underline"
title="View Person: {lq__event_session_obj?.poc_person_full_name} {lq__event_session_obj?.poc_person_id}"
title="View Person: {$lq__event_session_obj?.poc_person_full_name} {$lq__event_session_obj?.poc_person_id}"
>
{@html lq__event_session_obj?.poc_person_full_name
? lq__event_session_obj.poc_person_full_name
{@html $lq__event_session_obj?.poc_person_full_name
? $lq__event_session_obj.poc_person_full_name
: ae_snip.html__not_set}
</a>
{/if}
{#if $ae_loc.trusted_access || $events_loc.auth__kv.session[lq__event_session_obj?.event_session_id] === true}
{#if $ae_loc.trusted_access || $events_loc.auth__kv.session[$lq__event_session_obj?.event_session_id] === true}
<!-- Modal toggle -->
<button
class="btn btn-sm preset-tonal-primary hover:preset-filled-primary-500"
@@ -589,7 +589,7 @@
>
<span class="fas fa-id-card m-1"></span>
<!-- {$events_loc.pres_mgmt?.label__session_poc_name}'s -->
{lq__event_session_obj?.poc_person_full_name}'s Profile
{$lq__event_session_obj?.poc_person_full_name}'s Profile
</button>
<!-- Main modal -->
@@ -604,7 +604,7 @@
class_li={$events_sess.pres_mgmt.show__session_poc_profile
? ''
: ''}
{lq__event_session_obj}
{$lq__event_session_obj}
/>
{#snippet footer()}
@@ -631,15 +631,15 @@
type="button"
disabled={!$ae_loc.trusted_access &&
!$events_loc.auth__kv.session[
lq__event_session_obj?.event_session_id
$lq__event_session_obj?.event_session_id
] === true}
class="btn btn-sm hover:preset-filled-success-500"
class:preset-tonal-success={lq__event_session_obj?.poc_agree}
class:preset-tonal-warning={!lq__event_session_obj?.poc_agree}
class:preset-tonal-success={$lq__event_session_obj?.poc_agree}
class:preset-tonal-warning={!$lq__event_session_obj?.poc_agree}
onclick={() =>
($events_sess.pres_mgmt.show_modal__session_poc_agree = true)}
>
{#if !lq__event_session_obj?.poc_agree}
{#if !$lq__event_session_obj?.poc_agree}
<span
class="fas fa-times bg-red-500 text-white px-1 mx-1"
title="Not agreed to terms and conditions"
@@ -663,7 +663,7 @@
placement="top-center"
class="bg-white dark:bg-gray-800 text-gray-800 dark:text-gray-200 rounded-lg border-gray-200 dark:border-gray-700 divide-gray-200 dark:divide-gray-700 shadow-md relative flex flex-col mx-auto w-full divide-y"
>
<Comp_event_session_poc_form_agree {lq__event_session_obj} />
<Comp_event_session_poc_form_agree {$lq__event_session_obj} />
{#snippet footer()}
<div class="text-center w-full">
@@ -683,9 +683,9 @@
<!-- </div> -->
{:else}
<span title={lq__event_session_obj?.poc_person_id}>
{@html lq__event_session_obj.poc_person_full_name
? lq__event_session_obj.poc_person_full_name
<span title={$lq__event_session_obj?.poc_person_id}>
{@html $lq__event_session_obj.poc_person_full_name
? $lq__event_session_obj.poc_person_full_name
: ae_snip.html__not_set}
</span>
{/if}
@@ -695,8 +695,8 @@
<!-- {#if $ae_loc.trusted_access && $ae_loc.edit_mode} -->
<!-- <span title={lq__event_session_obj?.poc_person_id}>
{@html lq__event_session_obj.poc_person_full_name ? lq__event_session_obj.poc_person_full_name : ae_snip.html__not_set}
<!-- <span title={$lq__event_session_obj?.poc_person_id}>
{@html $lq__event_session_obj.poc_person_full_name ? $lq__event_session_obj.poc_person_full_name : ae_snip.html__not_set}
</span> -->
{#if $ae_loc.trusted_access && $ae_loc.edit_mode}
@@ -704,10 +704,10 @@
trigger_patch={ae_triggers.update_person_poc}
api_cfg={$ae_api}
object_type={'event_session'}
object_id={lq__event_session_obj?.event_session_id}
object_id={$lq__event_session_obj?.event_session_id}
field_name={'poc_person_id_random'}
field_type={'select'}
field_value={lq__event_session_obj?.poc_person_id}
field_value={$lq__event_session_obj?.poc_person_id}
select_option_li={$slct.person_obj_kv}
allow_null={$ae_loc.administrator_access}
hide_edit_btn={true}
@@ -721,7 +721,7 @@
events_func
.load_ae_obj_id__event_session({
api_cfg: $ae_api,
event_session_id: lq__event_session_obj?.event_session_id,
event_session_id: $lq__event_session_obj?.event_session_id,
log_lvl: 0
})
.then(function (load_results) {
@@ -805,7 +805,7 @@
return load_results;
});
ae_tmp.poc_person_id = lq__event_session_obj?.poc_person_id;
ae_tmp.poc_person_id = $lq__event_session_obj?.poc_person_id;
ae_tmp.show__edit_poc_person = true;
}}
class="btn btn-sm preset-tonal-warning group"
@@ -821,12 +821,12 @@
{#if $events_loc.auth__kv.session[$events_slct.event_session_id] === true}
<span class="text-green-500">Signed In</span>
{/if}
{#if $events_loc.pres_mgmt?.require__session_agree && $events_loc?.pres_mgmt?.show__email_access_link && lq__event_session_obj?.poc_person_primary_email && ($ae_loc.trusted_access || !$events_loc.auth__kv.session[lq__event_session_obj?.event_session_id])}
{#if $events_loc.pres_mgmt?.require__session_agree && $events_loc?.pres_mgmt?.show__email_access_link && $lq__event_session_obj?.poc_person_primary_email && ($ae_loc.trusted_access || !$events_loc.auth__kv.session[$lq__event_session_obj?.event_session_id])}
<button
type="button"
onclick={() => {
console.log('Email the access link');
if (!lq__event_session_obj.poc_person_primary_email) {
if (!$lq__event_session_obj.poc_person_primary_email) {
alert(
'No email address found for this point of contact (moderator/champion).'
);
@@ -834,7 +834,7 @@
}
if (
confirm(
`This will send the sign in email to ${lq__event_session_obj.poc_person_primary_email}`
`This will send the sign in email to ${$lq__event_session_obj.poc_person_primary_email}`
)
) {
console.log(
@@ -847,18 +847,18 @@
events_func.email_sign_in__event_session({
api_cfg: $ae_api,
to_email: lq__event_session_obj.poc_person_primary_email,
to_email: $lq__event_session_obj.poc_person_primary_email,
to_name:
lq__event_session_obj?.poc_person_full_name ??
$lq__event_session_obj?.poc_person_full_name ??
'-- not set --',
base_url: $ae_loc.url_origin,
person_id: lq__event_session_obj?.poc_person_id,
person_id: $lq__event_session_obj?.poc_person_id,
person_passcode:
lq__event_session_obj?.poc_person_passcode ??
$lq__event_session_obj?.poc_person_passcode ??
'-- not set --',
event_id: lq__event_session_obj?.event_id,
event_session_id: lq__event_session_obj?.event_session_id,
session_name: lq__event_session_obj?.name ?? '-- not set --'
event_id: $lq__event_session_obj?.event_id,
event_session_id: $lq__event_session_obj?.event_session_id,
session_name: $lq__event_session_obj?.name ?? '-- not set --'
});
}}
class="btn btn-sm preset-tonal-secondary border border-secondary-500 hover:preset-filled-secondary-500"
@@ -869,13 +869,13 @@
</button>
{/if}
{#if $events_loc.pres_mgmt?.show__copy_access_link && $ae_loc.trusted_access && lq__event_session_obj.poc_person_id}
{#if $events_loc.pres_mgmt?.show__copy_access_link && $ae_loc.trusted_access && $lq__event_session_obj.poc_person_id}
<!-- A button to copy the access link to the clipboard. -->
<!-- Example: /events/CHs3F44Xq76/session/Wh8UnJlbIA0?person_id=fV1dl_IJ0yY&person_pass=abc123 -->
<MyClipboard
value={encodeURI(
`${$ae_loc.url_origin}/events/${lq__event_session_obj.event_id}/session/${$events_slct.event_session_id}?person_id=${lq__event_session_obj.poc_person_id}&person_pass=${lq__event_session_obj.poc_person_passcode}&session_id=${lq__event_session_obj.event_session_id}`
`${$ae_loc.url_origin}/events/${$lq__event_session_obj.event_id}/session/${$events_slct.event_session_id}?person_id=${$lq__event_session_obj.poc_person_id}&person_pass=${$lq__event_session_obj.poc_person_passcode}&session_id=${$lq__event_session_obj.event_session_id}`
)}
btn_text="Copy Access Link"
btn_title="Copy the POC (moderator/champion) access link to the clipboard."
@@ -891,16 +891,16 @@
Session passcode:
</span>
<span class="fas fa-key text-surface-600-400"></span>
{@html lq__event_session_obj.passcode
? lq__event_session_obj.passcode
{@html $lq__event_session_obj.passcode
? $lq__event_session_obj.passcode
: ae_snip.html__not_set}
<Element_ae_crud
api_cfg={$ae_api}
object_type={'event_session'}
object_id={lq__event_session_obj?.event_session_id}
object_id={$lq__event_session_obj?.event_session_id}
field_name={'passcode'}
field_type={'text'}
field_value={lq__event_session_obj?.passcode}
field_value={$lq__event_session_obj?.passcode}
allow_null={true}
hide_edit_btn={!$ae_loc.trusted_access || !$ae_loc.edit_mode}
outline_element={false}
@@ -914,7 +914,7 @@
events_func
.load_ae_obj_id__event_session({
api_cfg: $ae_api,
event_session_id: lq__event_session_obj?.event_session_id,
event_session_id: $lq__event_session_obj?.event_session_id,
log_lvl: 1
})
.then(function (load_results) {});
@@ -928,10 +928,10 @@
<Element_ae_crud
api_cfg={$ae_api}
object_type={'event_session'}
object_id={lq__event_session_obj?.event_session_id}
object_id={$lq__event_session_obj?.event_session_id}
field_name={'description'}
field_type={'textarea'}
field_value={lq__event_session_obj.description}
field_value={$lq__event_session_obj.description}
allow_null={false}
hide_edit_btn={!$ae_loc.trusted_access || !$ae_loc.edit_mode}
outline_element={false}
@@ -945,7 +945,7 @@
events_func.load_ae_obj_id__event_session({
api_cfg: $ae_api,
event_session_id: lq__event_session_obj?.event_session_id,
event_session_id: $lq__event_session_obj?.event_session_id,
log_lvl: 1
});
}}
@@ -954,7 +954,7 @@
Session description:
</span>
{#if lq__event_session_obj.description}
{#if $lq__event_session_obj.description}
<button
type="button"
onclick={() => {
@@ -976,7 +976,7 @@
<pre
class="whitespace-pre-wrap p-2 bg-gray-100 dark:bg-gray-700 rounded-md"
class:hidden={!$events_loc.pres_mgmt
.show_content__session_description}>{lq__event_session_obj.description}</pre>
.show_content__session_description}>{$lq__event_session_obj.description}</pre>
{:else}
{@html ae_snip.html__not_set}
{/if}