- Introduced new translations for terms of use in French and English locales. - Added sync status detection logic for books in `BookList` and `BookCard` components. - Refactored `BookCard` to handle additional props and improve layout flexibility. - Enhanced `TermsOfUse` component with complete localization support and refuse functionality. - Updated data decryption logic in Rust services to handle optional fields and additional metadata consistently. - Improved offline/online synchronization workflows with extended context properties.
36 lines
1.6 KiB
TypeScript
36 lines
1.6 KiB
TypeScript
import {isDesktop} from '@/lib/configs';
|
|
|
|
export function getCookie(name: string): string | null {
|
|
const nameEQ: string = `${name}=`;
|
|
const allCookies: string[] = document.cookie.split(';');
|
|
for (let i: number = 0; i < allCookies.length; i++) {
|
|
let cookie: string = allCookies[i];
|
|
while (cookie.charAt(0) === ' ') cookie = cookie.substring(1, cookie.length);
|
|
if (cookie.indexOf(nameEQ) === 0) return cookie.substring(nameEQ.length, cookie.length);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
export function setCookie(name: string, value: string, days: number): void {
|
|
const date: Date = new Date();
|
|
date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
|
|
const expires: string = `expires=${date.toUTCString()}`;
|
|
let domain: string = '';
|
|
if (!isDesktop && !/localhost|127\.0\.0\.1/.test(window.location.hostname)) {
|
|
domain = `domain=${window.location.hostname};`;
|
|
}
|
|
const secure: string = isDesktop ? '' : 'Secure;';
|
|
const sameSite: string = 'SameSite=Strict;';
|
|
document.cookie = `${name}=${value}; ${expires}; ${domain} path=/; ${secure} ${sameSite}`;
|
|
}
|
|
|
|
export function removeCookie(name: string): void {
|
|
let domain: string = '';
|
|
if (!isDesktop && !/localhost|127\.0\.0\.1/.test(window.location.hostname)) {
|
|
domain = `domain=${window.location.hostname};`;
|
|
}
|
|
const secure: string = isDesktop ? '' : 'Secure;';
|
|
const sameSite: string = 'SameSite=Strict;';
|
|
document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; ${domain} path=/; ${secure} ${sameSite}`;
|
|
}
|