@bbki.ng/bbblog 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,15 @@
1
+ declare const LOGO_SRC = "";
2
+ declare class BBPost extends HTMLElement {
3
+ constructor();
4
+ set title(v: string);
5
+ set content(v: string);
6
+ set date(v: string);
7
+ }
8
+ declare class BBBlog extends HTMLElement {
9
+ static get observedAttributes(): string[];
10
+ constructor();
11
+ connectedCallback(): void;
12
+ attributeChangedCallback(name: string, oldValue: string | null, newValue: string | null): void;
13
+ render(): void;
14
+ fetchPosts(): Promise<void>;
15
+ }
package/dist/index.js ADDED
@@ -0,0 +1 @@
1
+ "use strict";const LOGO_SRC="";class BBPost extends HTMLElement{constructor(){super(),this.attachShadow({mode:"open"}).innerHTML='\n <style>\n .post{margin-bottom: 100px}\n .post-title{font-size:1.2em}\n .post-content{margin-top:4px;color:#121111}\n .post-date{font-size:.8em;color:#999}\n a {color: #007fff; text-decoration: none;}\n </style>\n <div class="post">\n <div class="post-title"></div>\n <div class="post-date"></div>\n <div class="post-content"></div>\n </div>'}set title(M){this.shadowRoot.querySelector(".post-title").textContent=M}set content(M){this.shadowRoot.querySelector(".post-content").innerHTML=M}set date(M){this.shadowRoot.querySelector(".post-date").textContent=M}}class BBBlog extends HTMLElement{static get observedAttributes(){return["content"]}constructor(){super(),this.attachShadow({mode:"open"})}connectedCallback(){this.render(),this.fetchPosts()}attributeChangedCallback(M,t,e){"content"===M&&t!==e&&this.isConnected&&this.fetchPosts()}render(){this.shadowRoot.innerHTML=`\n <style>\n .posts-container {\n display: grid;\n grid-template-columns: 1fr min(45rem, 84%) 1fr;\n line-height: 1.65;\n }\n .posts-container > * {\n grid-column: 2;\n }\n .logo {\n display: block;\n width: 24px;\n margin: 100px 0;\n }\n @media (min-width: 768px) {\n .posts-container {\n grid-template-columns: 1fr min(45rem, 34%) 1fr;\n }\n }\n </style>\n <div class="posts-container">\n <img class="logo" src="${LOGO_SRC}" alt="logo">\n <div class="fallback" style="display:none;"><slot></slot></div>\n </div>\n `}async fetchPosts(){const M=this.getAttribute("content");if(!M)return;const t=this.shadowRoot.querySelector(".posts-container"),e=this.shadowRoot.querySelector(".fallback");try{const n=await fetch(M);if(!n.ok)throw new Error("Fetch failed");const o=await n.json();e&&(e.style.display="none"),o.forEach(M=>{const e=document.createElement("bb-post");e.title=M.title,e.content=M.content,t?.appendChild(e)})}catch(M){t&&(t.innerHTML=""),e&&(e.style.display="block")}}}customElements.define("bb-post",BBPost),customElements.define("bb-blog",BBBlog);
package/package.json ADDED
@@ -0,0 +1,25 @@
1
+ {
2
+ "name": "@bbki.ng/bbblog",
3
+ "version": "0.0.1",
4
+ "description": "bbblog",
5
+ "main": "dist/index.js",
6
+ "type": "module",
7
+ "types": "dist/index.d.ts",
8
+ "author": "bbbottle <b@bbki.ng>",
9
+ "license": "MIT",
10
+ "repository": {
11
+ "type": "git",
12
+ "url": "https://github.com/bbb0ttle/bbblog"
13
+ },
14
+ "scripts": {
15
+ "start": "tsc -w",
16
+ "prepare": "tsc -d && terser dist/index.js --compress --mangle -o dist/index.js"
17
+ },
18
+ "publishConfig": {
19
+ "access": "public"
20
+ },
21
+ "devDependencies": {
22
+ "terser": "^5.19.2",
23
+ "typescript": "^5.2.2"
24
+ }
25
+ }
package/src/index.ts ADDED
@@ -0,0 +1,103 @@
1
+ const LOGO_SRC = "";
2
+
3
+ class BBPost extends HTMLElement {
4
+ constructor() {
5
+ super();
6
+ this.attachShadow({mode:'open'}).innerHTML = `
7
+ <style>
8
+ .post{margin-bottom: 100px}
9
+ .post-title{font-size:1.2em}
10
+ .post-content{margin-top:4px;color:#121111}
11
+ .post-date{font-size:.8em;color:#999}
12
+ a {color: #007fff; text-decoration: none;}
13
+ </style>
14
+ <div class="post">
15
+ <div class="post-title"></div>
16
+ <div class="post-date"></div>
17
+ <div class="post-content"></div>
18
+ </div>`;
19
+ }
20
+ set title(v: string){this.shadowRoot!.querySelector('.post-title')!.textContent=v}
21
+ set content(v: string){this.shadowRoot!.querySelector('.post-content')!.innerHTML=v}
22
+ set date(v: string){this.shadowRoot!.querySelector('.post-date')!.textContent=v}
23
+ }
24
+
25
+ class BBBlog extends HTMLElement {
26
+ static get observedAttributes() {
27
+ return ['content'];
28
+ }
29
+
30
+ constructor() {
31
+ super();
32
+ this.attachShadow({mode: 'open'});
33
+ }
34
+
35
+ connectedCallback() {
36
+ this.render();
37
+ this.fetchPosts();
38
+ }
39
+
40
+ attributeChangedCallback(name: string, oldValue: string | null, newValue: string | null) {
41
+ if (name === 'content' && oldValue !== newValue && this.isConnected) {
42
+ this.fetchPosts();
43
+ }
44
+ }
45
+
46
+ render() {
47
+ this.shadowRoot!.innerHTML = `
48
+ <style>
49
+ .posts-container {
50
+ display: grid;
51
+ grid-template-columns: 1fr min(45rem, 84%) 1fr;
52
+ line-height: 1.65;
53
+ }
54
+ .posts-container > * {
55
+ grid-column: 2;
56
+ }
57
+ .logo {
58
+ display: block;
59
+ width: 24px;
60
+ margin: 100px 0;
61
+ }
62
+ @media (min-width: 768px) {
63
+ .posts-container {
64
+ grid-template-columns: 1fr min(45rem, 34%) 1fr;
65
+ }
66
+ }
67
+ </style>
68
+ <div class="posts-container">
69
+ <img class="logo" src="${LOGO_SRC}" alt="logo">
70
+ <div class="fallback" style="display:none;"><slot></slot></div>
71
+ </div>
72
+ `;
73
+ }
74
+
75
+ async fetchPosts() {
76
+ const contentPath = this.getAttribute('content');
77
+ if (!contentPath) return;
78
+
79
+ const container = this.shadowRoot!.querySelector('.posts-container');
80
+ const fallback = this.shadowRoot!.querySelector('.fallback') as HTMLElement | null;
81
+
82
+ try {
83
+ const response = await fetch(contentPath);
84
+ if (!response.ok) throw new Error('Fetch failed');
85
+
86
+ const data: Array<{title: string; content: string}> = await response.json();
87
+ if (fallback) fallback.style.display = 'none';
88
+
89
+ data.forEach(p => {
90
+ const el = document.createElement('bb-post') as BBPost;
91
+ el.title = p.title;
92
+ el.content = p.content;
93
+ container?.appendChild(el);
94
+ });
95
+ } catch (error) {
96
+ if (container) container.innerHTML = '';
97
+ if (fallback) fallback.style.display = 'block';
98
+ }
99
+ }
100
+ }
101
+
102
+ customElements.define('bb-post', BBPost);
103
+ customElements.define('bb-blog', BBBlog);
package/tsconfig.json ADDED
@@ -0,0 +1,12 @@
1
+ {
2
+ "compilerOptions": {
3
+ "outDir": "dist",
4
+ "target": "ES2020", /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */
5
+ "module": "ESNext", /* Specify what module code is generated. */
6
+ "esModuleInterop": true, /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables 'allowSyntheticDefaultImports' for type compatibility. */
7
+ "forceConsistentCasingInFileNames": true, /* Ensure that casing is correct in imports. */
8
+ "strict": true, /* Enable all strict type-checking options. */
9
+ "skipLibCheck": true, /* Skip type checking all .d.ts files. */
10
+ "lib": ["ESNext", "ESNext.Intl", "DOM", "DOM.Iterable"]
11
+ }
12
+ }