feat: Upgrade to Astro with full PDPA compliance

PDPA Features:
 Cookie consent banner
 Consent logging API
 Admin dashboard
 Privacy Policy
 Terms & Conditions

Technical:
 Astro 5.x + Tailwind v4
 Docker on port 80
 SQLite database
 15 pages built

Ready for Easypanel deployment.
This commit is contained in:
Kunthawat
2026-03-12 10:01:04 +07:00
parent 668f69048f
commit 77ac4d2d05
13719 changed files with 307487 additions and 25765 deletions

80
node_modules/hast-util-from-html/lib/errors.d.ts generated vendored Normal file
View File

@@ -0,0 +1,80 @@
export namespace errors {
let abandonedHeadElementChild: ErrorInfo;
let abruptClosingOfEmptyComment: ErrorInfo;
let abruptDoctypePublicIdentifier: ErrorInfo;
let abruptDoctypeSystemIdentifier: ErrorInfo;
let absenceOfDigitsInNumericCharacterReference: ErrorInfo;
let cdataInHtmlContent: ErrorInfo;
let characterReferenceOutsideUnicodeRange: ErrorInfo;
let closingOfElementWithOpenChildElements: ErrorInfo;
let controlCharacterInInputStream: ErrorInfo;
let controlCharacterReference: ErrorInfo;
let disallowedContentInNoscriptInHead: ErrorInfo;
let duplicateAttribute: ErrorInfo;
let endTagWithAttributes: ErrorInfo;
let endTagWithTrailingSolidus: ErrorInfo;
let endTagWithoutMatchingOpenElement: ErrorInfo;
let eofBeforeTagName: ErrorInfo;
let eofInCdata: ErrorInfo;
let eofInComment: ErrorInfo;
let eofInDoctype: ErrorInfo;
let eofInElementThatCanContainOnlyText: ErrorInfo;
let eofInScriptHtmlCommentLikeText: ErrorInfo;
let eofInTag: ErrorInfo;
let incorrectlyClosedComment: ErrorInfo;
let incorrectlyOpenedComment: ErrorInfo;
let invalidCharacterSequenceAfterDoctypeName: ErrorInfo;
let invalidFirstCharacterOfTagName: ErrorInfo;
let misplacedDoctype: ErrorInfo;
let misplacedStartTagForHeadElement: ErrorInfo;
let missingAttributeValue: ErrorInfo;
let missingDoctype: ErrorInfo;
let missingDoctypeName: ErrorInfo;
let missingDoctypePublicIdentifier: ErrorInfo;
let missingDoctypeSystemIdentifier: ErrorInfo;
let missingEndTagName: ErrorInfo;
let missingQuoteBeforeDoctypePublicIdentifier: ErrorInfo;
let missingQuoteBeforeDoctypeSystemIdentifier: ErrorInfo;
let missingSemicolonAfterCharacterReference: ErrorInfo;
let missingWhitespaceAfterDoctypePublicKeyword: ErrorInfo;
let missingWhitespaceAfterDoctypeSystemKeyword: ErrorInfo;
let missingWhitespaceBeforeDoctypeName: ErrorInfo;
let missingWhitespaceBetweenAttributes: ErrorInfo;
let missingWhitespaceBetweenDoctypePublicAndSystemIdentifiers: ErrorInfo;
let nestedComment: ErrorInfo;
let nestedNoscriptInHead: ErrorInfo;
let nonConformingDoctype: ErrorInfo;
let nonVoidHtmlElementStartTagWithTrailingSolidus: ErrorInfo;
let noncharacterCharacterReference: ErrorInfo;
let noncharacterInInputStream: ErrorInfo;
let nullCharacterReference: ErrorInfo;
let openElementsLeftAfterEof: ErrorInfo;
let surrogateCharacterReference: ErrorInfo;
let surrogateInInputStream: ErrorInfo;
let unexpectedCharacterAfterDoctypeSystemIdentifier: ErrorInfo;
let unexpectedCharacterInAttributeName: ErrorInfo;
let unexpectedCharacterInUnquotedAttributeValue: ErrorInfo;
let unexpectedEqualsSignBeforeAttributeName: ErrorInfo;
let unexpectedNullCharacter: ErrorInfo;
let unexpectedQuestionMarkInsteadOfTagName: ErrorInfo;
let unexpectedSolidusInTag: ErrorInfo;
let unknownNamedCharacterReference: ErrorInfo;
}
/**
* Info on a `parse5` error.
*/
export type ErrorInfo = {
/**
* Reason of error.
*/
reason: string;
/**
* More info on error.
*/
description: string;
/**
* Turn off if this is not documented in the html5 spec (optional).
*/
url?: false;
};
//# sourceMappingURL=errors.d.ts.map