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

106
node_modules/drizzle-orm/sqlite-core/view.js generated vendored Normal file
View File

@@ -0,0 +1,106 @@
import { entityKind } from "../entity.js";
import { SelectionProxyHandler } from "../selection-proxy.js";
import { getTableColumns } from "../utils.js";
import { QueryBuilder } from "./query-builders/query-builder.js";
import { sqliteTable } from "./table.js";
import { SQLiteViewBase } from "./view-base.js";
class ViewBuilderCore {
constructor(name) {
this.name = name;
}
static [entityKind] = "SQLiteViewBuilderCore";
config = {};
}
class ViewBuilder extends ViewBuilderCore {
static [entityKind] = "SQLiteViewBuilder";
as(qb) {
if (typeof qb === "function") {
qb = qb(new QueryBuilder());
}
const selectionProxy = new SelectionProxyHandler({
alias: this.name,
sqlBehavior: "error",
sqlAliasedBehavior: "alias",
replaceOriginalName: true
});
const aliasedSelectedFields = qb.getSelectedFields();
return new Proxy(
new SQLiteView({
// sqliteConfig: this.config,
config: {
name: this.name,
schema: void 0,
selectedFields: aliasedSelectedFields,
query: qb.getSQL().inlineParams()
}
}),
selectionProxy
);
}
}
class ManualViewBuilder extends ViewBuilderCore {
static [entityKind] = "SQLiteManualViewBuilder";
columns;
constructor(name, columns) {
super(name);
this.columns = getTableColumns(sqliteTable(name, columns));
}
existing() {
return new Proxy(
new SQLiteView({
config: {
name: this.name,
schema: void 0,
selectedFields: this.columns,
query: void 0
}
}),
new SelectionProxyHandler({
alias: this.name,
sqlBehavior: "error",
sqlAliasedBehavior: "alias",
replaceOriginalName: true
})
);
}
as(query) {
return new Proxy(
new SQLiteView({
config: {
name: this.name,
schema: void 0,
selectedFields: this.columns,
query: query.inlineParams()
}
}),
new SelectionProxyHandler({
alias: this.name,
sqlBehavior: "error",
sqlAliasedBehavior: "alias",
replaceOriginalName: true
})
);
}
}
class SQLiteView extends SQLiteViewBase {
static [entityKind] = "SQLiteView";
constructor({ config }) {
super(config);
}
}
function sqliteView(name, selection) {
if (selection) {
return new ManualViewBuilder(name, selection);
}
return new ViewBuilder(name);
}
const view = sqliteView;
export {
ManualViewBuilder,
SQLiteView,
ViewBuilder,
ViewBuilderCore,
sqliteView,
view
};
//# sourceMappingURL=view.js.map