@htmlbricks/hb-footer 0.68.5 → 0.68.7
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.
- package/main.iife.js +1 -1
- package/main.iife.js.map +1 -1
- package/manifest.json +2 -2
- package/package.json +1 -1
- package/types/html-elements.d.ts +14 -1
- package/types/svelte-elements.d.ts +19 -3
package/manifest.json
CHANGED
|
@@ -702,7 +702,7 @@
|
|
|
702
702
|
}
|
|
703
703
|
}
|
|
704
704
|
],
|
|
705
|
-
"iifeIntegrity": "sha384-
|
|
705
|
+
"iifeIntegrity": "sha384-CL+sdjv8TAtKVIUhIxsACMopPmjIgQO/sku6mfTLf/l2z/f2HmHAls2pQuMhJfwg",
|
|
706
706
|
"dependencies": [
|
|
707
707
|
{
|
|
708
708
|
"name": "hb-contact-item",
|
|
@@ -730,5 +730,5 @@
|
|
|
730
730
|
},
|
|
731
731
|
"iifePath": "main.iife.js",
|
|
732
732
|
"repoName": "@htmlbricks/hb-footer",
|
|
733
|
-
"version": "0.68.
|
|
733
|
+
"version": "0.68.7"
|
|
734
734
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@htmlbricks/hb-footer",
|
|
3
|
-
"version": "0.68.
|
|
3
|
+
"version": "0.68.7",
|
|
4
4
|
"contributors": [],
|
|
5
5
|
"description": "Site footer in `small`, `regular`, or `large` layouts: company block, optional brand/contacts column, link columns, social icons, `hb-contact-item` rows, and policy links—all driven by JSON props. Regular layout uses Bulma `container`, `columns` / `column`, `title`, and `button`. On small layouts the body can expand/collapse unless `disable_expanding_small` is set; slots `footerheader`, `footercontent`, and `footerbottom` wrap major regions.",
|
|
6
6
|
"licenses": [
|
package/types/html-elements.d.ts
CHANGED
|
@@ -4,17 +4,30 @@
|
|
|
4
4
|
*/
|
|
5
5
|
import type { Component, Events } from "./webcomponent.type";
|
|
6
6
|
|
|
7
|
+
/**
|
|
8
|
+
* Host properties already on `HTMLElement` (no `svelte/elements` here — DOM typings stay
|
|
9
|
+
* usable without Svelte). Custom `Component` keys that collide stay on the native typing.
|
|
10
|
+
*/
|
|
7
11
|
type DomKeys = keyof HTMLElement;
|
|
8
12
|
type HbComponentAttrs = {
|
|
9
13
|
[K in keyof Component as K extends DomKeys ? never : K]?: string;
|
|
10
14
|
};
|
|
11
15
|
|
|
16
|
+
type HbHtmlElementWithoutListeners = Omit<
|
|
17
|
+
HTMLElement,
|
|
18
|
+
"addEventListener" | "removeEventListener"
|
|
19
|
+
>;
|
|
20
|
+
|
|
12
21
|
/**
|
|
13
22
|
* Re-declare listener methods so custom `Events` overloads are compatible with
|
|
14
23
|
* `HTMLElement` (subclass methods must remain assignable to the base signatures).
|
|
24
|
+
*
|
|
25
|
+
* Like `svelte-elements.d.ts`, we `Omit` keys we define on `HbComponentAttrs` from the DOM
|
|
26
|
+
* base, then add them back: avoids `extends A, B` merging the same key with incompatible types
|
|
27
|
+
* if a name slips past `DomKeys`.
|
|
15
28
|
*/
|
|
16
29
|
export interface HbFooterElement
|
|
17
|
-
extends Omit<
|
|
30
|
+
extends Omit<HbHtmlElementWithoutListeners, keyof HbComponentAttrs>,
|
|
18
31
|
HbComponentAttrs {
|
|
19
32
|
addEventListener<K extends keyof HTMLElementEventMap>(
|
|
20
33
|
type: K,
|
|
@@ -8,9 +8,13 @@
|
|
|
8
8
|
import type { HTMLAttributes } from "svelte/elements";
|
|
9
9
|
import type { Component, Events } from "./webcomponent.type";
|
|
10
10
|
|
|
11
|
-
|
|
11
|
+
/**
|
|
12
|
+
* Keys already modeled on `HTMLAttributes` (global attrs + DOM listeners). Exclude these from
|
|
13
|
+
* `Component` so host props stay plain strings and are not merged with unrelated DOM typings.
|
|
14
|
+
*/
|
|
15
|
+
type HtmlReservedAttrKeys = keyof HTMLAttributes<HTMLElement>;
|
|
12
16
|
type HbSvelteAttrs = {
|
|
13
|
-
[K in keyof Component as K extends
|
|
17
|
+
[K in keyof Component as K extends HtmlReservedAttrKeys ? never : K]?: string;
|
|
14
18
|
};
|
|
15
19
|
|
|
16
20
|
/** `detail` matches `Events[K]`; `currentTarget` is the host element. */
|
|
@@ -26,9 +30,21 @@ type HbSvelteEventAttrs = {
|
|
|
26
30
|
[K in keyof Events & string as `on:${K}`]?: HbSvelteCustomEventHandler<Events[K]>;
|
|
27
31
|
};
|
|
28
32
|
|
|
33
|
+
/**
|
|
34
|
+
* Strip keys we re-declare from Svelte’s base, then add them back: plain intersection would
|
|
35
|
+
* merge `on*` / attrs with conflicting DOM typings (`string & EventHandler` → errors or
|
|
36
|
+
* props treated like listeners).
|
|
37
|
+
*/
|
|
38
|
+
type HbSvelteHostAttributes = Omit<
|
|
39
|
+
HTMLAttributes<HTMLElement>,
|
|
40
|
+
keyof HbSvelteAttrs | keyof HbSvelteEventAttrs
|
|
41
|
+
> &
|
|
42
|
+
HbSvelteAttrs &
|
|
43
|
+
HbSvelteEventAttrs;
|
|
44
|
+
|
|
29
45
|
declare module "svelte/elements" {
|
|
30
46
|
export interface SvelteHTMLElements {
|
|
31
|
-
"hb-footer":
|
|
47
|
+
"hb-footer": HbSvelteHostAttributes;
|
|
32
48
|
}
|
|
33
49
|
}
|
|
34
50
|
|