Skip to content

Commit

Permalink
feat: fluid state for number input (#3002)
Browse files Browse the repository at this point in the history
Signed-off-by: Akshat Patel <[email protected]>
Co-authored-by: Akshat Patel <[email protected]>
Co-authored-by: Akshat Patel <[email protected]>
  • Loading branch information
3 people authored Oct 17, 2024
1 parent 968900d commit 73468cf
Show file tree
Hide file tree
Showing 2 changed files with 79 additions and 35 deletions.
40 changes: 37 additions & 3 deletions src/number-input/number.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import {
TemplateRef,
HostListener
} from "@angular/core";
import { NG_VALUE_ACCESSOR, ControlValueAccessor } from "@angular/forms";
import { ControlValueAccessor, NG_VALUE_ACCESSOR } from "@angular/forms";

import { I18n, Overridable } from "carbon-components-angular/i18n";
import { Observable } from "rxjs";
Expand Down Expand Up @@ -38,6 +38,7 @@ export class NumberChange {
@Component({
selector: "cds-number, ibm-number",
template: `
<label *ngIf="skeleton && label" class="cds--label cds--skeleton"></label>
<div
data-numberinput
[attr.data-invalid]="(invalid ? true : null)"
Expand All @@ -51,7 +52,6 @@ export class NumberChange {
'cds--number--md': size === 'md',
'cds--number--lg': size === 'lg'
}">
<label *ngIf="skeleton && label" class="cds--label cds--skeleton"></label>
<label
*ngIf="!skeleton && label"
[for]="id"
Expand All @@ -78,6 +78,8 @@ export class NumberChange {
[attr.aria-label]="ariaLabel"
[attr.data-invalid]="invalid ? invalid : null"
[placeholder]="placeholder"
(focus)="fluid ? handleFocus($event): null"
(blur)="fluid ? handleFocus($event): null"
(change)="onNumberInputChange($event)"/>
<svg
*ngIf="!skeleton && invalid"
Expand Down Expand Up @@ -116,8 +118,9 @@ export class NumberChange {
<div class="cds--number__rule-divider"></div>
</div>
</div>
<hr *ngIf="fluid" class="cds--number-input__divider" />
<div
*ngIf="helperText && !invalid && !warn"
*ngIf="helperText && !invalid && !warn && !fluid"
class="cds--form__helper-text"
[ngClass]="{
'cds--form__helper-text--disabled': disabled
Expand Down Expand Up @@ -265,6 +268,29 @@ export class NumberComponent implements ControlValueAccessor {
return this._incrementLabel.value;
}

/**
* Experimental: enable fluid state
*/
@HostBinding("class.cds--number-input--fluid") @Input() fluid = false;

@HostBinding("class.cds--number-input--fluid--invalid") get fluidInvalid() {
return this.fluid && this.invalid;
}

@HostBinding("class.cds--number-input--fluid--disabled") get fluidDisabled() {
return this.fluid && this.disabled;
}

@HostBinding("class.cds--number-input--fluid--focus") get fluidFocus() {
return this.fluid && this._isFocused;
}

@HostBinding("class.cds--text-input--fluid__skeleton") get fluidSkeleton() {
return this.fluid && this.skeleton;
}

protected _isFocused = false;

protected _value = 0;

protected _decrementLabel: Overridable = this.i18n.getOverridable("NUMBER.DECREMENT");
Expand Down Expand Up @@ -371,5 +397,13 @@ export class NumberComponent implements ControlValueAccessor {
public isTemplate(value) {
return value instanceof TemplateRef;
}

handleFocus(event: FocusEvent) {
if ("type" in event.target && (<HTMLInputElement>event.target).type === "button") {
this._isFocused = false;
} else {
this._isFocused = event.type === "focus";
}
}
}
export { NumberComponent as Number };
74 changes: 42 additions & 32 deletions src/number-input/number.stories.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,33 @@ export default {
imports: [NumberModule]
})
],
args: {
value: 0,
label: "Number input label",
helperText: "Optional helper text",
invalidText: "Invalid text",
min: 0,
max: 100,
step: 1,
invalid: false,
readonly: false,
disabled: false,
size: "md",
theme: "dark",
warn: false,
warnText: "Warn text",
fluid: false
},
argTypes: {
size: {
options: ["sm", "md", "lg"],
control: "radio"
},
theme: {
options: ["light", "dark"],
control: "radio"
}
},
component: NumberComponent
} as Meta;

Expand All @@ -29,34 +56,16 @@ const Template = (args) => ({
[warnText]="warnText"
[size]="size"
[readonly]="readonly"
[disabled]="disabled">
[disabled]="disabled"
[fluid]="fluid">
</cds-number>
`
});
export const Basic = Template.bind({});
Basic.args = {
value: 0,
label: "Number input label",
helperText: "Optional helper text",
invalidText: "Invalid text",
min: 0,
max: 100,
step: 1,
invalid: false,
readonly: false,
disabled: false,
size: "md",
theme: "dark"
};
Basic.argTypes = {
size: {
options: ["sm", "md", "lg"],
control: "radio"
},
theme: {
options: ["light", "dark"],
control: "radio"
}

export const Fluid = Template.bind({});
Fluid.args = {
fluid: true
};

const ModelTemplate = (args) => ({
Expand All @@ -73,25 +82,26 @@ const ModelTemplate = (args) => ({
[precision]="precision"
[invalid]="invalid"
[invalidText]="invalidText"
[warn]="warn"
[warnText]="warnText"
[disabled]="disabled"
[(ngModel)]="value">
[(ngModel)]="value"
[fluid]="fluid">
</cds-number>
{{ value }}
`
});
export const NgModel = ModelTemplate.bind({});
NgModel.story = "ngModel";
NgModel.args = {
...Basic.args
};
NgModel.argTypes = {
...Basic.argTypes
};

const SkeletonTemplate = (args) => ({
props: args,
template: `
<cds-number label="Number input label" skeleton="true"></cds-number>
<cds-number
label="Number input label"
skeleton="true"
[fluid]="fluid">
</cds-number>
`
});
export const Skeleton = SkeletonTemplate.bind({});

0 comments on commit 73468cf

Please sign in to comment.