aboutsummaryrefslogtreecommitdiff
path: root/static/icons/index.js
diff options
context:
space:
mode:
authorNathan Reiner <nathan@nathanreiner.xyz>2025-11-13 14:56:02 +0100
committerNathan Reiner <nathan@nathanreiner.xyz>2025-11-13 14:56:02 +0100
commitc7b02f02ad0a7e2888f2d7d3599719e59bbd1ee2 (patch)
tree9f782daf2e2ff78559958f15e0b9ffe5ece78334 /static/icons/index.js
parent7ee9d320e6ba9a84542d838892c43cf98b268552 (diff)
frontend: design prototype
Diffstat (limited to 'static/icons/index.js')
-rw-r--r--static/icons/index.js31
1 files changed, 31 insertions, 0 deletions
diff --git a/static/icons/index.js b/static/icons/index.js
new file mode 100644
index 0000000..08ab7ea
--- /dev/null
+++ b/static/icons/index.js
@@ -0,0 +1,31 @@
+import * as sfw from 'sfw';
+const { I } = sfw.element.native;
+
+const icons = [
+ 'settings',
+ 'shuffle',
+ 'calendar',
+ 'search',
+ 'close',
+ 'home',
+ 'add',
+ 'edit',
+ 'check',
+];
+
+const target = {
+ icons: await Promise.all(
+ icons.map(async v => [v, await import(`./${v}.js`)])
+ ).then(r => r.reduce((obj, [v, m]) => (obj[v] = m, obj), {})),
+};
+
+const handler = {
+ get(target, prop, receiver) {
+ return I.new({
+ innerHTML: target.icons[prop]?.default ?? '?',
+ className: 'icon',
+ });
+ }
+};
+
+export default new Proxy(target, handler);