@dsivd/prestations-ng 16.0.1 → 16.0.2
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.
- package/CHANGELOG.md +7 -0
- package/dsivd-prestations-ng-v16.0.2.tgz +0 -0
- package/esm2020/foehn-menu-prestation/foehn-list-summary/foehn-list-summary.component.mjs +4 -2
- package/fesm2015/dsivd-prestations-ng.mjs +3 -1
- package/fesm2015/dsivd-prestations-ng.mjs.map +1 -1
- package/fesm2020/dsivd-prestations-ng.mjs +3 -1
- package/fesm2020/dsivd-prestations-ng.mjs.map +1 -1
- package/package.json +1 -1
- package/dsivd-prestations-ng-v16.0.1.tgz +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -26,6 +26,13 @@ A change is considered **breaking** if you have to change your code or update yo
|
|
|
26
26
|
|
|
27
27
|
---
|
|
28
28
|
|
|
29
|
+
## [16.0.2]
|
|
30
|
+
|
|
31
|
+
### Fixed
|
|
32
|
+
|
|
33
|
+
- [foehn-list-summary.component.ts](projects/prestations-ng/src/foehn-menu-prestation/foehn-list-summary/foehn-list-summary.component.ts)
|
|
34
|
+
- fixed bug where `<foehn-table>` was not refreshed on item removal when `showAsTable = true`
|
|
35
|
+
|
|
29
36
|
|
|
30
37
|
## [16.0.1]
|
|
31
38
|
|
|
Binary file
|
|
@@ -56,8 +56,10 @@ export class FoehnListSummaryComponent extends FoehnInputComponent {
|
|
|
56
56
|
htmlContent: 'Souhaitez-vous vraiment supprimer cet élément ?'
|
|
57
57
|
})
|
|
58
58
|
.then(() => {
|
|
59
|
-
this.list.
|
|
59
|
+
this.list = this.list.filter((item, i) => i !== index);
|
|
60
60
|
this.itemRemoved.next();
|
|
61
|
+
}, () => {
|
|
62
|
+
// nothing to do
|
|
61
63
|
});
|
|
62
64
|
}
|
|
63
65
|
changeSort(sortEvent) {
|
|
@@ -109,4 +111,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
109
111
|
}], itemEdit: [{
|
|
110
112
|
type: Output
|
|
111
113
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-list-summary.component.js","sourceRoot":"","sources":["../../../../../projects/prestations-ng/src/foehn-menu-prestation/foehn-list-summary/foehn-list-summary.component.ts","../../../../../projects/prestations-ng/src/foehn-menu-prestation/foehn-list-summary/foehn-list-summary.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    EventEmitter,\n    forwardRef,\n    Input,\n    Output,\n    TemplateRef,\n    TrackByFunction,\n    ViewChild\n} from '@angular/core';\n\nimport { FoehnConfirmModalService } from '../../foehn-confirm-modal/foehn-confirm-modal.service';\nimport { FoehnInputComponent } from '../../foehn-input/foehn-input.component';\nimport { FoehnTableColumnConfiguration } from '../../foehn-table/foehn-table-column-configuration';\nimport { TableSort } from '../../foehn-table/tableSort';\nimport { FoehnListItem } from './foehn-list-item';\nimport { FoehnListItemDescription } from './foehn-list-item-description';\n\n@Component({\n    selector: 'foehn-list-summary',\n    templateUrl: './foehn-list-summary.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnListSummaryComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnListSummaryComponent\n    extends FoehnInputComponent<FoehnListItem[]>\n    implements AfterViewInit {\n    @ViewChild('tableActionButtons')\n    tableActionButtons: TemplateRef<unknown>;\n\n    @Input()\n    list: FoehnListItem[];\n\n    @Input()\n    getListItemTitle: (item: FoehnListItem) => string;\n\n    @Input()\n    showAsTable = false;\n\n    @Input()\n    listItemDescriptions: FoehnListItemDescription[];\n\n    @Output()\n    itemRemoved = new EventEmitter<void>();\n\n    @Output()\n    itemEdit = new EventEmitter<number>();\n\n    tableConfiguration: FoehnTableColumnConfiguration<FoehnListItem>[];\n\n    tableSort: TableSort = {\n        sortDirection: 'ASC'\n    };\n\n    constructor(private confirmModalService: FoehnConfirmModalService) {\n        super();\n    }\n\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        this.tableConfiguration = this.listItemDescriptions.map(\n            (item, index) => ({\n                id: `col-${index}`,\n                sortAttribute: index.toString(),\n                columnLabelKey: item.label,\n                valueGetter: (i: FoehnListItem) =>\n                    this.listItemDescriptions[index].getFormattedValue(i)\n            })\n        );\n        this.tableConfiguration.push({\n            id: 'actions',\n            columnLabelKey: 'foehn-table.header.actions',\n            template: this.tableActionButtons\n        });\n    }\n\n    trackByTrackingIndex(): TrackByFunction<FoehnListItem> {\n        return (index: number, item: FoehnListItem) => item.trackingIndex;\n    }\n\n    showLine(\n        item: FoehnListItem,\n        itemParam: FoehnListItemDescription\n    ): boolean {\n        const value = itemParam.getFormattedValue(item);\n        const hideIfEmptyExists = !!itemParam.hideIfEmpty;\n        if (value || !hideIfEmptyExists) {\n            return true;\n        } else {\n            return itemParam.hideIfEmpty(item);\n        }\n    }\n\n    editItem(index: number = null): void {\n        this.itemEdit.next(index);\n    }\n\n    removeItem(index: number): void {\n        this.confirmModalService\n            .openConfirmModal({\n                htmlContent: 'Souhaitez-vous vraiment supprimer cet élément ?'\n            })\n            .then(() => {\n                this.list.splice(index, 1);\n                this.itemRemoved.next();\n            });\n    }\n\n    changeSort(sortEvent: TableSort): void {\n        this.list = this.sortNow(this.list, sortEvent);\n        this.tableSort = sortEvent;\n    }\n\n    private sortNow(\n        elems: FoehnListItem[],\n        sortEvent: TableSort\n    ): FoehnListItem[] {\n        const listSorted = elems.sort((a, b) => {\n            const valueA = this.listItemDescriptions[\n                sortEvent.sortAttribute\n            ].getFormattedValue(a);\n            const valueB = this.listItemDescriptions[\n                sortEvent.sortAttribute\n            ].getFormattedValue(b);\n            return valueA.localeCompare(valueB);\n        });\n        if (sortEvent.sortDirection === 'DESC') {\n            listSorted.reverse();\n        }\n        return listSorted;\n    }\n}\n","<section\n    class=\"form-group clearable-input-form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <label\n        [attr.for]=\"buildChildId()\"\n        *ngIf=\"label && type !== 'hidden'\"\n        [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n    >\n        <span [innerHTML]=\"label\"></span>\n        <span\n            *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n            aria-hidden=\"true\"\n        >\n            {{ 'foehn-input.optional' | fromDictionary }}\n        </span>\n    </label>\n\n    <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n    <small\n        *ngIf=\"helpText && type !== 'hidden'\"\n        [attr.id]=\"buildChildId() + 'Help'\"\n        class=\"form-text text-secondary\"\n        [innerHTML]=\"helpText\"\n    ></small>\n\n    <section *ngIf=\"!showAsTable\">\n        <ul class=\"list-unstyled\" aria-describedby=\"sommaire-help-alt\">\n            <li\n                [id]=\"'list-summary-' + item.trackingIndex\"\n                class=\"mt-3 border-bottom\"\n                *ngFor=\"\n                    let item of list;\n                    let itemIndex = index;\n                    trackBy: trackByTrackingIndex\n                \"\n            >\n                <div class=\"d-flex align-items-baseline flex-wrap\">\n                    <h4 class=\"mt-0 mr-3\">{{ getListItemTitle(item) }}</h4>\n                    <span class=\"ml-auto\">\n                        <foehn-error-pill\n                            [incompleteIndicatorOnly]=\"true\"\n                            [errorPrefix]=\"name + '[' + itemIndex + ']'\"\n                        ></foehn-error-pill>\n                    </span>\n                </div>\n                <dl class=\"mb-0\">\n                    <ng-container\n                        *ngFor=\"let itemParam of listItemDescriptions\"\n                    >\n                        <div\n                            class=\"d-flex flex-wrap item-line\"\n                            *ngIf=\"showLine(item, itemParam)\"\n                        >\n                            <dt class=\"mr-1\">\n                                {{ itemParam.label }}\n                            </dt>\n                            <dd class=\"ml-auto text-right\">\n                                {{ itemParam.getFormattedValue(item) }}\n                            </dd>\n                        </div>\n                    </ng-container>\n                </dl>\n                <ul class=\"list-inline mb-3 mt-0\">\n                    <li class=\"list-inline-item\">\n                        <a\n                            [id]=\"'edit-link-' + item.trackingIndex\"\n                            href=\"#\"\n                            (click)=\"\n                                $event.preventDefault(); editItem(itemIndex)\n                            \"\n                        >\n                            Modifier\n                        </a>\n                        <span class=\"sr-only\">\n                            {{ getListItemTitle(item) }}\n                        </span>\n                    </li>\n                    <li class=\"list-inline-item\">\n                        &nbsp;\n                        <a\n                            [id]=\"'remove-link-' + item.trackingIndex\"\n                            href=\"#\"\n                            (click)=\"\n                                $event.preventDefault(); removeItem(itemIndex)\n                            \"\n                        >\n                            Supprimer\n                            <span class=\"sr-only\">\n                                {{ getListItemTitle(item) }}\n                            </span>\n                        </a>\n                    </li>\n                </ul>\n            </li>\n        </ul>\n    </section>\n\n    <section *ngIf=\"showAsTable && !!tableConfiguration?.length\">\n        <foehn-table\n            [list]=\"list\"\n            [itemsPerPage]=\"1000000\"\n            [columnsConfiguration]=\"tableConfiguration\"\n            [sort]=\"tableSort\"\n            (sortChange)=\"changeSort($event)\"\n        ></foehn-table>\n    </section>\n\n    <section [ngClass]=\"{ 'mt-5': !showAsTable }\">\n        <h2 class=\"sr-only\">Action</h2>\n        <ul class=\"list-inline mb-3\">\n            <li class=\"list-inline-item\">\n                <button class=\"btn btn-primary\" (click)=\"editItem()\">\n                    Ajouter\n                </button>\n            </li>\n        </ul>\n    </section>\n</section>\n\n<ng-template #tableActionButtons let-index=\"index\">\n    <div class=\"d-inline-flex\">\n        <foehn-icon-edit\n            [title]=\"'Modifier'\"\n            class=\"mr-3\"\n            (click)=\"editItem(index)\"\n        ></foehn-icon-edit>\n        <foehn-icon-trash-alt\n            [title]=\"'Supprimer'\"\n            (click)=\"removeItem(index)\"\n        ></foehn-icon-trash-alt>\n    </div>\n</ng-template>\n"]}
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-list-summary.component.js","sourceRoot":"","sources":["../../../../../projects/prestations-ng/src/foehn-menu-prestation/foehn-list-summary/foehn-list-summary.component.ts","../../../../../projects/prestations-ng/src/foehn-menu-prestation/foehn-list-summary/foehn-list-summary.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    EventEmitter,\n    forwardRef,\n    Input,\n    Output,\n    TemplateRef,\n    TrackByFunction,\n    ViewChild\n} from '@angular/core';\n\nimport { FoehnConfirmModalService } from '../../foehn-confirm-modal/foehn-confirm-modal.service';\nimport { FoehnInputComponent } from '../../foehn-input/foehn-input.component';\nimport { FoehnTableColumnConfiguration } from '../../foehn-table/foehn-table-column-configuration';\nimport { TableSort } from '../../foehn-table/tableSort';\nimport { FoehnListItem } from './foehn-list-item';\nimport { FoehnListItemDescription } from './foehn-list-item-description';\n\n@Component({\n    selector: 'foehn-list-summary',\n    templateUrl: './foehn-list-summary.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnListSummaryComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnListSummaryComponent\n    extends FoehnInputComponent<FoehnListItem[]>\n    implements AfterViewInit {\n    @ViewChild('tableActionButtons')\n    tableActionButtons: TemplateRef<unknown>;\n\n    @Input()\n    list: FoehnListItem[];\n\n    @Input()\n    getListItemTitle: (item: FoehnListItem) => string;\n\n    @Input()\n    showAsTable = false;\n\n    @Input()\n    listItemDescriptions: FoehnListItemDescription[];\n\n    @Output()\n    itemRemoved = new EventEmitter<void>();\n\n    @Output()\n    itemEdit = new EventEmitter<number>();\n\n    tableConfiguration: FoehnTableColumnConfiguration<FoehnListItem>[];\n\n    tableSort: TableSort = {\n        sortDirection: 'ASC'\n    };\n\n    constructor(private confirmModalService: FoehnConfirmModalService) {\n        super();\n    }\n\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        this.tableConfiguration = this.listItemDescriptions.map(\n            (item, index) => ({\n                id: `col-${index}`,\n                sortAttribute: index.toString(),\n                columnLabelKey: item.label,\n                valueGetter: (i: FoehnListItem) =>\n                    this.listItemDescriptions[index].getFormattedValue(i)\n            })\n        );\n        this.tableConfiguration.push({\n            id: 'actions',\n            columnLabelKey: 'foehn-table.header.actions',\n            template: this.tableActionButtons\n        });\n    }\n\n    trackByTrackingIndex(): TrackByFunction<FoehnListItem> {\n        return (index: number, item: FoehnListItem) => item.trackingIndex;\n    }\n\n    showLine(\n        item: FoehnListItem,\n        itemParam: FoehnListItemDescription\n    ): boolean {\n        const value = itemParam.getFormattedValue(item);\n        const hideIfEmptyExists = !!itemParam.hideIfEmpty;\n        if (value || !hideIfEmptyExists) {\n            return true;\n        } else {\n            return itemParam.hideIfEmpty(item);\n        }\n    }\n\n    editItem(index: number = null): void {\n        this.itemEdit.next(index);\n    }\n\n    removeItem(index: number): void {\n        this.confirmModalService\n            .openConfirmModal({\n                htmlContent: 'Souhaitez-vous vraiment supprimer cet élément ?'\n            })\n            .then(\n                () => {\n                    this.list = this.list.filter((item, i) => i !== index);\n                    this.itemRemoved.next();\n                },\n                () => {\n                    // nothing to do\n                }\n            );\n    }\n\n    changeSort(sortEvent: TableSort): void {\n        this.list = this.sortNow(this.list, sortEvent);\n        this.tableSort = sortEvent;\n    }\n\n    private sortNow(\n        elems: FoehnListItem[],\n        sortEvent: TableSort\n    ): FoehnListItem[] {\n        const listSorted = elems.sort((a, b) => {\n            const valueA = this.listItemDescriptions[\n                sortEvent.sortAttribute\n            ].getFormattedValue(a);\n            const valueB = this.listItemDescriptions[\n                sortEvent.sortAttribute\n            ].getFormattedValue(b);\n            return valueA.localeCompare(valueB);\n        });\n        if (sortEvent.sortDirection === 'DESC') {\n            listSorted.reverse();\n        }\n        return listSorted;\n    }\n}\n","<section\n    class=\"form-group clearable-input-form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <label\n        [attr.for]=\"buildChildId()\"\n        *ngIf=\"label && type !== 'hidden'\"\n        [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n    >\n        <span [innerHTML]=\"label\"></span>\n        <span\n            *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n            aria-hidden=\"true\"\n        >\n            {{ 'foehn-input.optional' | fromDictionary }}\n        </span>\n    </label>\n\n    <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n    <small\n        *ngIf=\"helpText && type !== 'hidden'\"\n        [attr.id]=\"buildChildId() + 'Help'\"\n        class=\"form-text text-secondary\"\n        [innerHTML]=\"helpText\"\n    ></small>\n\n    <section *ngIf=\"!showAsTable\">\n        <ul class=\"list-unstyled\" aria-describedby=\"sommaire-help-alt\">\n            <li\n                [id]=\"'list-summary-' + item.trackingIndex\"\n                class=\"mt-3 border-bottom\"\n                *ngFor=\"\n                    let item of list;\n                    let itemIndex = index;\n                    trackBy: trackByTrackingIndex\n                \"\n            >\n                <div class=\"d-flex align-items-baseline flex-wrap\">\n                    <h4 class=\"mt-0 mr-3\">{{ getListItemTitle(item) }}</h4>\n                    <span class=\"ml-auto\">\n                        <foehn-error-pill\n                            [incompleteIndicatorOnly]=\"true\"\n                            [errorPrefix]=\"name + '[' + itemIndex + ']'\"\n                        ></foehn-error-pill>\n                    </span>\n                </div>\n                <dl class=\"mb-0\">\n                    <ng-container\n                        *ngFor=\"let itemParam of listItemDescriptions\"\n                    >\n                        <div\n                            class=\"d-flex flex-wrap item-line\"\n                            *ngIf=\"showLine(item, itemParam)\"\n                        >\n                            <dt class=\"mr-1\">\n                                {{ itemParam.label }}\n                            </dt>\n                            <dd class=\"ml-auto text-right\">\n                                {{ itemParam.getFormattedValue(item) }}\n                            </dd>\n                        </div>\n                    </ng-container>\n                </dl>\n                <ul class=\"list-inline mb-3 mt-0\">\n                    <li class=\"list-inline-item\">\n                        <a\n                            [id]=\"'edit-link-' + item.trackingIndex\"\n                            href=\"#\"\n                            (click)=\"\n                                $event.preventDefault(); editItem(itemIndex)\n                            \"\n                        >\n                            Modifier\n                        </a>\n                        <span class=\"sr-only\">\n                            {{ getListItemTitle(item) }}\n                        </span>\n                    </li>\n                    <li class=\"list-inline-item\">\n                        &nbsp;\n                        <a\n                            [id]=\"'remove-link-' + item.trackingIndex\"\n                            href=\"#\"\n                            (click)=\"\n                                $event.preventDefault(); removeItem(itemIndex)\n                            \"\n                        >\n                            Supprimer\n                            <span class=\"sr-only\">\n                                {{ getListItemTitle(item) }}\n                            </span>\n                        </a>\n                    </li>\n                </ul>\n            </li>\n        </ul>\n    </section>\n\n    <section *ngIf=\"showAsTable && !!tableConfiguration?.length\">\n        <foehn-table\n            [list]=\"list\"\n            [itemsPerPage]=\"1000000\"\n            [columnsConfiguration]=\"tableConfiguration\"\n            [sort]=\"tableSort\"\n            (sortChange)=\"changeSort($event)\"\n        ></foehn-table>\n    </section>\n\n    <section [ngClass]=\"{ 'mt-5': !showAsTable }\">\n        <h2 class=\"sr-only\">Action</h2>\n        <ul class=\"list-inline mb-3\">\n            <li class=\"list-inline-item\">\n                <button class=\"btn btn-primary\" (click)=\"editItem()\">\n                    Ajouter\n                </button>\n            </li>\n        </ul>\n    </section>\n</section>\n\n<ng-template #tableActionButtons let-index=\"index\">\n    <div class=\"d-inline-flex\">\n        <foehn-icon-edit\n            [title]=\"'Modifier'\"\n            class=\"mr-3\"\n            (click)=\"editItem(index)\"\n        ></foehn-icon-edit>\n        <foehn-icon-trash-alt\n            [title]=\"'Supprimer'\"\n            (click)=\"removeItem(index)\"\n        ></foehn-icon-trash-alt>\n    </div>\n</ng-template>\n"]}
|
|
@@ -13186,8 +13186,10 @@ class FoehnListSummaryComponent extends FoehnInputComponent {
|
|
|
13186
13186
|
htmlContent: 'Souhaitez-vous vraiment supprimer cet élément ?'
|
|
13187
13187
|
})
|
|
13188
13188
|
.then(() => {
|
|
13189
|
-
this.list.
|
|
13189
|
+
this.list = this.list.filter((item, i) => i !== index);
|
|
13190
13190
|
this.itemRemoved.next();
|
|
13191
|
+
}, () => {
|
|
13192
|
+
// nothing to do
|
|
13191
13193
|
});
|
|
13192
13194
|
}
|
|
13193
13195
|
changeSort(sortEvent) {
|