Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(styles): Update form-control and form-select sizes #2396

Merged
merged 45 commits into from
Jan 30, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
abf203b
feat(styles): Add success state to text input
imagoiq Dec 11, 2023
17f937f
Test update to stencil/core4.8.2 to fix unit
imagoiq Dec 12, 2023
b6ac40f
Merge branch 'main' into feat/1835-text-input-success-state
imagoiq Dec 12, 2023
73866ec
fix(unit): Upgrade to Jest 29
imagoiq Dec 12, 2023
3202f8f
Merge remote-tracking branch 'origin/feat/1835-text-input-success-sta…
imagoiq Dec 12, 2023
8dc04fc
fix(unit): Add missing jest-environment-jsdom
imagoiq Dec 12, 2023
b19ba6e
fix(unit): Upgrade ts-jest
imagoiq Dec 12, 2023
79d0614
Merge branch 'main' into feat/1835-text-input-success-state
imagoiq Dec 12, 2023
1eb8aa0
Remove early optimization on duplication of icons
imagoiq Dec 12, 2023
b244e47
Readd input size condition
imagoiq Dec 12, 2023
5694872
Better support for success and other type of inputs
imagoiq Dec 13, 2023
d144c78
Fix missing variables
imagoiq Dec 13, 2023
638faca
Merge success state into is-valid for select and input
imagoiq Jan 8, 2024
8601562
Fix for floating label
imagoiq Jan 8, 2024
4a4d435
Fix changelog
imagoiq Jan 8, 2024
f07fe5a
Merge branch 'main' into feat/1835-text-input-success-state
imagoiq Jan 8, 2024
9e1abc2
feat(styles): Update forms styles
imagoiq Dec 13, 2023
1122cfa
Add changeset
imagoiq Dec 13, 2023
8db2880
Fix test
imagoiq Dec 13, 2023
bb7bd03
Fix mixins test
imagoiq Dec 13, 2023
ceb12ac
Fix icon size validation
imagoiq Dec 13, 2023
066c487
Add floatingLabel small variant to snapshot
imagoiq Dec 13, 2023
8521bbf
Improve date native icon centering
imagoiq Dec 13, 2023
95bb3c3
Fix missing import
imagoiq Dec 13, 2023
20546a8
Lint
imagoiq Dec 13, 2023
f2306a0
Lint
imagoiq Dec 13, 2023
5bb5e47
Fix code smell
imagoiq Dec 13, 2023
09ec89e
Change input story to display large variant by default
imagoiq Jan 8, 2024
80204c2
Fix line-height and padding
imagoiq Jan 8, 2024
018aacd
Remove duplication
imagoiq Jan 8, 2024
f1012c3
Improve structure
imagoiq Jan 8, 2024
825c4f1
Fixes for input multiple and arrows
imagoiq Jan 9, 2024
465c19d
Lint
imagoiq Jan 9, 2024
376ee3e
Merge branch 'main' into feat/1835-update-form-styles
imagoiq Jan 15, 2024
dd08ce7
Merge branch 'main' into feat/1835-update-form-styles
imagoiq Jan 16, 2024
6846d5e
Fix code smell
imagoiq Jan 16, 2024
6a5b0a4
Merge branch 'main' into feat/1835-update-form-styles
imagoiq Jan 18, 2024
f45aa3e
Merge branch 'main' into feat/1835-update-form-styles
imagoiq Jan 30, 2024
12f2b1f
Hide deprecated sizes when using floating-label
imagoiq Jan 30, 2024
3d12da2
Remove success from snapshots
imagoiq Jan 30, 2024
ba75717
fix(docs): update select snapshot tests
alizedebray Jan 30, 2024
f58875b
Slight improvement for select multiple
imagoiq Jan 30, 2024
0231a08
Improvement position of validation icon for date and time input and t…
imagoiq Jan 30, 2024
1e0935a
Merge branch 'main' into feat/1835-update-form-styles
imagoiq Jan 30, 2024
179a9a7
Support week and month input type
imagoiq Jan 30, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions .changeset/grumpy-pianos-dress.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@swisspost/design-system-styles': patch
---

Updated `form-control` and `form-select` sizes and added support for floating label small size variant.
Original file line number Diff line number Diff line change
Expand Up @@ -48,11 +48,7 @@ The size can be changed by simply adding one of four classes:
- Large: `.form-control-lg`

<div className="alert alert-info">
<h4 className="alert-heading">Do not apply size classes on floating-label elements</h4>
<div className="mt-0">
It is not intended to apply the size classes to `input` elements that are nested in a
`.form-floating` container.
</div>
Regular and medium size classes are not available on floating-label elements
</div>

<Canvas of={InputStories.Size} />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,10 @@ function renderInputSnapshot(_args: Args, context: StoryContext) {
label: `Label - with Value`,
value: 'Lorem Ipsum',
},
{
label: `Label - Floating label`,
floatingLabel: true,
},
];
return html`
<div class="d-flex flex-wrap align-items-start gap-regular">
Expand Down
oliverschuerch marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@ const meta: Meta = {
hiddenLabel: false,
placeholder: 'Placeholder',
type: 'text',
size: 'null',
size: 'form-control-lg',
sizeFloatingLabel: 'form-control-lg',
hint: 'Hintus textus elare volare cantare hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis.',
disabled: false,
validation: 'null',
Expand Down Expand Up @@ -121,6 +122,25 @@ const meta: Meta = {
category: 'General',
},
},
sizeFloatingLabel: {
name: 'Size',
description: "Sets the size of the component's appearance.",
if: {
arg: 'floatingLabel',
truthy: true,
},
control: {
type: 'select',
labels: {
'form-control-sm': 'Small',
'form-control-lg': 'Large',
},
},
options: ['form-control-sm', 'form-control-lg'],
table: {
category: 'General',
},
},
hint: {
name: 'Helper Text',
description: 'Text to place in the help text area of the component.',
Expand Down Expand Up @@ -171,6 +191,7 @@ function render(args: Args, context: StoryContext) {
'form-control',
args.type === 'color' && 'form-control-color',
args.size,
args.sizeFloatingLabel,
args.validation,
]
.filter(c => c && c !== 'null')
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ The size can be adjusted, by simply adding one of the following four classes:
- Large: `.form-select-lg`

<div className="alert alert-info alert-md">
Do not use this classes on `select` elements wrapped within a `.form-floating` container.
Regular and medium size classes are not available on floating-label elements
</div>

<Canvas of={SelectStories.Size} />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,15 +32,14 @@ export const Select: Story = {
}),
...bombArgs({
size: context.argTypes.size.options,
success: [false, true],
validation: context.argTypes.validation.options.filter((option: string) => option !== 'is-invalid'),
validation: context.argTypes.validation.options.filter(
(option: string) => option !== 'is-invalid',
),
}),
]
// remove disabled & validated examples
.filter((args: Args) => !(args.disabled && args.validation !== 'null'));

console.log('bombArg', bombArgsGeneratedDefault);

//Arguments for Multiple Version
const bombArgsGeneratedMultiple = [
...bombArgs({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ const meta: Meta = {
hiddenLabel: false,
value: undefined,
size: 'form-select-lg',
sizeFloatingLabel: 'form-select-lg',
options: 5,
multiple: false,
multipleSize: 4,
Expand Down Expand Up @@ -77,6 +78,10 @@ const meta: Meta = {
size: {
name: 'Size',
description: "Sets the size of the component's appearance.",
if: {
arg: 'floatingLabel',
truthy: false,
},
control: {
type: 'select',
labels: {
Expand All @@ -91,6 +96,25 @@ const meta: Meta = {
category: 'General',
},
},
sizeFloatingLabel: {
name: 'Size',
description: "Sets the size of the component's appearance.",
if: {
arg: 'floatingLabel',
truthy: true,
},
control: {
type: 'select',
labels: {
'form-select-sm': 'Small',
'form-select-lg': 'Large',
},
},
options: ['form-select-sm', 'form-select-lg'],
table: {
category: 'General',
},
},
options: {
name: 'Options',
description: 'Amount of `option` elements to render in the component.',
Expand Down Expand Up @@ -185,6 +209,7 @@ const Template: Story = {
const classes = [
'form-select',
args.size,
args.sizeFloatingLabel,
args.validation,
args.floatingLabelPlaceholder && !args.value ? 'form-select-empty' : null,
]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,19 +24,10 @@ export const COMBINATIONS = [
label: `${SHORT_LABEL} - Disabled`,
disabled: true,
},
{
label: `${SHORT_LABEL} - Success`,
success: true,
},
{
label: `${SHORT_LABEL} - Valid`,
validation: 'is-valid',
},
{
label: `${SHORT_LABEL} - Valid with success`,
validation: 'is-valid',
success: true,
},
{
label: `${SHORT_LABEL} - Invalid`,
validation: 'is-invalid',
Expand Down
103 changes: 76 additions & 27 deletions packages/styles/src/components/floating-label.scss
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
@forward './../variables/options';

@use './../lic/bootstrap-license';
@use './../themes/bootstrap/core' as b;
@use './../themes/bootstrap/forms/floating-labels' as bffl;
@use './../themes/bootstrap/forms/form-control' as bffc;
@use './../mixins/forms' as forms-mx;
Expand Down Expand Up @@ -52,6 +53,7 @@
padding-bottom: forms.$form-floating-input-padding-b;

~ label {
color: forms.$form-floating-label-color;
padding-top: 0.7rem;
max-width: calc(
(100% * #{forms.$form-floating-label-upscale}) - #{forms.$form-floating-label-translate-x *
Expand All @@ -68,6 +70,39 @@
padding-top: forms.$form-floating-input-padding-t * 1.33;
}
}

&[type='week'],
&[type='month'],
&[type='date'],
&[type='time'] {
background-position: right b.$input-height-inner-quarter bottom 0.5rem;
}

&.form-control-sm {
&[type='date']::-webkit-calendar-picker-indicator {
margin-top: -(spacing.$size-small-regular);
}
font-size: forms.$form-floating-label-font-size-placeholder-sm;
height: forms.$form-floating-label-height-sm;
min-height: forms.$form-floating-label-height-sm;
padding-inline: forms.$form-floating-padding-x-sm;

~ label {
font-size: forms.$form-floating-label-font-size-placeholder-sm;
padding-top: forms.$form-floating-label-padding-t-sm;
padding-inline: calc(#{forms.$form-floating-padding-x-sm} - #{forms.$input-border-width});
}

&:focus,
&:not(:placeholder-shown) {
padding-top: forms.$form-floating-padding-y-sm * 2;

~ label {
padding-top: forms.$form-floating-padding-y-sm;
font-size: forms.$form-floating-label-font-size-sm;
}
}
}
}

> .form-select {
Expand Down Expand Up @@ -107,8 +142,31 @@
}
}

&.form-select-sm {
padding-inline: forms.$form-floating-padding-x-sm;
padding-top: forms.$form-floating-padding-y-sm * 2;
font-size: forms.$form-floating-label-font-size-placeholder-sm;
height: forms.$form-floating-label-height-sm;
min-height: forms.$form-floating-label-height-sm;

~ label {
padding-top: forms.$form-floating-padding-y-sm;
font-size: forms.$form-floating-label-font-size-sm;
padding-inline: forms.$form-floating-padding-x-sm;
}

// TODO: replace with :has
&:empty,
&.form-select-empty {
~ label {
padding-top: forms.$form-floating-label-padding-t-sm;
font-size: forms.$form-floating-label-font-size-placeholder-sm;
}
}
}

&[multiple] {
padding-top: forms.$form-floating-input-padding-t * 1.5;
padding-top: spacing.$size-big;
padding-bottom: 0;
height: auto;

Expand All @@ -121,7 +179,21 @@
2} - #{forms.$form-floating-padding-x * forms.$form-floating-label-upscale}
);
height: auto;
background: forms.$input-bg;
left: forms.$input-border-width * 3;
}

&.form-select-sm {
padding-top: forms.$form-floating-input-padding-t;

~ label {
left: forms.$input-border-width * 2;
}
}

&:not(:disabled) {
~ label {
background: forms.$input-bg;
}
}

&:empty {
Expand All @@ -135,33 +207,10 @@
}
}
}

&.form-select-sm {
padding-inline: forms.$form-floating-padding-x-sm;
padding-top: forms.$form-floating-padding-y-sm * 2;
font-size: forms.$form-floating-label-font-size-placeholder-sm;
height: forms.$form-floating-label-height-sm;
min-height: forms.$form-floating-label-height-sm;

~ label {
padding-top: forms.$form-floating-padding-y-sm;
font-size: forms.$form-floating-label-font-size-sm;
padding-inline: calc(#{forms.$form-floating-padding-x-sm} - #{forms.$input-border-width});
}

// TODO: replace with :has
&:empty,
&.form-select-empty {
~ label {
padding-top: forms.$form-floating-label-padding-t-sm;
font-size: forms.$form-floating-label-font-size-placeholder-sm;
}
}
}
}

> textarea.form-control {
padding-top: forms.$input-padding-y-lg * 1.5;
padding-top: forms.$input-padding-y-lg * 2;
padding-bottom: forms.$input-padding-y-lg;
height: auto;

Expand All @@ -174,7 +223,7 @@

&:focus,
&:not(:placeholder-shown) {
padding-top: forms.$input-padding-y-lg * 1.5;
padding-top: forms.$input-padding-y-lg * 2;
padding-bottom: forms.$input-padding-y-lg;

~ label {
Expand Down
Loading
Loading