From 82e3628edf3c0f00b295056b8599038b65c4c8b8 Mon Sep 17 00:00:00 2001 From: Akshat Patel Date: Mon, 11 Nov 2024 19:13:14 -0500 Subject: [PATCH 1/2] feat: create link directive to pair icon with link Signed-off-by: Akshat Patel --- src/icon/icon.directive.ts | 3 ++- src/link/link-icon.directive.ts | 8 ++++++++ src/link/link.module.ts | 7 +++++-- src/link/link.stories.ts | 23 ++++++++++++++++++++++- 4 files changed, 37 insertions(+), 4 deletions(-) create mode 100644 src/link/link-icon.directive.ts diff --git a/src/icon/icon.directive.ts b/src/icon/icon.directive.ts index c3a5fea1fd..d912742020 100644 --- a/src/icon/icon.directive.ts +++ b/src/icon/icon.directive.ts @@ -91,7 +91,8 @@ export class IconDirective implements AfterViewInit, OnChanges { "aria-label": this.ariaLabel, "aria-labelledby": this.ariaLabelledBy, "aria-hidden": this.ariaHidden, - focusable: this.isFocusable.toString() + focusable: this.isFocusable.toString(), + fill: icon.attrs.fill }); const attrKeys = Object.keys(attributes); diff --git a/src/link/link-icon.directive.ts b/src/link/link-icon.directive.ts new file mode 100644 index 0000000000..792e79679f --- /dev/null +++ b/src/link/link-icon.directive.ts @@ -0,0 +1,8 @@ +import { Directive, HostBinding } from "@angular/core"; + +@Directive({ + selector: "[ibmLinkIcon], [cdsLinkIcon]" +}) +export class LinkIconDirective { + @HostBinding("class.cds--link__icon") iconClass = true; +} diff --git a/src/link/link.module.ts b/src/link/link.module.ts index 2bba2cd56d..9781fe18af 100644 --- a/src/link/link.module.ts +++ b/src/link/link.module.ts @@ -2,13 +2,16 @@ import { NgModule } from "@angular/core"; import { CommonModule } from "@angular/common"; import { Link } from "./link.directive"; +import { LinkIconDirective } from "./link-icon.directive"; @NgModule({ declarations: [ - Link + Link, + LinkIconDirective ], exports: [ - Link + Link, + LinkIconDirective ], imports: [ CommonModule diff --git a/src/link/link.stories.ts b/src/link/link.stories.ts index 150d40fea5..ae5d09232c 100644 --- a/src/link/link.stories.ts +++ b/src/link/link.stories.ts @@ -3,11 +3,13 @@ import { moduleMetadata, Meta } from "@storybook/angular"; import { LinkModule, Link } from "./"; +import { IconModule } from "../icon"; + export default { title: "Components/Link", decorators: [ moduleMetadata({ - imports: [LinkModule] + imports: [LinkModule, IconModule] }) ], component: Link @@ -24,3 +26,22 @@ Basic.args = { disabled: false, inline: false }; + +const IconTemplate = (args) => ({ + props: args, + template: ` + + Link + + + ` +}); +export const WithIcon = IconTemplate.bind({}); +WithIcon.args = { + disabled: false, + inline: false +}; From 7db29d7c93297f19efaf0cd5d869c35ed8308c2d Mon Sep 17 00:00:00 2001 From: Akshat Patel Date: Mon, 11 Nov 2024 19:28:57 -0500 Subject: [PATCH 2/2] fix: export link icon directive Signed-off-by: Akshat Patel --- src/link/index.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/src/link/index.ts b/src/link/index.ts index 480f5396de..e17aac5039 100644 --- a/src/link/index.ts +++ b/src/link/index.ts @@ -1,2 +1,3 @@ export * from "./link.directive"; +export * from "./link-icon.directive"; export * from "./link.module";