API bug fixes. Clean up. New util functions. Highlight times for newer files.
This commit is contained in:
@@ -5,24 +5,24 @@ import { get_object } from './api_get_object';
|
|||||||
export async function get_ae_obj_id_crud(
|
export async function get_ae_obj_id_crud(
|
||||||
{
|
{
|
||||||
api_cfg,
|
api_cfg,
|
||||||
no_account_id=false,
|
no_account_id = false,
|
||||||
obj_type,
|
obj_type,
|
||||||
obj_id,
|
obj_id,
|
||||||
use_alt_table=false,
|
use_alt_table = false,
|
||||||
use_alt_base=false,
|
use_alt_base = false,
|
||||||
inc={},
|
inc = {},
|
||||||
enabled='enabled',
|
enabled = 'enabled',
|
||||||
hidden='not_hidden',
|
hidden = 'not_hidden',
|
||||||
limit=999999,
|
limit = 999999,
|
||||||
offset=0,
|
offset = 0,
|
||||||
data={},
|
data = {},
|
||||||
// key,
|
// key,
|
||||||
// jwt=null,
|
// jwt = null,
|
||||||
headers={},
|
headers = {},
|
||||||
params={},
|
params = {},
|
||||||
timeout=25000,
|
timeout = 25000,
|
||||||
return_meta=false,
|
return_meta = false,
|
||||||
log_lvl=0
|
log_lvl = 0
|
||||||
}: {
|
}: {
|
||||||
api_cfg: any,
|
api_cfg: any,
|
||||||
no_account_id?: boolean,
|
no_account_id?: boolean,
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ export let patch_object = async function patch_object(
|
|||||||
log_lvl?: number
|
log_lvl?: number
|
||||||
}
|
}
|
||||||
) {
|
) {
|
||||||
console.log('*** patch_object() ***');
|
console.log('*** patch_object() XXXX ***');
|
||||||
|
|
||||||
if (log_lvl) {
|
if (log_lvl) {
|
||||||
// console.log(api_cfg);
|
// console.log(api_cfg);
|
||||||
|
|||||||
@@ -19,15 +19,15 @@ import {
|
|||||||
let ae_promises: key_val = {}; // Promise<any>;
|
let ae_promises: key_val = {}; // Promise<any>;
|
||||||
|
|
||||||
|
|
||||||
// Updated 2024-08-12
|
// Updated 2024-10-02
|
||||||
async function check_hosted_file_obj_w_hash(
|
async function check_hosted_file_obj_w_hash(
|
||||||
{
|
{
|
||||||
api_cfg,
|
api_cfg,
|
||||||
hosted_file_hash,
|
hosted_file_hash,
|
||||||
check_for_local=true,
|
check_for_local = true, // Forces a check on the host server for the file.
|
||||||
params={},
|
params = {},
|
||||||
return_meta=false,
|
return_meta = false,
|
||||||
log_lvl=0
|
log_lvl = 0
|
||||||
} : {
|
} : {
|
||||||
api_cfg: any,
|
api_cfg: any,
|
||||||
hosted_file_hash: string,
|
hosted_file_hash: string,
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
// Import external files first. Eventually this will be broken up in to smaller files.
|
// Import external files first. Eventually this will be broken up in to smaller files.
|
||||||
import { process_permission_checks } from './ae_utils__perm_checks';
|
import { process_permission_checks } from './ae_utils__perm_checks';
|
||||||
import { iso_datetime_formatter } from './ae_utils__datetime_format';
|
import { iso_datetime_formatter } from './ae_utils__datetime_format';
|
||||||
|
import { is_datetime_recent } from './ae_utils__is_datetime_recent';
|
||||||
|
import { format_bytes, guess_file_name, guess_file_extension, get_file_hash } from './ae_utils__files';
|
||||||
|
|
||||||
type key_str = {
|
type key_str = {
|
||||||
[key: string]: string;
|
[key: string]: string;
|
||||||
@@ -11,21 +12,6 @@ type key_val = {
|
|||||||
[key: string]: any;
|
[key: string]: any;
|
||||||
};
|
};
|
||||||
|
|
||||||
function format_bytes(
|
|
||||||
bytes: number,
|
|
||||||
decimals: number = 2
|
|
||||||
) {
|
|
||||||
if (bytes === 0) return '0 Bytes';
|
|
||||||
|
|
||||||
const k = 1024;
|
|
||||||
const dm = decimals < 0 ? 0 : decimals;
|
|
||||||
const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];
|
|
||||||
|
|
||||||
const i = Math.floor(Math.log(bytes) / Math.log(k));
|
|
||||||
|
|
||||||
return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + ' ' + sizes[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* This utility function will add commas to a number. */
|
/* This utility function will add commas to a number. */
|
||||||
function number_w_commas(x) {
|
function number_w_commas(x) {
|
||||||
@@ -33,63 +19,6 @@ function number_w_commas(x) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Updated 2024-08-12
|
|
||||||
function guess_file_name(filename_string: string) {
|
|
||||||
// console.log('*** guess_file_name() ***');
|
|
||||||
if (!filename_string) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (filename_string.includes('.')) {
|
|
||||||
let file_name = filename_string.substring(0, filename_string.lastIndexOf('.'));
|
|
||||||
// console.log(file_name);
|
|
||||||
return file_name;
|
|
||||||
} else {
|
|
||||||
return filename_string;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Updated 2024-08-12
|
|
||||||
function guess_file_extension(filename_string: string) {
|
|
||||||
// console.log('*** guess_file_extension() ***');
|
|
||||||
if (!filename_string) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!filename_string.includes('.')) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
let file_extension = filename_string.substring(filename_string.lastIndexOf('.') + 1, filename_string.length) || filename_string;
|
|
||||||
// console.log(file_extension);
|
|
||||||
return file_extension;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Updated 2024-08-12
|
|
||||||
async function get_file_hash(file) {
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
let file_reader = new FileReader();
|
|
||||||
|
|
||||||
file_reader.onload = async function() {
|
|
||||||
if (file_reader.result.byteLength !== file.size) {
|
|
||||||
console.log('File was not read completely');
|
|
||||||
reject("Error reading the file");
|
|
||||||
}
|
|
||||||
|
|
||||||
const hash_buffer = await crypto.subtle.digest('SHA-256', file_reader.result);
|
|
||||||
const hash_array = Array.from(new Uint8Array(hash_buffer));
|
|
||||||
const hash_hex = hash_array.map(b => b.toString(16).padStart(2, '0')).join('');
|
|
||||||
|
|
||||||
resolve(hash_hex);
|
|
||||||
};
|
|
||||||
|
|
||||||
file_reader.readAsArrayBuffer(file);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* This utility function looks for any form data with the prefixed name passed and returns a new object.
|
/* This utility function looks for any form data with the prefixed name passed and returns a new object.
|
||||||
* This function is used heavily! Be very careful making changes!!!
|
* This function is used heavily! Be very careful making changes!!!
|
||||||
* If rm_empty_id then it will remove/ignore fields matching. This helps with the API and new records/objects
|
* If rm_empty_id then it will remove/ignore fields matching. This helps with the API and new records/objects
|
||||||
@@ -777,8 +706,8 @@ function return_obj_type_path({obj_type=null, obj_type_prop_name=null}) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
export let ae_util = {
|
export let ae_util = {
|
||||||
|
is_datetime_recent: is_datetime_recent,
|
||||||
process_permission_checks: process_permission_checks,
|
process_permission_checks: process_permission_checks,
|
||||||
iso_datetime_formatter: iso_datetime_formatter,
|
iso_datetime_formatter: iso_datetime_formatter,
|
||||||
format_bytes: format_bytes,
|
format_bytes: format_bytes,
|
||||||
|
|||||||
72
src/lib/ae_utils/ae_utils__files.ts
Normal file
72
src/lib/ae_utils/ae_utils__files.ts
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
// These are all file related functions.
|
||||||
|
|
||||||
|
export let format_bytes = function format_bytes(
|
||||||
|
bytes: number,
|
||||||
|
decimals: number = 2
|
||||||
|
) {
|
||||||
|
if (bytes === 0) return '0 Bytes';
|
||||||
|
|
||||||
|
const k = 1024;
|
||||||
|
const dm = decimals < 0 ? 0 : decimals;
|
||||||
|
const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];
|
||||||
|
|
||||||
|
const i = Math.floor(Math.log(bytes) / Math.log(k));
|
||||||
|
|
||||||
|
return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + ' ' + sizes[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Updated 2024-08-12
|
||||||
|
export let guess_file_name = function guess_file_name(filename_string: string) {
|
||||||
|
// console.log('*** guess_file_name() ***');
|
||||||
|
if (!filename_string) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (filename_string.includes('.')) {
|
||||||
|
let file_name = filename_string.substring(0, filename_string.lastIndexOf('.'));
|
||||||
|
// console.log(file_name);
|
||||||
|
return file_name;
|
||||||
|
} else {
|
||||||
|
return filename_string;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Updated 2024-08-12
|
||||||
|
export let guess_file_extension = function guess_file_extension(filename_string: string) {
|
||||||
|
// console.log('*** guess_file_extension() ***');
|
||||||
|
if (!filename_string) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!filename_string.includes('.')) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
let file_extension = filename_string.substring(filename_string.lastIndexOf('.') + 1, filename_string.length) || filename_string;
|
||||||
|
// console.log(file_extension);
|
||||||
|
return file_extension;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Updated 2024-08-12
|
||||||
|
export let get_file_hash = async function get_file_hash(file) {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
let file_reader = new FileReader();
|
||||||
|
|
||||||
|
file_reader.onload = async function() {
|
||||||
|
if (file_reader.result.byteLength !== file.size) {
|
||||||
|
console.log('File was not read completely');
|
||||||
|
reject("Error reading the file");
|
||||||
|
}
|
||||||
|
|
||||||
|
const hash_buffer = await crypto.subtle.digest('SHA-256', file_reader.result);
|
||||||
|
const hash_array = Array.from(new Uint8Array(hash_buffer));
|
||||||
|
const hash_hex = hash_array.map(b => b.toString(16).padStart(2, '0')).join('');
|
||||||
|
|
||||||
|
resolve(hash_hex);
|
||||||
|
};
|
||||||
|
|
||||||
|
file_reader.readAsArrayBuffer(file);
|
||||||
|
});
|
||||||
|
}
|
||||||
23
src/lib/ae_utils/ae_utils__is_datetime_recent.ts
Normal file
23
src/lib/ae_utils/ae_utils__is_datetime_recent.ts
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
// Function to check if the file (or anything) timestamp was created within the last X minutes
|
||||||
|
export let is_datetime_recent = function is_datetime_recent(
|
||||||
|
{
|
||||||
|
datetime,
|
||||||
|
minutes
|
||||||
|
}: {
|
||||||
|
datetime: string,
|
||||||
|
minutes: number
|
||||||
|
}) {
|
||||||
|
console.log(`*** is_datetime_recent() *** datetime=${datetime} minutes=${minutes}`);
|
||||||
|
|
||||||
|
let now: any = new Date();
|
||||||
|
let then: any = new Date(datetime);
|
||||||
|
|
||||||
|
let diff = now - then;
|
||||||
|
let diff_minutes = Math.floor(diff / 60000);
|
||||||
|
|
||||||
|
if (diff_minutes < minutes) {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -342,9 +342,10 @@ export let update_ae_obj_id_crud = async function update_ae_obj_id_crud(
|
|||||||
|
|
||||||
if (!data) {
|
if (!data) {
|
||||||
data = {};
|
data = {};
|
||||||
data['super_key'] = key;
|
|
||||||
data['jwt'] = jwt;
|
|
||||||
}
|
}
|
||||||
|
data['super_key'] = key;
|
||||||
|
data['jwt'] = jwt;
|
||||||
|
|
||||||
// NOTE: The key and or JWT should be in the header of the DELETE, GET, PATCH, POST
|
// NOTE: The key and or JWT should be in the header of the DELETE, GET, PATCH, POST
|
||||||
|
|
||||||
// This obj_v_name is the view name to use when returning data. Do not prefix it with v_. This is checked and done automatically by the API.
|
// This obj_v_name is the view name to use when returning data. Do not prefix it with v_. This is checked and done automatically by the API.
|
||||||
|
|||||||
@@ -316,7 +316,7 @@ onMount(() => {
|
|||||||
api_cfg: $ae_api,
|
api_cfg: $ae_api,
|
||||||
event_file_id: event_file_obj.event_file_id_random,
|
event_file_id: event_file_obj.event_file_id_random,
|
||||||
data_kv: event_file_data,
|
data_kv: event_file_data,
|
||||||
log_lvl: 3
|
log_lvl: 0
|
||||||
})
|
})
|
||||||
.then (function (update_results) {
|
.then (function (update_results) {
|
||||||
console.log(`Update results:`, update_results);
|
console.log(`Update results:`, update_results);
|
||||||
@@ -517,7 +517,12 @@ onMount(() => {
|
|||||||
</span>
|
</span>
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
<span>
|
<!-- If this file was uploaded (created) within the last 15 minutes we want to highlight it in blue. -->
|
||||||
|
<span
|
||||||
|
class:bg-yellow-200={ae_util.is_datetime_recent({datetime: event_file_obj?.created_on, minutes: 30})}
|
||||||
|
class:bg-green-200={ae_util.is_datetime_recent({datetime: event_file_obj?.created_on, minutes: 240})}
|
||||||
|
class:bg-blue-200={ae_util.is_datetime_recent({datetime: event_file_obj?.created_on, minutes: 2880})}
|
||||||
|
>
|
||||||
{#if display_mode == 'default'}
|
{#if display_mode == 'default'}
|
||||||
<!-- <span class="fas fa-cloud-upload-alt mx-1"></span> -->
|
<!-- <span class="fas fa-cloud-upload-alt mx-1"></span> -->
|
||||||
<!-- Uploaded: -->
|
<!-- Uploaded: -->
|
||||||
|
|||||||
@@ -176,7 +176,10 @@ let lq_kv__event_file_obj_li = liveQuery(
|
|||||||
</button>
|
</button>
|
||||||
</td>
|
</td>
|
||||||
<td class="px-4 py-2">{ae_util.format_bytes(event_file_obj?.file_size)}</td>
|
<td class="px-4 py-2">{ae_util.format_bytes(event_file_obj?.file_size)}</td>
|
||||||
<td class="px-4 py-2">
|
<td
|
||||||
|
class="px-4 py-2"
|
||||||
|
|
||||||
|
>
|
||||||
<div>
|
<div>
|
||||||
<span>
|
<span>
|
||||||
{ae_util.iso_datetime_formatter(event_file_obj?.created_on, 'dddd')}
|
{ae_util.iso_datetime_formatter(event_file_obj?.created_on, 'dddd')}
|
||||||
@@ -185,7 +188,11 @@ let lq_kv__event_file_obj_li = liveQuery(
|
|||||||
{ae_util.iso_datetime_formatter(event_file_obj?.created_on, 'date_long_month_day')}
|
{ae_util.iso_datetime_formatter(event_file_obj?.created_on, 'date_long_month_day')}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<span>
|
<span
|
||||||
|
class:bg-yellow-200={ae_util.is_datetime_recent({datetime: event_file_obj?.created_on, minutes: 30})}
|
||||||
|
class:bg-green-200={ae_util.is_datetime_recent({datetime: event_file_obj?.created_on, minutes: 240})}
|
||||||
|
class:bg-blue-200={ae_util.is_datetime_recent({datetime: event_file_obj?.created_on, minutes: 2880})}
|
||||||
|
>
|
||||||
{ae_util.iso_datetime_formatter(event_file_obj?.created_on, 'time_12_short')}
|
{ae_util.iso_datetime_formatter(event_file_obj?.created_on, 'time_12_short')}
|
||||||
</span>
|
</span>
|
||||||
</td>
|
</td>
|
||||||
|
|||||||
Reference in New Issue
Block a user