@progress/kendo-angular-spreadsheet 14.1.1-develop.8 → 14.2.0-develop.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.
Files changed (35) hide show
  1. package/esm2020/localization/messages.mjs +21 -1
  2. package/esm2020/package-metadata.mjs +2 -2
  3. package/esm2020/sheets-bar/action-dialog.component.mjs +8 -7
  4. package/esm2020/spreadsheet.component.mjs +103 -20
  5. package/esm2020/spreadsheet.module.mjs +48 -10
  6. package/esm2020/tools/{align-tool.directive.mjs → align/align-tool.directive.mjs} +8 -8
  7. package/esm2020/tools/align/horizontal-align-tool.directive.mjs +58 -0
  8. package/esm2020/tools/align/vertical-align-tool.directive.mjs +58 -0
  9. package/esm2020/tools/decrease-decimal-tool.directive.mjs +40 -0
  10. package/esm2020/tools/font-family/font-family-dropdownlist.component.mjs +0 -2
  11. package/esm2020/tools/font-size/decrease-font-tool.directive.mjs +50 -0
  12. package/esm2020/tools/font-size/increase-font-tool.directive.mjs +50 -0
  13. package/esm2020/tools/increase-decimal-tool.directive.mjs +40 -0
  14. package/esm2020/tools/index.mjs +8 -1
  15. package/esm2020/tools/insert/insert-link-dialog.component.mjs +49 -0
  16. package/esm2020/tools/insert/insert-link-tool.directive.mjs +91 -0
  17. package/esm2020/tools/shared/command-icons.mjs +17 -3
  18. package/fesm2015/progress-kendo-angular-spreadsheet.mjs +490 -31
  19. package/fesm2020/progress-kendo-angular-spreadsheet.mjs +489 -31
  20. package/localization/messages.d.ts +41 -1
  21. package/models/main-menu-item.d.ts +1 -1
  22. package/package.json +13 -13
  23. package/schematics/ngAdd/index.js +1 -1
  24. package/spreadsheet.module.d.ts +23 -15
  25. package/tools/{align-tool.directive.d.ts → align/align-tool.directive.d.ts} +3 -3
  26. package/tools/align/horizontal-align-tool.directive.d.ts +25 -0
  27. package/tools/align/vertical-align-tool.directive.d.ts +25 -0
  28. package/tools/decrease-decimal-tool.directive.d.ts +19 -0
  29. package/tools/font-size/decrease-font-tool.directive.d.ts +22 -0
  30. package/tools/font-size/increase-font-tool.directive.d.ts +22 -0
  31. package/tools/increase-decimal-tool.directive.d.ts +19 -0
  32. package/tools/index.d.ts +8 -1
  33. package/tools/insert/insert-link-dialog.component.d.ts +18 -0
  34. package/tools/insert/insert-link-tool.directive.d.ts +26 -0
  35. package/tools/shared/commands.d.ts +1 -1
@@ -8,7 +8,7 @@ import { validatePackage } from '@progress/kendo-licensing';
8
8
  import { SpreadsheetWidget } from '@progress/kendo-spreadsheet-common';
9
9
  import * as i1$5 from '@progress/kendo-angular-intl';
10
10
  import { localeData, IntlModule } from '@progress/kendo-angular-intl';
11
- import { formulaFxIcon, trashIcon, copyIcon, pencilIcon, arrowRightIcon, arrowLeftIcon, alignCenterIcon, alignJustifyIcon, alignLeftIcon, alignRightIcon, alignTopIcon, alignMiddleIcon, alignBottomIcon, dropletIcon, boldIcon, foregroundColorIcon, italicIcon, arrowRotateCwIcon, underlineIcon, arrowRotateCcwIcon, textWrapIcon, tableColumnInsertLeftIcon, tableColumnInsertRightIcon, tableRowInsertAboveIcon, tableRowInsertBelowIcon, tableRowDeleteIcon, tableColumnDeleteIcon, bordersNoneIcon, folderOpenIcon, downloadIcon, customFormatIcon, fontSizeIcon, fontFamilyIcon, cellsMergeIcon, cellsMergeHorizontallyIcon, cellsMergeVerticallyIcon, tableUnmergeIcon, plusIcon, menuIcon, caretAltDownIcon, caretAltLeftIcon, caretAltRightIcon, eyeIcon } from '@progress/kendo-svg-icons';
11
+ import { formulaFxIcon, trashIcon, copyIcon, pencilIcon, arrowRightIcon, arrowLeftIcon, alignCenterIcon, alignJustifyIcon, alignLeftIcon, alignRightIcon, alignTopIcon, alignMiddleIcon, alignBottomIcon, dropletIcon, boldIcon, foregroundColorIcon, italicIcon, arrowRotateCwIcon, underlineIcon, arrowRotateCcwIcon, textWrapIcon, tableColumnInsertLeftIcon, tableColumnInsertRightIcon, tableRowInsertAboveIcon, tableRowInsertBelowIcon, tableRowDeleteIcon, tableColumnDeleteIcon, bordersNoneIcon, folderOpenIcon, downloadIcon, customFormatIcon, fontSizeIcon, fontFamilyIcon, cellsMergeIcon, cellsMergeHorizontallyIcon, cellsMergeVerticallyIcon, tableUnmergeIcon, linkIcon, fontGrowIcon, fontShrinkIcon, decimalDecreaseIcon, decimalIncreaseIcon, plusIcon, menuIcon, caretAltDownIcon, caretAltLeftIcon, caretAltRightIcon, eyeIcon } from '@progress/kendo-svg-icons';
12
12
  import { Subject, Subscription } from 'rxjs';
13
13
  import * as i1 from '@progress/kendo-angular-l10n';
14
14
  import { LocalizationService, L10N_PREFIX, RTL, ComponentMessages } from '@progress/kendo-angular-l10n';
@@ -33,11 +33,12 @@ import * as i1$3 from '@progress/kendo-angular-dropdowns';
33
33
  import { DropDownListComponent, ComboBoxModule, DropDownListModule } from '@progress/kendo-angular-dropdowns';
34
34
  import * as i5 from '@progress/kendo-angular-inputs';
35
35
  import { InputsModule } from '@progress/kendo-angular-inputs';
36
+ import * as i2 from '@progress/kendo-angular-label';
37
+ import { LabelModule } from '@progress/kendo-angular-label';
36
38
  import * as i5$1 from '@progress/kendo-angular-layout';
37
39
  import { TabStripModule } from '@progress/kendo-angular-layout';
38
40
  import { saveAs } from '@progress/kendo-file-saver';
39
41
  import { Workbook } from '@progress/kendo-ooxml';
40
- import { LabelModule } from '@progress/kendo-angular-label';
41
42
 
42
43
  /**
43
44
  * @hidden
@@ -46,8 +47,8 @@ const packageMetadata = {
46
47
  name: '@progress/kendo-angular-spreadsheet',
47
48
  productName: 'Kendo UI for Angular',
48
49
  productCodes: ['KENDOUIANGULAR', 'KENDOUICOMPLETE'],
49
- publishDate: 1700478634,
50
- version: '14.1.1-develop.8',
50
+ publishDate: 1700668297,
51
+ version: '14.2.0-develop.2',
51
52
  licensingDocsUrl: 'https://www.telerik.com/kendo-angular-ui/my-license/?utm_medium=product&utm_source=kendoangular&utm_campaign=kendo-ui-angular-purchase-license-keys-warning',
52
53
  };
53
54
 
@@ -441,6 +442,8 @@ const commandIcons = {
441
442
  alignMiddle: 'align-middle',
442
443
  alignBottom: 'align-bottom',
443
444
  align: 'align-left',
445
+ alignHorizontal: 'align-left',
446
+ alignVertical: 'align-middle',
444
447
  background: 'droplet',
445
448
  bold: 'bold',
446
449
  color: 'foreground-color',
@@ -465,7 +468,12 @@ const commandIcons = {
465
468
  mergeAll: 'cells-merge',
466
469
  mergeHorizontally: 'cells-merge-horizontally',
467
470
  mergeVertically: 'cells-merge-vertically',
468
- unmerge: 'table-unmerge'
471
+ unmerge: 'table-unmerge',
472
+ insertLink: 'hyperlink',
473
+ increaseFontSize: 'font-grow',
474
+ decreaseFontSize: 'font-shrink',
475
+ increaseDecimal: 'decimal-increase',
476
+ decreaseDecimal: 'decimal-decrease'
469
477
  };
470
478
  /**
471
479
  * @hidden
@@ -479,6 +487,8 @@ const commandSVGIcons = {
479
487
  alignMiddle: alignMiddleIcon,
480
488
  alignBottom: alignBottomIcon,
481
489
  align: alignLeftIcon,
490
+ alignHorizontal: alignLeftIcon,
491
+ alignVertical: alignMiddleIcon,
482
492
  background: dropletIcon,
483
493
  bold: boldIcon,
484
494
  color: foregroundColorIcon,
@@ -503,7 +513,12 @@ const commandSVGIcons = {
503
513
  mergeAll: cellsMergeIcon,
504
514
  mergeHorizontally: cellsMergeHorizontallyIcon,
505
515
  mergeVertically: cellsMergeVerticallyIcon,
506
- unmerge: tableUnmergeIcon
516
+ unmerge: tableUnmergeIcon,
517
+ insertLink: linkIcon,
518
+ increaseFontSize: fontGrowIcon,
519
+ decreaseFontSize: fontShrinkIcon,
520
+ decreaseDecimal: decimalDecreaseIcon,
521
+ increaseDecimal: decimalIncreaseIcon
507
522
  };
508
523
 
509
524
  /**
@@ -810,7 +825,6 @@ FontFamilyDropDownListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion:
810
825
  #element
811
826
  [data]="data"
812
827
  [(value)]="value"
813
- [attr.title]="title"
814
828
  [tabindex]="tabindex"
815
829
  (valueChange)="onValueChange($event)"
816
830
  [leftRightArrowsNavigation]="false"
@@ -832,7 +846,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
832
846
  #element
833
847
  [data]="data"
834
848
  [(value)]="value"
835
- [attr.title]="title"
836
849
  [tabindex]="tabindex"
837
850
  (valueChange)="onValueChange($event)"
838
851
  [leftRightArrowsNavigation]="false"
@@ -1583,9 +1596,9 @@ ActionDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0",
1583
1596
 
1584
1597
  <form class="k-form k-form-md" *ngIf="commandName === 'rename'" method="dialog">
1585
1598
  <div class="k-form-field">
1586
- <label class="k-label k-form-label">Rename sheet</label>
1599
+ <kendo-label [for]="textbox" text="Rename sheet"></kendo-label>
1587
1600
  <div class="k-form-field-wrap">
1588
- <kendo-textbox
1601
+ <kendo-textbox #textbox
1589
1602
  autocomplete="off"
1590
1603
  placeholder="Sheet name"
1591
1604
  [(value)]="value">
@@ -1593,7 +1606,7 @@ ActionDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0",
1593
1606
  </div>
1594
1607
  </div>
1595
1608
  </form>
1596
- `, isInline: true, components: [{ type: i5.TextBoxComponent, selector: "kendo-textbox", inputs: ["focusableId", "title", "disabled", "readonly", "tabindex", "value", "selectOnFocus", "showSuccessIcon", "showErrorIcon", "clearButton", "successIcon", "successSvgIcon", "errorIcon", "errorSvgIcon", "clearButtonIcon", "clearButtonSvgIcon", "size", "rounded", "fillMode", "tabIndex", "placeholder", "maxlength"], outputs: ["valueChange", "inputFocus", "inputBlur", "focus", "blur"], exportAs: ["kendoTextBox"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
1609
+ `, isInline: true, components: [{ type: i2.LabelComponent, selector: "kendo-label", inputs: ["text", "for", "optional", "labelCssStyle", "labelCssClass"], exportAs: ["kendoLabel"] }, { type: i5.TextBoxComponent, selector: "kendo-textbox", inputs: ["focusableId", "title", "disabled", "readonly", "tabindex", "value", "selectOnFocus", "showSuccessIcon", "showErrorIcon", "clearButton", "successIcon", "successSvgIcon", "errorIcon", "errorSvgIcon", "clearButtonIcon", "clearButtonSvgIcon", "size", "rounded", "fillMode", "tabIndex", "placeholder", "maxlength"], outputs: ["valueChange", "inputFocus", "inputBlur", "focus", "blur"], exportAs: ["kendoTextBox"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
1597
1610
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: ActionDialogComponent, decorators: [{
1598
1611
  type: Component,
1599
1612
  args: [{
@@ -1605,9 +1618,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
1605
1618
 
1606
1619
  <form class="k-form k-form-md" *ngIf="commandName === 'rename'" method="dialog">
1607
1620
  <div class="k-form-field">
1608
- <label class="k-label k-form-label">Rename sheet</label>
1621
+ <kendo-label [for]="textbox" text="Rename sheet"></kendo-label>
1609
1622
  <div class="k-form-field-wrap">
1610
- <kendo-textbox
1623
+ <kendo-textbox #textbox
1611
1624
  autocomplete="off"
1612
1625
  placeholder="Sheet name"
1613
1626
  [(value)]="value">
@@ -1939,7 +1952,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
1939
1952
  class MessagesDirective extends ComponentMessages {
1940
1953
  }
1941
1954
  MessagesDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: MessagesDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
1942
- MessagesDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: MessagesDirective, selector: "[kendoSpreadsheetMessages]", inputs: { home: "home", file: "file", insert: "insert", saveFile: "saveFile", loadFile: "loadFile", bold: "bold", italic: "italic", underline: "underline", format: "format", fontFamily: "fontFamily", fontSize: "fontSize", undo: "undo", redo: "redo", background: "background", color: "color", gridLines: "gridLines", addColumnLeft: "addColumnLeft", addColumnRight: "addColumnRight", addRowBelow: "addRowBelow", addRowAbove: "addRowAbove", deleteColumn: "deleteColumn", deleteRow: "deleteRow", wrap: "wrap", align: "align", dialogApply: "dialogApply", dialogCancel: "dialogCancel", dialogDelete: "dialogDelete", dialogRename: "dialogRename", delete: "delete", rename: "rename", nameBox: "nameBox", addSheet: "addSheet", sheetsMenu: "sheetsMenu", view: "view", merge: "merge" }, usesInheritance: true, ngImport: i0 });
1955
+ MessagesDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: MessagesDirective, selector: "[kendoSpreadsheetMessages]", inputs: { home: "home", file: "file", insert: "insert", formatTab: "formatTab", saveFile: "saveFile", loadFile: "loadFile", bold: "bold", italic: "italic", underline: "underline", format: "format", fontFamily: "fontFamily", fontSize: "fontSize", undo: "undo", redo: "redo", background: "background", color: "color", gridLines: "gridLines", addColumnLeft: "addColumnLeft", addColumnRight: "addColumnRight", addRowBelow: "addRowBelow", addRowAbove: "addRowAbove", deleteColumn: "deleteColumn", deleteRow: "deleteRow", wrap: "wrap", align: "align", alignHorizontal: "alignHorizontal", alignVertical: "alignVertical", dialogApply: "dialogApply", dialogCancel: "dialogCancel", dialogDelete: "dialogDelete", dialogRename: "dialogRename", dialogInsert: "dialogInsert", dialogRemoveLink: "dialogRemoveLink", delete: "delete", rename: "rename", nameBox: "nameBox", addSheet: "addSheet", sheetsMenu: "sheetsMenu", view: "view", merge: "merge", insertLink: "insertLink", increaseDecimal: "increaseDecimal", decreaseDecimal: "decreaseDecimal", increaseFontSize: "increaseFontSize", decreaseFontSize: "decreaseFontSize" }, usesInheritance: true, ngImport: i0 });
1943
1956
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: MessagesDirective, decorators: [{
1944
1957
  type: Directive,
1945
1958
  args: [{
@@ -1951,6 +1964,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
1951
1964
  type: Input
1952
1965
  }], insert: [{
1953
1966
  type: Input
1967
+ }], formatTab: [{
1968
+ type: Input
1954
1969
  }], saveFile: [{
1955
1970
  type: Input
1956
1971
  }], loadFile: [{
@@ -1993,6 +2008,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
1993
2008
  type: Input
1994
2009
  }], align: [{
1995
2010
  type: Input
2011
+ }], alignHorizontal: [{
2012
+ type: Input
2013
+ }], alignVertical: [{
2014
+ type: Input
1996
2015
  }], dialogApply: [{
1997
2016
  type: Input
1998
2017
  }], dialogCancel: [{
@@ -2001,6 +2020,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
2001
2020
  type: Input
2002
2021
  }], dialogRename: [{
2003
2022
  type: Input
2023
+ }], dialogInsert: [{
2024
+ type: Input
2025
+ }], dialogRemoveLink: [{
2026
+ type: Input
2004
2027
  }], delete: [{
2005
2028
  type: Input
2006
2029
  }], rename: [{
@@ -2015,6 +2038,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
2015
2038
  type: Input
2016
2039
  }], merge: [{
2017
2040
  type: Input
2041
+ }], insertLink: [{
2042
+ type: Input
2043
+ }], increaseDecimal: [{
2044
+ type: Input
2045
+ }], decreaseDecimal: [{
2046
+ type: Input
2047
+ }], increaseFontSize: [{
2048
+ type: Input
2049
+ }], decreaseFontSize: [{
2050
+ type: Input
2018
2051
  }] } });
2019
2052
 
2020
2053
  /**
@@ -2214,6 +2247,76 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
2214
2247
  }]
2215
2248
  }], ctorParameters: function () { return [{ type: i1$2.ToolBarButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
2216
2249
 
2250
+ /**
2251
+ * @hidden
2252
+ */
2253
+ class SpreadsheetIncreaseFontSizeDirective extends SpreadsheetCommandButton {
2254
+ constructor(button, localization, spreadsheetService, toolsService) {
2255
+ super('increaseFontSize', button, localization, spreadsheetService, toolsService, {
2256
+ command: 'PropertyChangeCommand',
2257
+ options: { property: 'fontSize' }
2258
+ });
2259
+ this.value = DEFAULT_FONT_VALUES.fontSize;
2260
+ }
2261
+ clickHandler() {
2262
+ const newValue = this.value + 1;
2263
+ const options = {
2264
+ command: 'PropertyChangeCommand',
2265
+ options: { property: 'fontSize', value: newValue || null }
2266
+ };
2267
+ this.spreadsheetService.spreadsheet.executeCommand(options);
2268
+ }
2269
+ ngAfterViewInit() {
2270
+ this.value = this.toolsService.toolsState['fontSize'];
2271
+ this.subs.add(this.toolsService.stateChange.subscribe(state => {
2272
+ this.value = state['fontSize'];
2273
+ }));
2274
+ }
2275
+ }
2276
+ SpreadsheetIncreaseFontSizeDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetIncreaseFontSizeDirective, deps: [{ token: i1$2.ToolBarButtonComponent }, { token: SpreadsheetLocalizationService }, { token: SpreadsheetService }, { token: SpreadsheetToolsService }], target: i0.ɵɵFactoryTarget.Directive });
2277
+ SpreadsheetIncreaseFontSizeDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: SpreadsheetIncreaseFontSizeDirective, selector: "kendo-toolbar-button[kendoSpreadsheetIncreaseFontSize]", usesInheritance: true, ngImport: i0 });
2278
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetIncreaseFontSizeDirective, decorators: [{
2279
+ type: Directive,
2280
+ args: [{
2281
+ selector: 'kendo-toolbar-button[kendoSpreadsheetIncreaseFontSize]'
2282
+ }]
2283
+ }], ctorParameters: function () { return [{ type: i1$2.ToolBarButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
2284
+
2285
+ /**
2286
+ * @hidden
2287
+ */
2288
+ class SpreadsheetDecreaseFontSizeDirective extends SpreadsheetCommandButton {
2289
+ constructor(button, localization, spreadsheetService, toolsService) {
2290
+ super('decreaseFontSize', button, localization, spreadsheetService, toolsService, {
2291
+ command: 'PropertyChangeCommand',
2292
+ options: { property: 'fontSize' }
2293
+ });
2294
+ this.value = DEFAULT_FONT_VALUES.fontSize;
2295
+ }
2296
+ clickHandler() {
2297
+ const newValue = this.value - 1;
2298
+ const options = {
2299
+ command: 'PropertyChangeCommand',
2300
+ options: { property: 'fontSize', value: newValue || null }
2301
+ };
2302
+ this.spreadsheetService.spreadsheet.executeCommand(options);
2303
+ }
2304
+ ngAfterViewInit() {
2305
+ this.value = this.toolsService.toolsState['fontSize'];
2306
+ this.subs.add(this.toolsService.stateChange.subscribe(state => {
2307
+ this.value = state['fontSize'];
2308
+ }));
2309
+ }
2310
+ }
2311
+ SpreadsheetDecreaseFontSizeDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetDecreaseFontSizeDirective, deps: [{ token: i1$2.ToolBarButtonComponent }, { token: SpreadsheetLocalizationService }, { token: SpreadsheetService }, { token: SpreadsheetToolsService }], target: i0.ɵɵFactoryTarget.Directive });
2312
+ SpreadsheetDecreaseFontSizeDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: SpreadsheetDecreaseFontSizeDirective, selector: "kendo-toolbar-button[kendoSpreadsheetDecreaseFontSize]", usesInheritance: true, ngImport: i0 });
2313
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetDecreaseFontSizeDirective, decorators: [{
2314
+ type: Directive,
2315
+ args: [{
2316
+ selector: 'kendo-toolbar-button[kendoSpreadsheetDecreaseFontSize]'
2317
+ }]
2318
+ }], ctorParameters: function () { return [{ type: i1$2.ToolBarButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
2319
+
2217
2320
  /**
2218
2321
  * @hidden
2219
2322
  */
@@ -2283,18 +2386,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
2283
2386
  /**
2284
2387
  * @hidden
2285
2388
  */
2286
- class SpreadsheetTextAlignDirective {
2389
+ class SpreadsheetHorizontalTextAlignDirective {
2287
2390
  constructor(host, localization, spreadsheetService, toolsService) {
2288
2391
  this.host = host;
2289
2392
  this.spreadsheetService = spreadsheetService;
2290
2393
  this.toolsService = toolsService;
2291
- this.commandName = 'align';
2394
+ this.commandName = 'alignHorizontal';
2292
2395
  this.subs = new Subscription();
2293
2396
  host.svgIcon = commandSVGIcons[this.commandName];
2294
2397
  host.icon = commandIcons[this.commandName];
2295
2398
  host.arrowIcon = true;
2296
2399
  host.fillMode = 'flat';
2297
- host.data = [...ALIGNS];
2400
+ host.data = ALIGNS.filter(value => value.commandName === 'textAlign');
2298
2401
  this.subs.add(host.itemClick.subscribe((e) => this.onItemClick(e)));
2299
2402
  host.title = localization.get(this.commandName);
2300
2403
  host.textField = 'textKey';
@@ -2313,12 +2416,54 @@ class SpreadsheetTextAlignDirective {
2313
2416
  this.spreadsheetService.spreadsheet.executeCommand(options);
2314
2417
  }
2315
2418
  }
2316
- SpreadsheetTextAlignDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetTextAlignDirective, deps: [{ token: i1$2.ToolBarDropDownButtonComponent }, { token: SpreadsheetLocalizationService }, { token: SpreadsheetService }, { token: SpreadsheetToolsService }], target: i0.ɵɵFactoryTarget.Directive });
2317
- SpreadsheetTextAlignDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: SpreadsheetTextAlignDirective, selector: "[kendoSpreadsheetTextAlign]", ngImport: i0 });
2318
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetTextAlignDirective, decorators: [{
2419
+ SpreadsheetHorizontalTextAlignDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetHorizontalTextAlignDirective, deps: [{ token: i1$2.ToolBarDropDownButtonComponent }, { token: SpreadsheetLocalizationService }, { token: SpreadsheetService }, { token: SpreadsheetToolsService }], target: i0.ɵɵFactoryTarget.Directive });
2420
+ SpreadsheetHorizontalTextAlignDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: SpreadsheetHorizontalTextAlignDirective, selector: "[kendoSpreadsheetHorizontalTextAlign]", ngImport: i0 });
2421
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetHorizontalTextAlignDirective, decorators: [{
2319
2422
  type: Directive,
2320
2423
  args: [{
2321
- selector: '[kendoSpreadsheetTextAlign]',
2424
+ selector: '[kendoSpreadsheetHorizontalTextAlign]',
2425
+ }]
2426
+ }], ctorParameters: function () { return [{ type: i1$2.ToolBarDropDownButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
2427
+
2428
+ /**
2429
+ * @hidden
2430
+ */
2431
+ class SpreadsheetVerticalTextAlignDirective {
2432
+ constructor(host, localization, spreadsheetService, toolsService) {
2433
+ this.host = host;
2434
+ this.spreadsheetService = spreadsheetService;
2435
+ this.toolsService = toolsService;
2436
+ this.commandName = 'alignVertical';
2437
+ this.subs = new Subscription();
2438
+ host.svgIcon = commandSVGIcons[this.commandName];
2439
+ host.icon = commandIcons[this.commandName];
2440
+ host.arrowIcon = true;
2441
+ host.fillMode = 'flat';
2442
+ host.data = ALIGNS.filter(value => value.commandName === 'verticalAlign');
2443
+ this.subs.add(host.itemClick.subscribe((e) => this.onItemClick(e)));
2444
+ host.title = localization.get(this.commandName);
2445
+ host.textField = 'textKey';
2446
+ }
2447
+ ngOnInit() {
2448
+ this.subs.add(this.toolsService.stateChange.subscribe(state => this.host.data.forEach(i => i.cssClass = i.value === state[i.commandName] ? 'k-selected' : '')));
2449
+ }
2450
+ ngOnDestroy() {
2451
+ this.subs.unsubscribe();
2452
+ }
2453
+ onItemClick(item) {
2454
+ const value = item.value || null;
2455
+ const options = {
2456
+ command: 'PropertyChangeCommand', options: { property: item.commandName, value }
2457
+ };
2458
+ this.spreadsheetService.spreadsheet.executeCommand(options);
2459
+ }
2460
+ }
2461
+ SpreadsheetVerticalTextAlignDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetVerticalTextAlignDirective, deps: [{ token: i1$2.ToolBarDropDownButtonComponent }, { token: SpreadsheetLocalizationService }, { token: SpreadsheetService }, { token: SpreadsheetToolsService }], target: i0.ɵɵFactoryTarget.Directive });
2462
+ SpreadsheetVerticalTextAlignDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: SpreadsheetVerticalTextAlignDirective, selector: "[kendoSpreadsheetVerticalTextAlign]", ngImport: i0 });
2463
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetVerticalTextAlignDirective, decorators: [{
2464
+ type: Directive,
2465
+ args: [{
2466
+ selector: '[kendoSpreadsheetVerticalTextAlign]',
2322
2467
  }]
2323
2468
  }], ctorParameters: function () { return [{ type: i1$2.ToolBarDropDownButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
2324
2469
 
@@ -2400,6 +2545,118 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
2400
2545
  }]
2401
2546
  }], ctorParameters: function () { return [{ type: i1$2.ToolBarDropDownButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
2402
2547
 
2548
+ /**
2549
+ * @hidden
2550
+ */
2551
+ class InsertLinkDialogComponent extends DialogContentBase {
2552
+ constructor(dialog) {
2553
+ super(dialog);
2554
+ this.dialog = dialog;
2555
+ this.urlLink = '';
2556
+ }
2557
+ setData(args) {
2558
+ this.urlLink = args.link;
2559
+ }
2560
+ }
2561
+ InsertLinkDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: InsertLinkDialogComponent, deps: [{ token: i1$4.DialogRef }], target: i0.ɵɵFactoryTarget.Component });
2562
+ InsertLinkDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: InsertLinkDialogComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: `
2563
+ <form class="k-form k-form-md" method="dialog">
2564
+ <div class="k-form-field">
2565
+ <kendo-label [for]="textbox" text="URL"></kendo-label>
2566
+ <kendo-textbox #textbox
2567
+ [(value)]="urlLink">
2568
+ </kendo-textbox>
2569
+ </div>
2570
+ </form>
2571
+ `, isInline: true, components: [{ type: i2.LabelComponent, selector: "kendo-label", inputs: ["text", "for", "optional", "labelCssStyle", "labelCssClass"], exportAs: ["kendoLabel"] }, { type: i5.TextBoxComponent, selector: "kendo-textbox", inputs: ["focusableId", "title", "disabled", "readonly", "tabindex", "value", "selectOnFocus", "showSuccessIcon", "showErrorIcon", "clearButton", "successIcon", "successSvgIcon", "errorIcon", "errorSvgIcon", "clearButtonIcon", "clearButtonSvgIcon", "size", "rounded", "fillMode", "tabIndex", "placeholder", "maxlength"], outputs: ["valueChange", "inputFocus", "inputBlur", "focus", "blur"], exportAs: ["kendoTextBox"] }] });
2572
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: InsertLinkDialogComponent, decorators: [{
2573
+ type: Component,
2574
+ args: [{
2575
+ template: `
2576
+ <form class="k-form k-form-md" method="dialog">
2577
+ <div class="k-form-field">
2578
+ <kendo-label [for]="textbox" text="URL"></kendo-label>
2579
+ <kendo-textbox #textbox
2580
+ [(value)]="urlLink">
2581
+ </kendo-textbox>
2582
+ </div>
2583
+ </form>
2584
+ `
2585
+ }]
2586
+ }], ctorParameters: function () { return [{ type: i1$4.DialogRef }]; } });
2587
+
2588
+ /**
2589
+ * @hidden
2590
+ */
2591
+ class SpreadsheetInsertLinkDirective extends SpreadsheetCommandButton {
2592
+ constructor(button, localization, spreadsheetService, toolsService, dialogService) {
2593
+ super('insertLink', button, localization, spreadsheetService, toolsService, {
2594
+ command: 'HyperlinkCommand'
2595
+ });
2596
+ this.dialogService = dialogService;
2597
+ spreadsheetService.selectionChanged.subscribe(range => this.currentRange = range);
2598
+ }
2599
+ clickHandler() {
2600
+ const sheet = this.spreadsheetService.spreadsheet.activeSheet();
2601
+ if (sheet) {
2602
+ this.openDialog();
2603
+ }
2604
+ }
2605
+ /**
2606
+ * @hidden
2607
+ */
2608
+ openDialog() {
2609
+ const hasLink = isPresent(this.currentRange?.link());
2610
+ const dialogSettings = {
2611
+ appendTo: this.spreadsheetService.dialogContainer,
2612
+ title: this.localization.get(this.command),
2613
+ content: InsertLinkDialogComponent,
2614
+ actions: [{
2615
+ text: this.localization.get('dialogInsert'),
2616
+ themeColor: 'primary'
2617
+ }, {
2618
+ text: this.localization.get('dialogCancel')
2619
+ },
2620
+ 'spacer', {
2621
+ text: this.localization.get('dialogRemoveLink'),
2622
+ themeColor: 'primary',
2623
+ fillMode: 'clear',
2624
+ cssClass: hasLink ? '' : 'k-disabled'
2625
+ }],
2626
+ actionsLayout: 'start',
2627
+ width: 400,
2628
+ autoFocusedElement: '.k-textbox > .k-input-inner'
2629
+ };
2630
+ const dialog = this.dialogService.open(dialogSettings);
2631
+ const dialogInstance = dialog.dialog.instance;
2632
+ const dialogContent = dialog.content.instance;
2633
+ if (hasLink) {
2634
+ dialogContent.setData({ link: this.currentRange?.link() });
2635
+ }
2636
+ dialogInstance.action.pipe(take(1)).subscribe((event) => {
2637
+ if (event.text === this.localization.get('dialogCancel')) {
2638
+ return;
2639
+ }
2640
+ let link = null;
2641
+ if (event.text === this.localization.get('dialogInsert')) {
2642
+ link = dialogContent.urlLink || null;
2643
+ }
2644
+ this.spreadsheetService.spreadsheet.executeCommand({
2645
+ command: 'HyperlinkCommand',
2646
+ options: { link }
2647
+ });
2648
+ });
2649
+ }
2650
+ }
2651
+ SpreadsheetInsertLinkDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetInsertLinkDirective, deps: [{ token: i1$2.ToolBarButtonComponent }, { token: SpreadsheetLocalizationService }, { token: SpreadsheetService }, { token: SpreadsheetToolsService }, { token: i1$4.DialogService }], target: i0.ɵɵFactoryTarget.Directive });
2652
+ SpreadsheetInsertLinkDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: SpreadsheetInsertLinkDirective, selector: "kendo-toolbar-button[kendoSpreadsheetInsertLink]", usesInheritance: true, ngImport: i0 });
2653
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetInsertLinkDirective, decorators: [{
2654
+ type: Directive,
2655
+ args: [{
2656
+ selector: 'kendo-toolbar-button[kendoSpreadsheetInsertLink]'
2657
+ }]
2658
+ }], ctorParameters: function () { return [{ type: i1$2.ToolBarButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }, { type: i1$4.DialogService }]; } });
2659
+
2403
2660
  /**
2404
2661
  * @hidden
2405
2662
  */
@@ -2528,6 +2785,58 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
2528
2785
  }]
2529
2786
  }], ctorParameters: function () { return [{ type: i1$2.ToolBarButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
2530
2787
 
2788
+ /**
2789
+ * @hidden
2790
+ */
2791
+ class SpreadsheetDecreaseDecimalDirective extends SpreadsheetCommandButton {
2792
+ constructor(button, localization, spreadsheetService, toolsService) {
2793
+ super('decreaseDecimal', button, localization, spreadsheetService, toolsService, {
2794
+ command: 'AdjustDecimalsCommand'
2795
+ });
2796
+ }
2797
+ clickHandler() {
2798
+ const options = {
2799
+ command: 'AdjustDecimalsCommand',
2800
+ options: { value: -1 }
2801
+ };
2802
+ this.spreadsheetService.spreadsheet.executeCommand(options);
2803
+ }
2804
+ }
2805
+ SpreadsheetDecreaseDecimalDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetDecreaseDecimalDirective, deps: [{ token: i1$2.ToolBarButtonComponent }, { token: SpreadsheetLocalizationService }, { token: SpreadsheetService }, { token: SpreadsheetToolsService }], target: i0.ɵɵFactoryTarget.Directive });
2806
+ SpreadsheetDecreaseDecimalDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: SpreadsheetDecreaseDecimalDirective, selector: "kendo-toolbar-button[kendoSpreadsheetDecreaseDecimal]", usesInheritance: true, ngImport: i0 });
2807
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetDecreaseDecimalDirective, decorators: [{
2808
+ type: Directive,
2809
+ args: [{
2810
+ selector: 'kendo-toolbar-button[kendoSpreadsheetDecreaseDecimal]'
2811
+ }]
2812
+ }], ctorParameters: function () { return [{ type: i1$2.ToolBarButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
2813
+
2814
+ /**
2815
+ * @hidden
2816
+ */
2817
+ class SpreadsheetIncreaseDecimalDirective extends SpreadsheetCommandButton {
2818
+ constructor(button, localization, spreadsheetService, toolsService) {
2819
+ super('increaseDecimal', button, localization, spreadsheetService, toolsService, {
2820
+ command: 'AdjustDecimalsCommand'
2821
+ });
2822
+ }
2823
+ clickHandler() {
2824
+ const options = {
2825
+ command: 'AdjustDecimalsCommand',
2826
+ options: { value: 1 }
2827
+ };
2828
+ this.spreadsheetService.spreadsheet.executeCommand(options);
2829
+ }
2830
+ }
2831
+ SpreadsheetIncreaseDecimalDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetIncreaseDecimalDirective, deps: [{ token: i1$2.ToolBarButtonComponent }, { token: SpreadsheetLocalizationService }, { token: SpreadsheetService }, { token: SpreadsheetToolsService }], target: i0.ɵɵFactoryTarget.Directive });
2832
+ SpreadsheetIncreaseDecimalDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: SpreadsheetIncreaseDecimalDirective, selector: "kendo-toolbar-button[kendoSpreadsheetIncreaseDecimal]", usesInheritance: true, ngImport: i0 });
2833
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetIncreaseDecimalDirective, decorators: [{
2834
+ type: Directive,
2835
+ args: [{
2836
+ selector: 'kendo-toolbar-button[kendoSpreadsheetIncreaseDecimal]'
2837
+ }]
2838
+ }], ctorParameters: function () { return [{ type: i1$2.ToolBarButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
2839
+
2531
2840
  /**
2532
2841
  * @hidden
2533
2842
  */
@@ -2704,17 +3013,25 @@ class SpreadsheetComponent {
2704
3013
  * @hidden
2705
3014
  */
2706
3015
  this.showLicenseWatermark = false;
2707
- this.onChange = (e) => hasObservers(this.change) && this.change.emit(e);
3016
+ this.onChange = (e) => {
3017
+ hasObservers(this.change) && this.change.emit(e);
3018
+ this.spreadsheetService.selectionChanged.next(e.range);
3019
+ };
2708
3020
  this.onSelectionChange = (e) => {
2709
3021
  hasObservers(this.selectionChange) && this.selectionChange.emit(e);
2710
3022
  this.spreadsheetService.selectionChanged.next(e.range);
2711
3023
  };
2712
- this.onChangeFormat = (e) => hasObservers(this.formatChange) && this.formatChange.emit(e);
3024
+ this.onChangeFormat = (e) => {
3025
+ hasObservers(this.formatChange) && this.formatChange.emit(e);
3026
+ this.spreadsheetService.selectionChanged.next(e.range);
3027
+ };
2713
3028
  this.onExcelExport = (e) => hasObservers(this.excelExport) && this.excelExport.emit(e);
2714
3029
  this.onExcelImport = (e) => hasObservers(this.excelImport) && this.excelImport.emit(e);
2715
3030
  this.onActiveSheetChanged = (sheet) => {
2716
3031
  const eventArgs = { sender: this.spreadsheetService.spreadsheet, sheet };
2717
3032
  hasObservers(this.activeSheetChange) && this.activeSheetChange.emit(eventArgs);
3033
+ const range = sheet.range(sheet.activeCell());
3034
+ this.spreadsheetService.selectionChanged.next(range);
2718
3035
  };
2719
3036
  this.updateState = (e) => {
2720
3037
  this.toolsService.updateTools(e);
@@ -2737,6 +3054,9 @@ class SpreadsheetComponent {
2737
3054
  }, {
2738
3055
  id: 'insert',
2739
3056
  text: this.messageFor('insert')
3057
+ }, {
3058
+ id: 'format',
3059
+ text: this.messageFor('formatTab')
2740
3060
  }, {
2741
3061
  id: 'view',
2742
3062
  text: this.messageFor('view')
@@ -2945,6 +3265,8 @@ SpreadsheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
2945
3265
  file="File"
2946
3266
  i18n-insert="kendo.spreadsheet.insert|The text of the Insert toolbar tab."
2947
3267
  insert="Insert"
3268
+ i18n-formatTab="kendo.spreadsheet.formatTab|The text of the Format toolbar tab."
3269
+ formatTab="Format"
2948
3270
  i18n-view="kendo.spreadsheet.view|The text of the View toolbar tab."
2949
3271
  view="View"
2950
3272
  i18n-undo="kendo.spreadsheet.undo|The title of the Undo tool."
@@ -2969,8 +3291,22 @@ SpreadsheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
2969
3291
  wrap="Text wrap"
2970
3292
  i18n-align="kendo.spreadsheet.align|The title of the Text Align tool."
2971
3293
  align="Align"
3294
+ i18n-alignHorizontal="kendo.spreadsheet.alignHorizontal|The title of the Text Align Horizontal tool."
3295
+ alignHorizontal="Align horizontally"
3296
+ i18n-alignVertical="kendo.spreadsheet.alignVertical|The title of the Text Align Vertical tool."
3297
+ alignVertical="Align vertically"
2972
3298
  i18n-merge="kendo.spreadsheet.merge|The title of the Cells Merge tool."
2973
3299
  merge="Merge"
3300
+ i18n-insertLink="kendo.spreadsheet.insertLink|The title of the tool that inserts a link."
3301
+ insertLink="Insert link"
3302
+ i18n-decreaseDecimal="kendo.spreadsheet.decreaseDecimal|The title of the tool that decreases decimals."
3303
+ decreaseDecimal="Decrease decimal"
3304
+ i18n-increaseDecimal="kendo.spreadsheet.increaseDecimal|The title of the tool that increases decimals."
3305
+ increaseDecimal="Increase decimal"
3306
+ i18n-increaseFontSize="kendo.spreadsheet.increaseFontSize|The title of the tool that increases the cell font size."
3307
+ increaseFontSize="Increase font size"
3308
+ i18n-decreaseFontSize="kendo.spreadsheet.decreaseFontSize|The title of the tool that decreases the cell font size."
3309
+ decreaseFontSize="Decrease font size"
2974
3310
  i18n-dialogApply="kendo.spreadsheet.dialogApply|The text of the **Apply** button in all Spreadsheet dialogs."
2975
3311
  dialogApply="Apply"
2976
3312
  i18n-dialogCancel="kendo.spreadsheet.dialogCancel|The text of the **Cancel** button in all Spreadsheet dialogs."
@@ -2979,6 +3315,10 @@ SpreadsheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
2979
3315
  dialogDelete="Delete"
2980
3316
  i18n-dialogRename="kendo.spreadsheet.dialogRename|The text of the **Rename** button in the Rename sheet dialog."
2981
3317
  dialogRename="Rename"
3318
+ i18n-dialogInsert="kendo.spreadsheet.dialogInsert|The text of the **Insert** button in all Spreadsheet dialogs."
3319
+ dialogInsert="Insert"
3320
+ i18n-dialogRemoveLink="kendo.spreadsheet.dialogRemoveLink|The text of the **Remove link** button in the Link tool dialog."
3321
+ dialogRemoveLink="Remove link"
2982
3322
  i18n-rename="kendo.spreadsheet.rename|The title of the Rename sheet dialog."
2983
3323
  rename="Rename Sheet"
2984
3324
  i18n-delete="kendo.spreadsheet.delete|The title of the Delete sheet dialog."
@@ -3012,6 +3352,9 @@ SpreadsheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
3012
3352
  <kendo-toolbar-separator></kendo-toolbar-separator>
3013
3353
  <kendo-toolbar-dropdownlist kendoSpreadsheetFontFamily></kendo-toolbar-dropdownlist>
3014
3354
  <kendo-toolbar-dropdownlist kendoSpreadsheetFontSize></kendo-toolbar-dropdownlist>
3355
+ <kendo-toolbar-button kendoSpreadsheetIncreaseFontSize></kendo-toolbar-button>
3356
+ <kendo-toolbar-button kendoSpreadsheetDecreaseFontSize></kendo-toolbar-button>
3357
+ <kendo-toolbar-separator></kendo-toolbar-separator>
3015
3358
  <kendo-toolbar-buttongroup>
3016
3359
  <kendo-toolbar-button kendoSpreadsheetBold></kendo-toolbar-button>
3017
3360
  <kendo-toolbar-button kendoSpreadsheetItalic></kendo-toolbar-button>
@@ -3021,7 +3364,8 @@ SpreadsheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
3021
3364
  <kendo-toolbar-separator></kendo-toolbar-separator>
3022
3365
  <kendo-spreadsheet-backcolor-tool></kendo-spreadsheet-backcolor-tool>
3023
3366
  <kendo-toolbar-separator></kendo-toolbar-separator>
3024
- <kendo-toolbar-dropdownbutton kendoSpreadsheetTextAlign></kendo-toolbar-dropdownbutton>
3367
+ <kendo-toolbar-dropdownbutton kendoSpreadsheetHorizontalTextAlign></kendo-toolbar-dropdownbutton>
3368
+ <kendo-toolbar-dropdownbutton kendoSpreadsheetVerticalTextAlign></kendo-toolbar-dropdownbutton>
3025
3369
  <kendo-toolbar-button kendoSpreadsheetTextWrap></kendo-toolbar-button>
3026
3370
  <kendo-toolbar-separator></kendo-toolbar-separator>
3027
3371
  <kendo-toolbar-dropdownbutton kendoSpreadsheetFormat></kendo-toolbar-dropdownbutton>
@@ -3030,6 +3374,8 @@ SpreadsheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
3030
3374
  [attr.aria-label]="messageFor('insert')"
3031
3375
  class="k-spreadsheet-toolbar"
3032
3376
  [overflow]="overflow">
3377
+ <kendo-toolbar-button kendoSpreadsheetInsertLink></kendo-toolbar-button>
3378
+ <kendo-toolbar-separator></kendo-toolbar-separator>
3033
3379
  <kendo-toolbar-button kendoSpreadsheetAddColumnLeftButton></kendo-toolbar-button>
3034
3380
  <kendo-toolbar-button kendoSpreadsheetAddColumnRightButton></kendo-toolbar-button>
3035
3381
  <kendo-toolbar-button kendoSpreadsheetAddRowBelowButton></kendo-toolbar-button>
@@ -3038,6 +3384,13 @@ SpreadsheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
3038
3384
  <kendo-toolbar-button kendoSpreadsheetDeleteColumnButton></kendo-toolbar-button>
3039
3385
  <kendo-toolbar-button kendoSpreadsheetDeleteRowButton></kendo-toolbar-button>
3040
3386
  </kendo-toolbar>
3387
+ <kendo-toolbar *ngIf="selectedMenuItem?.active && selectedMenuItem.id === 'format'"
3388
+ [attr.aria-label]="messageFor('formatTab')"
3389
+ class="k-spreadsheet-toolbar"
3390
+ [overflow]="overflow">
3391
+ <kendo-toolbar-button kendoSpreadsheetDecreaseDecimal></kendo-toolbar-button>
3392
+ <kendo-toolbar-button kendoSpreadsheetIncreaseDecimal></kendo-toolbar-button>
3393
+ </kendo-toolbar>
3041
3394
  <kendo-toolbar *ngIf="selectedMenuItem?.active && selectedMenuItem.id === 'view'"
3042
3395
  [attr.aria-label]="messageFor('view')"
3043
3396
  class="k-spreadsheet-toolbar"
@@ -3075,7 +3428,7 @@ SpreadsheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
3075
3428
  <ng-container #dialogContainer></ng-container>
3076
3429
 
3077
3430
  <div kendoWatermarkOverlay *ngIf="showLicenseWatermark"></div>
3078
- `, isInline: true, components: [{ type: i5$2.MenuComponent, selector: "kendo-menu", inputs: ["menuItemTemplate", "ariaRole", "menuItemLinkTemplate"], outputs: ["select", "open", "close"], exportAs: ["kendoMenu"] }, { type: i5$2.MenuItemComponent, selector: "kendo-menu-item", inputs: ["text", "url", "disabled", "cssClass", "cssStyle", "icon", "svgIcon", "data", "separator"] }, { type: i1$2.ToolBarComponent, selector: "kendo-toolbar", inputs: ["overflow", "resizable", "popupSettings", "tabindex", "size", "tabIndex"], outputs: ["open", "close"], exportAs: ["kendoToolBar"] }, { type: SpreadsheetLoadFileComponent, selector: "kendo-spreadsheet-load-file-tool" }, { type: i1$2.ToolBarButtonComponent, selector: "kendo-toolbar-button", inputs: ["showText", "showIcon", "text", "style", "className", "title", "disabled", "toggleable", "look", "togglable", "selected", "fillMode", "themeColor", "icon", "iconClass", "svgIcon", "imageUrl"], outputs: ["click", "pointerdown", "selectedChange"], exportAs: ["kendoToolBarButton"] }, { type: i1$2.ToolBarButtonGroupComponent, selector: "kendo-toolbar-buttongroup", inputs: ["disabled", "selection", "width", "look"], exportAs: ["kendoToolBarButtonGroup"] }, { type: i1$2.ToolBarSeparatorComponent, selector: "kendo-toolbar-separator", exportAs: ["kendoToolBarSeparator"] }, { type: SpreadsheetFontFamilyComponent, selector: "kendo-toolbar-dropdownlist[kendoSpreadsheetFontFamily]" }, { type: SpreadsheetFontSizeComponent, selector: "kendo-toolbar-dropdownlist[kendoSpreadsheetFontSize]" }, { type: SpreadsheetForeColorComponent, selector: "kendo-spreadsheet-forecolor-tool" }, { type: SpreadsheetBackColorComponent, selector: "kendo-spreadsheet-backcolor-tool" }, { type: i1$2.ToolBarDropDownButtonComponent, selector: "kendo-toolbar-dropdownbutton", inputs: ["arrowIcon", "title", "showText", "showIcon", "text", "icon", "svgIcon", "iconClass", "imageUrl", "popupSettings", "look", "primary", "fillMode", "themeColor", "buttonClass", "textField", "disabled", "data"], outputs: ["itemClick", "open", "close"], exportAs: ["kendoToolBarDropDownButton"] }, { type: NameBoxComponent, selector: "[kendoSpreadsheetNameBox]", inputs: ["data", "spreadsheetWidget"] }, { type: i6.IconWrapperComponent, selector: "kendo-icon-wrapper", inputs: ["name", "svgIcon", "innerCssClass", "customFontClass", "size"], exportAs: ["kendoIconWrapper"] }, { type: SheetsBarComponent, selector: "[kendoSpreadsheetSheetsBar]", inputs: ["sheets", "sheetDescriptors"] }, { type: i3.WatermarkOverlayComponent, selector: "div[kendoWatermarkOverlay]" }], directives: [{ type: LocalizedMessagesDirective, selector: "[kendoSpreadsheetLocalizedMessages]" }, { type: MainMenuDirective, selector: "[kendoSpreadsheetMenu]" }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: SpreadsheetSaveFileDirective, selector: "[kendoSpreadsheetSaveFile]" }, { type: SpreadsheetUndoDirective, selector: "kendo-toolbar-button[kendoSpreadsheetUndo]" }, { type: SpreadsheetRedoDirective, selector: "kendo-toolbar-button[kendoSpreadsheetRedo]" }, { type: SpreadsheetBoldDirective, selector: "kendo-toolbar-button[kendoSpreadsheetBold]" }, { type: SpreadsheetItalicDirective, selector: "kendo-toolbar-button[kendoSpreadsheetItalic]" }, { type: SpreadsheetUnderlineDirective, selector: "kendo-toolbar-button[kendoSpreadsheetUnderline]" }, { type: SpreadsheetTextAlignDirective, selector: "[kendoSpreadsheetTextAlign]" }, { type: SpreadsheetTextWrapDirective, selector: "kendo-toolbar-button[kendoSpreadsheetTextWrap]" }, { type: SpreadsheetFormatDirective, selector: "[kendoSpreadsheetFormat]" }, { type: SpreadsheetAddColumnLeftButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetAddColumnLeftButton]" }, { type: SpreadsheetAddColumnRightButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetAddColumnRightButton]" }, { type: SpreadsheetAddRowBelowButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetAddRowBelowButton]" }, { type: SpreadsheetAddRowAboveButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetAddRowAboveButton]" }, { type: SpreadsheetDeleteColumnButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetDeleteColumnButton]" }, { type: SpreadsheetDeleteRowButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetDeleteRowButton]" }, { type: SpreadsheetMergeDirective, selector: "[kendoSpreadsheetMerge]" }, { type: SpreadsheetGridLinesDirective, selector: "kendo-toolbar-button[kendoSpreadsheetGridLines]" }, { type: FormulaInputDirective, selector: "[kendoSpreadsheetFormulaInput]" }] });
3431
+ `, isInline: true, components: [{ type: i5$2.MenuComponent, selector: "kendo-menu", inputs: ["menuItemTemplate", "ariaRole", "menuItemLinkTemplate"], outputs: ["select", "open", "close"], exportAs: ["kendoMenu"] }, { type: i5$2.MenuItemComponent, selector: "kendo-menu-item", inputs: ["text", "url", "disabled", "cssClass", "cssStyle", "icon", "svgIcon", "data", "separator"] }, { type: i1$2.ToolBarComponent, selector: "kendo-toolbar", inputs: ["overflow", "resizable", "popupSettings", "tabindex", "size", "tabIndex"], outputs: ["open", "close"], exportAs: ["kendoToolBar"] }, { type: SpreadsheetLoadFileComponent, selector: "kendo-spreadsheet-load-file-tool" }, { type: i1$2.ToolBarButtonComponent, selector: "kendo-toolbar-button", inputs: ["showText", "showIcon", "text", "style", "className", "title", "disabled", "toggleable", "look", "togglable", "selected", "fillMode", "themeColor", "icon", "iconClass", "svgIcon", "imageUrl"], outputs: ["click", "pointerdown", "selectedChange"], exportAs: ["kendoToolBarButton"] }, { type: i1$2.ToolBarButtonGroupComponent, selector: "kendo-toolbar-buttongroup", inputs: ["disabled", "selection", "width", "look"], exportAs: ["kendoToolBarButtonGroup"] }, { type: i1$2.ToolBarSeparatorComponent, selector: "kendo-toolbar-separator", exportAs: ["kendoToolBarSeparator"] }, { type: SpreadsheetFontFamilyComponent, selector: "kendo-toolbar-dropdownlist[kendoSpreadsheetFontFamily]" }, { type: SpreadsheetFontSizeComponent, selector: "kendo-toolbar-dropdownlist[kendoSpreadsheetFontSize]" }, { type: SpreadsheetForeColorComponent, selector: "kendo-spreadsheet-forecolor-tool" }, { type: SpreadsheetBackColorComponent, selector: "kendo-spreadsheet-backcolor-tool" }, { type: i1$2.ToolBarDropDownButtonComponent, selector: "kendo-toolbar-dropdownbutton", inputs: ["arrowIcon", "title", "showText", "showIcon", "text", "icon", "svgIcon", "iconClass", "imageUrl", "popupSettings", "look", "primary", "fillMode", "themeColor", "buttonClass", "textField", "disabled", "data"], outputs: ["itemClick", "open", "close"], exportAs: ["kendoToolBarDropDownButton"] }, { type: NameBoxComponent, selector: "[kendoSpreadsheetNameBox]", inputs: ["data", "spreadsheetWidget"] }, { type: i6.IconWrapperComponent, selector: "kendo-icon-wrapper", inputs: ["name", "svgIcon", "innerCssClass", "customFontClass", "size"], exportAs: ["kendoIconWrapper"] }, { type: SheetsBarComponent, selector: "[kendoSpreadsheetSheetsBar]", inputs: ["sheets", "sheetDescriptors"] }, { type: i3.WatermarkOverlayComponent, selector: "div[kendoWatermarkOverlay]" }], directives: [{ type: LocalizedMessagesDirective, selector: "[kendoSpreadsheetLocalizedMessages]" }, { type: MainMenuDirective, selector: "[kendoSpreadsheetMenu]" }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: SpreadsheetSaveFileDirective, selector: "[kendoSpreadsheetSaveFile]" }, { type: SpreadsheetUndoDirective, selector: "kendo-toolbar-button[kendoSpreadsheetUndo]" }, { type: SpreadsheetRedoDirective, selector: "kendo-toolbar-button[kendoSpreadsheetRedo]" }, { type: SpreadsheetIncreaseFontSizeDirective, selector: "kendo-toolbar-button[kendoSpreadsheetIncreaseFontSize]" }, { type: SpreadsheetDecreaseFontSizeDirective, selector: "kendo-toolbar-button[kendoSpreadsheetDecreaseFontSize]" }, { type: SpreadsheetBoldDirective, selector: "kendo-toolbar-button[kendoSpreadsheetBold]" }, { type: SpreadsheetItalicDirective, selector: "kendo-toolbar-button[kendoSpreadsheetItalic]" }, { type: SpreadsheetUnderlineDirective, selector: "kendo-toolbar-button[kendoSpreadsheetUnderline]" }, { type: SpreadsheetHorizontalTextAlignDirective, selector: "[kendoSpreadsheetHorizontalTextAlign]" }, { type: SpreadsheetVerticalTextAlignDirective, selector: "[kendoSpreadsheetVerticalTextAlign]" }, { type: SpreadsheetTextWrapDirective, selector: "kendo-toolbar-button[kendoSpreadsheetTextWrap]" }, { type: SpreadsheetFormatDirective, selector: "[kendoSpreadsheetFormat]" }, { type: SpreadsheetInsertLinkDirective, selector: "kendo-toolbar-button[kendoSpreadsheetInsertLink]" }, { type: SpreadsheetAddColumnLeftButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetAddColumnLeftButton]" }, { type: SpreadsheetAddColumnRightButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetAddColumnRightButton]" }, { type: SpreadsheetAddRowBelowButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetAddRowBelowButton]" }, { type: SpreadsheetAddRowAboveButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetAddRowAboveButton]" }, { type: SpreadsheetDeleteColumnButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetDeleteColumnButton]" }, { type: SpreadsheetDeleteRowButtonDirective, selector: "kendo-toolbar-button[kendoSpreadsheetDeleteRowButton]" }, { type: SpreadsheetDecreaseDecimalDirective, selector: "kendo-toolbar-button[kendoSpreadsheetDecreaseDecimal]" }, { type: SpreadsheetIncreaseDecimalDirective, selector: "kendo-toolbar-button[kendoSpreadsheetIncreaseDecimal]" }, { type: SpreadsheetMergeDirective, selector: "[kendoSpreadsheetMerge]" }, { type: SpreadsheetGridLinesDirective, selector: "kendo-toolbar-button[kendoSpreadsheetGridLines]" }, { type: FormulaInputDirective, selector: "[kendoSpreadsheetFormulaInput]" }] });
3079
3432
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetComponent, decorators: [{
3080
3433
  type: Component,
3081
3434
  args: [{
@@ -3123,6 +3476,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
3123
3476
  file="File"
3124
3477
  i18n-insert="kendo.spreadsheet.insert|The text of the Insert toolbar tab."
3125
3478
  insert="Insert"
3479
+ i18n-formatTab="kendo.spreadsheet.formatTab|The text of the Format toolbar tab."
3480
+ formatTab="Format"
3126
3481
  i18n-view="kendo.spreadsheet.view|The text of the View toolbar tab."
3127
3482
  view="View"
3128
3483
  i18n-undo="kendo.spreadsheet.undo|The title of the Undo tool."
@@ -3147,8 +3502,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
3147
3502
  wrap="Text wrap"
3148
3503
  i18n-align="kendo.spreadsheet.align|The title of the Text Align tool."
3149
3504
  align="Align"
3505
+ i18n-alignHorizontal="kendo.spreadsheet.alignHorizontal|The title of the Text Align Horizontal tool."
3506
+ alignHorizontal="Align horizontally"
3507
+ i18n-alignVertical="kendo.spreadsheet.alignVertical|The title of the Text Align Vertical tool."
3508
+ alignVertical="Align vertically"
3150
3509
  i18n-merge="kendo.spreadsheet.merge|The title of the Cells Merge tool."
3151
3510
  merge="Merge"
3511
+ i18n-insertLink="kendo.spreadsheet.insertLink|The title of the tool that inserts a link."
3512
+ insertLink="Insert link"
3513
+ i18n-decreaseDecimal="kendo.spreadsheet.decreaseDecimal|The title of the tool that decreases decimals."
3514
+ decreaseDecimal="Decrease decimal"
3515
+ i18n-increaseDecimal="kendo.spreadsheet.increaseDecimal|The title of the tool that increases decimals."
3516
+ increaseDecimal="Increase decimal"
3517
+ i18n-increaseFontSize="kendo.spreadsheet.increaseFontSize|The title of the tool that increases the cell font size."
3518
+ increaseFontSize="Increase font size"
3519
+ i18n-decreaseFontSize="kendo.spreadsheet.decreaseFontSize|The title of the tool that decreases the cell font size."
3520
+ decreaseFontSize="Decrease font size"
3152
3521
  i18n-dialogApply="kendo.spreadsheet.dialogApply|The text of the **Apply** button in all Spreadsheet dialogs."
3153
3522
  dialogApply="Apply"
3154
3523
  i18n-dialogCancel="kendo.spreadsheet.dialogCancel|The text of the **Cancel** button in all Spreadsheet dialogs."
@@ -3157,6 +3526,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
3157
3526
  dialogDelete="Delete"
3158
3527
  i18n-dialogRename="kendo.spreadsheet.dialogRename|The text of the **Rename** button in the Rename sheet dialog."
3159
3528
  dialogRename="Rename"
3529
+ i18n-dialogInsert="kendo.spreadsheet.dialogInsert|The text of the **Insert** button in all Spreadsheet dialogs."
3530
+ dialogInsert="Insert"
3531
+ i18n-dialogRemoveLink="kendo.spreadsheet.dialogRemoveLink|The text of the **Remove link** button in the Link tool dialog."
3532
+ dialogRemoveLink="Remove link"
3160
3533
  i18n-rename="kendo.spreadsheet.rename|The title of the Rename sheet dialog."
3161
3534
  rename="Rename Sheet"
3162
3535
  i18n-delete="kendo.spreadsheet.delete|The title of the Delete sheet dialog."
@@ -3190,6 +3563,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
3190
3563
  <kendo-toolbar-separator></kendo-toolbar-separator>
3191
3564
  <kendo-toolbar-dropdownlist kendoSpreadsheetFontFamily></kendo-toolbar-dropdownlist>
3192
3565
  <kendo-toolbar-dropdownlist kendoSpreadsheetFontSize></kendo-toolbar-dropdownlist>
3566
+ <kendo-toolbar-button kendoSpreadsheetIncreaseFontSize></kendo-toolbar-button>
3567
+ <kendo-toolbar-button kendoSpreadsheetDecreaseFontSize></kendo-toolbar-button>
3568
+ <kendo-toolbar-separator></kendo-toolbar-separator>
3193
3569
  <kendo-toolbar-buttongroup>
3194
3570
  <kendo-toolbar-button kendoSpreadsheetBold></kendo-toolbar-button>
3195
3571
  <kendo-toolbar-button kendoSpreadsheetItalic></kendo-toolbar-button>
@@ -3199,7 +3575,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
3199
3575
  <kendo-toolbar-separator></kendo-toolbar-separator>
3200
3576
  <kendo-spreadsheet-backcolor-tool></kendo-spreadsheet-backcolor-tool>
3201
3577
  <kendo-toolbar-separator></kendo-toolbar-separator>
3202
- <kendo-toolbar-dropdownbutton kendoSpreadsheetTextAlign></kendo-toolbar-dropdownbutton>
3578
+ <kendo-toolbar-dropdownbutton kendoSpreadsheetHorizontalTextAlign></kendo-toolbar-dropdownbutton>
3579
+ <kendo-toolbar-dropdownbutton kendoSpreadsheetVerticalTextAlign></kendo-toolbar-dropdownbutton>
3203
3580
  <kendo-toolbar-button kendoSpreadsheetTextWrap></kendo-toolbar-button>
3204
3581
  <kendo-toolbar-separator></kendo-toolbar-separator>
3205
3582
  <kendo-toolbar-dropdownbutton kendoSpreadsheetFormat></kendo-toolbar-dropdownbutton>
@@ -3208,6 +3585,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
3208
3585
  [attr.aria-label]="messageFor('insert')"
3209
3586
  class="k-spreadsheet-toolbar"
3210
3587
  [overflow]="overflow">
3588
+ <kendo-toolbar-button kendoSpreadsheetInsertLink></kendo-toolbar-button>
3589
+ <kendo-toolbar-separator></kendo-toolbar-separator>
3211
3590
  <kendo-toolbar-button kendoSpreadsheetAddColumnLeftButton></kendo-toolbar-button>
3212
3591
  <kendo-toolbar-button kendoSpreadsheetAddColumnRightButton></kendo-toolbar-button>
3213
3592
  <kendo-toolbar-button kendoSpreadsheetAddRowBelowButton></kendo-toolbar-button>
@@ -3216,6 +3595,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
3216
3595
  <kendo-toolbar-button kendoSpreadsheetDeleteColumnButton></kendo-toolbar-button>
3217
3596
  <kendo-toolbar-button kendoSpreadsheetDeleteRowButton></kendo-toolbar-button>
3218
3597
  </kendo-toolbar>
3598
+ <kendo-toolbar *ngIf="selectedMenuItem?.active && selectedMenuItem.id === 'format'"
3599
+ [attr.aria-label]="messageFor('formatTab')"
3600
+ class="k-spreadsheet-toolbar"
3601
+ [overflow]="overflow">
3602
+ <kendo-toolbar-button kendoSpreadsheetDecreaseDecimal></kendo-toolbar-button>
3603
+ <kendo-toolbar-button kendoSpreadsheetIncreaseDecimal></kendo-toolbar-button>
3604
+ </kendo-toolbar>
3219
3605
  <kendo-toolbar *ngIf="selectedMenuItem?.active && selectedMenuItem.id === 'view'"
3220
3606
  [attr.aria-label]="messageFor('view')"
3221
3607
  class="k-spreadsheet-toolbar"
@@ -3347,6 +3733,48 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
3347
3733
  }]
3348
3734
  }], ctorParameters: function () { return [{ type: i1.LocalizationService }]; } });
3349
3735
 
3736
+ /**
3737
+ * @hidden
3738
+ */
3739
+ class SpreadsheetTextAlignDirective {
3740
+ constructor(host, localization, spreadsheetService, toolsService) {
3741
+ this.host = host;
3742
+ this.spreadsheetService = spreadsheetService;
3743
+ this.toolsService = toolsService;
3744
+ this.commandName = 'align';
3745
+ this.subs = new Subscription();
3746
+ host.svgIcon = commandSVGIcons[this.commandName];
3747
+ host.icon = commandIcons[this.commandName];
3748
+ host.arrowIcon = true;
3749
+ host.fillMode = 'flat';
3750
+ host.data = [...ALIGNS];
3751
+ this.subs.add(host.itemClick.subscribe((e) => this.onItemClick(e)));
3752
+ host.title = localization.get(this.commandName);
3753
+ host.textField = 'textKey';
3754
+ }
3755
+ ngOnInit() {
3756
+ this.subs.add(this.toolsService.stateChange.subscribe(state => this.host.data.forEach(i => i.cssClass = i.value === state[i.commandName] ? 'k-selected' : '')));
3757
+ }
3758
+ ngOnDestroy() {
3759
+ this.subs.unsubscribe();
3760
+ }
3761
+ onItemClick(item) {
3762
+ const value = item.value || null;
3763
+ const options = {
3764
+ command: 'PropertyChangeCommand', options: { property: item.commandName, value }
3765
+ };
3766
+ this.spreadsheetService.spreadsheet.executeCommand(options);
3767
+ }
3768
+ }
3769
+ SpreadsheetTextAlignDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetTextAlignDirective, deps: [{ token: i1$2.ToolBarDropDownButtonComponent }, { token: SpreadsheetLocalizationService }, { token: SpreadsheetService }, { token: SpreadsheetToolsService }], target: i0.ɵɵFactoryTarget.Directive });
3770
+ SpreadsheetTextAlignDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: SpreadsheetTextAlignDirective, selector: "[kendoSpreadsheetTextAlign]", ngImport: i0 });
3771
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetTextAlignDirective, decorators: [{
3772
+ type: Directive,
3773
+ args: [{
3774
+ selector: '[kendoSpreadsheetTextAlign]',
3775
+ }]
3776
+ }], ctorParameters: function () { return [{ type: i1$2.ToolBarDropDownButtonComponent }, { type: SpreadsheetLocalizationService }, { type: SpreadsheetService }, { type: SpreadsheetToolsService }]; } });
3777
+
3350
3778
  const DIRECTIVES = [
3351
3779
  SpreadsheetComponent,
3352
3780
  MessagesDirective,
@@ -3382,7 +3810,15 @@ const DIRECTIVES = [
3382
3810
  DialogContentComponent,
3383
3811
  MainMenuDirective,
3384
3812
  ActionDialogComponent,
3385
- SpreadsheetMergeDirective
3813
+ SpreadsheetMergeDirective,
3814
+ SpreadsheetInsertLinkDirective,
3815
+ InsertLinkDialogComponent,
3816
+ SpreadsheetIncreaseFontSizeDirective,
3817
+ SpreadsheetDecreaseFontSizeDirective,
3818
+ SpreadsheetIncreaseDecimalDirective,
3819
+ SpreadsheetDecreaseDecimalDirective,
3820
+ SpreadsheetHorizontalTextAlignDirective,
3821
+ SpreadsheetVerticalTextAlignDirective
3386
3822
  ];
3387
3823
  const EXPORTS = [
3388
3824
  SpreadsheetComponent,
@@ -3408,7 +3844,14 @@ const EXPORTS = [
3408
3844
  SpreadsheetDeleteRowButtonDirective,
3409
3845
  SpreadsheetTextAlignDirective,
3410
3846
  SpreadsheetTextWrapDirective,
3411
- SpreadsheetMergeDirective
3847
+ SpreadsheetMergeDirective,
3848
+ SpreadsheetInsertLinkDirective,
3849
+ SpreadsheetIncreaseFontSizeDirective,
3850
+ SpreadsheetDecreaseFontSizeDirective,
3851
+ SpreadsheetIncreaseDecimalDirective,
3852
+ SpreadsheetDecreaseDecimalDirective,
3853
+ SpreadsheetHorizontalTextAlignDirective,
3854
+ SpreadsheetVerticalTextAlignDirective
3412
3855
  ];
3413
3856
  /**
3414
3857
  * Represents the [NgModule](link:site.data.urls.angular['ngmoduleapi'])
@@ -3451,7 +3894,15 @@ SpreadsheetModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versi
3451
3894
  DialogContentComponent,
3452
3895
  MainMenuDirective,
3453
3896
  ActionDialogComponent,
3454
- SpreadsheetMergeDirective], imports: [CommonModule,
3897
+ SpreadsheetMergeDirective,
3898
+ SpreadsheetInsertLinkDirective,
3899
+ InsertLinkDialogComponent,
3900
+ SpreadsheetIncreaseFontSizeDirective,
3901
+ SpreadsheetDecreaseFontSizeDirective,
3902
+ SpreadsheetIncreaseDecimalDirective,
3903
+ SpreadsheetDecreaseDecimalDirective,
3904
+ SpreadsheetHorizontalTextAlignDirective,
3905
+ SpreadsheetVerticalTextAlignDirective], imports: [CommonModule,
3455
3906
  ButtonsModule,
3456
3907
  ComboBoxModule,
3457
3908
  DropDownListModule,
@@ -3488,7 +3939,14 @@ SpreadsheetModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versi
3488
3939
  SpreadsheetDeleteRowButtonDirective,
3489
3940
  SpreadsheetTextAlignDirective,
3490
3941
  SpreadsheetTextWrapDirective,
3491
- SpreadsheetMergeDirective] });
3942
+ SpreadsheetMergeDirective,
3943
+ SpreadsheetInsertLinkDirective,
3944
+ SpreadsheetIncreaseFontSizeDirective,
3945
+ SpreadsheetDecreaseFontSizeDirective,
3946
+ SpreadsheetIncreaseDecimalDirective,
3947
+ SpreadsheetDecreaseDecimalDirective,
3948
+ SpreadsheetHorizontalTextAlignDirective,
3949
+ SpreadsheetVerticalTextAlignDirective] });
3492
3950
  SpreadsheetModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: SpreadsheetModule, imports: [[
3493
3951
  CommonModule,
3494
3952
  ButtonsModule,
@@ -3535,5 +3993,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
3535
3993
  * Generated bundle index. Do not edit.
3536
3994
  */
3537
3995
 
3538
- export { CustomMessagesComponent, FormulaInputDirective, FormulaListComponent, NameBoxComponent, SheetsBarComponent, SpreadsheetAddColumnLeftButtonDirective, SpreadsheetAddColumnRightButtonDirective, SpreadsheetAddRowAboveButtonDirective, SpreadsheetAddRowBelowButtonDirective, SpreadsheetBackColorComponent, SpreadsheetBoldDirective, SpreadsheetComponent, SpreadsheetDeleteColumnButtonDirective, SpreadsheetDeleteRowButtonDirective, SpreadsheetFontFamilyComponent, SpreadsheetFontSizeComponent, SpreadsheetForeColorComponent, SpreadsheetFormatDirective, SpreadsheetGridLinesDirective, SpreadsheetItalicDirective, SpreadsheetLoadFileComponent, SpreadsheetMergeDirective, SpreadsheetModule, SpreadsheetRedoDirective, SpreadsheetSaveFileDirective, SpreadsheetTextAlignDirective, SpreadsheetTextWrapDirective, SpreadsheetUnderlineDirective, SpreadsheetUndoDirective };
3996
+ export { CustomMessagesComponent, FormulaInputDirective, FormulaListComponent, NameBoxComponent, SheetsBarComponent, SpreadsheetAddColumnLeftButtonDirective, SpreadsheetAddColumnRightButtonDirective, SpreadsheetAddRowAboveButtonDirective, SpreadsheetAddRowBelowButtonDirective, SpreadsheetBackColorComponent, SpreadsheetBoldDirective, SpreadsheetComponent, SpreadsheetDecreaseDecimalDirective, SpreadsheetDecreaseFontSizeDirective, SpreadsheetDeleteColumnButtonDirective, SpreadsheetDeleteRowButtonDirective, SpreadsheetFontFamilyComponent, SpreadsheetFontSizeComponent, SpreadsheetForeColorComponent, SpreadsheetFormatDirective, SpreadsheetGridLinesDirective, SpreadsheetHorizontalTextAlignDirective, SpreadsheetIncreaseDecimalDirective, SpreadsheetIncreaseFontSizeDirective, SpreadsheetInsertLinkDirective, SpreadsheetItalicDirective, SpreadsheetLoadFileComponent, SpreadsheetMergeDirective, SpreadsheetModule, SpreadsheetRedoDirective, SpreadsheetSaveFileDirective, SpreadsheetTextAlignDirective, SpreadsheetTextWrapDirective, SpreadsheetUnderlineDirective, SpreadsheetUndoDirective, SpreadsheetVerticalTextAlignDirective };
3539
3997