UNPKG

carbon-components-angular

Version:
173 lines 16.2 kB
import { Component, EventEmitter, Input, Output } from "@angular/core"; import * as i0 from "@angular/core"; import * as i1 from "carbon-components-angular/i18n"; import * as i2 from "@angular/common"; import * as i3 from "carbon-components-angular/button"; /** * The table toolbar is reserved for global table actions such as table settings, complex filter, export, or editing table data. * * ## Basic usage * * ```html * <cds-table-toolbar [model]="model"> * <cds-table-toolbar-actions> * <button cdsButton="primary"> * Delete * <svg cdsIcon="trash-can" size="16" class="cds--btn__icon"></svg> * </button> * <button cdsButton="primary"> * Save * <svg cdsIcon="save" size="16" class="cds--btn__icon"></svg> * </button> * <button cdsButton="primary"> * Download * <svg cdsIcon="download" size="16" class="cds--btn__icon"></svg> * </button> * </cds-table-toolbar-actions> * <cds-table-toolbar-content> * <cds-table-toolbar-search [expandable]="true"></cds-table-toolbar-search> * <button cdsButton="toolbar-action"> * <svg cdsIcon="settings" size="16" class="cds--toolbar-action__icon"></svg> * </button> * <button cdsButton="primary" size="sm"> * Primary Button * <svg cdsIcon="add" size="20" class="cds--btn__icon"></svg> * </button> * </cds-table-toolbar-content> * </cds-table-toolbar> * ``` * */ export class TableToolbar { constructor(i18n) { this.i18n = i18n; this.size = "md"; this.cancel = new EventEmitter(); this.actionBarLabel = this.i18n.getOverridable("TABLE_TOOLBAR.ACTION_BAR"); this._cancelText = this.i18n.getOverridable("TABLE_TOOLBAR.CANCEL"); this._batchTextLegacy = this.i18n.getOverridable("TABLE_TOOLBAR.BATCH_TEXT"); this._batchTextSingle = this.i18n.getOverridable("TABLE_TOOLBAR.BATCH_TEXT_SINGLE"); this._batchTextMultiple = this.i18n.getOverridable("TABLE_TOOLBAR.BATCH_TEXT_MULTIPLE"); } set batchText(value) { if (typeof value === "object") { this._batchTextSingle.override(value.SINGLE); this._batchTextMultiple.override(value.MULTIPLE); } else { // For compatibility with old code this._batchTextLegacy.override(value); } } set ariaLabel(value) { this.actionBarLabel.override(value.ACTION_BAR); } set cancelText(value) { this._cancelText.override(value.CANCEL); } get cancelText() { return { CANCEL: this._cancelText.value }; } get count() { return this.model.totalDataLength > 0 ? this.model.rowsSelected.reduce((previous, current) => previous + (current ? 1 : 0), 0) : 0; } get selected() { return this.model.totalDataLength > 0 ? this.model.rowsSelected.some(item => item) : false; } onCancel() { this.model.selectAll(false); this.cancel.emit(); } } TableToolbar.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableToolbar, deps: [{ token: i1.I18n }], target: i0.ɵɵFactoryTarget.Component }); TableToolbar.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableToolbar, selector: "cds-table-toolbar, ibm-table-toolbar", inputs: { model: "model", batchText: "batchText", ariaLabel: "ariaLabel", cancelText: "cancelText", size: "size" }, outputs: { cancel: "cancel" }, ngImport: i0, template: ` <section class="cds--table-toolbar" [ngClass]="{'cds--table-toolbar--sm' : size === 'sm'}" [attr.aria-label]="actionBarLabel.subject | async"> <div *ngIf="model" class="cds--batch-actions" [ngClass]="{ 'cds--batch-actions--active': selected }"> <div class="cds--batch-summary"> <p class="cds--batch-summary__para" *ngIf="count as n"> <ng-container *ngIf="_batchTextLegacy.subject | async as legacyText; else batchTextBlock"> <span>{{n}}</span> {{legacyText}} </ng-container> <ng-template #batchTextBlock> <span *ngIf="n === 1">{{_batchTextSingle.subject | async}}</span> <span *ngIf="n !== 1">{{_batchTextMultiple.subject | i18nReplace: {count: n} | async}}</span> </ng-template> </p> </div> <div class="cds--action-list"> <ng-content select="cds-table-toolbar-actions,ibm-table-toolbar-actions"></ng-content> <button cdsButton="primary" class="cds--batch-summary__cancel" [tabindex]="selected ? 0 : -1" (click)="onCancel()"> {{_cancelText.subject | async}} </button> </div> </div> <ng-content></ng-content> </section> `, isInline: true, dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.ReplacePipe, name: "i18nReplace" }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableToolbar, decorators: [{ type: Component, args: [{ selector: "cds-table-toolbar, ibm-table-toolbar", template: ` <section class="cds--table-toolbar" [ngClass]="{'cds--table-toolbar--sm' : size === 'sm'}" [attr.aria-label]="actionBarLabel.subject | async"> <div *ngIf="model" class="cds--batch-actions" [ngClass]="{ 'cds--batch-actions--active': selected }"> <div class="cds--batch-summary"> <p class="cds--batch-summary__para" *ngIf="count as n"> <ng-container *ngIf="_batchTextLegacy.subject | async as legacyText; else batchTextBlock"> <span>{{n}}</span> {{legacyText}} </ng-container> <ng-template #batchTextBlock> <span *ngIf="n === 1">{{_batchTextSingle.subject | async}}</span> <span *ngIf="n !== 1">{{_batchTextMultiple.subject | i18nReplace: {count: n} | async}}</span> </ng-template> </p> </div> <div class="cds--action-list"> <ng-content select="cds-table-toolbar-actions,ibm-table-toolbar-actions"></ng-content> <button cdsButton="primary" class="cds--batch-summary__cancel" [tabindex]="selected ? 0 : -1" (click)="onCancel()"> {{_cancelText.subject | async}} </button> </div> </div> <ng-content></ng-content> </section> ` }] }], ctorParameters: function () { return [{ type: i1.I18n }]; }, propDecorators: { model: [{ type: Input }], batchText: [{ type: Input }], ariaLabel: [{ type: Input }], cancelText: [{ type: Input }], size: [{ type: Input }], cancel: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-toolbar.component.js","sourceRoot":"","sources":["../../../../src/table/toolbar/table-toolbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { TableModel } from \"../table-model.class\";\nimport {\n\tComponent,\n\tEventEmitter,\n\tInput,\n\tOutput\n} from \"@angular/core\";\nimport { I18n, Overridable } from \"carbon-components-angular/i18n\";\nimport { TableRowSize } from \"../table.types\";\n\n/**\n * The table toolbar is reserved for global table actions such as table settings, complex filter, export, or editing table data.\n *\n * ## Basic usage\n *\n * ```html\n * <cds-table-toolbar [model]=\"model\">\n *\t\t<cds-table-toolbar-actions>\n *\t\t\t<button cdsButton=\"primary\">\n *\t\t\t\tDelete\n *\t\t\t\t<svg cdsIcon=\"trash-can\" size=\"16\" class=\"cds--btn__icon\"></svg>\n *\t\t\t</button>\n *\t\t\t<button cdsButton=\"primary\">\n *\t\t\t\tSave\n *\t\t\t\t<svg cdsIcon=\"save\" size=\"16\" class=\"cds--btn__icon\"></svg>\n *\t\t\t</button>\n *\t\t\t<button cdsButton=\"primary\">\n *\t\t\t\tDownload\n *\t\t\t\t<svg cdsIcon=\"download\" size=\"16\" class=\"cds--btn__icon\"></svg>\n *\t\t\t</button>\n *\t\t</cds-table-toolbar-actions>\n *\t\t\t<cds-table-toolbar-content>\n *\t\t\t<cds-table-toolbar-search [expandable]=\"true\"></cds-table-toolbar-search>\n *\t\t\t<button cdsButton=\"toolbar-action\">\n *\t\t\t\t<svg cdsIcon=\"settings\" size=\"16\" class=\"cds--toolbar-action__icon\"></svg>\n *\t\t\t</button>\n *\t\t\t<button cdsButton=\"primary\" size=\"sm\">\n *\t\t\t\tPrimary Button\n *\t\t\t\t<svg cdsIcon=\"add\" size=\"20\" class=\"cds--btn__icon\"></svg>\n *\t\t\t</button>\n *\t\t</cds-table-toolbar-content>\n *\t</cds-table-toolbar>\n * ```\n *\n */\n@Component({\n\tselector: \"cds-table-toolbar, ibm-table-toolbar\",\n\ttemplate: `\n\t<section\n\t\tclass=\"cds--table-toolbar\"\n\t\t[ngClass]=\"{'cds--table-toolbar--sm' : size === 'sm'}\"\n\t\t[attr.aria-label]=\"actionBarLabel.subject | async\">\n\t\t<div\n\t\t\t*ngIf=\"model\"\n\t\t\tclass=\"cds--batch-actions\"\n\t\t\t[ngClass]=\"{\n\t\t\t\t'cds--batch-actions--active': selected\n\t\t\t}\">\n\t\t\t<div class=\"cds--batch-summary\">\n\t\t\t\t<p class=\"cds--batch-summary__para\" *ngIf=\"count as n\">\n\t\t\t\t\t<ng-container *ngIf=\"_batchTextLegacy.subject | async as legacyText; else batchTextBlock\">\n\t\t\t\t\t\t<span>{{n}}</span> {{legacyText}}\n\t\t\t\t\t</ng-container>\n\t\t\t\t\t<ng-template #batchTextBlock>\n\t\t\t\t\t\t<span *ngIf=\"n === 1\">{{_batchTextSingle.subject | async}}</span>\n\t\t\t\t\t\t<span *ngIf=\"n !== 1\">{{_batchTextMultiple.subject | i18nReplace: {count: n} | async}}</span>\n\t\t\t\t\t</ng-template>\n\t\t\t\t</p>\n\t\t\t</div>\n\t\t\t<div class=\"cds--action-list\">\n\t\t\t\t<ng-content select=\"cds-table-toolbar-actions,ibm-table-toolbar-actions\"></ng-content>\n\t\t\t\t<button\n\t\t\t\t\tcdsButton=\"primary\"\n\t\t\t\t\tclass=\"cds--batch-summary__cancel\"\n\t\t\t\t\t[tabindex]=\"selected ? 0 : -1\"\n\t\t\t\t\t(click)=\"onCancel()\">\n\t\t\t\t\t{{_cancelText.subject | async}}\n\t\t\t\t</button>\n\t\t\t</div>\n\t\t</div>\n\t\t<ng-content></ng-content>\n\t</section>\n\t`\n})\nexport class TableToolbar {\n\t@Input() model: TableModel;\n\n\t@Input() set batchText (value: string | { SINGLE: string, MULTIPLE: string }) {\n\t\tif (typeof value === \"object\") {\n\t\t\tthis._batchTextSingle.override(value.SINGLE);\n\t\t\tthis._batchTextMultiple.override(value.MULTIPLE);\n\t\t} else {\n\t\t\t// For compatibility with old code\n\t\t\tthis._batchTextLegacy.override(value);\n\t\t}\n\t}\n\t@Input() set ariaLabel (value: { ACTION_BAR: string }) {\n\t\tthis.actionBarLabel.override(value.ACTION_BAR);\n\t}\n\t@Input() set cancelText(value: { CANCEL: string }) {\n\t\tthis._cancelText.override(value.CANCEL);\n\t}\n\t@Input() size: TableRowSize = \"md\";\n\n\tget cancelText(): { CANCEL: string } {\n\t\treturn { CANCEL: this._cancelText.value as string };\n\t}\n\n\t@Output() cancel = new EventEmitter();\n\n\tactionBarLabel: Overridable = this.i18n.getOverridable(\"TABLE_TOOLBAR.ACTION_BAR\");\n\t_cancelText: Overridable = this.i18n.getOverridable(\"TABLE_TOOLBAR.CANCEL\");\n\t_batchTextLegacy: Overridable = this.i18n.getOverridable(\"TABLE_TOOLBAR.BATCH_TEXT\");\n\t_batchTextSingle: Overridable = this.i18n.getOverridable(\"TABLE_TOOLBAR.BATCH_TEXT_SINGLE\");\n\t_batchTextMultiple: Overridable = this.i18n.getOverridable(\"TABLE_TOOLBAR.BATCH_TEXT_MULTIPLE\");\n\n\tconstructor(protected i18n: I18n) {}\n\n\tget count() {\n\t\treturn this.model.totalDataLength > 0 ? this.model.rowsSelected.reduce((previous, current) => previous + (current ? 1 : 0), 0) : 0;\n\t}\n\tget selected() {\n\t\treturn this.model.totalDataLength > 0 ? this.model.rowsSelected.some(item => item) : false;\n\t}\n\n\tonCancel() {\n\t\tthis.model.selectAll(false);\n\t\tthis.cancel.emit();\n\t}\n}\n"]}