@kirbydesign/designsystem 6.3.1 → 6.3.2-nopadding.0

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.
Files changed (35) hide show
  1. package/esm2020/lib/components/item/item.component.mjs +2 -2
  2. package/esm2020/lib/components/page/page.component.mjs +14 -13
  3. package/esm2020/lib/components/segmented-control/segmented-control.component.mjs +12 -6
  4. package/fesm2015/kirbydesign-designsystem.mjs +26 -19
  5. package/fesm2015/kirbydesign-designsystem.mjs.map +1 -1
  6. package/fesm2020/kirbydesign-designsystem.mjs +26 -19
  7. package/fesm2020/kirbydesign-designsystem.mjs.map +1 -1
  8. package/lib/components/page/page.component.d.ts +2 -2
  9. package/lib/components/segmented-control/segmented-control.component.d.ts +3 -2
  10. package/package.json +2 -2
  11. package/scss/_trigger-publish.scss +1 -0
  12. package/scss/_trigger.scss +1 -0
  13. package/scss/awesome-stylesheet.scss +1 -0
  14. package/scss/base/_awesome-partial.scss +1 -0
  15. package/scss/base/_index.scss +1 -0
  16. package/scss/base/_interaction-states.scss +1 -0
  17. package/scss/base/_link.scss +1 -0
  18. package/scss/base/index.scss +1 -0
  19. package/scss/interaction-state/_active.scss +1 -0
  20. package/scss/interaction-state/_focus.scss +1 -0
  21. package/scss/interaction-state/_hover.scss +1 -0
  22. package/scss/interaction-state/_index.scss +1 -0
  23. package/scss/interaction-state/_interaction-state.utilities.scss +1 -0
  24. package/scss/interaction-state/_layer.scss +1 -0
  25. package/scss/interaction-state/_state-layer.scss +1 -0
  26. package/scss/interaction-state/_utilities.scss +1 -0
  27. package/scss/interaction-state/ionic/_active.scss +1 -0
  28. package/scss/interaction-state/ionic/_hover.scss +1 -0
  29. package/scss/interaction-state/ionic/_index.scss +1 -0
  30. package/scss/interaction-states/_hover.scss +1 -0
  31. package/scss/interaction-states/_index.scss +1 -0
  32. package/scss/opt-out/_index.scss +1 -0
  33. package/scss/opt-out/_link.scss +1 -0
  34. package/src/lib/components/icon/README.md +16 -0
  35. package/README.md +0 -7
@@ -22,10 +22,10 @@ export class ItemComponent {
22
22
  }
23
23
  }
24
24
  /** @nocollapse */ ItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
25
- /** @nocollapse */ ItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: ItemComponent, selector: "kirby-item", inputs: { disabled: "disabled", selected: "selected", selectable: "selectable", reorderable: "reorderable", size: "size" }, host: { properties: { "class.selected": "this.selected", "class": "this.size" } }, ngImport: i0, template: "<ion-item\n lines=\"none\"\n [attr.disabled]=\"disabled\"\n [attr.button]=\"selectable ? true : null\"\n [attr.tabindex]=\"selectable ? null : 0\"\n detail=\"false\"\n (mousedown)=\"onMouseDown($event)\"\n>\n <div class=\"outside\" slot=\"start\">\n <ng-content select=\"[slot='outside']\"></ng-content>\n </div>\n <ng-content></ng-content>\n <ion-reorder slot=\"end\" *ngIf=\"reorderable\">\n <kirby-icon name=\"reorder\"></kirby-icon>\n </ion-reorder>\n</ion-item>\n", styles: [":host{display:block;position:relative}:host ion-item{--padding-top: var(--item-padding-top, 0px);--padding-bottom: var(--item-padding-bottom, 0px);font-size:14px;--min-height: 56px;--padding-start: 16px;--inner-padding-top: 8px;--inner-padding-bottom: 8px;--inner-padding-end: 16px;--background: var(--kirby-item-background, var(--kirby-white));--background-activated: var( --kirby-item-background-activated, var(--kirby-white-shade) );--background-activated-opacity: .99;--background-focused: var( --kirby-item-background-focused, var(--kirby-background-color) );--background-focused-opacity: 1;--background-hover: var(--kirby-item-background-hover, var(--kirby-background-color));--background-hover-opacity: 1}@media screen and (orientation: landscape){:host ion-item{--ion-safe-area-left: 0px;--ion-safe-area-right: 0px}}:host ion-item ::ng-deep>[slot=end]{margin-inline-start:0;margin-inline-end:0;text-align:right}:host ion-item ::ng-deep>time[slot=end]{margin-inline-start:12px}:host ion-item ::ng-deep>data[slot=end],:host ion-item ::ng-deep>[detail][slot=end],:host ion-item ::ng-deep>ion-reorder[slot=end]{margin-inline-start:16px}:host ion-item ::ng-deep>h1,:host ion-item ::ng-deep>h2,:host ion-item ::ng-deep>h3,:host ion-item ::ng-deep>h4,:host ion-item ::ng-deep>h5,:host ion-item ::ng-deep>h6,:host ion-item ::ng-deep>p,:host ion-item ::ng-deep>data{font-size:16px;line-height:24px;color:var(--kirby-text-color-black);display:block;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}:host ion-item ::ng-deep>h1.kirby-text-bold,:host ion-item ::ng-deep>h2.kirby-text-bold,:host ion-item ::ng-deep>h3.kirby-text-bold,:host ion-item ::ng-deep>h4.kirby-text-bold,:host ion-item ::ng-deep>h5.kirby-text-bold,:host ion-item ::ng-deep>h6.kirby-text-bold,:host ion-item ::ng-deep>p.kirby-text-bold,:host ion-item ::ng-deep>data.kirby-text-bold{font-weight:700}:host ion-item ::ng-deep>p{font-size:14px}:host ion-item ::ng-deep>[subtitle],:host ion-item ::ng-deep>[detail]{font-size:12px;line-height:16px}:host ion-item ::ng-deep>[subtitle]:not(:last-child){margin-bottom:4px}:host ion-item ::ng-deep>[detail]{color:var(--kirby-text-color-semi-dark)}:host ion-item ::ng-deep>:not([slot]){width:100%}:host ion-item ::ng-deep>input[slot=end],:host ion-item ::ng-deep>kirby-form-field[slot=end] input{margin-inline-start:16px;width:auto;text-align:right}:host.sm ion-item{--min-height: 44px}:host.xs ion-item{--min-height: 32px;--inner-padding-top: 4px;--inner-padding-bottom: 4px}:host .outside{left:4px;margin:0;position:absolute;width:16px;z-index:1}:host-context(kirby-dropdown) ion-item,:host-context(kirby-popover) ion-item{--min-height: 44px}:host-context(kirby-list-item:first-of-type) ion-item{--padding-top: 8px}:host-context(kirby-list-item:first-of-type kirby-card) ion-item{--padding-top: 0}:host-context(kirby-list-item:last-of-type) ion-item{--padding-bottom: 8px}:host-context(kirby-list-item:last-of-type kirby-card) ion-item{--padding-bottom: 0}:host(.selected) ion-item ::ng-deep>h1,:host(.selected) ion-item ::ng-deep>h2,:host(.selected) ion-item ::ng-deep>h3,:host(.selected) ion-item ::ng-deep>h4,:host(.selected) ion-item ::ng-deep>h5,:host(.selected) ion-item ::ng-deep>h6,:host(.selected) ion-item ::ng-deep>p,:host(.selected) ion-item ::ng-deep>data,:host-context(kirby-list .selected) ion-item ::ng-deep>h1,:host-context(kirby-list .selected) ion-item ::ng-deep>h2,:host-context(kirby-list .selected) ion-item ::ng-deep>h3,:host-context(kirby-list .selected) ion-item ::ng-deep>h4,:host-context(kirby-list .selected) ion-item ::ng-deep>h5,:host-context(kirby-list .selected) ion-item ::ng-deep>h6,:host-context(kirby-list .selected) ion-item ::ng-deep>p,:host-context(kirby-list .selected) ion-item ::ng-deep>data{font-weight:700}:host-context(.shape-rounded .is-single) ion-item{--border-radius: 16px}:host-context(.has-header .is-single) ion-item::part(native){border-top-left-radius:0;border-top-right-radius:0}:host-context(.has-footer .is-single) ion-item::part(native){border-bottom-left-radius:0;border-bottom-right-radius:0}:host-context(.shape-rounded.has-sections .list-items kirby-list-item:first-of-type) ion-item::part(native){border-top-left-radius:16px;border-top-right-radius:16px}\n"], components: [{ type: i1.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { type: i1.IonReorder, selector: "ion-reorder" }, { type: i2.IconComponent, selector: "kirby-icon", inputs: ["size", "name", "customName"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
25
+ /** @nocollapse */ ItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: ItemComponent, selector: "kirby-item", inputs: { disabled: "disabled", selected: "selected", selectable: "selectable", reorderable: "reorderable", size: "size" }, host: { properties: { "class.selected": "this.selected", "class": "this.size" } }, ngImport: i0, template: "<ion-item\n lines=\"none\"\n [attr.disabled]=\"disabled\"\n [attr.button]=\"selectable ? true : null\"\n [attr.tabindex]=\"selectable ? null : 0\"\n detail=\"false\"\n (mousedown)=\"onMouseDown($event)\"\n>\n <div class=\"outside\" slot=\"start\">\n <ng-content select=\"[slot='outside']\"></ng-content>\n </div>\n <ng-content></ng-content>\n <ion-reorder slot=\"end\" *ngIf=\"reorderable\">\n <kirby-icon name=\"reorder\"></kirby-icon>\n </ion-reorder>\n</ion-item>\n", styles: [":host{display:block;position:relative}:host ion-item{--padding-top: var(--item-padding-top, 0px);--padding-bottom: var(--item-padding-bottom, 0px);font-size:14px;--min-height: 56px;--padding-start: 16px;--inner-padding-top: 8px;--inner-padding-bottom: 8px;--inner-padding-end: 16px;--background: var(--kirby-item-background, var(--kirby-white));--background-activated: var( --kirby-item-background-activated, var(--kirby-white-shade) );--background-activated-opacity: .99;--background-focused: var( --kirby-item-background-focused, var(--kirby-background-color) );--background-focused-opacity: 1;--background-hover: var(--kirby-item-background-hover, var(--kirby-background-color));--background-hover-opacity: 1}@media screen and (orientation: landscape){:host ion-item{--ion-safe-area-left: 0px;--ion-safe-area-right: 0px}}:host ion-item ::ng-deep>[slot=end]{margin-inline-start:0;margin-inline-end:0;text-align:right}:host ion-item ::ng-deep>time[slot=end]{margin-inline-start:12px}:host ion-item ::ng-deep>data[slot=end],:host ion-item ::ng-deep>[detail][slot=end],:host ion-item ::ng-deep>ion-reorder[slot=end]{margin-inline-start:16px}:host ion-item ::ng-deep>h1,:host ion-item ::ng-deep>h2,:host ion-item ::ng-deep>h3,:host ion-item ::ng-deep>h4,:host ion-item ::ng-deep>h5,:host ion-item ::ng-deep>h6,:host ion-item ::ng-deep>p,:host ion-item ::ng-deep>data{font-size:16px;line-height:24px;color:var(--kirby-text-color-black);display:block;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}:host ion-item ::ng-deep>h1.kirby-text-bold,:host ion-item ::ng-deep>h2.kirby-text-bold,:host ion-item ::ng-deep>h3.kirby-text-bold,:host ion-item ::ng-deep>h4.kirby-text-bold,:host ion-item ::ng-deep>h5.kirby-text-bold,:host ion-item ::ng-deep>h6.kirby-text-bold,:host ion-item ::ng-deep>p.kirby-text-bold,:host ion-item ::ng-deep>data.kirby-text-bold{font-weight:700}:host ion-item ::ng-deep>p{font-size:14px}:host ion-item ::ng-deep>[subtitle],:host ion-item ::ng-deep>[detail]{font-size:12px;line-height:16px}:host ion-item ::ng-deep>[subtitle]:not(:last-child){margin-bottom:4px}:host ion-item ::ng-deep>[detail]{color:var(--kirby-text-color-semi-dark)}:host ion-item ::ng-deep>:not([slot]){width:100%}:host ion-item ::ng-deep>input[slot=end],:host ion-item ::ng-deep>kirby-form-field[slot=end] input{margin-inline-start:16px;width:auto;text-align:right}:host.sm ion-item{--min-height: 44px}:host.xs ion-item{--min-height: 32px;--inner-padding-top: 4px;--inner-padding-bottom: 4px}:host .outside{left:4px;margin:0;position:absolute;width:16px;z-index:1}:host-context(kirby-dropdown) ion-item,:host-context(kirby-popover) ion-item{--min-height: 44px}:host-context(kirby-list-item:first-of-type kirby-card) ion-item{--padding-top: 0}:host-context(kirby-list-item:last-of-type kirby-card) ion-item{--padding-bottom: 0}:host(.selected) ion-item ::ng-deep>h1,:host(.selected) ion-item ::ng-deep>h2,:host(.selected) ion-item ::ng-deep>h3,:host(.selected) ion-item ::ng-deep>h4,:host(.selected) ion-item ::ng-deep>h5,:host(.selected) ion-item ::ng-deep>h6,:host(.selected) ion-item ::ng-deep>p,:host(.selected) ion-item ::ng-deep>data,:host-context(kirby-list .selected) ion-item ::ng-deep>h1,:host-context(kirby-list .selected) ion-item ::ng-deep>h2,:host-context(kirby-list .selected) ion-item ::ng-deep>h3,:host-context(kirby-list .selected) ion-item ::ng-deep>h4,:host-context(kirby-list .selected) ion-item ::ng-deep>h5,:host-context(kirby-list .selected) ion-item ::ng-deep>h6,:host-context(kirby-list .selected) ion-item ::ng-deep>p,:host-context(kirby-list .selected) ion-item ::ng-deep>data{font-weight:700}:host-context(.shape-rounded .is-single) ion-item{--border-radius: 16px}:host-context(.has-header .is-single) ion-item::part(native){border-top-left-radius:0;border-top-right-radius:0}:host-context(.has-footer .is-single) ion-item::part(native){border-bottom-left-radius:0;border-bottom-right-radius:0}:host-context(.shape-rounded.has-sections .list-items kirby-list-item:first-of-type) ion-item::part(native){border-top-left-radius:16px;border-top-right-radius:16px}\n"], components: [{ type: i1.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { type: i1.IonReorder, selector: "ion-reorder" }, { type: i2.IconComponent, selector: "kirby-icon", inputs: ["size", "name", "customName"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
26
26
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ItemComponent, decorators: [{
27
27
  type: Component,
28
- args: [{ selector: 'kirby-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ion-item\n lines=\"none\"\n [attr.disabled]=\"disabled\"\n [attr.button]=\"selectable ? true : null\"\n [attr.tabindex]=\"selectable ? null : 0\"\n detail=\"false\"\n (mousedown)=\"onMouseDown($event)\"\n>\n <div class=\"outside\" slot=\"start\">\n <ng-content select=\"[slot='outside']\"></ng-content>\n </div>\n <ng-content></ng-content>\n <ion-reorder slot=\"end\" *ngIf=\"reorderable\">\n <kirby-icon name=\"reorder\"></kirby-icon>\n </ion-reorder>\n</ion-item>\n", styles: [":host{display:block;position:relative}:host ion-item{--padding-top: var(--item-padding-top, 0px);--padding-bottom: var(--item-padding-bottom, 0px);font-size:14px;--min-height: 56px;--padding-start: 16px;--inner-padding-top: 8px;--inner-padding-bottom: 8px;--inner-padding-end: 16px;--background: var(--kirby-item-background, var(--kirby-white));--background-activated: var( --kirby-item-background-activated, var(--kirby-white-shade) );--background-activated-opacity: .99;--background-focused: var( --kirby-item-background-focused, var(--kirby-background-color) );--background-focused-opacity: 1;--background-hover: var(--kirby-item-background-hover, var(--kirby-background-color));--background-hover-opacity: 1}@media screen and (orientation: landscape){:host ion-item{--ion-safe-area-left: 0px;--ion-safe-area-right: 0px}}:host ion-item ::ng-deep>[slot=end]{margin-inline-start:0;margin-inline-end:0;text-align:right}:host ion-item ::ng-deep>time[slot=end]{margin-inline-start:12px}:host ion-item ::ng-deep>data[slot=end],:host ion-item ::ng-deep>[detail][slot=end],:host ion-item ::ng-deep>ion-reorder[slot=end]{margin-inline-start:16px}:host ion-item ::ng-deep>h1,:host ion-item ::ng-deep>h2,:host ion-item ::ng-deep>h3,:host ion-item ::ng-deep>h4,:host ion-item ::ng-deep>h5,:host ion-item ::ng-deep>h6,:host ion-item ::ng-deep>p,:host ion-item ::ng-deep>data{font-size:16px;line-height:24px;color:var(--kirby-text-color-black);display:block;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}:host ion-item ::ng-deep>h1.kirby-text-bold,:host ion-item ::ng-deep>h2.kirby-text-bold,:host ion-item ::ng-deep>h3.kirby-text-bold,:host ion-item ::ng-deep>h4.kirby-text-bold,:host ion-item ::ng-deep>h5.kirby-text-bold,:host ion-item ::ng-deep>h6.kirby-text-bold,:host ion-item ::ng-deep>p.kirby-text-bold,:host ion-item ::ng-deep>data.kirby-text-bold{font-weight:700}:host ion-item ::ng-deep>p{font-size:14px}:host ion-item ::ng-deep>[subtitle],:host ion-item ::ng-deep>[detail]{font-size:12px;line-height:16px}:host ion-item ::ng-deep>[subtitle]:not(:last-child){margin-bottom:4px}:host ion-item ::ng-deep>[detail]{color:var(--kirby-text-color-semi-dark)}:host ion-item ::ng-deep>:not([slot]){width:100%}:host ion-item ::ng-deep>input[slot=end],:host ion-item ::ng-deep>kirby-form-field[slot=end] input{margin-inline-start:16px;width:auto;text-align:right}:host.sm ion-item{--min-height: 44px}:host.xs ion-item{--min-height: 32px;--inner-padding-top: 4px;--inner-padding-bottom: 4px}:host .outside{left:4px;margin:0;position:absolute;width:16px;z-index:1}:host-context(kirby-dropdown) ion-item,:host-context(kirby-popover) ion-item{--min-height: 44px}:host-context(kirby-list-item:first-of-type) ion-item{--padding-top: 8px}:host-context(kirby-list-item:first-of-type kirby-card) ion-item{--padding-top: 0}:host-context(kirby-list-item:last-of-type) ion-item{--padding-bottom: 8px}:host-context(kirby-list-item:last-of-type kirby-card) ion-item{--padding-bottom: 0}:host(.selected) ion-item ::ng-deep>h1,:host(.selected) ion-item ::ng-deep>h2,:host(.selected) ion-item ::ng-deep>h3,:host(.selected) ion-item ::ng-deep>h4,:host(.selected) ion-item ::ng-deep>h5,:host(.selected) ion-item ::ng-deep>h6,:host(.selected) ion-item ::ng-deep>p,:host(.selected) ion-item ::ng-deep>data,:host-context(kirby-list .selected) ion-item ::ng-deep>h1,:host-context(kirby-list .selected) ion-item ::ng-deep>h2,:host-context(kirby-list .selected) ion-item ::ng-deep>h3,:host-context(kirby-list .selected) ion-item ::ng-deep>h4,:host-context(kirby-list .selected) ion-item ::ng-deep>h5,:host-context(kirby-list .selected) ion-item ::ng-deep>h6,:host-context(kirby-list .selected) ion-item ::ng-deep>p,:host-context(kirby-list .selected) ion-item ::ng-deep>data{font-weight:700}:host-context(.shape-rounded .is-single) ion-item{--border-radius: 16px}:host-context(.has-header .is-single) ion-item::part(native){border-top-left-radius:0;border-top-right-radius:0}:host-context(.has-footer .is-single) ion-item::part(native){border-bottom-left-radius:0;border-bottom-right-radius:0}:host-context(.shape-rounded.has-sections .list-items kirby-list-item:first-of-type) ion-item::part(native){border-top-left-radius:16px;border-top-right-radius:16px}\n"] }]
28
+ args: [{ selector: 'kirby-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ion-item\n lines=\"none\"\n [attr.disabled]=\"disabled\"\n [attr.button]=\"selectable ? true : null\"\n [attr.tabindex]=\"selectable ? null : 0\"\n detail=\"false\"\n (mousedown)=\"onMouseDown($event)\"\n>\n <div class=\"outside\" slot=\"start\">\n <ng-content select=\"[slot='outside']\"></ng-content>\n </div>\n <ng-content></ng-content>\n <ion-reorder slot=\"end\" *ngIf=\"reorderable\">\n <kirby-icon name=\"reorder\"></kirby-icon>\n </ion-reorder>\n</ion-item>\n", styles: [":host{display:block;position:relative}:host ion-item{--padding-top: var(--item-padding-top, 0px);--padding-bottom: var(--item-padding-bottom, 0px);font-size:14px;--min-height: 56px;--padding-start: 16px;--inner-padding-top: 8px;--inner-padding-bottom: 8px;--inner-padding-end: 16px;--background: var(--kirby-item-background, var(--kirby-white));--background-activated: var( --kirby-item-background-activated, var(--kirby-white-shade) );--background-activated-opacity: .99;--background-focused: var( --kirby-item-background-focused, var(--kirby-background-color) );--background-focused-opacity: 1;--background-hover: var(--kirby-item-background-hover, var(--kirby-background-color));--background-hover-opacity: 1}@media screen and (orientation: landscape){:host ion-item{--ion-safe-area-left: 0px;--ion-safe-area-right: 0px}}:host ion-item ::ng-deep>[slot=end]{margin-inline-start:0;margin-inline-end:0;text-align:right}:host ion-item ::ng-deep>time[slot=end]{margin-inline-start:12px}:host ion-item ::ng-deep>data[slot=end],:host ion-item ::ng-deep>[detail][slot=end],:host ion-item ::ng-deep>ion-reorder[slot=end]{margin-inline-start:16px}:host ion-item ::ng-deep>h1,:host ion-item ::ng-deep>h2,:host ion-item ::ng-deep>h3,:host ion-item ::ng-deep>h4,:host ion-item ::ng-deep>h5,:host ion-item ::ng-deep>h6,:host ion-item ::ng-deep>p,:host ion-item ::ng-deep>data{font-size:16px;line-height:24px;color:var(--kirby-text-color-black);display:block;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}:host ion-item ::ng-deep>h1.kirby-text-bold,:host ion-item ::ng-deep>h2.kirby-text-bold,:host ion-item ::ng-deep>h3.kirby-text-bold,:host ion-item ::ng-deep>h4.kirby-text-bold,:host ion-item ::ng-deep>h5.kirby-text-bold,:host ion-item ::ng-deep>h6.kirby-text-bold,:host ion-item ::ng-deep>p.kirby-text-bold,:host ion-item ::ng-deep>data.kirby-text-bold{font-weight:700}:host ion-item ::ng-deep>p{font-size:14px}:host ion-item ::ng-deep>[subtitle],:host ion-item ::ng-deep>[detail]{font-size:12px;line-height:16px}:host ion-item ::ng-deep>[subtitle]:not(:last-child){margin-bottom:4px}:host ion-item ::ng-deep>[detail]{color:var(--kirby-text-color-semi-dark)}:host ion-item ::ng-deep>:not([slot]){width:100%}:host ion-item ::ng-deep>input[slot=end],:host ion-item ::ng-deep>kirby-form-field[slot=end] input{margin-inline-start:16px;width:auto;text-align:right}:host.sm ion-item{--min-height: 44px}:host.xs ion-item{--min-height: 32px;--inner-padding-top: 4px;--inner-padding-bottom: 4px}:host .outside{left:4px;margin:0;position:absolute;width:16px;z-index:1}:host-context(kirby-dropdown) ion-item,:host-context(kirby-popover) ion-item{--min-height: 44px}:host-context(kirby-list-item:first-of-type kirby-card) ion-item{--padding-top: 0}:host-context(kirby-list-item:last-of-type kirby-card) ion-item{--padding-bottom: 0}:host(.selected) ion-item ::ng-deep>h1,:host(.selected) ion-item ::ng-deep>h2,:host(.selected) ion-item ::ng-deep>h3,:host(.selected) ion-item ::ng-deep>h4,:host(.selected) ion-item ::ng-deep>h5,:host(.selected) ion-item ::ng-deep>h6,:host(.selected) ion-item ::ng-deep>p,:host(.selected) ion-item ::ng-deep>data,:host-context(kirby-list .selected) ion-item ::ng-deep>h1,:host-context(kirby-list .selected) ion-item ::ng-deep>h2,:host-context(kirby-list .selected) ion-item ::ng-deep>h3,:host-context(kirby-list .selected) ion-item ::ng-deep>h4,:host-context(kirby-list .selected) ion-item ::ng-deep>h5,:host-context(kirby-list .selected) ion-item ::ng-deep>h6,:host-context(kirby-list .selected) ion-item ::ng-deep>p,:host-context(kirby-list .selected) ion-item ::ng-deep>data{font-weight:700}:host-context(.shape-rounded .is-single) ion-item{--border-radius: 16px}:host-context(.has-header .is-single) ion-item::part(native){border-top-left-radius:0;border-top-right-radius:0}:host-context(.has-footer .is-single) ion-item::part(native){border-bottom-left-radius:0;border-bottom-right-radius:0}:host-context(.shape-rounded.has-sections .list-items kirby-list-item:first-of-type) ion-item::part(native){border-top-left-radius:16px;border-top-right-radius:16px}\n"] }]
29
29
  }], propDecorators: { disabled: [{
30
30
  type: Input
31
31
  }], selected: [{
@@ -180,7 +180,6 @@ export class PageComponent {
180
180
  this.refresh = new EventEmitter();
181
181
  this.backButtonClick = new EventEmitter();
182
182
  this.pageTitleIntersectionObserverRef = this.pageTitleIntersectionObserver();
183
- this.urls = [];
184
183
  this.ngOnDestroy$ = new Subject();
185
184
  this.navigationStart$ = this.router.events.pipe(takeUntil(this.ngOnDestroy$), filter((event) => event instanceof NavigationStart));
186
185
  this.navigationEnd$ = this.router.events.pipe(takeUntil(this.ngOnDestroy$), filter((event) => event instanceof NavigationEnd));
@@ -211,15 +210,19 @@ export class PageComponent {
211
210
  }
212
211
  }
213
212
  ngAfterViewInit() {
213
+ // This instance has observed a page enter so register the correct url for this instance
214
+ this.url = this.router.url;
215
+ this.onEnter();
216
+ // Watch navigation events for page enter and leave
214
217
  this.navigationStart$.subscribe((event) => {
215
- if (!this.urls.includes(event.url) &&
216
- !this.modalNavigationService.isModalRoute(event.url) &&
217
- !this.modalNavigationService.isModalRoute(this.router.url)) {
218
+ if (event.url !== this.url &&
219
+ !this.modalNavigationService.isModalRoute(this.url) &&
220
+ !this.modalNavigationService.isModalRoute(event.url)) {
218
221
  this.onLeave();
219
222
  }
220
223
  });
221
224
  this.navigationEnd$.subscribe((event) => {
222
- if (this.urls.includes(event.urlAfterRedirects)) {
225
+ if (event.urlAfterRedirects === this.url) {
223
226
  this.onEnter();
224
227
  }
225
228
  });
@@ -229,10 +232,6 @@ export class PageComponent {
229
232
  this.interceptBackButtonClicksSetup();
230
233
  }
231
234
  ngAfterContentChecked() {
232
- if (!this.urls.includes(this.router.url)) {
233
- this.urls.push(this.router.url);
234
- this.onEnter();
235
- }
236
235
  this.initializeTitle();
237
236
  this.initializeActions();
238
237
  this.initializeContent();
@@ -252,20 +251,22 @@ export class PageComponent {
252
251
  });
253
252
  }
254
253
  onEnter() {
255
- if (this.hasEntered)
254
+ if (this.isActive)
256
255
  return;
257
- this.hasEntered = true;
256
+ this.isActive = true;
258
257
  this.enter.emit();
259
258
  if (this.pageTitle) {
260
259
  this.pageTitleIntersectionObserverRef.observe(this.pageTitle.nativeElement);
261
260
  }
262
261
  }
263
262
  onLeave() {
263
+ if (!this.isActive)
264
+ return;
265
+ this.isActive = false;
264
266
  this.leave.emit();
265
267
  if (this.pageTitle) {
266
268
  this.pageTitleIntersectionObserverRef.unobserve(this.pageTitle.nativeElement);
267
269
  }
268
- this.hasEntered = false;
269
270
  if (this.tabBarBottomHidden && this.tabsComponent) {
270
271
  this.tabsComponent.tabBarBottomHidden = false;
271
272
  }
@@ -439,4 +440,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImpor
439
440
  type: HostListener,
440
441
  args: ['window:keyboardWillHide']
441
442
  }] } });
442
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../../../libs/designsystem/src/lib/components/page/page.component.ts","../../../../../../../libs/designsystem/src/lib/components/page/page.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  SkipSelf,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { NavigationEnd, NavigationStart, Router, RouterEvent } from '@angular/router';\nimport { IonBackButtonDelegate, IonContent, IonFooter, IonHeader } from '@ionic/angular';\nimport { Observable, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\n\nimport { KirbyAnimation } from '../../animation/kirby-animation';\nimport { FitHeadingConfig } from '../../directives/fit-heading/fit-heading.directive';\nimport { WindowRef } from '../../types/window-ref';\nimport { ModalWrapperComponent } from '../modal/modal-wrapper/modal-wrapper.component';\nimport { ModalNavigationService } from '../modal/services/modal-navigation.service';\nimport {\n  ModalElementComponent,\n  ModalElementsAdvertiser,\n  ModalElementType,\n} from '../modal/services/modal.interfaces';\nimport { selectedTabClickEvent } from '../tabs/tab-button/tab-button.events';\nimport { TabsComponent } from '../tabs/tabs.component';\n\ntype stickyConfig = { sticky: boolean };\ntype fixedConfig = { fixed: boolean };\n\n/**\n * Event emitted when \"pull-to-refresh\" begins.\n */\nexport interface PullToRefreshEvent {\n  /**\n   * Invoke this callback-method when action to perform upon \"pull-to-refresh\" completes.\n   */\n  complete();\n}\n\n@Directive({\n  selector: '[kirbyPageTitle]',\n})\nexport class PageTitleDirective {}\n\n@Directive({\n  selector: '[kirbyPageSubtitle]',\n})\nexport class PageSubtitleDirective {}\n\n@Directive({\n  selector: '[kirbyPageToolbarTitle]',\n})\nexport class PageToolbarTitleDirective {}\n\n@Directive({\n  selector: '[kirbyPageActions]',\n})\nexport class PageActionsDirective {\n  @Input('kirbyPageActions') config: stickyConfig | fixedConfig;\n  private readonly stickyDefault = true;\n  private readonly fixedDefault = false;\n\n  constructor(public template: TemplateRef<any>) {}\n\n  get isSticky(): boolean {\n    return this.config ? (this.config as stickyConfig).sticky : this.stickyDefault;\n  }\n\n  get isFixed(): boolean {\n    return this.config ? (this.config as fixedConfig).fixed : this.fixedDefault;\n  }\n}\n\n@Directive({\n  selector: '[kirbyPageContent]',\n})\nexport class PageContentDirective {\n  @Input('kirbyPageContent') config: fixedConfig;\n\n  constructor(public template: TemplateRef<any>) {}\n\n  get isFixed(): boolean {\n    return this.config && this.config.fixed;\n  }\n}\n\n@Component({\n  selector: 'kirby-page-progress',\n  template: ` <ng-content></ng-content> `,\n  styles: [':host {display: flex}'],\n})\nexport class PageProgressComponent extends ModalElementComponent implements OnInit {\n  // TODO: Find alternative implementation, which aligns with future page configuration / consumption\n  // This implementation was chosen over expanding `moveChild` method in component wrapper with yet another scenario\n  @HostBinding('attr.slot') slot = 'start';\n\n  constructor(\n    @Optional() @SkipSelf() private modalWrapper: ModalWrapperComponent,\n    @Optional() modalElementsAdvertiser: ModalElementsAdvertiser,\n    elementRef: ElementRef<HTMLElement>\n  ) {\n    super(ModalElementType.PAGE_PROGRESS, elementRef, modalElementsAdvertiser);\n  }\n\n  ngOnInit(): void {\n    if (this.modalWrapper && this.modalWrapper.config.flavor === 'drawer') {\n      this.slot = 'end';\n    }\n  }\n}\n@Component({\n  selector: 'kirby-page-title',\n  template: ` <ng-content></ng-content> `,\n})\nexport class PageTitleComponent extends ModalElementComponent {\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    @Optional() modalElementsAdvertiser: ModalElementsAdvertiser\n  ) {\n    super(ModalElementType.TITLE, elementRef, modalElementsAdvertiser);\n  }\n}\n\n@Component({\n  selector: 'kirby-page-content',\n  template: ` <ng-content></ng-content> `,\n})\nexport class PageContentComponent {}\n\n@Component({\n  selector: 'kirby-page-actions',\n  template: ` <ng-content select=\"button[kirby-button]\"></ng-content> `,\n})\nexport class PageActionsComponent {}\n\n@Component({\n  selector: 'kirby-page',\n  templateUrl: './page.component.html',\n  styleUrls: ['./page.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PageComponent\n  implements OnInit, OnDestroy, AfterViewInit, AfterContentChecked, OnChanges\n{\n  @Input() title: string;\n  @Input() subtitle: string;\n  @Input() toolbarTitle: string;\n  @Input() titleAlignment: 'left' | 'center' | 'right' = 'left';\n  @Input() defaultBackHref: string;\n  @Input() hideBackButton: boolean;\n  @Input() titleMaxLines: number;\n\n  private _tabBarBottomHidden: boolean;\n  public get tabBarBottomHidden(): boolean {\n    return this._tabBarBottomHidden;\n  }\n  @Input()\n  public set tabBarBottomHidden(value: boolean) {\n    if (this.tabsComponent) {\n      // as we are setting a class on tabs, we need this to happen in a separate cd cycle\n      setTimeout(() => (this.tabsComponent.tabBarBottomHidden = value));\n    }\n    this._tabBarBottomHidden = value;\n  }\n\n  @Output() enter = new EventEmitter<void>();\n  @Output() leave = new EventEmitter<void>();\n  @Output() refresh = new EventEmitter<PullToRefreshEvent>();\n  @Output() backButtonClick = new EventEmitter<Event>();\n\n  @ViewChild(IonContent, { static: true }) private content: IonContent;\n  @ViewChild(IonContent, { static: true, read: ElementRef })\n  private ionContentElement: ElementRef<HTMLIonContentElement>;\n  @ViewChild(IonHeader, { static: true, read: ElementRef })\n  ionHeaderElement: ElementRef<HTMLIonHeaderElement>;\n  @ViewChild(IonFooter, { static: true, read: ElementRef })\n  private ionFooterElement: ElementRef<HTMLIonFooterElement>;\n\n  @ViewChild(IonBackButtonDelegate, { static: false })\n  private backButtonDelegate: IonBackButtonDelegate;\n  @ViewChild('pageTitle', { static: false, read: ElementRef })\n  private pageTitle: ElementRef;\n\n  @ViewChild('simpleTitleTemplate', { static: true, read: TemplateRef })\n  private simpleTitleTemplate: TemplateRef<any>;\n  @ViewChild('simpleToolbarTitleTemplate', { static: true, read: TemplateRef })\n  private simpleToolbarTitleTemplate: TemplateRef<any>;\n  @ContentChild(PageToolbarTitleDirective, { static: false, read: TemplateRef })\n  private customToolbarTitleTemplate: TemplateRef<any>;\n  @ContentChild(PageTitleDirective, { static: false, read: TemplateRef })\n  customTitleTemplate: TemplateRef<any>;\n  @ContentChild(PageSubtitleDirective, { static: false, read: TemplateRef })\n  customSubtitleTemplate: TemplateRef<any>;\n  @ContentChildren(PageActionsDirective)\n  customActions: QueryList<PageActionsDirective>;\n  @ContentChildren(PageContentDirective)\n  private customContent: QueryList<PageContentDirective>;\n\n  hasPageTitle: boolean;\n  hasPageSubtitle: boolean;\n  hasActionsInPage: boolean;\n  toolbarTitleVisible: boolean;\n  toolbarFixedActionsVisible: boolean;\n  toolbarStickyActionsVisible: boolean;\n\n  fitHeadingConfig: FitHeadingConfig;\n\n  toolbarTitleTemplate: TemplateRef<any>;\n  customContentTemplate: TemplateRef<any>;\n  pageActionsTemplate: TemplateRef<any>;\n  fixedContentTemplate: TemplateRef<any>;\n  stickyActionsTemplate: TemplateRef<any>;\n  fixedActionsTemplate: TemplateRef<any>;\n  private pageTitleIntersectionObserverRef: IntersectionObserver =\n    this.pageTitleIntersectionObserver();\n  private urls: string[] = [];\n  private hasEntered: boolean;\n\n  private ngOnDestroy$ = new Subject();\n  private navigationStart$: Observable<RouterEvent> = this.router.events.pipe(\n    takeUntil(this.ngOnDestroy$),\n    filter((event: RouterEvent) => event instanceof NavigationStart)\n  );\n\n  private navigationEnd$: Observable<RouterEvent> = this.router.events.pipe(\n    takeUntil(this.ngOnDestroy$),\n    filter((event: RouterEvent) => event instanceof NavigationEnd)\n  );\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private router: Router,\n    private changeDetectorRef: ChangeDetectorRef,\n    private windowRef: WindowRef,\n    private modalNavigationService: ModalNavigationService,\n    @Optional() @SkipSelf() private tabsComponent: TabsComponent\n  ) {}\n\n  ngOnInit(): void {\n    this.removeWrapper();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.titleMaxLines) {\n      this.fitHeadingConfig = {\n        ...this.fitHeadingConfig,\n        maxLines: changes.titleMaxLines.currentValue,\n      };\n    }\n    if (changes.subtitle && !changes.subtitle.isFirstChange) {\n      this.subtitle = changes.title.currentValue;\n      this.hasPageSubtitle = this.subtitle !== undefined;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.navigationStart$.subscribe((event: NavigationStart) => {\n      if (\n        !this.urls.includes(event.url) &&\n        !this.modalNavigationService.isModalRoute(event.url) &&\n        !this.modalNavigationService.isModalRoute(this.router.url)\n      ) {\n        this.onLeave();\n      }\n    });\n\n    this.navigationEnd$.subscribe((event: NavigationEnd) => {\n      if (this.urls.includes(event.urlAfterRedirects)) {\n        this.onEnter();\n      }\n    });\n\n    this.windowRef.nativeWindow.addEventListener(selectedTabClickEvent, () => {\n      this.content.scrollToTop(KirbyAnimation.Duration.LONG);\n    });\n\n    this.interceptBackButtonClicksSetup();\n  }\n\n  ngAfterContentChecked(): void {\n    if (!this.urls.includes(this.router.url)) {\n      this.urls.push(this.router.url);\n      this.onEnter();\n    }\n\n    this.initializeTitle();\n    this.initializeActions();\n    this.initializeContent();\n    this.changeDetectorRef.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.ngOnDestroy$.next();\n    this.ngOnDestroy$.complete();\n\n    this.pageTitleIntersectionObserverRef.disconnect();\n    this.windowRef.nativeWindow.removeEventListener(selectedTabClickEvent, () => {\n      this.content.scrollToTop(KirbyAnimation.Duration.LONG);\n    });\n  }\n\n  delegateRefreshEvent(event: any): void {\n    this.refresh.emit({\n      complete: event.target.complete.bind(event.target),\n    });\n  }\n\n  private onEnter() {\n    if (this.hasEntered) return;\n    this.hasEntered = true;\n\n    this.enter.emit();\n    if (this.pageTitle) {\n      this.pageTitleIntersectionObserverRef.observe(this.pageTitle.nativeElement);\n    }\n  }\n\n  private onLeave() {\n    this.leave.emit();\n    if (this.pageTitle) {\n      this.pageTitleIntersectionObserverRef.unobserve(this.pageTitle.nativeElement);\n    }\n    this.hasEntered = false;\n\n    if (this.tabBarBottomHidden && this.tabsComponent) {\n      this.tabsComponent.tabBarBottomHidden = false;\n    }\n  }\n\n  private interceptBackButtonClicksSetup() {\n    // Intercept back-button click events, defaulting to the built-in click-handler.\n    if (this.backButtonClick.observers.length === 0) {\n      this.backButtonClick\n        .pipe(takeUntil(this.ngOnDestroy$))\n        .subscribe(this.backButtonDelegate.onClick.bind(this.backButtonDelegate));\n    }\n    this.backButtonDelegate.onClick = (event: Event) => {\n      this.backButtonClick.emit(event);\n    };\n  }\n\n  private initializeTitle() {\n    // Ensures initializeTitle() won't run, if already initialized\n    if (this.hasPageTitle) return;\n    this.hasPageTitle = this.title !== undefined || !!this.customTitleTemplate;\n    this.toolbarTitleVisible = !this.hasPageTitle;\n    this.hasPageSubtitle = this.subtitle !== undefined || !!this.customSubtitleTemplate;\n\n    if (this.hasPageTitle) {\n      setTimeout(() => {\n        this.pageTitleIntersectionObserverRef.observe(this.pageTitle.nativeElement);\n      });\n    }\n\n    const defaultTitleTemplate = this.customTitleTemplate || this.simpleTitleTemplate;\n    // tslint:disable:prettier\n    // prettier-ignore\n    this.toolbarTitleTemplate = this.customToolbarTitleTemplate\n      ? this.customToolbarTitleTemplate\n      : typeof this.toolbarTitle === 'string'\n        ? this.simpleToolbarTitleTemplate\n        : defaultTitleTemplate;\n  }\n\n  private initializeActions() {\n    this.customActions.forEach((pageAction) => {\n      if (pageAction.isFixed) {\n        this.fixedActionsTemplate = pageAction.template;\n        this.toolbarFixedActionsVisible = true;\n      } else {\n        this.pageActionsTemplate = pageAction.template;\n        if (pageAction.isSticky) {\n          this.stickyActionsTemplate = pageAction.template;\n        }\n      }\n    });\n    this.hasActionsInPage = !!this.pageActionsTemplate;\n  }\n\n  private initializeContent() {\n    this.customContent.forEach((content) => {\n      if (content.isFixed) {\n        this.fixedContentTemplate = content.template;\n      } else {\n        this.customContentTemplate = content.template;\n      }\n    });\n  }\n\n  private removeWrapper() {\n    const parent = this.elementRef.nativeElement.parentNode;\n    this.renderer.removeChild(parent, this.elementRef.nativeElement);\n    this.renderer.appendChild(parent, this.ionHeaderElement.nativeElement);\n    this.renderer.appendChild(parent, this.ionContentElement.nativeElement);\n    this.renderer.appendChild(parent, this.ionFooterElement.nativeElement);\n  }\n\n  private pageTitleIntersectionObserver() {\n    const options = {\n      rootMargin: '0px',\n    };\n\n    let initialized = false;\n    const callback = (entries) => {\n      if (initialized) {\n        this.toolbarTitleVisible = !entries[0].isIntersecting;\n        this.toolbarStickyActionsVisible = !entries[0].isIntersecting;\n        this.changeDetectorRef.detectChanges();\n      } else {\n        initialized = true;\n      }\n    };\n    return new IntersectionObserver(callback, options);\n  }\n\n  @HostListener('window:keyboardWillShow', ['$event'])\n  _onKeyboardWillShow(info?: { keyboardHeight: number }) {\n    if (info && info.keyboardHeight) {\n      this.ionContentElement.nativeElement.style.setProperty(\n        '--keyboard-offset',\n        `${info.keyboardHeight}px`\n      );\n    }\n  }\n\n  @HostListener('window:keyboardWillHide')\n  _onKeyboardWillHide() {\n    this.ionContentElement.nativeElement.style.setProperty('--keyboard-offset', '0px');\n  }\n}\n","<ion-header>\n  <ion-toolbar>\n    <ion-buttons slot=\"start\">\n      <ion-back-button\n        text=\"\"\n        [defaultHref]=\"defaultBackHref\"\n        icon=\"assets/kirby/icons/svg/arrow-back.svg\"\n        [style.visibility]=\"hideBackButton ? 'hidden' : null\"\n      ></ion-back-button>\n    </ion-buttons>\n    <ion-title>\n      <div class=\"toolbar-title hide\" [class.fade-in]=\"toolbarTitleVisible\">\n        <ng-container *ngTemplateOutlet=\"toolbarTitleTemplate\"></ng-container>\n      </div>\n    </ion-title>\n    <ion-buttons\n      class=\"hide\"\n      slot=\"primary\"\n      [class.fade-in]=\"toolbarStickyActionsVisible && stickyActionsTemplate\"\n    >\n      <ng-container *ngTemplateOutlet=\"stickyActionsTemplate\"></ng-container>\n    </ion-buttons>\n    <ion-buttons\n      class=\"hide\"\n      slot=\"secondary\"\n      [class.fade-in]=\"toolbarFixedActionsVisible && fixedActionsTemplate\"\n    >\n      <ng-container *ngTemplateOutlet=\"fixedActionsTemplate\"></ng-container>\n    </ion-buttons>\n  </ion-toolbar>\n</ion-header>\n\n<ion-content scrollEvents=\"true\" forceOverscroll=\"false\">\n  <ion-refresher\n    *ngIf=\"refresh.observers.length > 0\"\n    (ionRefresh)=\"delegateRefreshEvent($event)\"\n    slot=\"fixed\"\n  >\n    <kirby-spinner></kirby-spinner>\n  </ion-refresher>\n\n  <div class=\"content-inner\">\n    <div\n      class=\"page-header\"\n      *ngIf=\"hasPageTitle\"\n      [ngClass]=\"{\n        'text-center': titleAlignment === 'center',\n        'text-right': titleAlignment === 'right'\n      }\"\n    >\n      <div #pageTitle class=\"page-title\" [class.has-actions]=\"hasActionsInPage\">\n        <ng-container\n          *ngTemplateOutlet=\"customTitleTemplate || defaultPageTitleTemplate\"\n        ></ng-container>\n        <ng-container\n          *ngTemplateOutlet=\"pageActionsTemplate || defaultPageActionsTemplate\"\n        ></ng-container>\n      </div>\n      <div *ngIf=\"hasPageSubtitle\" class=\"page-subtitle\">\n        <ng-container\n          *ngTemplateOutlet=\"customSubtitleTemplate || defaultPageSubtitleTemplate\"\n        ></ng-container>\n      </div>\n    </div>\n\n    <!-- Content -->\n    <ng-container\n      *ngTemplateOutlet=\"customContentTemplate || defaultContentTemplate\"\n    ></ng-container>\n  </div>\n\n  <div slot=\"fixed\" class=\"fixed-content\" *ngIf=\"fixedContentTemplate\">\n    <div class=\"content-inner\">\n      <ng-container *ngTemplateOutlet=\"fixedContentTemplate\"></ng-container>\n    </div>\n  </div>\n</ion-content>\n\n<ion-footer>\n  <ng-content select=\"kirby-page-footer\"></ng-content>\n</ion-footer>\n\n<ng-template #defaultPageTitleTemplate>\n  <h1 [kirbyFitHeading]=\"fitHeadingConfig\">\n    <ng-container *ngTemplateOutlet=\"simpleTitleTemplate\"></ng-container>\n  </h1>\n</ng-template>\n<ng-template #defaultPageSubtitleTemplate>\n  <ng-container *ngTemplateOutlet=\"simpleSubtitleTemplate\"></ng-container>\n</ng-template>\n<ng-template #defaultPageActionsTemplate>\n  <ng-content select=\"kirby-page-actions\"></ng-content>\n</ng-template>\n\n<ng-template #defaultContentTemplate>\n  <ng-content select=\"kirby-page-content\"></ng-content>\n</ng-template>\n\n<ng-template #simpleTitleTemplate>{{ title }}</ng-template>\n<ng-template #simpleSubtitleTemplate>{{ subtitle }}</ng-template>\n<ng-template #simpleToolbarTitleTemplate>{{ toolbarTitle }}</ng-template>\n"]}
443
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../../../libs/designsystem/src/lib/components/page/page.component.ts","../../../../../../../libs/designsystem/src/lib/components/page/page.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  SkipSelf,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { NavigationEnd, NavigationStart, Router, RouterEvent } from '@angular/router';\nimport { IonBackButtonDelegate, IonContent, IonFooter, IonHeader } from '@ionic/angular';\nimport { Observable, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\n\nimport { KirbyAnimation } from '../../animation/kirby-animation';\nimport { FitHeadingConfig } from '../../directives/fit-heading/fit-heading.directive';\nimport { WindowRef } from '../../types/window-ref';\nimport { ModalWrapperComponent } from '../modal/modal-wrapper/modal-wrapper.component';\nimport { ModalNavigationService } from '../modal/services/modal-navigation.service';\nimport {\n  ModalElementComponent,\n  ModalElementsAdvertiser,\n  ModalElementType,\n} from '../modal/services/modal.interfaces';\nimport { selectedTabClickEvent } from '../tabs/tab-button/tab-button.events';\nimport { TabsComponent } from '../tabs/tabs.component';\n\ntype stickyConfig = { sticky: boolean };\ntype fixedConfig = { fixed: boolean };\n\n/**\n * Event emitted when \"pull-to-refresh\" begins.\n */\nexport interface PullToRefreshEvent {\n  /**\n   * Invoke this callback-method when action to perform upon \"pull-to-refresh\" completes.\n   */\n  complete();\n}\n\n@Directive({\n  selector: '[kirbyPageTitle]',\n})\nexport class PageTitleDirective {}\n\n@Directive({\n  selector: '[kirbyPageSubtitle]',\n})\nexport class PageSubtitleDirective {}\n\n@Directive({\n  selector: '[kirbyPageToolbarTitle]',\n})\nexport class PageToolbarTitleDirective {}\n\n@Directive({\n  selector: '[kirbyPageActions]',\n})\nexport class PageActionsDirective {\n  @Input('kirbyPageActions') config: stickyConfig | fixedConfig;\n  private readonly stickyDefault = true;\n  private readonly fixedDefault = false;\n\n  constructor(public template: TemplateRef<any>) {}\n\n  get isSticky(): boolean {\n    return this.config ? (this.config as stickyConfig).sticky : this.stickyDefault;\n  }\n\n  get isFixed(): boolean {\n    return this.config ? (this.config as fixedConfig).fixed : this.fixedDefault;\n  }\n}\n\n@Directive({\n  selector: '[kirbyPageContent]',\n})\nexport class PageContentDirective {\n  @Input('kirbyPageContent') config: fixedConfig;\n\n  constructor(public template: TemplateRef<any>) {}\n\n  get isFixed(): boolean {\n    return this.config && this.config.fixed;\n  }\n}\n\n@Component({\n  selector: 'kirby-page-progress',\n  template: ` <ng-content></ng-content> `,\n  styles: [':host {display: flex}'],\n})\nexport class PageProgressComponent extends ModalElementComponent implements OnInit {\n  // TODO: Find alternative implementation, which aligns with future page configuration / consumption\n  // This implementation was chosen over expanding `moveChild` method in component wrapper with yet another scenario\n  @HostBinding('attr.slot') slot = 'start';\n\n  constructor(\n    @Optional() @SkipSelf() private modalWrapper: ModalWrapperComponent,\n    @Optional() modalElementsAdvertiser: ModalElementsAdvertiser,\n    elementRef: ElementRef<HTMLElement>\n  ) {\n    super(ModalElementType.PAGE_PROGRESS, elementRef, modalElementsAdvertiser);\n  }\n\n  ngOnInit(): void {\n    if (this.modalWrapper && this.modalWrapper.config.flavor === 'drawer') {\n      this.slot = 'end';\n    }\n  }\n}\n@Component({\n  selector: 'kirby-page-title',\n  template: ` <ng-content></ng-content> `,\n})\nexport class PageTitleComponent extends ModalElementComponent {\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    @Optional() modalElementsAdvertiser: ModalElementsAdvertiser\n  ) {\n    super(ModalElementType.TITLE, elementRef, modalElementsAdvertiser);\n  }\n}\n\n@Component({\n  selector: 'kirby-page-content',\n  template: ` <ng-content></ng-content> `,\n})\nexport class PageContentComponent {}\n\n@Component({\n  selector: 'kirby-page-actions',\n  template: ` <ng-content select=\"button[kirby-button]\"></ng-content> `,\n})\nexport class PageActionsComponent {}\n\n@Component({\n  selector: 'kirby-page',\n  templateUrl: './page.component.html',\n  styleUrls: ['./page.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PageComponent\n  implements OnInit, OnDestroy, AfterViewInit, AfterContentChecked, OnChanges\n{\n  @Input() title: string;\n  @Input() subtitle: string;\n  @Input() toolbarTitle: string;\n  @Input() titleAlignment: 'left' | 'center' | 'right' = 'left';\n  @Input() defaultBackHref: string;\n  @Input() hideBackButton: boolean;\n  @Input() titleMaxLines: number;\n\n  private _tabBarBottomHidden: boolean;\n  public get tabBarBottomHidden(): boolean {\n    return this._tabBarBottomHidden;\n  }\n  @Input()\n  public set tabBarBottomHidden(value: boolean) {\n    if (this.tabsComponent) {\n      // as we are setting a class on tabs, we need this to happen in a separate cd cycle\n      setTimeout(() => (this.tabsComponent.tabBarBottomHidden = value));\n    }\n    this._tabBarBottomHidden = value;\n  }\n\n  @Output() enter = new EventEmitter<void>();\n  @Output() leave = new EventEmitter<void>();\n  @Output() refresh = new EventEmitter<PullToRefreshEvent>();\n  @Output() backButtonClick = new EventEmitter<Event>();\n\n  @ViewChild(IonContent, { static: true }) private content: IonContent;\n  @ViewChild(IonContent, { static: true, read: ElementRef })\n  private ionContentElement: ElementRef<HTMLIonContentElement>;\n  @ViewChild(IonHeader, { static: true, read: ElementRef })\n  ionHeaderElement: ElementRef<HTMLIonHeaderElement>;\n  @ViewChild(IonFooter, { static: true, read: ElementRef })\n  private ionFooterElement: ElementRef<HTMLIonFooterElement>;\n\n  @ViewChild(IonBackButtonDelegate, { static: false })\n  private backButtonDelegate: IonBackButtonDelegate;\n  @ViewChild('pageTitle', { static: false, read: ElementRef })\n  private pageTitle: ElementRef;\n\n  @ViewChild('simpleTitleTemplate', { static: true, read: TemplateRef })\n  private simpleTitleTemplate: TemplateRef<any>;\n  @ViewChild('simpleToolbarTitleTemplate', { static: true, read: TemplateRef })\n  private simpleToolbarTitleTemplate: TemplateRef<any>;\n  @ContentChild(PageToolbarTitleDirective, { static: false, read: TemplateRef })\n  private customToolbarTitleTemplate: TemplateRef<any>;\n  @ContentChild(PageTitleDirective, { static: false, read: TemplateRef })\n  customTitleTemplate: TemplateRef<any>;\n  @ContentChild(PageSubtitleDirective, { static: false, read: TemplateRef })\n  customSubtitleTemplate: TemplateRef<any>;\n  @ContentChildren(PageActionsDirective)\n  customActions: QueryList<PageActionsDirective>;\n  @ContentChildren(PageContentDirective)\n  private customContent: QueryList<PageContentDirective>;\n\n  hasPageTitle: boolean;\n  hasPageSubtitle: boolean;\n  hasActionsInPage: boolean;\n  toolbarTitleVisible: boolean;\n  toolbarFixedActionsVisible: boolean;\n  toolbarStickyActionsVisible: boolean;\n\n  fitHeadingConfig: FitHeadingConfig;\n\n  toolbarTitleTemplate: TemplateRef<any>;\n  customContentTemplate: TemplateRef<any>;\n  pageActionsTemplate: TemplateRef<any>;\n  fixedContentTemplate: TemplateRef<any>;\n  stickyActionsTemplate: TemplateRef<any>;\n  fixedActionsTemplate: TemplateRef<any>;\n  private pageTitleIntersectionObserverRef: IntersectionObserver =\n    this.pageTitleIntersectionObserver();\n  private url: string;\n  private isActive: boolean;\n\n  private ngOnDestroy$ = new Subject();\n  private navigationStart$: Observable<RouterEvent> = this.router.events.pipe(\n    takeUntil(this.ngOnDestroy$),\n    filter((event: RouterEvent) => event instanceof NavigationStart)\n  );\n\n  private navigationEnd$: Observable<RouterEvent> = this.router.events.pipe(\n    takeUntil(this.ngOnDestroy$),\n    filter((event: RouterEvent) => event instanceof NavigationEnd)\n  );\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private router: Router,\n    private changeDetectorRef: ChangeDetectorRef,\n    private windowRef: WindowRef,\n    private modalNavigationService: ModalNavigationService,\n    @Optional() @SkipSelf() private tabsComponent: TabsComponent\n  ) {}\n\n  ngOnInit(): void {\n    this.removeWrapper();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.titleMaxLines) {\n      this.fitHeadingConfig = {\n        ...this.fitHeadingConfig,\n        maxLines: changes.titleMaxLines.currentValue,\n      };\n    }\n    if (changes.subtitle && !changes.subtitle.isFirstChange) {\n      this.subtitle = changes.title.currentValue;\n      this.hasPageSubtitle = this.subtitle !== undefined;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    // This instance has observed a page enter so register the correct url for this instance\n    this.url = this.router.url;\n    this.onEnter();\n\n    // Watch navigation events for page enter and leave\n    this.navigationStart$.subscribe((event: NavigationStart) => {\n      if (\n        event.url !== this.url &&\n        !this.modalNavigationService.isModalRoute(this.url) &&\n        !this.modalNavigationService.isModalRoute(event.url)\n      ) {\n        this.onLeave();\n      }\n    });\n\n    this.navigationEnd$.subscribe((event: NavigationEnd) => {\n      if (event.urlAfterRedirects === this.url) {\n        this.onEnter();\n      }\n    });\n\n    this.windowRef.nativeWindow.addEventListener(selectedTabClickEvent, () => {\n      this.content.scrollToTop(KirbyAnimation.Duration.LONG);\n    });\n\n    this.interceptBackButtonClicksSetup();\n  }\n\n  ngAfterContentChecked(): void {\n    this.initializeTitle();\n    this.initializeActions();\n    this.initializeContent();\n    this.changeDetectorRef.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.ngOnDestroy$.next();\n    this.ngOnDestroy$.complete();\n\n    this.pageTitleIntersectionObserverRef.disconnect();\n    this.windowRef.nativeWindow.removeEventListener(selectedTabClickEvent, () => {\n      this.content.scrollToTop(KirbyAnimation.Duration.LONG);\n    });\n  }\n\n  delegateRefreshEvent(event: any): void {\n    this.refresh.emit({\n      complete: event.target.complete.bind(event.target),\n    });\n  }\n\n  private onEnter() {\n    if (this.isActive) return;\n    this.isActive = true;\n\n    this.enter.emit();\n    if (this.pageTitle) {\n      this.pageTitleIntersectionObserverRef.observe(this.pageTitle.nativeElement);\n    }\n  }\n\n  private onLeave() {\n    if (!this.isActive) return;\n    this.isActive = false;\n\n    this.leave.emit();\n    if (this.pageTitle) {\n      this.pageTitleIntersectionObserverRef.unobserve(this.pageTitle.nativeElement);\n    }\n\n    if (this.tabBarBottomHidden && this.tabsComponent) {\n      this.tabsComponent.tabBarBottomHidden = false;\n    }\n  }\n\n  private interceptBackButtonClicksSetup() {\n    // Intercept back-button click events, defaulting to the built-in click-handler.\n    if (this.backButtonClick.observers.length === 0) {\n      this.backButtonClick\n        .pipe(takeUntil(this.ngOnDestroy$))\n        .subscribe(this.backButtonDelegate.onClick.bind(this.backButtonDelegate));\n    }\n    this.backButtonDelegate.onClick = (event: Event) => {\n      this.backButtonClick.emit(event);\n    };\n  }\n\n  private initializeTitle() {\n    // Ensures initializeTitle() won't run, if already initialized\n    if (this.hasPageTitle) return;\n    this.hasPageTitle = this.title !== undefined || !!this.customTitleTemplate;\n    this.toolbarTitleVisible = !this.hasPageTitle;\n    this.hasPageSubtitle = this.subtitle !== undefined || !!this.customSubtitleTemplate;\n\n    if (this.hasPageTitle) {\n      setTimeout(() => {\n        this.pageTitleIntersectionObserverRef.observe(this.pageTitle.nativeElement);\n      });\n    }\n\n    const defaultTitleTemplate = this.customTitleTemplate || this.simpleTitleTemplate;\n    // tslint:disable:prettier\n    // prettier-ignore\n    this.toolbarTitleTemplate = this.customToolbarTitleTemplate\n      ? this.customToolbarTitleTemplate\n      : typeof this.toolbarTitle === 'string'\n        ? this.simpleToolbarTitleTemplate\n        : defaultTitleTemplate;\n  }\n\n  private initializeActions() {\n    this.customActions.forEach((pageAction) => {\n      if (pageAction.isFixed) {\n        this.fixedActionsTemplate = pageAction.template;\n        this.toolbarFixedActionsVisible = true;\n      } else {\n        this.pageActionsTemplate = pageAction.template;\n        if (pageAction.isSticky) {\n          this.stickyActionsTemplate = pageAction.template;\n        }\n      }\n    });\n    this.hasActionsInPage = !!this.pageActionsTemplate;\n  }\n\n  private initializeContent() {\n    this.customContent.forEach((content) => {\n      if (content.isFixed) {\n        this.fixedContentTemplate = content.template;\n      } else {\n        this.customContentTemplate = content.template;\n      }\n    });\n  }\n\n  private removeWrapper() {\n    const parent = this.elementRef.nativeElement.parentNode;\n    this.renderer.removeChild(parent, this.elementRef.nativeElement);\n    this.renderer.appendChild(parent, this.ionHeaderElement.nativeElement);\n    this.renderer.appendChild(parent, this.ionContentElement.nativeElement);\n    this.renderer.appendChild(parent, this.ionFooterElement.nativeElement);\n  }\n\n  private pageTitleIntersectionObserver() {\n    const options = {\n      rootMargin: '0px',\n    };\n\n    let initialized = false;\n    const callback = (entries) => {\n      if (initialized) {\n        this.toolbarTitleVisible = !entries[0].isIntersecting;\n        this.toolbarStickyActionsVisible = !entries[0].isIntersecting;\n        this.changeDetectorRef.detectChanges();\n      } else {\n        initialized = true;\n      }\n    };\n    return new IntersectionObserver(callback, options);\n  }\n\n  @HostListener('window:keyboardWillShow', ['$event'])\n  _onKeyboardWillShow(info?: { keyboardHeight: number }) {\n    if (info && info.keyboardHeight) {\n      this.ionContentElement.nativeElement.style.setProperty(\n        '--keyboard-offset',\n        `${info.keyboardHeight}px`\n      );\n    }\n  }\n\n  @HostListener('window:keyboardWillHide')\n  _onKeyboardWillHide() {\n    this.ionContentElement.nativeElement.style.setProperty('--keyboard-offset', '0px');\n  }\n}\n","<ion-header>\n  <ion-toolbar>\n    <ion-buttons slot=\"start\">\n      <ion-back-button\n        text=\"\"\n        [defaultHref]=\"defaultBackHref\"\n        icon=\"assets/kirby/icons/svg/arrow-back.svg\"\n        [style.visibility]=\"hideBackButton ? 'hidden' : null\"\n      ></ion-back-button>\n    </ion-buttons>\n    <ion-title>\n      <div class=\"toolbar-title hide\" [class.fade-in]=\"toolbarTitleVisible\">\n        <ng-container *ngTemplateOutlet=\"toolbarTitleTemplate\"></ng-container>\n      </div>\n    </ion-title>\n    <ion-buttons\n      class=\"hide\"\n      slot=\"primary\"\n      [class.fade-in]=\"toolbarStickyActionsVisible && stickyActionsTemplate\"\n    >\n      <ng-container *ngTemplateOutlet=\"stickyActionsTemplate\"></ng-container>\n    </ion-buttons>\n    <ion-buttons\n      class=\"hide\"\n      slot=\"secondary\"\n      [class.fade-in]=\"toolbarFixedActionsVisible && fixedActionsTemplate\"\n    >\n      <ng-container *ngTemplateOutlet=\"fixedActionsTemplate\"></ng-container>\n    </ion-buttons>\n  </ion-toolbar>\n</ion-header>\n\n<ion-content scrollEvents=\"true\" forceOverscroll=\"false\">\n  <ion-refresher\n    *ngIf=\"refresh.observers.length > 0\"\n    (ionRefresh)=\"delegateRefreshEvent($event)\"\n    slot=\"fixed\"\n  >\n    <kirby-spinner></kirby-spinner>\n  </ion-refresher>\n\n  <div class=\"content-inner\">\n    <div\n      class=\"page-header\"\n      *ngIf=\"hasPageTitle\"\n      [ngClass]=\"{\n        'text-center': titleAlignment === 'center',\n        'text-right': titleAlignment === 'right'\n      }\"\n    >\n      <div #pageTitle class=\"page-title\" [class.has-actions]=\"hasActionsInPage\">\n        <ng-container\n          *ngTemplateOutlet=\"customTitleTemplate || defaultPageTitleTemplate\"\n        ></ng-container>\n        <ng-container\n          *ngTemplateOutlet=\"pageActionsTemplate || defaultPageActionsTemplate\"\n        ></ng-container>\n      </div>\n      <div *ngIf=\"hasPageSubtitle\" class=\"page-subtitle\">\n        <ng-container\n          *ngTemplateOutlet=\"customSubtitleTemplate || defaultPageSubtitleTemplate\"\n        ></ng-container>\n      </div>\n    </div>\n\n    <!-- Content -->\n    <ng-container\n      *ngTemplateOutlet=\"customContentTemplate || defaultContentTemplate\"\n    ></ng-container>\n  </div>\n\n  <div slot=\"fixed\" class=\"fixed-content\" *ngIf=\"fixedContentTemplate\">\n    <div class=\"content-inner\">\n      <ng-container *ngTemplateOutlet=\"fixedContentTemplate\"></ng-container>\n    </div>\n  </div>\n</ion-content>\n\n<ion-footer>\n  <ng-content select=\"kirby-page-footer\"></ng-content>\n</ion-footer>\n\n<ng-template #defaultPageTitleTemplate>\n  <h1 [kirbyFitHeading]=\"fitHeadingConfig\">\n    <ng-container *ngTemplateOutlet=\"simpleTitleTemplate\"></ng-container>\n  </h1>\n</ng-template>\n<ng-template #defaultPageSubtitleTemplate>\n  <ng-container *ngTemplateOutlet=\"simpleSubtitleTemplate\"></ng-container>\n</ng-template>\n<ng-template #defaultPageActionsTemplate>\n  <ng-content select=\"kirby-page-actions\"></ng-content>\n</ng-template>\n\n<ng-template #defaultContentTemplate>\n  <ng-content select=\"kirby-page-content\"></ng-content>\n</ng-template>\n\n<ng-template #simpleTitleTemplate>{{ title }}</ng-template>\n<ng-template #simpleSubtitleTemplate>{{ subtitle }}</ng-template>\n<ng-template #simpleToolbarTitleTemplate>{{ toolbarTitle }}</ng-template>\n"]}
@@ -19,6 +19,7 @@ export class SegmentedControlComponent {
19
19
  this.mode = SegmentedControlMode.default;
20
20
  this._items = [];
21
21
  this._selectedIndex = -1;
22
+ this.selectedIndexChange = new EventEmitter();
22
23
  this._disableChangeOnSwipe = false;
23
24
  this.segmentSelect = new EventEmitter();
24
25
  }
@@ -59,10 +60,11 @@ export class SegmentedControlComponent {
59
60
  get selectedIndex() {
60
61
  return this._selectedIndex;
61
62
  }
62
- set selectedIndex(value) {
63
- if (value !== this._selectedIndex) {
64
- this._selectedIndex = value;
63
+ set selectedIndex(index) {
64
+ if (index !== this._selectedIndex) {
65
+ this._selectedIndex = index;
65
66
  this._value = this.items[this.selectedIndex];
67
+ this.selectedIndexChange.emit(this.selectedIndex);
66
68
  }
67
69
  }
68
70
  get value() {
@@ -84,12 +86,14 @@ export class SegmentedControlComponent {
84
86
  const selectedItemIndex = this.items.findIndex((item) => selectedId === item.id);
85
87
  if (selectedItemIndex !== this.selectedIndex) {
86
88
  this.selectedIndex = selectedItemIndex;
87
- this.segmentSelect.emit(this.value);
89
+ setTimeout(() => {
90
+ this.segmentSelect.emit(this.value);
91
+ });
88
92
  }
89
93
  }
90
94
  }
91
95
  /** @nocollapse */ SegmentedControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: SegmentedControlComponent, deps: [{ token: i1.IconRegistryService }], target: i0.ɵɵFactoryTarget.Component });
92
- /** @nocollapse */ SegmentedControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: SegmentedControlComponent, selector: "kirby-segmented-control", inputs: { mode: "mode", items: "items", selectedIndex: "selectedIndex", value: "value", size: "size", disableChangeOnSwipe: "disableChangeOnSwipe" }, outputs: { segmentSelect: "segmentSelect" }, host: { attributes: { "role": "group" }, properties: { "class": "this._modeCssClass", "class.sm": "this.isSmallSize" } }, ngImport: i0, template: "<ion-segment\n *ngIf=\"mode === 'default'\"\n [value]=\"value?.id\"\n [scrollable]=\"disableChangeOnSwipe\"\n (ionChange)=\"onSegmentSelect($event.detail.value)\"\n (click)=\"preventOutsideClick($event)\"\n>\n <div *ngFor=\"let item of items\" class=\"segment-btn-wrapper\">\n <ion-segment-button [value]=\"item.id\">{{ item.text }}</ion-segment-button>\n <kirby-badge\n *ngIf=\"item.badge\"\n role=\"text\"\n [attr.aria-label]=\"item.badge.description\"\n [themeColor]=\"item.badge.themeColor\"\n >\n <ng-container *ngIf=\"item.badge.icon; else badgeContent\">\n <kirby-icon\n *ngIf=\"item.badge.isCustomIcon; else defaultIconName\"\n [customName]=\"item.badge.icon\"\n ></kirby-icon>\n <ng-template #defaultIconName>\n <kirby-icon [name]=\"item.badge.icon\"></kirby-icon>\n </ng-template>\n </ng-container>\n <ng-template #badgeContent>\n {{ item.badge.content }}\n </ng-template>\n </kirby-badge>\n </div>\n</ion-segment>\n\n<ng-container *ngIf=\"mode === 'chip' || mode === 'compactChip'\">\n <kirby-chip\n *ngFor=\"let item of items; let index = index\"\n [text]=\"item.text\"\n [isSelected]=\"index === selectedIndex\"\n (click)=\"onSegmentSelect(item.id)\"\n role=\"button\"\n ></kirby-chip>\n</ng-container>\n", styles: [":host{display:block;-webkit-user-select:none;user-select:none;--kirby-badge-elevation: 0 5px 10px -10px rgba(28, 28, 28, .3), 0 0 5px 0 rgba(28, 28, 28, .08);--kirby-badge-position: absolute;--kirby-badge-top: -8px;--kirby-badge-right: 8px;--kirby-badge-z-index: 2}:host.sm ion-segment-button{min-height:32px;font-size:12px;--padding-start: 16px;--padding-end: 16px}:host.chip-mode{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden}@media (pointer: coarse){:host.chip-mode{scrollbar-width:none}:host.chip-mode::-webkit-scrollbar{display:none}}ion-segment{display:inline-flex;width:auto;overflow:visible;contain:unset;--background: var(--kirby-white);border-radius:999px}ion-segment-button{position:relative;min-height:40px;font-weight:400;font-size:14px;text-transform:none;--border-radius: 999px;--border-style: none;--background: none;--color: var(--kirby-white-contrast);--indicator-color: var(--kirby-black);--color-checked: var(--kirby-black-contrast);--color-hover: var(--kirby-black-tint);--indicator-box-shadow: none;--padding-start: 24px;--padding-end: 24px;--margin-bottom: 0;--margin-end: 0;--margin-start: 0;--margin-top: 0;margin:0}ion-segment-button:after{content:\"\";position:absolute;min-height:44px;min-width:44px;width:100%;height:100%;transform:translate(-50%,-50%);left:50%;top:50%}.segment-btn-wrapper{position:relative}:host-context(.plt-desktop) ion-segment-button:focus-within{outline-color:-webkit-focus-ring-color;outline-style:auto}\n"], components: [{ type: i2.IonSegment, selector: "ion-segment", inputs: ["color", "disabled", "mode", "scrollable", "selectOnFocus", "swipeGesture", "value"] }, { type: i2.IonSegmentButton, selector: "ion-segment-button", inputs: ["disabled", "layout", "mode", "type", "value"] }, { type: i3.KirbyBadge, selector: "kirby-badge", inputs: ["size", "text", "themeColor"] }, { type: i4.IconComponent, selector: "kirby-icon", inputs: ["size", "name", "customName"] }, { type: i5.ChipComponent, selector: "kirby-chip", inputs: ["text", "isSelected"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.SelectValueAccessor, selector: "ion-range, ion-select, ion-radio-group, ion-segment, ion-datetime" }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
96
+ /** @nocollapse */ SegmentedControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: SegmentedControlComponent, selector: "kirby-segmented-control", inputs: { mode: "mode", items: "items", selectedIndex: "selectedIndex", value: "value", size: "size", disableChangeOnSwipe: "disableChangeOnSwipe" }, outputs: { selectedIndexChange: "selectedIndexChange", segmentSelect: "segmentSelect" }, host: { attributes: { "role": "group" }, properties: { "class": "this._modeCssClass", "class.sm": "this.isSmallSize" } }, ngImport: i0, template: "<ion-segment\n *ngIf=\"mode === 'default'\"\n [value]=\"value?.id\"\n [scrollable]=\"disableChangeOnSwipe\"\n (ionChange)=\"onSegmentSelect($event.detail.value)\"\n (click)=\"preventOutsideClick($event)\"\n>\n <div *ngFor=\"let item of items\" class=\"segment-btn-wrapper\">\n <ion-segment-button [value]=\"item.id\">{{ item.text }}</ion-segment-button>\n <kirby-badge\n *ngIf=\"item.badge\"\n role=\"text\"\n [attr.aria-label]=\"item.badge.description\"\n [themeColor]=\"item.badge.themeColor\"\n >\n <ng-container *ngIf=\"item.badge.icon; else badgeContent\">\n <kirby-icon\n *ngIf=\"item.badge.isCustomIcon; else defaultIconName\"\n [customName]=\"item.badge.icon\"\n ></kirby-icon>\n <ng-template #defaultIconName>\n <kirby-icon [name]=\"item.badge.icon\"></kirby-icon>\n </ng-template>\n </ng-container>\n <ng-template #badgeContent>\n {{ item.badge.content }}\n </ng-template>\n </kirby-badge>\n </div>\n</ion-segment>\n\n<ng-container *ngIf=\"mode === 'chip' || mode === 'compactChip'\">\n <kirby-chip\n *ngFor=\"let item of items; let index = index\"\n [text]=\"item.text\"\n [isSelected]=\"index === selectedIndex\"\n (click)=\"onSegmentSelect(item.id)\"\n role=\"button\"\n ></kirby-chip>\n</ng-container>\n", styles: [":host{display:block;-webkit-user-select:none;user-select:none;--kirby-badge-elevation: 0 5px 10px -10px rgba(28, 28, 28, .3), 0 0 5px 0 rgba(28, 28, 28, .08);--kirby-badge-position: absolute;--kirby-badge-top: -8px;--kirby-badge-right: 8px;--kirby-badge-z-index: 2}:host.sm ion-segment-button{min-height:32px;font-size:12px;--padding-start: 16px;--padding-end: 16px}:host.chip-mode{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden}@media (pointer: coarse){:host.chip-mode{scrollbar-width:none}:host.chip-mode::-webkit-scrollbar{display:none}}ion-segment{display:inline-flex;width:auto;overflow:visible;contain:unset;--background: var(--kirby-white);border-radius:999px}ion-segment-button{position:relative;min-height:40px;font-weight:400;font-size:14px;text-transform:none;--border-radius: 999px;--border-style: none;--background: none;--color: var(--kirby-white-contrast);--indicator-color: var(--kirby-black);--color-checked: var(--kirby-black-contrast);--color-hover: var(--kirby-black-tint);--indicator-box-shadow: none;--padding-start: 24px;--padding-end: 24px;--margin-bottom: 0;--margin-end: 0;--margin-start: 0;--margin-top: 0;margin:0}ion-segment-button:after{content:\"\";position:absolute;min-height:44px;min-width:44px;width:100%;height:100%;transform:translate(-50%,-50%);left:50%;top:50%}.segment-btn-wrapper{position:relative}:host-context(.plt-desktop) ion-segment-button:focus-within{outline-color:-webkit-focus-ring-color;outline-style:auto}\n"], components: [{ type: i2.IonSegment, selector: "ion-segment", inputs: ["color", "disabled", "mode", "scrollable", "selectOnFocus", "swipeGesture", "value"] }, { type: i2.IonSegmentButton, selector: "ion-segment-button", inputs: ["disabled", "layout", "mode", "type", "value"] }, { type: i3.KirbyBadge, selector: "kirby-badge", inputs: ["size", "text", "themeColor"] }, { type: i4.IconComponent, selector: "kirby-icon", inputs: ["size", "name", "customName"] }, { type: i5.ChipComponent, selector: "kirby-chip", inputs: ["text", "isSelected"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.SelectValueAccessor, selector: "ion-range, ion-select, ion-radio-group, ion-segment, ion-datetime" }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
93
97
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: SegmentedControlComponent, decorators: [{
94
98
  type: Component,
95
99
  args: [{ selector: 'kirby-segmented-control', host: { role: 'group' }, template: "<ion-segment\n *ngIf=\"mode === 'default'\"\n [value]=\"value?.id\"\n [scrollable]=\"disableChangeOnSwipe\"\n (ionChange)=\"onSegmentSelect($event.detail.value)\"\n (click)=\"preventOutsideClick($event)\"\n>\n <div *ngFor=\"let item of items\" class=\"segment-btn-wrapper\">\n <ion-segment-button [value]=\"item.id\">{{ item.text }}</ion-segment-button>\n <kirby-badge\n *ngIf=\"item.badge\"\n role=\"text\"\n [attr.aria-label]=\"item.badge.description\"\n [themeColor]=\"item.badge.themeColor\"\n >\n <ng-container *ngIf=\"item.badge.icon; else badgeContent\">\n <kirby-icon\n *ngIf=\"item.badge.isCustomIcon; else defaultIconName\"\n [customName]=\"item.badge.icon\"\n ></kirby-icon>\n <ng-template #defaultIconName>\n <kirby-icon [name]=\"item.badge.icon\"></kirby-icon>\n </ng-template>\n </ng-container>\n <ng-template #badgeContent>\n {{ item.badge.content }}\n </ng-template>\n </kirby-badge>\n </div>\n</ion-segment>\n\n<ng-container *ngIf=\"mode === 'chip' || mode === 'compactChip'\">\n <kirby-chip\n *ngFor=\"let item of items; let index = index\"\n [text]=\"item.text\"\n [isSelected]=\"index === selectedIndex\"\n (click)=\"onSegmentSelect(item.id)\"\n role=\"button\"\n ></kirby-chip>\n</ng-container>\n", styles: [":host{display:block;-webkit-user-select:none;user-select:none;--kirby-badge-elevation: 0 5px 10px -10px rgba(28, 28, 28, .3), 0 0 5px 0 rgba(28, 28, 28, .08);--kirby-badge-position: absolute;--kirby-badge-top: -8px;--kirby-badge-right: 8px;--kirby-badge-z-index: 2}:host.sm ion-segment-button{min-height:32px;font-size:12px;--padding-start: 16px;--padding-end: 16px}:host.chip-mode{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden}@media (pointer: coarse){:host.chip-mode{scrollbar-width:none}:host.chip-mode::-webkit-scrollbar{display:none}}ion-segment{display:inline-flex;width:auto;overflow:visible;contain:unset;--background: var(--kirby-white);border-radius:999px}ion-segment-button{position:relative;min-height:40px;font-weight:400;font-size:14px;text-transform:none;--border-radius: 999px;--border-style: none;--background: none;--color: var(--kirby-white-contrast);--indicator-color: var(--kirby-black);--color-checked: var(--kirby-black-contrast);--color-hover: var(--kirby-black-tint);--indicator-box-shadow: none;--padding-start: 24px;--padding-end: 24px;--margin-bottom: 0;--margin-end: 0;--margin-start: 0;--margin-top: 0;margin:0}ion-segment-button:after{content:\"\";position:absolute;min-height:44px;min-width:44px;width:100%;height:100%;transform:translate(-50%,-50%);left:50%;top:50%}.segment-btn-wrapper{position:relative}:host-context(.plt-desktop) ion-segment-button:focus-within{outline-color:-webkit-focus-ring-color;outline-style:auto}\n"] }]
@@ -102,6 +106,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImpor
102
106
  type: Input
103
107
  }], selectedIndex: [{
104
108
  type: Input
109
+ }], selectedIndexChange: [{
110
+ type: Output
105
111
  }], value: [{
106
112
  type: Input
107
113
  }], isSmallSize: [{
@@ -114,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImpor
114
120
  }], segmentSelect: [{
115
121
  type: Output
116
122
  }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"segmented-control.component.js","sourceRoot":"","sources":["../../../../../../../libs/designsystem/src/lib/components/segmented-control/segmented-control.component.ts","../../../../../../../libs/designsystem/src/lib/components/segmented-control/segmented-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';\n\nimport { IconRegistryService } from '../icon/icon-registry.service';\n\nimport { SegmentItem, SegmentItemInternal } from './segment-item';\n\nexport enum SegmentedControlMode {\n  chip = 'chip',\n  compactChip = 'compactChip',\n  default = 'default',\n}\n\n@Component({\n  selector: 'kirby-segmented-control',\n  templateUrl: './segmented-control.component.html',\n  styleUrls: ['./segmented-control.component.scss'],\n  // tslint:disable-next-line: no-host-metadata-property\n  host: { role: 'group' },\n})\nexport class SegmentedControlComponent {\n  constructor(private iconRegistryService: IconRegistryService) {}\n\n  /**\n   * Ensure that the click actually did originate from within the segment-button.\n   * We do not want to react to clicks on e.g. segment-btn-wrapper or badge.\n   */\n  preventOutsideClick(event: TouchEvent) {\n    if (event.target instanceof HTMLElement) {\n      const targetIsInSegmentBtn = !!event.target.closest('ion-segment-button');\n      if (!targetIsInSegmentBtn) {\n        event.stopImmediatePropagation();\n      }\n    }\n  }\n\n  @Input() mode: SegmentedControlMode | `${SegmentedControlMode}` = SegmentedControlMode.default;\n\n  @HostBinding('class')\n  get _modeCssClass() {\n    return {\n      [SegmentedControlMode.chip]: 'chip-mode',\n      [SegmentedControlMode.default]: 'default-mode',\n      [SegmentedControlMode.compactChip]: 'compact chip-mode',\n    }[this.mode];\n  }\n\n  private _items: SegmentItemInternal[] = [];\n  get items(): SegmentItem[] {\n    return this._items;\n  }\n\n  @Input() set items(value: SegmentItem[]) {\n    this._items = value || [];\n    this._items.forEach((item) => {\n      if (!item.badge) return;\n      // We need to verify whether badges icon is custom or default, so we can check for it in the template\n      item.badge.isCustomIcon =\n        item.badge.icon !== undefined &&\n        this.iconRegistryService.getIcon(item.badge.icon) !== undefined;\n    });\n    this._value = this.items[this.selectedIndex];\n  }\n\n  private _selectedIndex: number = -1;\n  get selectedIndex(): number {\n    return this._selectedIndex;\n  }\n\n  @Input() set selectedIndex(value: number) {\n    if (value !== this._selectedIndex) {\n      this._selectedIndex = value;\n      this._value = this.items[this.selectedIndex];\n    }\n  }\n\n  private _value: SegmentItem;\n  get value(): SegmentItem {\n    return this._value;\n  }\n\n  @Input() set value(value: SegmentItem) {\n    this.selectedIndex = this.items.indexOf(value);\n  }\n\n  @HostBinding('class.sm')\n  isSmallSize: boolean;\n\n  @Input() set size(size: 'sm' | 'md') {\n    this.isSmallSize = size === 'sm';\n  }\n\n  private _disableChangeOnSwipe: boolean = false;\n  get disableChangeOnSwipe(): boolean {\n    return this._disableChangeOnSwipe;\n  }\n\n  @Input() set disableChangeOnSwipe(value: boolean) {\n    this._disableChangeOnSwipe = value;\n  }\n\n  @Output() segmentSelect: EventEmitter<SegmentItem> = new EventEmitter();\n\n  onSegmentSelect(selectedId: string) {\n    const selectedItemIndex = this.items.findIndex((item) => selectedId === item.id);\n    if (selectedItemIndex !== this.selectedIndex) {\n      this.selectedIndex = selectedItemIndex;\n      this.segmentSelect.emit(this.value);\n    }\n  }\n}\n","<ion-segment\n  *ngIf=\"mode === 'default'\"\n  [value]=\"value?.id\"\n  [scrollable]=\"disableChangeOnSwipe\"\n  (ionChange)=\"onSegmentSelect($event.detail.value)\"\n  (click)=\"preventOutsideClick($event)\"\n>\n  <div *ngFor=\"let item of items\" class=\"segment-btn-wrapper\">\n    <ion-segment-button [value]=\"item.id\">{{ item.text }}</ion-segment-button>\n    <kirby-badge\n      *ngIf=\"item.badge\"\n      role=\"text\"\n      [attr.aria-label]=\"item.badge.description\"\n      [themeColor]=\"item.badge.themeColor\"\n    >\n      <ng-container *ngIf=\"item.badge.icon; else badgeContent\">\n        <kirby-icon\n          *ngIf=\"item.badge.isCustomIcon; else defaultIconName\"\n          [customName]=\"item.badge.icon\"\n        ></kirby-icon>\n        <ng-template #defaultIconName>\n          <kirby-icon [name]=\"item.badge.icon\"></kirby-icon>\n        </ng-template>\n      </ng-container>\n      <ng-template #badgeContent>\n        {{ item.badge.content }}\n      </ng-template>\n    </kirby-badge>\n  </div>\n</ion-segment>\n\n<ng-container *ngIf=\"mode === 'chip' || mode === 'compactChip'\">\n  <kirby-chip\n    *ngFor=\"let item of items; let index = index\"\n    [text]=\"item.text\"\n    [isSelected]=\"index === selectedIndex\"\n    (click)=\"onSegmentSelect(item.id)\"\n    role=\"button\"\n  ></kirby-chip>\n</ng-container>\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"segmented-control.component.js","sourceRoot":"","sources":["../../../../../../../libs/designsystem/src/lib/components/segmented-control/segmented-control.component.ts","../../../../../../../libs/designsystem/src/lib/components/segmented-control/segmented-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';\n\nimport { IconRegistryService } from '../icon/icon-registry.service';\n\nimport { SegmentItem, SegmentItemInternal } from './segment-item';\n\nexport enum SegmentedControlMode {\n  chip = 'chip',\n  compactChip = 'compactChip',\n  default = 'default',\n}\n\n@Component({\n  selector: 'kirby-segmented-control',\n  templateUrl: './segmented-control.component.html',\n  styleUrls: ['./segmented-control.component.scss'],\n  // tslint:disable-next-line: no-host-metadata-property\n  host: { role: 'group' },\n})\nexport class SegmentedControlComponent {\n  constructor(private iconRegistryService: IconRegistryService) {}\n\n  /**\n   * Ensure that the click actually did originate from within the segment-button.\n   * We do not want to react to clicks on e.g. segment-btn-wrapper or badge.\n   */\n  preventOutsideClick(event: TouchEvent) {\n    if (event.target instanceof HTMLElement) {\n      const targetIsInSegmentBtn = !!event.target.closest('ion-segment-button');\n      if (!targetIsInSegmentBtn) {\n        event.stopImmediatePropagation();\n      }\n    }\n  }\n\n  @Input() mode: SegmentedControlMode | `${SegmentedControlMode}` = SegmentedControlMode.default;\n\n  @HostBinding('class')\n  get _modeCssClass() {\n    return {\n      [SegmentedControlMode.chip]: 'chip-mode',\n      [SegmentedControlMode.default]: 'default-mode',\n      [SegmentedControlMode.compactChip]: 'compact chip-mode',\n    }[this.mode];\n  }\n\n  private _items: SegmentItemInternal[] = [];\n  get items(): SegmentItem[] {\n    return this._items;\n  }\n\n  @Input() set items(value: SegmentItem[]) {\n    this._items = value || [];\n    this._items.forEach((item) => {\n      if (!item.badge) return;\n      // We need to verify whether badges icon is custom or default, so we can check for it in the template\n      item.badge.isCustomIcon =\n        item.badge.icon !== undefined &&\n        this.iconRegistryService.getIcon(item.badge.icon) !== undefined;\n    });\n    this._value = this.items[this.selectedIndex];\n  }\n\n  private _selectedIndex: number = -1;\n  get selectedIndex(): number {\n    return this._selectedIndex;\n  }\n\n  @Input() set selectedIndex(index: number) {\n    if (index !== this._selectedIndex) {\n      this._selectedIndex = index;\n      this._value = this.items[this.selectedIndex];\n      this.selectedIndexChange.emit(this.selectedIndex);\n    }\n  }\n\n  @Output() selectedIndexChange = new EventEmitter<number>();\n\n  private _value: SegmentItem;\n  get value(): SegmentItem {\n    return this._value;\n  }\n\n  @Input() set value(value: SegmentItem) {\n    this.selectedIndex = this.items.indexOf(value);\n  }\n\n  @HostBinding('class.sm')\n  isSmallSize: boolean;\n\n  @Input() set size(size: 'sm' | 'md') {\n    this.isSmallSize = size === 'sm';\n  }\n\n  private _disableChangeOnSwipe: boolean = false;\n  get disableChangeOnSwipe(): boolean {\n    return this._disableChangeOnSwipe;\n  }\n\n  @Input() set disableChangeOnSwipe(value: boolean) {\n    this._disableChangeOnSwipe = value;\n  }\n\n  @Output() segmentSelect: EventEmitter<SegmentItem> = new EventEmitter();\n\n  onSegmentSelect(selectedId: string) {\n    const selectedItemIndex = this.items.findIndex((item) => selectedId === item.id);\n\n    if (selectedItemIndex !== this.selectedIndex) {\n      this.selectedIndex = selectedItemIndex;\n      setTimeout(() => {\n        this.segmentSelect.emit(this.value);\n      });\n    }\n  }\n}\n","<ion-segment\n  *ngIf=\"mode === 'default'\"\n  [value]=\"value?.id\"\n  [scrollable]=\"disableChangeOnSwipe\"\n  (ionChange)=\"onSegmentSelect($event.detail.value)\"\n  (click)=\"preventOutsideClick($event)\"\n>\n  <div *ngFor=\"let item of items\" class=\"segment-btn-wrapper\">\n    <ion-segment-button [value]=\"item.id\">{{ item.text }}</ion-segment-button>\n    <kirby-badge\n      *ngIf=\"item.badge\"\n      role=\"text\"\n      [attr.aria-label]=\"item.badge.description\"\n      [themeColor]=\"item.badge.themeColor\"\n    >\n      <ng-container *ngIf=\"item.badge.icon; else badgeContent\">\n        <kirby-icon\n          *ngIf=\"item.badge.isCustomIcon; else defaultIconName\"\n          [customName]=\"item.badge.icon\"\n        ></kirby-icon>\n        <ng-template #defaultIconName>\n          <kirby-icon [name]=\"item.badge.icon\"></kirby-icon>\n        </ng-template>\n      </ng-container>\n      <ng-template #badgeContent>\n        {{ item.badge.content }}\n      </ng-template>\n    </kirby-badge>\n  </div>\n</ion-segment>\n\n<ng-container *ngIf=\"mode === 'chip' || mode === 'compactChip'\">\n  <kirby-chip\n    *ngFor=\"let item of items; let index = index\"\n    [text]=\"item.text\"\n    [isSelected]=\"index === selectedIndex\"\n    (click)=\"onSegmentSelect(item.id)\"\n    role=\"button\"\n  ></kirby-chip>\n</ng-container>\n"]}