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

LF 18.2 #2998

Merged
merged 84 commits into from
Aug 22, 2024
Merged

LF 18.2 #2998

Changes from all commits
Commits
Show all changes
84 commits
Select commit Hold shift + click to select a range
c0b6fb7
Merge pull request #2873 from LuccaSA/18.1-update-rc
jeremie-lucca Jun 19, 2024
49f1781
feat(numberFormat): models, functions, pipe, directive, formField for…
guillerot Jun 6, 2024
a0204c5
feat(numberFormat): handle single minusSign in directive input event
guillerot Jun 6, 2024
22bf42c
feat(numberFormat): cleanup input event listener
guillerot Jun 6, 2024
0ca63e9
feat(numberFormat): based on "Intl number input" library
guillerot Jun 7, 2024
66cc943
feat(numberFormat): based on "Intl number input" library
guillerot Jun 10, 2024
50d83b1
feat(numberFormat): remove autoDecimalDigits & AutoDecimalDigitsNumbe…
guillerot Jun 10, 2024
92eaafe
feat(numberFormat): refacto number-format models, directive and input…
guillerot Jun 11, 2024
e2714f1
feat(numberFormat): fix build
guillerot Jun 11, 2024
1ede444
feat(numberFormat): add min/max
guillerot Jun 12, 2024
3f028b5
feat(numberFormat): add stories for currency/unit/percent
guillerot Jun 12, 2024
c2bf34f
feat(numberFormat): fix division on percent value
guillerot Jun 12, 2024
7279bab
feat(numberFormat): refacto
guillerot Jun 12, 2024
8c20080
test(numberFormat): parse
guillerot Jun 12, 2024
4361fdb
test(numberFormat): suffix and prefix
guillerot Jun 12, 2024
f4856a1
feat(numberFormat): auto suffix and prefix are not used by default
guillerot Jun 16, 2024
1290c88
test(numberFormat): test focus and blur format
guillerot Jun 16, 2024
e337f51
Merge pull request #2899 from LuccaSA/update.rc.18.1.1
jeremie-lucca Jun 28, 2024
c207399
fix(numberFormat): min max behave differently for percent values
guillerot Jun 28, 2024
2d3e789
Story settings
jeremie-lucca Jun 28, 2024
dfddda8
fix(numberFormat): should use minus sign instead of hyphen for negati…
guillerot Jun 28, 2024
9f4a405
Merge remote-tracking branch 'origin/feat/number-format-field' into f…
guillerot Jun 28, 2024
aa32410
Merge pull request #2847 from LuccaSA/feat/number-format-field
guillerot Jun 28, 2024
329079c
feat: move all translations to Lokalise
GuillaumeNury Jul 8, 2024
fe89ba3
ref(ng): use wider LuTranslation type and deprecate ILuTranslation
GuillaumeNury Jul 9, 2024
80e251b
ref(ng): remove formatDay as it is not translatable
GuillaumeNury Jul 9, 2024
41cbb70
chore(ng): update translations
GuillaumeNury Jul 9, 2024
86ed668
chore(ng): update translations
GuillaumeNury Jul 9, 2024
a030f3d
fix(ng): wrong post-i18n prettify
GuillaumeNury Jul 9, 2024
61983e0
rem(ng): unused translation file
GuillaumeNury Jul 9, 2024
d2dd556
fix(ng): missing translation token exports
GuillaumeNury Jul 9, 2024
9c7ec8c
fix(ng): wrong LuTranslation import
GuillaumeNury Jul 9, 2024
d1b64e1
ref(ng): remove useless fr-CH overrides
GuillaumeNury Jul 9, 2024
4c6d57e
feat(storybook): setup LOCALE_ID with browser language
GuillaumeNury Jul 9, 2024
183d953
Merge pull request #2919 from LuccaSA/feat/lokalise
GuillaumeNury Jul 9, 2024
9e9cce5
feat(time-picker): AM/PM support (#2888)
Supamiu Jul 12, 2024
9c8aa69
Back button for page header (#2948)
vvalentin-lucca Jul 15, 2024
97ce9cc
fix(date): date adapter format should not be overriden
GuillaumeNury Jul 19, 2024
95a17ae
Merge pull request #2971 from LuccaSA/fix/formatDate
GuillaumeNury Jul 19, 2024
d8d98a1
chore(ng): update translations
GuillaumeNury Jul 19, 2024
dc39b87
Merge pull request #2973 from LuccaSA/chore/lokalise
GuillaumeNury Jul 22, 2024
7f4c5e3
[Icons] Add medical + arrow line (#2975)
vvalentin-lucca Jul 22, 2024
a5097a8
Merge remote-tracking branch 'origin/rc' into 18.1.2.master
GuillaumeNury Jul 23, 2024
2b11958
Merge pull request #2978 from LuccaSA/18.1.2.master
jeremie-lucca Jul 23, 2024
35dea92
Update icons (#2979)
jeremie-lucca Jul 23, 2024
5307f3d
[Status badge] Fix vertical alignement in tables (#2986)
jeremie-lucca Jul 25, 2024
409a44e
Add option luTooltipOnlyForDisplay for tooltips (#2974)
vvalentin-lucca Jul 25, 2024
5391fd3
Replace title with heading (#2946)
vvalentin-lucca Jul 25, 2024
6e94cc9
Merge pull request #2987 from LuccaSA/18.1.3-master2rc
GuillaumeNury Jul 25, 2024
56ba4c3
feat(popover2): hover+focus trigger mode (#2895)
Supamiu Jul 25, 2024
69d12b5
columnSticky is deprecated (#2928)
vvalentin-lucca Jul 25, 2024
811c317
feat(plgPush): add new component and all stories (#2911)
nbrun-lucca Jul 26, 2024
2b1075d
feat(schematics): add empty-state-heading migration (#2955)
GuillaumeNury Jul 29, 2024
c817fbe
Fix footer on dialogs with Safari (#2933)
vvalentin-lucca Jul 29, 2024
dd76138
Deprecated for black and white – Add neutral 0 (#2921)
vvalentin-lucca Jul 29, 2024
b597257
Remove tooltip generated by Safari desktop (#2958)
vvalentin-lucca Jul 30, 2024
91dd6e7
Show index table link (#2838)
vvalentin-lucca Jul 30, 2024
9ecaa3f
Change disabled colors (#2966)
vvalentin-lucca Jul 30, 2024
4c9fc3b
docs(radio-input): add base usage docs (#2922)
Supamiu Jul 31, 2024
2ff08cb
Toast position when footer is present (#2916)
vvalentin-lucca Aug 1, 2024
46366e9
New component: viewTabs (#2498)
vvalentin-lucca Aug 1, 2024
a9a49d9
fix(core-select): fix former employees param for users core select
lukah Aug 2, 2024
38f6606
Merge pull request #2997 from LuccaSA/fix/core.select.users.former.em…
lukah Aug 2, 2024
94f185d
feat(popover2): handled popover2 resize after content changed (#2991)
obraud Aug 5, 2024
da0438e
fix(story): dialog story not opening with focus set to first-input (#…
Supamiu Aug 6, 2024
dd35ab1
Merge branch 'rc' into 18.1.4-master2rc
jeremie-lucca Aug 6, 2024
b257dec
Merge pull request #3008 from LuccaSA/18.1.4-master2rc
jeremie-lucca Aug 6, 2024
dda17e2
[Page header] Component padding (#3012)
jeremie-lucca Aug 7, 2024
1766f0a
feat(dialog-routing): Open dialog through routes (#2901)
guillerot Aug 8, 2024
0b0e564
i18n-text-input (#2890)
vvalentin-lucca Aug 16, 2024
9b618b3
[Divider] Fix margins & icon color (#3018)
jeremie-lucca Aug 19, 2024
a69b1c8
indexTable sortable (#2858)
vvalentin-lucca Aug 19, 2024
22716b6
[User tile] Move NG style in CSS package (#2940)
jeremie-lucca Aug 20, 2024
dc0da55
[Avatar] Move style in SCSS (#3015)
jeremie-lucca Aug 20, 2024
626dcc0
fix(lu-form-field): aria-labelledby sometimes filling with label id a…
Supamiu Aug 20, 2024
57253b7
[Popover2] Add option to remove keyboard close button (#3027)
jeremie-lucca Aug 20, 2024
013a21c
[DurationPicker] Fix legend (#3026)
vvalentin-lucca Aug 20, 2024
2fc526b
Replace absolute position with grid (#2935)
vvalentin-lucca Aug 20, 2024
8aeaf0c
ref(core-select)!: optionKey is mandatory on ApiDirectives (#2950)
GuillaumeNury Aug 21, 2024
5b72579
feat(forms): new phone number input component (#3022)
Supamiu Aug 21, 2024
cb9663a
InlineMessage with PortalContent (#2947)
vvalentin-lucca Aug 21, 2024
5e1fe38
Fix indexTable, checkbox-radio, tableSortable (#3028)
vvalentin-lucca Aug 22, 2024
4464154
fix conflicts
jeremie-lucca Aug 22, 2024
27b7da2
Merge pull request #3029 from LuccaSA/18.2fixconflits
jeremie-lucca Aug 22, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
4 changes: 0 additions & 4 deletions .storybook/styles.scss
Original file line number Diff line number Diff line change
@@ -4,10 +4,6 @@
@import '../packages/scss/src/main-all';
@import '../packages/ng/styles/main';

.sb-show-main {
background-color: white;
}

.demo-utilityWrapper {
display: flex;
gap: var(--pr-t-spacings-100);
4 changes: 2 additions & 2 deletions docs/dialog.md
Original file line number Diff line number Diff line change
@@ -177,14 +177,14 @@ la dialog box a accès à tout ce que le composant expose au template, fonctions

## Utilisation des formulaires

Dans le cas où vous souhaitez utiliser un formulaire au sein d’une dialog box, il vous suffit de placer la balise `form` avec une classe `dialog-formOptionnal` autour du contenu de votre dialog, que celle-ci soit template-driven ou non:
Dans le cas où vous souhaitez utiliser un formulaire au sein d’une [dialog box](https://prisme.lucca.io/94310e217/p/841b0b-dialogs), il vous suffit de placer la balise `form` avec une classe `dialog-formOptional` autour du contenu de votre dialog, que celle-ci soit template-driven ou non :

```html
<lu-dialog>
<!--form = new FormGroup({
example: new FormControl('', Validators.required)
})-->
<form [formControl]="form" class="dialog-formOptionnal">
<form [formGroup]="form" class="dialog-formOptional">
<lu-dialog-header>Header with Form inside</lu-dialog-header>

<lu-dialog-content>
31 changes: 31 additions & 0 deletions docs/radio-input.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
# Radio input

# Utilisation

Au sein de votre template, l'utilisation de l'input radio se fait via deux composants distincts:

- `lu-radio-group-input` qui gère le lien entre chaque radio et qui porte le `formControl`.
- `lu-radio` qui permet de lister les options.

Exemple:

```angular2html

<lu-radio-group-input required [(ngModel)]="example">
<lu-radio [value]="1" inlineMessage="Option text">Option A</lu-radio>
<lu-radio [value]="2" inlineMessage="Option text">Option B</lu-radio>
<lu-radio [value]="3" inlineMessage="Option text" disabled>
Option C
</lu-radio>
</lu-radio-group-input>
```

Comme tous les `lu-***-input`, il est recommandé de les utiliser dans un `lu-form-field` même si vous n'avez pas de label à afficher, afin d'assurer une bonne accessibilité (le label est obligatoire mais vous pouvez le rendre caché pour que seules les technologies d'assistance puissent le voir).

## lu-radio

Le composant `lu-radio` porte les valeurs, les options que vous souhaitez proposer.

Il vous permet d'assigner une valeur via `[value]` et le label affiché vient se placer au sein de la balise, en tant que contenu projeté. Si vous souhaitez ajouter un texte sous le label, vous pouvez le faire via `inlineMessage`, uniquement en `string`.

Il est également possible de désactiver une option via l'input `disabled` sur celle-ci.
6 changes: 6 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
@@ -48,6 +48,7 @@
"@ngx-formly/core": "^6.3.1",
"date-fns": "^3.6.0",
"isomorphic-dompurify": "^2.11.0",
"libphonenumber-js": "^1.11.5",
"normalize.css": "^8.0.1",
"rxjs": "^7.8.1",
"tslib": "^2.6.2",
6 changes: 6 additions & 0 deletions packages/icons/font/lucca-icons.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified packages/icons/font/lucca-icons.ttf
Binary file not shown.
Binary file modified packages/icons/font/lucca-icons.woff
Binary file not shown.
Binary file modified packages/icons/font/lucca-icons.woff2
Binary file not shown.
3 changes: 3 additions & 0 deletions packages/icons/icons-list.ts
Original file line number Diff line number Diff line change
@@ -53,6 +53,8 @@ export const IconsList = [
{ icon: 'forward', deprecated: true },
{ icon: 'arrowLeft', deprecated: false },
{ icon: 'arrowFullWest', deprecated: true },
{ icon: 'arrowLineBottom', deprecated: false },
{ icon: 'arrowLineTop', deprecated: false },
{ icon: 'arrowLogin', deprecated: false },
{ icon: 'login', deprecated: true },
{ icon: 'arrowLogout', deprecated: false },
@@ -326,6 +328,7 @@ export const IconsList = [
{ icon: 'mathsPlus', deprecated: false },
{ icon: 'plus', deprecated: true },
{ icon: 'plusBold', deprecated: true },
{ icon: 'medicalDoctor', deprecated: false },
{ icon: 'menuBurger', deprecated: false },
{ icon: 'menu', deprecated: true },
{ icon: 'hamburgerMenu', deprecated: true },
3 changes: 3 additions & 0 deletions packages/icons/index.d.ts
Original file line number Diff line number Diff line change
@@ -53,6 +53,8 @@ export type LuccaIcon =
| 'forward'
| 'arrowLeft'
| 'arrowFullWest'
| 'arrowLineBottom'
| 'arrowLineTop'
| 'arrowLogin'
| 'login'
| 'arrowLogout'
@@ -326,6 +328,7 @@ export type LuccaIcon =
| 'mathsPlus'
| 'plus'
| 'plusBold'
| 'medicalDoctor'
| 'menuBurger'
| 'menu'
| 'hamburgerMenu'
2 changes: 1 addition & 1 deletion packages/icons/selection.json

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions packages/icons/src/commons/config.scss
Original file line number Diff line number Diff line change
@@ -58,6 +58,8 @@ $icons: (
'forward': '\e9c5',
'arrow_left': '\e9b4',
'arrow_full_west': '\e9b4',
'arrow_line_bottom': '\ea01',
'arrow_line_top': '\ea02',
'arrow_login': '\e93f',
'login': '\e93f',
'arrow_logout': '\e940',
@@ -331,6 +333,7 @@ $icons: (
'maths_plus': '\e985',
'plus': '\e985',
'plus_bold': '\e985',
'medical_doctor': '\ea03',
'menu_burger': '\e950',
'menu': '\e950',
'hamburger_menu': '\e950',
2 changes: 1 addition & 1 deletion packages/ng/a11y/skip-links/skip-links.component.scss
Original file line number Diff line number Diff line change
@@ -27,7 +27,7 @@
text-decoration: none;
vertical-align: baseline;
white-space: nowrap;
color: var(--colors-white-color);
color: var(--palettes-neutral-0);
cursor: pointer;

&:focus-visible {
2 changes: 2 additions & 0 deletions packages/ng/core-select/api/api.directive.spec.ts
Original file line number Diff line number Diff line change
@@ -25,6 +25,8 @@ class TestDirective extends ALuCoreSelectApiDirective<TestEntity> {

protected override optionComparer = (a: TestEntity, b: TestEntity) => a.id === b.id;

protected override optionKey = (option: TestEntity) => option.id;

public override getOptions(): Observable<TestEntity[]> {
return of([{ id: 1, name: 'test' }]);
}
7 changes: 2 additions & 5 deletions packages/ng/core-select/api/api.directive.ts
Original file line number Diff line number Diff line change
@@ -33,7 +33,7 @@ export abstract class ALuCoreSelectApiDirective<TOption, TParams = Record<string
/**
* Return a key to identify the option in for-of loops
*/
protected optionKey?: (option: TOption) => unknown;
protected abstract optionKey: (option: TOption) => unknown;

/**
* Return the options for the given params and page
@@ -42,10 +42,7 @@ export abstract class ALuCoreSelectApiDirective<TOption, TParams = Record<string

public ngOnInit(): void {
this.select.optionComparer = this.optionComparer;

if (this.optionKey) {
this.select.optionKey = this.optionKey;
}
this.select.optionKey = this.optionKey;

this.buildOptions()
.pipe(takeUntil(this.destroy$))
4 changes: 2 additions & 2 deletions packages/ng/core-select/option/option.component.scss
Original file line number Diff line number Diff line change
@@ -2,12 +2,12 @@
@include optionItemStyle;

.is-disabled {
color: var(--palettes-neutral-500);
color: var(--palettes-neutral-500); // disabled token candidate
user-select: none;
cursor: default;

&.is-selected {
background-color: var(--palettes-neutral-100);
background-color: var(--commons-disabled-background);
}

&:hover {
2 changes: 1 addition & 1 deletion packages/ng/core-select/user/users.directive.ts
Original file line number Diff line number Diff line change
@@ -107,7 +107,7 @@ export class LuCoreSelectUsersDirective<T extends LuCoreSelectUser = LuCoreSelec
...(clue ? { clue: clue } : {}),
...(operationIds ? { operations: operationIds.join(',') } : {}),
...(appInstanceId ? { appInstanceId } : {}),
...(enableFormerEmployees ? { formerEmployee: enableFormerEmployees } : {}),
...(enableFormerEmployees ? { formerEmployees: enableFormerEmployees } : {}),
})),
);

9 changes: 5 additions & 4 deletions packages/ng/date/calendar/calendar-input.component.scss
Original file line number Diff line number Diff line change
@@ -118,30 +118,31 @@

&:focus-visible {
@include a11y.focusVisible($borderRadius: var(--commons-borderRadius-L));

z-index: 1;
}

&.is-active {
.calendar-grid-item-content {
background: var(--palettes-product-700);
color: var(--palettes-product-text);
color: var(--palettes-product-0);
}

&.is-today {
&:after {
background: white !important;
background-color: var(--palettes-neutral-0) !important;
transition: background-color var(--commons-animations-durations-fast);
}
}
}

&.is-disabled,
&[disabled] {
color: var(--palettes-neutral-500);
color: var(--palettes-neutral-500); // disabled token candidate
pointer-events: none;

&:hover .calendar-grid-item-content {
background-color: white;
background-color: var(--palettes-neutral-0); // disabled token candidate
}
}
}
4 changes: 2 additions & 2 deletions packages/ng/date/input/date-input.directive.ts
Original file line number Diff line number Diff line change
@@ -59,10 +59,10 @@ export class LuDateInputDirective<D> extends ALuInput<D, HTMLInputElement> imple
let format: string;
switch (this.granularity) {
case ELuDateGranularity.year:
format = this._intl.formatYear;
format = 'Y';
break;
case ELuDateGranularity.month:
format = this._intl.formatMonth;
format = 'MM/Y';
break;
case ELuDateGranularity.day:
default:
2 changes: 0 additions & 2 deletions packages/ng/date/input/date-input.translate.ts
Original file line number Diff line number Diff line change
@@ -10,8 +10,6 @@ export interface ILuDateInputLabel {
placeholderDay: string;
placeholderMonth: string;
placeholderYear: string;
formatMonth: string;
formatYear: string;
}

export const luDateInputTranslations: LuTranslation<ILuDateInputLabel> = Translations;
16 changes: 0 additions & 16 deletions packages/ng/date/input/translations.ts
Original file line number Diff line number Diff line change
@@ -3,56 +3,40 @@
placeholderDay: 'DD/MM/YYYY',
placeholderMonth: 'MM/YYYY',
placeholderYear: 'YYYY',
formatMonth: 'MM/Y',
formatYear: 'Y',
},
de: {
placeholderDay: 'TT/MM/JJJJ',
placeholderMonth: 'MM/JJJJ',
placeholderYear: 'JJJJ',
formatMonth: 'MM/J',
formatYear: 'J',
},
fr: {
placeholderDay: 'JJ/MM/AAAA',
placeholderMonth: 'MM/AAAA',
placeholderYear: 'AAAA',
formatMonth: 'MM/Y',
formatYear: 'Y',
},
it: {
placeholderDay: 'GG/MM/AAAA',
placeholderMonth: 'MM/AAAA',
placeholderYear: 'AAAA',
formatMonth: 'MM/Y',
formatYear: 'Y',
},
nl: {
placeholderDay: 'DD/MM/JJJJ',
placeholderMonth: 'MM/JJJJ',
placeholderYear: 'JJJJ',
formatMonth: 'MM/J',
formatYear: 'J',
},
'nl-BE': {
placeholderDay: 'DD/MM/JJJJ',
placeholderMonth: 'MM/JJJJ',
placeholderYear: 'JJJJ',
formatMonth: 'MM/J',
formatYear: 'J',
},
es: {
placeholderDay: 'DD/MM/AAAA',
placeholderMonth: 'MM/AAAA',
placeholderYear: 'AAAA',
formatMonth: 'MM/A',
formatYear: 'A',
},
pt: {
placeholderDay: 'DD/MM/AAAA',
placeholderMonth: 'MM/AAAA',
placeholderYear: 'AAAA',
formatMonth: 'MM/Y',
formatYear: 'Y',
},
};
6 changes: 3 additions & 3 deletions packages/ng/date/select/date-select-input.component.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { Overlay, OverlayModule } from '@angular/cdk/overlay';
import { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input, Renderer2, ViewContainerRef } from '@angular/core';
import { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Input, Renderer2, ViewContainerRef, forwardRef } from '@angular/core';
import { AbstractControl, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from '@angular/forms';
import { ALuDateAdapter, ELuDateGranularity, LuDateGranularity, getIntl } from '@lucca-front/ng/core';
import { LuInputClearerComponent, LuInputDirective, LuInputDisplayerDirective } from '@lucca-front/ng/input';
@@ -48,9 +48,9 @@ export class LuDateSelectInputComponent<D> extends ALuSelectInputComponent<D> im
get format(): string {
switch (this.granularity) {
case ELuDateGranularity.year:
return this._intl.formatYear;
return 'Y';
case ELuDateGranularity.month:
return this._intl.formatMonth;
return 'MM/Y';
case ELuDateGranularity.day:
default:
return 'shortDate';
2 changes: 0 additions & 2 deletions packages/ng/date/select/date-select-input.translate.ts
Original file line number Diff line number Diff line change
@@ -10,8 +10,6 @@ export interface ILuDateSelectInputLabel {
placeholderDay: string;
placeholderMonth: string;
placeholderYear: string;
formatMonth: string;
formatYear: string;
}

export const luDateSelectInputTranslations: LuTranslation<ILuDateSelectInputLabel> = Translations;
Loading