diff --git a/docs/TOC.md b/docs/TOC.md index 40038d548..89e717f13 100644 --- a/docs/TOC.md +++ b/docs/TOC.md @@ -10,7 +10,6 @@ * [Dark Mode](styling/dark-mode.md) * [Styling CSS/SASS/Themes](styling/styling.md) -* [SVG Icons](styling/svg-icons.md) ## Column Functionalities @@ -18,6 +17,7 @@ * [Editors](column-functionalities/editors.md) * [new Autocomplete (Kraaden-lib)](column-functionalities/editors/autocomplete-editor-kraaden.md) * [Date Picker (flatpickr)](column-functionalities/editors/date-editor-flatpickr.md) + * [Date Picker (vanilla-calendar)](column-functionalities/editors/date-editor-(vanilla-calendar).md) * [LongText (textarea)](column-functionalities/editors/longtext-editor-textarea.md) * [Select Dropdown Editor (single/multiple)](column-functionalities/editors/select-dropdown-editor.md) * [Filters](column-functionalities/filters/README.md) diff --git a/docs/column-functionalities/cell-menu.md b/docs/column-functionalities/cell-menu.md index 0fbe23077..8337ec1d2 100644 --- a/docs/column-functionalities/cell-menu.md +++ b/docs/column-functionalities/cell-menu.md @@ -38,7 +38,7 @@ this.columnDefinitions = [ console.log(args.dataContext, args.column); // action callback.. do something } }, - { command: 'help', title: 'HELP', iconCssClass: 'fa fa-question-circle', positionOrder: 62 }, + { command: 'help', title: 'HELP', iconCssClass: 'mdi mdi-help-circle', positionOrder: 62 }, // you can add sub-menus by adding nested `commandItems` { // we can also have multiple nested sub-menus @@ -74,8 +74,8 @@ this.columnDefinitions = [ cellMenu: { optionTitle: 'Change Effort Driven Flag', // optional, add title optionItems: [ - { option: true, title: 'True', iconCssClass: 'fa fa-check-square-o' }, - { option: false, title: 'False', iconCssClass: 'fa fa-square-o' }, + { option: true, title: 'True', iconCssClass: 'mdi mdi-check-box-outline' }, + { option: false, title: 'False', iconCssClass: 'mdi mdi-checkbox-blank-outline' }, { divider: true, command: '', positionOrder: 60 }, ], // subscribe to Context Menu onOptionSelected event (or use the "action" callback on each option) @@ -174,9 +174,9 @@ this.columnDefinitions = [ const dataContext = args && args.dataContext; return !dataContext.completed; }, - { option: 1, iconCssClass: 'fa fa-star-o yellow', title: 'Low' }, - { option: 2, iconCssClass: 'fa fa-star-half-o orange', title: 'Medium' }, - { option: 3, iconCssClass: 'fa fa-star red', title: 'High' }, + { option: 1, iconCssClass: 'mdi mdi-star-outline yellow', title: 'Low' }, + { option: 2, iconCssClass: 'mdi mdi-star orange', title: 'Medium' }, + { option: 3, iconCssClass: 'mdi mdi-star red', title: 'High' }, ] } } @@ -191,9 +191,9 @@ this.columnDefinitions = [ cellMenu: { optionTitleKey: 'COMMANDS', // optionally pass a title to show over the Options optionItems: [ - { option: 1, titleKey: 'LOW', iconCssClass: 'fa fa-star-o yellow' }, - { option: 2, titleKey: 'MEDIUM', iconCssClass: 'fa fa-star-half-o orange' }, - { option: 3, titleKey: 'HIGH', iconCssClass: 'fa fa-star red' }, + { option: 1, titleKey: 'LOW', iconCssClass: 'mdi mdi-star-outline yellow' }, + { option: 2, titleKey: 'MEDIUM', iconCssClass: 'mdi mdi-star orange' }, + { option: 3, titleKey: 'HIGH', iconCssClass: 'mdi mdi-star red' }, ] } } diff --git a/docs/column-functionalities/editors.md b/docs/column-functionalities/editors.md index 398911058..a8c9738e3 100644 --- a/docs/column-functionalities/editors.md +++ b/docs/column-functionalities/editors.md @@ -48,7 +48,7 @@ this.columnDefinitions = [ } }, { - id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', formatter: Formatters.checkmark, + id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', formatter: Formatters.checkmarkMaterial, type: FieldType.number, editor: { model: Editors.checkbox } } ]; @@ -91,7 +91,7 @@ this.columnDefinitions = [ ]; ``` -So to make it more clear, the `saveOutputType` is the format that will be sent to the `onCellChange` event, then the `outputType` is how the date will show up in the date picker (Flatpickr) and finally the `type` is basically the input format (coming from your dataset). Note however that each property are cascading, if 1 property is missing it will go to the next one until 1 is found... for example, on the `onCellChange` if you aren't defining `saveOutputType`, it will try to use `outputType`, if again none is provided it will try to use `type` and finally if none is provided it will use `FieldType.dateIso` as the default. +So to make it more clear, the `saveOutputType` is the format that will be sent to the `onCellChange` event, then the `outputType` is how the date will show up in the date picker (Vanilla-Calendar) and finally the `type` is basically the input format (coming from your dataset). Note however that each property are cascading, if 1 property is missing it will go to the next one until 1 is found... for example, on the `onCellChange` if you aren't defining `saveOutputType`, it will try to use `outputType`, if again none is provided it will try to use `type` and finally if none is provided it will use `FieldType.dateIso` as the default. ## Perform an action After Inline Edit #### Recommended way @@ -325,12 +325,12 @@ By default HTML is not rendered and the `label` will simply show HTML as text. B this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, editor: { // display checkmark icon when True enableRenderHtml: true, - collection: [{ value: '', label: '' }, { value: true, label: 'True', labelPrefix: `<i class="fa fa-check"></i> ` }, { value: false, label: 'False' }], + collection: [{ value: '', label: '' }, { value: true, label: 'True', labelPrefix: `<i class="mdi mdi-check"></i> ` }, { value: false, label: 'False' }], model: Editors.singleSelect } } @@ -386,7 +386,7 @@ this.columnDefinitions = [{ id: 'start', name: 'Start Date', field: 'start', editor: { model: Editors.date, - editorOptions: { minDate: 'today' } + editorOptions: { range: { date: 'today' } } as VanillaCalendarOption } }]; ``` @@ -398,7 +398,7 @@ You could also define certain options as a global level (for the entire grid or this.gridOptions = { defaultEditorOptions: { autocompleter: { debounceWaitMs: 150 }, // typed as AutocompleterOption - date: { minDate: 'today' }, + date: { range: { date: 'today' } }, longText: { cols: 50, rows: 5 } } } diff --git a/docs/column-functionalities/editors/autocomplete-editor-kraaden.md b/docs/column-functionalities/editors/autocomplete-editor-kraaden.md index a24c243f3..9042d78c9 100644 --- a/docs/column-functionalities/editors/autocomplete-editor-kraaden.md +++ b/docs/column-functionalities/editors/autocomplete-editor-kraaden.md @@ -69,7 +69,7 @@ By default HTML is not rendered and the `label` will simply show HTML as text. B this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, editor: { model: Editors.autocompleter, diff --git a/docs/column-functionalities/editors/date-editor-(vanilla-calendar).md b/docs/column-functionalities/editors/date-editor-(vanilla-calendar).md new file mode 100644 index 000000000..df1ecbec5 --- /dev/null +++ b/docs/column-functionalities/editors/date-editor-(vanilla-calendar).md @@ -0,0 +1,70 @@ +##### index +- [Editor Options](#editor-options) +- [Custom Validator](#custom-validator) +- See the [Editors - Wiki](../Editors.md) for more general info about Editors (validators, event handlers, ...) + +### Information +The Date Editor is provided through an external library named [Vanilla-Calendar-Picker](https://github.com/ghiscoding/vanilla-calendar-picker) (a fork of [Vanilla-Calendar-Pro](https://vanilla-calendar.pro)) and all options from that library can be added to your `editorOptions` (see below), so in order to add things like minimum date, disabling dates, ... just review all the [Vanilla-Calendar-Pro](https://vanilla-calendar.pro/docs/reference/additionally/settings) and then add them into `editorOptions`. Also just so you know, `editorOptions` is use by all other editors as well to expose external library like Autocompleter, Multiple-Select, etc... + +### Demo +[Demo Page](https://ghiscoding.github.io/slickgrid-universal/#/example12) | [Demo Component](https://github.com/ghiscoding/slickgrid-universal/blob/master/examples/webpack-demo-vanilla-bundle/src/examples/example12.ts) + +### Editor Options +You can use any of the Vanilla-Calendar [settings](https://vanilla-calendar.pro/docs/reference/additionally/settings) by adding them to `editorOptions` as shown below. + +> **Note** for easier implementation, you should import `VanillaCalendarOption` from Slickgrid-Universal common package. + +```ts +import { type VanillaCalendarOption } from '@slickgrid-universal/common'; + +prepareGrid() { + this.columnDefinitions = [ + { + id: 'title', name: 'Title', field: 'title', + editor: { + model: Editors.date, + editorOptions: { + range: { + max: 'today', + disabled: ['2022-08-15', '2022-08-20'], + } + } as VanillaCalendarOption, + }, + }, + ]; +} +``` + +#### Grid Option `defaultEditorOptions +You could also define certain options as a global level (for the entire grid or even all grids) by taking advantage of the `defaultEditorOptions` Grid Option. Note that they are set via the editor type as a key name (`autocompleter`, `date`, ...) and then the content is the same as `editorOptions` (also note that each key is already typed with the correct editor option interface), for example + +```ts +this.gridOptions = { + defaultEditorOptions: { + date: { range: { min: 'today' } }, // typed as VanillaCalendarOption + } +} +``` + +### Custom Validator +You can add a Custom Validator from an external function or inline (inline is shown below and comes from [Example 12](https://ghiscoding.github.io/slickgrid-universal/#/example12)) +```ts +initializeGrid() { + this.columnDefinitions = [ + { + id: 'title', name: 'Title', field: 'title', + editor: { + model: Editors.date, + required: true, + validator: (value, args) => { + const dataContext = args && args.item; + if (dataContext && (dataContext.completed && !value)) { + return { valid: false, msg: 'You must provide a "Finish" date when "Completed" is checked.' }; + } + return { valid: true, msg: '' }; + } + }, + }, + ]; +} +``` \ No newline at end of file diff --git a/docs/column-functionalities/editors/select-dropdown-editor.md b/docs/column-functionalities/editors/select-dropdown-editor.md index d2915d465..d427556f2 100644 --- a/docs/column-functionalities/editors/select-dropdown-editor.md +++ b/docs/column-functionalities/editors/select-dropdown-editor.md @@ -158,12 +158,12 @@ By default HTML is not rendered and the `label` will simply show HTML as text. B this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, editor: { // display checkmark icon when True enableRenderHtml: true, - collection: [{ value: '', label: '' }, { value: true, label: 'True', labelPrefix: `<i class="fa fa-check"></i> ` }, { value: false, label: 'False' }], + collection: [{ value: '', label: '' }, { value: true, label: 'True', labelPrefix: `<i class="mdi mdi-check"></i> ` }, { value: false, label: 'False' }], model: Editors.singleSelect } } @@ -177,7 +177,7 @@ Sometime you wish that whenever you change your filter collection, you'd like th this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, editor: { // watch for any changes in the collection and re-render when that happens diff --git a/docs/column-functionalities/filters/compound-filters.md b/docs/column-functionalities/filters/compound-filters.md index 9fa3e82ec..3099b7ee7 100644 --- a/docs/column-functionalities/filters/compound-filters.md +++ b/docs/column-functionalities/filters/compound-filters.md @@ -3,7 +3,6 @@ - [SASS Styling](#sass-styling) - [Compound Input Filter](#how-to-use-compoundinput-filter) - [Compound Date Filter](#how-to-use-compounddate-filter) - - [Filter Options (`FlatpickrOption` interface)](#filter-options-flatpickroption-interface) - [Compound Operator List (custom list)](#compound-operator-list-custom-list) - [Compound Operator Alternate Texts](#compound-operator-alternate-texts) - [Filter Complex Object](../Input-Filter.md#how-to-filter-complex-objects) @@ -11,7 +10,7 @@ - [How to avoid filtering when only Operator dropdown is changed?](#how-to-avoid-filtering-when-only-operator-dropdown-is-changed) ### Description -Compound filters are a combination of 2 elements (Operator Select + Input Filter) used as a filter on a column. This is very useful to make it obvious to the user that there are Operator available and even more useful with a date picker (`Flatpickr`). +Compound filters are a combination of 2 elements (Operator Select + Input Filter) used as a filter on a column. This is very useful to make it obvious to the user that there are Operator available and even more useful with a date picker (`Vanilla-Calendar`). ### Demo [Demo Page](https://ghiscoding.github.io/aurelia-slickgrid/#/slickgrid/example4) / [Demo Component](https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example4.ts) @@ -21,12 +20,9 @@ There are multiple types of compound filters available 1. `Filters.compoundInputText` adds an Operator combine to an Input of type `text` (alias to `Filters.compoundInput`). 2. `Filters.compoundInputNumber` adds an Operator combine to an Input of type `number`. 3. `Filters.compoundInputPassword` adds an Operator combine to an Input of type `password. -4. `Filters.compoundDate` adds an Operator combine to a Date Picker (flatpickr). +4. `Filters.compoundDate` adds an Operator combine to a Date Picker. 5. `Filters.compoundSlider` adds an Operator combine to a Slider Filter. -### SASS Styling -You can change the `$flatpickr-bgcolor` and any of the `$compound-filter-X` SASS [variables](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/styles/_variables.scss#L660) for styling. For more info on how to use SASS in your project, read the [Wiki - Styling](../../styling/styling.md) - ### How to use CompoundInput Filter Simply set the flag `filterable` to True and use the filter type `Filters.compoundInput`. Here is an example with a full column definition: ```ts @@ -125,34 +121,18 @@ this.gridOptions = { }; ``` -#### Filter Options (`FlatpickrOption` interface) -All the available options that can be provided as `filterOptions` to your column definitions can be found under this [FlatpickrOption interface](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/interfaces/flatpickrOption.interface.ts) and you should cast your `filterOptions` to that interface to make sure that you use only valid options of the [Flatpickr](https://flatpickr.js.org/) library. +#### Filter Options (`VanillaCalendarOption` interface) +All the available options that can be provided as `filterOptions` to your column definitions can be found under this [VanillaCalendarOption interface](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/interfaces/vanillaCalendarOption.interface.ts) and you should cast your `filterOptions` with the expected interface to make sure that you use only valid settings of the [Vanilla-Calendar](https://vanilla-calendar.pro/docs/reference/additionally/settings) library. ```ts filter: { model: Filters.compoundDate, filterOptions: { - minDate: 'today' - } as FlatpickrOption + range: { min: 'today' } + } as VanillaCalendarOption } ``` -### Date Picker - Flatpickr Localization -In order to use different locale, you will have to import whichever Flatpickr locale you need. The best place to do these imports is in your App Module so it's global and you do it only once. In some rare cases it might not be sufficient, you move the import into your first entry component, typically the App Component - - -##### with WebPack -```ts -import { Aurelia } from 'aurelia-framework'; -import { GridOption } from 'aurelia-slickgrid'; - -export function configure(aurelia: Aurelia) { - aurelia.use.plugin(PLATFORM.moduleName('aurelia-slickgrid'), (config) => { - // load necessary Flatpickr Locale(s), but make sure it's imported AFTER loading Aurelia-Slickgrid plugin - import('flatpickr/dist/l10n/fr'); - }); -``` - #### Grid Option `defaultFilterOptions You could also define certain options as a global level (for the entire grid or even all grids) by taking advantage of the `defaultFilterOptions` Grid Option. Note that they are set via the filter type as a key name (`autocompleter`, `date`, ...) and then the content is the same as `filterOptions` (also note that each key is already typed with the correct filter option interface), for example @@ -160,8 +140,8 @@ You could also define certain options as a global level (for the entire grid or this.gridOptions = { defaultFilterOptions: { // Note: that `date`, `select` and `slider` are combining both compound & range filters together - date: { minDate: 'today' }, - select: { minHeight: 350 }, // typed as MultipleSelectOption + date: { range: { min: 'today' } }, // typed as VanillaCalendarOption + select: { minHeight: 350 }, // typed as MultipleSelectOption slider: { sliderStartValue: 10 } } } diff --git a/docs/column-functionalities/filters/range-filters.md b/docs/column-functionalities/filters/range-filters.md index 45c444d74..f0b3f37ad 100644 --- a/docs/column-functionalities/filters/range-filters.md +++ b/docs/column-functionalities/filters/range-filters.md @@ -4,14 +4,10 @@ - [Using a Slider Range](#using-a-slider-range-filter) - [Filter Options](#filter-options) - [Using a Date Range](#using-a-date-range-filter) - - [Filter Options (`FlatpickrOption` interface)](#filter-options-flatpickroption-interface) - [Update Filters Dynamically](Input-Filter.md#update-filters-dynamically) -### Demo -[Demo Page](https://ghiscoding.github.io/aurelia-slickgrid/#/slickgrid/example23) | [Demo Component](https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example23.ts) - ### Introduction -Range filters allows you to search for a value between 2 min/max values, the 2 most common use case would be to filter between 2 numbers or dates, you can do that with the new Slider & Date Range Filters. The range can also be defined as inclusive (`>= 0 and <= 10`) or exclusive (`> 0 and < 10`), the default is exclusive but you can change that, see below for more info. +Range filters allows you to search for a value between 2 min/max values, the 2 most common use case would be to filter between 2 numbers or dates, you can do that with the Slider & Date Range Filters. The range can also be defined as inclusive (`>= 0 and <= 10`) or exclusive (`> 0 and < 10`), the default is exclusive but you can change that, see below for more info. ### Using an Inclusive Range (default is Exclusive) By default all the range filters are with exclusive range, which mean between value `x` and `y` but without including them. If you wish to include the `x` and `y` values, you can change that through the `operator` property. @@ -38,8 +34,8 @@ this.columnDefinitions = [ You can use a regular input filter with the 2 dots (..) notation to represent a range, for example `5..90` would search between the value 5 and 90 (exclusive search unless specified). ##### Component -```typescript -import { Filters, Formatters, GridOption, OperatorType } from 'aurelia-slickgrid'; +```ts +import { Filters, Formatters, GridOption, OperatorType } from '@slickgrid-universal/common'; export class GridBasicComponent { columnDefinitions: Column[]; @@ -51,12 +47,12 @@ export class GridBasicComponent { this.columnDefinitions = [ { id: 'duration', field: 'duration', name: 'Duration', - type: FieldType.number, // you can optionally specify that the data are numbers + type: 'number', // you can optionally specify that the data are numbers filterable: true, // input filter is the default, so you can skip this unless you want to specify the `operator` filter: { - model: Filters.input, + model: 'input', operator: OperatorType.rangeInclusive // defaults to exclusive } }, @@ -73,8 +69,8 @@ export class GridBasicComponent { The slider range filter is very useful if you can just want to use the mouse to drag/slide a cursor, you can also optionally show/hide the slider values on screen (hiding them would giving you more room without but without the precision). ##### Component -```typescript -import { Filters, Formatters, GridOption, SliderRangeOption, OperatorType } from 'aurelia-slickgrid'; +```ts +import { Filters, Formatters, GridOption, SliderRangeOption, OperatorType } from '@slickgrid-universal/commomn'; export class GridBasicComponent { columnDefinitions: Column[]; @@ -88,7 +84,7 @@ export class GridBasicComponent { id: 'complete', name: '% Complete', field: 'percentComplete', headerKey: 'PERCENT_COMPLETE', minWidth: 120, sortable: true, formatter: Formatters.progressBar, - type: FieldType.number, + type: 'number', filterable: true, filter: { model: Filters.sliderRange, @@ -96,7 +92,7 @@ export class GridBasicComponent { operator: OperatorType.rangeInclusive, // optional, defaults to exclusive params: { hideSliderNumbers: false }, // you can hide/show the slider numbers on both side - // you can also optionally pass any option of the Slider filter + // you can also optionally pass any option of the Slider filter filterOptions: { sliderStartValue: 5 } as SliderRangeOption } }, @@ -109,7 +105,7 @@ export class GridBasicComponent { } ``` -##### Filter Options (`JQueryUiSliderOption` interface) +##### Filter Options All the available options that can be provided as `filterOptions` to your column definitions and you should try to cast your `filterOptions` to the specific interface as much as possible to make sure that you use only valid options of allowed by the targeted filter ```ts @@ -128,7 +124,7 @@ You could also define certain options as a global level (for the entire grid or this.gridOptions = { defaultFilterOptions: { // Note: that `date`, `select` and `slider` are combining both compound & range filters together - date: { minDate: 'today' }, + date: { range: { min: 'today' } }, select: { minHeight: 350 }, // typed as MultipleSelectOption slider: { sliderStartValue: 10 } } @@ -136,29 +132,31 @@ this.gridOptions = { ``` ### Using a Date Range Filter -The date range filter allows you to search data between 2 dates (it uses [Flatpickr Range](https://flatpickr.js.org/examples/#range-calendar) feature). +The date range filter allows you to search data between 2 dates (it uses [Vanilla-Calendar Range](https://vanilla-calendar.pro/) feature). ##### Component -import { Filters, FlatpickrOption, Formatters, GridOption, OperatorType } from '@slickgrid-universal/common'; +import { Filters, Formatters, GridOption, OperatorType, VanillaCalendarOption } from '@slickgrid-universal/common'; ```typescript -export class GridBasicComponent implement OnInit { +export class GridBasicComponent { columnDefinitions: Column[]; gridOptions: GridOption; dataset: any[]; - ngOnInit(): void { + attached(): void { // your columns definition this.columnDefinitions = [ { - id: 'finish', name: 'Finish', field: 'finish', nameKey: 'FINISH', formatter: Formatters.dateIso, sortable: true, minWidth: 75, width: 120, exportWithFormatter: true, + id: 'finish', name: 'Finish', field: 'finish', headerKey: 'FINISH', + minWidth: 75, width: 120, exportWithFormatter: true, + formatter: Formatters.dateIso, sortable: true, type: FieldType.date, filterable: true, filter: { model: Filters.dateRange, - // override any of the Flatpickr options through "filterOptions" - editorOptions: { minDate: 'today' } as FlatpickrOption + // override any of the Vanilla-Calendar options through "filterOptions" + editorOptions: { range: { min: 'today' } } as VanillaCalendarOption } }, ]; @@ -170,14 +168,14 @@ export class GridBasicComponent implement OnInit { } ``` -##### Filter Options (`FlatpickrOption` interface) -All the available options that can be provided as `filterOptions` to your column definitions can be found under this [FlatpickrOption interface](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/interfaces/flatpickrOption.interface.ts) and you should cast your `filterOptions` to that interface to make sure that you use only valid options of the [Flatpickr](https://flatpickr.js.org/) library. +#### Filter Options (`VanillaCalendarOption` interface) +All the available options that can be provided as `filterOptions` to your column definitions can be found under this [VanillaCalendarOption interface](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/interfaces/vanillaCalendarOption.interface.ts) and you should cast your `filterOptions` with the expected interface to make sure that you use only valid settings of the [Vanilla-Calendar](https://vanilla-calendar.pro/docs/reference/additionally/settings) library. ```ts filter: { - model: Filters.dateRange, + model: Filters.compoundDate, filterOptions: { - minDate: 'today' - } as FlatpickrOption + range: { min: 'today' } + } as VanillaCalendarOption } ``` diff --git a/docs/column-functionalities/filters/select-filter.md b/docs/column-functionalities/filters/select-filter.md index 30ce345cd..121b6050f 100644 --- a/docs/column-functionalities/filters/select-filter.md +++ b/docs/column-functionalities/filters/select-filter.md @@ -117,7 +117,7 @@ For the Select (dropdown) filter, you can fill in the "labelKey" property, if fo // define you columns, in this demo Effort Driven will use a Select Filter this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { @@ -133,7 +133,7 @@ You could also use the `enableTranslateLabel` which will translate regardless of // define you columns, in this demo Effort Driven will use a Select Filter this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { @@ -150,7 +150,7 @@ What if your select options (collection) have totally different value/label pair // define you columns, in this demo Effort Driven will use a Select Filter this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { @@ -175,7 +175,7 @@ What if you want to use `customStructure` and translate the labels? Simply pass // define you columns, in this demo Effort Driven will use a Select Filter this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { @@ -205,7 +205,7 @@ Note: the defaults for single & multiple select filters are different // define you columns, in this demo Effort Driven will use a Select Filter this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { @@ -229,7 +229,7 @@ Full example: // define you columns, in this demo Effort Driven will use a Select Filter this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { @@ -266,7 +266,7 @@ for (let i = 0; i < 365; i++) { this.columnDefinitions = [ { id: 'duration', name: 'Duration', field: 'duration', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { @@ -316,7 +316,7 @@ What if you want to use `customStructure` and translate the labels? Simply pass // define you columns, in this demo Effort Driven will use a Select Filter this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { @@ -341,7 +341,7 @@ You can also pre-sort or pre-filter the collection given to the multipleSelect/s // define you columns, in this demo Effort Driven will use a Select Filter this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { @@ -413,13 +413,13 @@ By default HTML is not rendered and the `label` will simply show HTML as text. B this.columnDefinitions = [ { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, filter: { // display checkmark icon when True enableRenderHtml: true, - collection: [{ value: '', label: '' }, { value: true, label: 'True', labelPrefix: `<i class="fa fa-check"></i> ` }, { value: false, label: 'False' }], + collection: [{ value: '', label: '' }, { value: true, label: 'True', labelPrefix: `<i class="mdi mdi-check"></i> ` }, { value: false, label: 'False' }], model: Filters.singleSelect } } diff --git a/docs/column-functionalities/filters/styling-filled-filters.md b/docs/column-functionalities/filters/styling-filled-filters.md index 8ac7c970b..895d103f0 100644 --- a/docs/column-functionalities/filters/styling-filled-filters.md +++ b/docs/column-functionalities/filters/styling-filled-filters.md @@ -1,55 +1,45 @@ -You can style any (or all) of the Filter(s) when they have value, the lib will automatically add a `filled` CSS class which you can style as your wish. There is no style by default, if you wish to add styling, you will be required to add your own. +You can style any (or all) of the Filter(s) when they have value, the lib will automatically add a `filled` CSS class which you can style as your wish. There is no style by default, if you wish to add styling, you will be required to add your own. -## Styled Example +## Styled Example ![grid_filled_styling](https://user-images.githubusercontent.com/643976/51334569-14306d00-1a4e-11e9-816c-439796eb8a59.png) ## Code example -For example, the print screen shown earlier was styled using this piece of SASS (`.scss`) code. Also note that the demo adds a Font-Awesome icon which can be used with `font-family: "FontAwesome"` and the relevent unicode character, for example the filter icon is `content: " \f0b0"`. You can basically add a lot of different styling to your populated filters. +For example, the print screen shown earlier was styled using this piece of SASS (`.scss`) code. You can customize the styling to your liking. ```scss -$filter-filled-bg-color: darkorange; - -.search-filter.filled { - // color: rgb(189, 104, 1); - // font-weight: bold; - background-color: $filter-filled-bg-color; - .ms-choice { - // color: rgb(189, 104, 1); - // font-weight: bold; - background-color: $filter-filled-bg-color; - } - - - input, input.flatpickr-input { - // border: 1px solid darken(rgb(204, 204, 204), 15%) !important; - // color: rgb(189, 104, 1); - // font-weight: bold; - background-color: $filter-filled-bg-color !important; +$slick-filled-filter-color: $slick-form-control-focus-border-color; +$slick-filled-filter-border: $slick-form-control-border; +$slick-filled-filter-box-shadow: $slick-form-control-focus-border-color; +$slick-filled-filter-font-weight: 400; + +.slick-headerrow { + input.search-filter.filled, + .search-filter.filled input, + .search-filter.filled .date-picker input, + .search-filter.filled .input-group-addon.slider-value, + .search-filter.filled .input-group-addon.slider-range-value, + .search-filter.filled .input-group-addon select { + color: $slick-filled-filter-color; + font-weight: $slick-filled-filter-font-weight; + border: $slick-filled-filter-border; + box-shadow: $slick-filled-filter-box-shadow; + &.input-group-prepend { + border-right: 0; + } + &.input-group-append { + border-left: 0; + } } - /* - &.ms-parent, .flatpickr > input, .input-group > input { - border: 1px solid darken(rgb(204, 204, 204), 15%) !important; - } - */ - - div.flatpickr:after, button > div:after, & + span:after, .input-group > span:after { - font-family: "FontAwesome"; - font-size: 75%; - content: " \f0b0"; - position: absolute; - top: 2px; - right: 5px; - z-index: 1000; - color: #ca880f; - } - - .ms-choice > div:after { - top: -4px; - right: 16px; + .search-filter.filled .input-group-prepend select { + border-right: 0; } - & + span:after { - top: 6px; - right: 10px; + .search-filter.filled .ms-choice { + box-shadow: $slick-filled-filter-box-shadow; + border:$slick-filled-filter-border; + span { + font-weight: $slick-filled-filter-font-weight; + color: $slick-filled-filter-color; + } } } ``` diff --git a/docs/column-functionalities/formatters.md b/docs/column-functionalities/formatters.md index a0e0b35d8..02bfb5713 100644 --- a/docs/column-functionalities/formatters.md +++ b/docs/column-functionalities/formatters.md @@ -20,7 +20,7 @@ `Formatters` are functions that can be used to change and format certain column(s) in the grid. Please note that it does not alter the input data, it simply changes the styling by formatting the data differently to the screen (what the user visually see). -A good example of a `Formatter` could be a column name `isActive` which is a `boolean` field with input data as `True` or `False`. User would prefer to simply see a checkbox as a visual indication representing the `True` flag, for this behavior you can use `Formatters.checkmark` which will use [Font-Awesome](http://fontawesome.io/icons/) icon of `fa-check` when `True` or an empty string when `False`. +A good example of a `Formatter` could be a column name `isActive` which is a `boolean` field with input data as `True` or `False`. User would prefer to simply see a checkbox as a visual indication representing the `True` flag, for this behavior you can use `Formatters.checkmark` which will use Material Design icon of `mdi-check` when `True` or an empty string when `False`. For a [UI sample](#ui-sample), scroll down below. @@ -34,7 +34,6 @@ For a [UI sample](#ui-sample), scroll down below. * `arrayObjectToCsv`: Takes an array of complex objects converts it to a comma delimited string. * `arrayToCsv` : takes an array of text and returns it as CSV string -* `checkmark` : uses Font-Awesome [(fa-check)](http://fontawesome.io/icon/check/) * `checkmarkMaterial` use Material Design to display a checkmark icon * `collection`: Looks up values from the columnDefinition.params.collection property and displays the label in CSV or string format * `complexObject`: takes a complex object (with a `field` that has a `.` notation) and pull correct value, there are multiple ways to use it @@ -176,14 +175,13 @@ export interface FormatterResultObject { } ``` -#### Example of a Custom Formatter with HTML string - -For example, we will use `Font-Awesome` with a `boolean` as input data, and display a (fire) icon when `True` or a (snowflake) when `False`. This custom formatter is actually display in the [UI sample](#ui-sample) shown below. +### Example of a Custom Formatter with HTML string +For example, we will use our optional SVG icons `.mdi` with a `boolean` as input data, and display a (fire) icon when `True` or a (snowflake) when `False`. This custom formatter is actually display in the [UI sample](#ui-sample) shown below. ```ts // create a custom Formatter with the Formatter type -const myCustomCheckboxFormatter: Formatter = (row: number, cell: number, value: any, columnDef: Column, dataContext: any, grid?: any) => - value ? `<i class="fa fa-fire" aria-hidden="true"></i>` : '<i class="fa fa-snowflake-o" aria-hidden="true"></i>'; +const myCustomCheckboxFormatter: Formatter = (row: number, cell: number, value: any, columnDef: Column, dataContext: any) => + value ? `<i class="mdi mdi-fire" aria-hidden="true"></i>` : '<i class="mdi mdi-snowflake" aria-hidden="true"></i>'; ``` #### Example with `FormatterResultObject` instead of a string @@ -193,7 +191,7 @@ Using this object return type will provide the user the same look and feel, it w ```ts // create a custom Formatter and returning a string and/or an object of type FormatterResultObject const myCustomCheckboxFormatter: Formatter = (row: number, cell: number, value: any, columnDef: Column, dataContext: any, grid?: any) => - value ? { addClasses: 'fa fa-fire', text: '', tooltip: 'burning fire' } : '<i class="fa fa-snowflake-o" aria-hidden="true"></i>'; + value ? { addClasses: 'mdi mdi-fire', text: '', tooltip: 'burning fire' } : '<i class="mdi mdi-snowflake" aria-hidden="true"></i>'; ``` ### Example of Custom Formatter with Native DOM Element diff --git a/docs/getting-started/quick-start.md b/docs/getting-started/quick-start.md index a5e75437d..7257a77a5 100644 --- a/docs/getting-started/quick-start.md +++ b/docs/getting-started/quick-start.md @@ -8,12 +8,12 @@ The easiest is to simply clone the [Aurelia-Slickgrid-Demos](https://github.com/ ### 1. Install NPM Package Install the `Aurelia-Slickgrid`, `Bootstrap` and potentially a font library like `Font-Awesome` ```bash -npm install --save aurelia-slickgrid bootstrap font-awesome # the last deps are optional +npm install --save aurelia-slickgrid bootstrap # the last deps are optional # install required @types npm install --save-dev @types/sortablejs @types/dompurify ``` -_Note: `Bootstrap` and `Font-Awesome` are both optional, you can use any other libs too_ +_Note: `Bootstrap` is optional, you can use any other lib that you want_ ### 2. CSS / SASS Styles Load the default Bootstrap theme style or scroll down for SASS customization. @@ -24,8 +24,6 @@ Default compiled `css` (if you use the plain Bootstrap Theme CSS, you could simp ##### WebPack ```typescript import 'bootstrap/dist/css/bootstrap.css'; -import 'font-awesome/css/font-awesome.css'; -import 'flatpickr/dist/flatpickr.min.css'; import 'multiple-select-modified/src/multiple-select.css'; // if you use CSS instead of SASS @@ -62,9 +60,6 @@ To provide locales other than English (default locale), you have 2 options that 1. Using [Custom Locale](../localization/localization-with-custom-locales.md), that is when you use **only 1** locale (other thank English)... this is a new feature starting from version `2.10.0` and up. 2. Using [Localization with I18N](../localization/localization.md), that is when you want to use multiple locales dynamically. -#### Date Picker - Flatpickr Localization -If you use multiple locale, you will also need to import necessary Flatpickr Locale, for more info see this [Flatpickr Localization Wiki](../column-functionalities/filters/compound-filters.md) - ### 5. Create a basic grid #### View ```html diff --git a/docs/grid-functionalities/composite-editor-modal.md b/docs/grid-functionalities/composite-editor-modal.md index 71852c6ef..85a0330b3 100644 --- a/docs/grid-functionalities/composite-editor-modal.md +++ b/docs/grid-functionalities/composite-editor-modal.md @@ -403,6 +403,7 @@ export class GridExample { if (columnDef.id === 'completed') { this.compositeEditorInstance.changeFormEditorOption('percentComplete', 'filter', formValues.completed); this.compositeEditorInstance.changeFormEditorOption('product', 'minLength', 3); + this.compositeEditorInstance.changeFormEditorOption('finish', 'range', { min: 'today' }); } } } @@ -439,7 +440,7 @@ export class GridExample { if (columnDef.id === 'completed') { this.compositeEditorInstance.changeFormEditorOption('percentComplete', 'filter', true); // multiple-select.js, show filter in dropdown this.compositeEditorInstance.changeFormEditorOption('product', 'minLength', 3); // autocomplete, change minLength char to type - this.compositeEditorInstance.changeFormEditorOption('finish', 'minDate', 'today'); // flatpickr date picker, change minDate to today + this.compositeEditorInstance.changeFormEditorOption('finish', 'range', { min: 'today' }); } } } diff --git a/docs/grid-functionalities/context-menu.md b/docs/grid-functionalities/context-menu.md index 76697547b..458b21bdd 100644 --- a/docs/grid-functionalities/context-menu.md +++ b/docs/grid-functionalities/context-menu.md @@ -42,7 +42,7 @@ this.gridOptions = { console.log(args.dataContext, args.column); // action callback.. do something } }, - { command: 'help', title: 'HELP', iconCssClass: 'fa fa-question-circle', positionOrder: 62 }, + { command: 'help', title: 'HELP', iconCssClass: 'mdi mdi-help-circle', positionOrder: 62 }, // you can add sub-menus by adding nested `commandItems` { // we can also have multiple nested sub-menus @@ -72,8 +72,8 @@ this.gridOptions = { hideCloseButton: false, optionTitle: 'Change Effort Driven Flag', // optional, add title optionItems: [ - { option: true, title: 'True', iconCssClass: 'fa fa-check-square-o' }, - { option: false, title: 'False', iconCssClass: 'fa fa-square-o' }, + { option: true, title: 'True', iconCssClass: 'mdi mdi-check-box-outline' }, + { option: false, title: 'False', iconCssClass: 'mdi mdi-checkbox-blank-outline' }, { divider: true, command: '', positionOrder: 60 }, ], // subscribe to Context Menu onOptionSelected event (or use the "action" callback on each option) @@ -157,9 +157,9 @@ contextMenu: { return !dataContext.completed; }, }, - { option: 1, iconCssClass: 'fa fa-star-o yellow', title: 'Low' }, - { option: 2, iconCssClass: 'fa fa-star-half-o orange', title: 'Medium' }, - { option: 3, iconCssClass: 'fa fa-star red', title: 'High' }, + { option: 1, iconCssClass: 'mdi mdi-star-outline yellow', title: 'Low' }, + { option: 2, iconCssClass: 'mdi mdi-star orange', title: 'Medium' }, + { option: 3, iconCssClass: 'mdi mdi-star red', title: 'High' }, ] } ``` @@ -170,9 +170,9 @@ It works exactly like the rest of the library when `enableTranslate` is set, all contextMenu: { optionTitleKey: 'COMMANDS', // optionally pass a title to show over the Options optionItems: [ - { option: 1, titleKey: 'LOW', iconCssClass: 'fa fa-star-o yellow' }, - { option: 2, titleKey: 'MEDIUM', iconCssClass: 'fa fa-star-half-o orange' }, - { option: 3, titleKey: 'HIGH', iconCssClass: 'fa fa-star red' }, + { option: 1, titleKey: 'LOW', iconCssClass: 'mdi mdi-star-outline yellow' }, + { option: 2, titleKey: 'MEDIUM', iconCssClass: 'mdi mdi-star orange' }, + { option: 3, titleKey: 'HIGH', iconCssClass: 'mdi mdi-star red' }, ] } ``` @@ -206,10 +206,10 @@ contextMenu: { hideExportTextDelimitedCommand: true, hideMenuOnScroll: true, hideOptionSection: false, - iconCopyCellValueCommand: 'fa fa-clone', - iconExportCsvCommand: 'fa fa-download', - iconExportExcelCommand: 'fa fa-file-excel-o text-success', - iconExportTextDelimitedCommand: 'fa fa-download', + iconCopyCellValueCommand: 'mdi mdi-content-copy', + iconExportCsvCommand: 'mdi mdi-download', + iconExportExcelCommand: 'mdi mdi-file-excel-outline text-success', + iconExportTextDelimitedCommand: 'mdi mdi-download', width: 200, }, ``` diff --git a/docs/grid-functionalities/export-to-excel.md b/docs/grid-functionalities/export-to-excel.md index a2041e402..96acfa161 100644 --- a/docs/grid-functionalities/export-to-excel.md +++ b/docs/grid-functionalities/export-to-excel.md @@ -63,7 +63,7 @@ defineGrid() { - So basically, if `exportWithFormatter` is set to True in the `excelExportOptions` of the Grid Options, but is set to False in the Column Definition, then the result will be False and will not evaluate it's Formatter. - `exportCustomFormatter` will let you choose a different Formatter when exporting - For example, you might have `formatter: Formatters.checkmark` but you want to see a boolean translated value, in this case you would define an extra property of `customFormatter: Formatters.translateBoolean`. -- set `sanitizeDataExport` to remove any HTML/Script code from being export. For example if your value is `<span class="fa fa-check">True</span>` will export `True` without any HTML (data is sanitized). +- set `sanitizeDataExport` to remove any HTML/Script code from being export. For example if your value is `<span class="mdi mdi-check">True</span>` will export `True` without any HTML (data is sanitized). - this flag can be used in the Grid Options (all columns) or in a Column Definition (per column). #### Grid Options @@ -78,7 +78,7 @@ Inside the column definition there are couple of flags you can set in `excelExpo - `sheetName` allows you to change the Excel Sheet Name (defaults to "Sheet1") - `groupingColumnHeaderTitle` The column header title (at A0 in Excel) of the Group by. If nothing is provided it will use "Group By" - `groupingAggregatorRowText` The default text to display in 1st column of the File Export, which will identify that the current row is a Grouping Aggregator -- set `sanitizeDataExport` to remove any HTML/Script code from being export. For example if your value is `<span class="fa fa-check">True</span>` will export `True` without any HTML (data is sanitized). +- set `sanitizeDataExport` to remove any HTML/Script code from being export. For example if your value is `<span class="mdi mdi-check">True</span>` will export `True` without any HTML (data is sanitized). - this flag can be used in the Grid Options (all columns) or in a Column Definition (per column). - `customExcelHeader` is a callback method that can be used to provide a custom Header Title to your Excel File @@ -106,7 +106,7 @@ defineGrid() { formatter: Formatters.dateIso // this formatter will be used for the export }, { id: 'completed', name: 'Completed', field: 'completed', headerKey: 'COMPLETED', - formatter: Formatters.checkmark, // will display a checkmark icon in the UI + formatter: Formatters.checkmarkMaterial, // will display a checkmark icon in the UI customFormatter: Formatters.translateBoolean, // will export a translated value, e.g. in French, True would show as 'Vrai' } ]; @@ -242,7 +242,7 @@ If you have lots of data, you might want to show a spinner telling the user that #### View ```html <span if.bind="!processing"> - <i class="fa fa-refresh fa-spin fa-lg fa-fw"></i> + <i class="mdi mdi-sync mdi-spin"></i> </span> <aurelia-slickgrid diff --git a/docs/grid-functionalities/export-to-text-file.md b/docs/grid-functionalities/export-to-text-file.md index 5bd310507..17ee332a1 100644 --- a/docs/grid-functionalities/export-to-text-file.md +++ b/docs/grid-functionalities/export-to-text-file.md @@ -52,7 +52,7 @@ Inside the column definition there are couple of flags you can set and also some - `exportCustomFormatter` will let you choose a different Formatter when exporting - For example, you might have `formatter: Formatters.checkmark` but you want to see a boolean translated value, in this case you would define an extra property of `exportCustomFormatter: Formatters.translateBoolean`. - you can set `exportCsvForceToKeepAsString` flag, this one will wrap the cell value into double quotes and add an equal sign in the front, this is especially useful on a column that could be turned into an exponential number by Excel. For example, we could have "1E06" and without this flag will become (1.0E06) in Excel, unless we enable the flag which will become `="1E06"` which will keep it as a string, also note that it will be shown as "1E06" but if you click on the cell value, you will see `="1E06"` -- set `sanitizeDataExport` to remove any HTML/Script code from being export. For example if your value is `<span class="fa fa-check">True</span>` will export `True` without any HTML (data is sanitized). +- set `sanitizeDataExport` to remove any HTML/Script code from being export. For example if your value is `<span class="mdi mdi-check">True</span>` will export `True` without any HTML (data is sanitized). - this flag can be used in the Grid Options (all columns) or in a Column Definition (per column). #### Behaviors @@ -81,7 +81,7 @@ defineGrid() { formatter: Formatters.dateIso // this formatter will be used for the export }, { id: 'completed', name: 'Completed', field: 'completed', headerKey: 'COMPLETED', - formatter: Formatters.checkmark, // will display a checkmark icon in the UI + formatter: Formatters.checkmarkMaterial, // will display a checkmark icon in the UI customFormatter: Formatters.translateBoolean, // will export a translated value, e.g. in French, True would show as 'Vrai' } ]; @@ -140,7 +140,7 @@ If you have lots of data, you might want to show a spinner telling the user that #### View ```html <span if.bind="!processing"> - <i class="fa fa-refresh fa-spin fa-lg fa-fw"></i> + <i class="mdi mdi-sync mdi-spin"></i> </span> <aurelia-slickgrid diff --git a/docs/grid-functionalities/frozen-columns-rows.md b/docs/grid-functionalities/frozen-columns-rows.md index 153c3d0f4..51b8a687a 100644 --- a/docs/grid-functionalities/frozen-columns-rows.md +++ b/docs/grid-functionalities/frozen-columns-rows.md @@ -86,7 +86,7 @@ You can change the number of pinned columns/rows and even the pinning of columns </span> <span style="margin-left: 15px"> <button class="btn btn-default btn-sm" (click)="toggleFrozenBottomRows()"> - <i class="fa fa-random fa-lg"></i> Toggle Pinned Rows + <i class="mdi mdi-flip-vertical"></i> Toggle Pinned Rows </button> <span style="font-weight: bold;">: {{ isFrozenBottom ? 'Bottom' : 'Top' }}</span> </span> diff --git a/docs/grid-functionalities/global-options.md b/docs/grid-functionalities/global-options.md index 5f1eed3c2..311f6fe05 100644 --- a/docs/grid-functionalities/global-options.md +++ b/docs/grid-functionalities/global-options.md @@ -9,7 +9,7 @@ export function configure(aurelia) { aurelia.use.plugin('aurelia-slickgrid', config => { // change any of the default global options // for example we can change the Grid Menu (hamburger menu) default icon - config.options.gridMenu.iconCssClass = 'fa fa-ellipsis-v'; + config.options.gridMenu.iconCssClass = 'mdi mdi-dots-vertical'; }); aurelia.start().then(() => aurelia.setRoot('app')); @@ -23,7 +23,7 @@ export function configure(aurelia) { aurelia.use.plugin(PLATFORM.moduleName('aurelia-slickgrid'), config => { // change any of the default global options // for example we can change the Grid Menu (hamburger menu) default icon - config.options.gridMenu.iconCssClass = 'fa fa-ellipsis-v'; + config.options.gridMenu.iconCssClass = 'mdi mdi-dots-vertical'; }); aurelia.start().then(() => aurelia.setRoot(PLATFORM.moduleName('app'))); diff --git a/docs/grid-functionalities/grid-menu.md b/docs/grid-functionalities/grid-menu.md index 3e900de91..c1abf2b77 100644 --- a/docs/grid-functionalities/grid-menu.md +++ b/docs/grid-functionalities/grid-menu.md @@ -30,18 +30,18 @@ this.gridOptions = { gridMenu: { commandTitle: 'Custom Commands', columnTitle: 'Columns', - iconCssClass: 'fa fa-ellipsis-v', + iconCssClass: 'mdi mdi-dots-vertical', menuWidth: 17, resizeOnShowHeaderRow: true, commandItems: [ { - iconCssClass: 'fa fa-filter text-danger', + iconCssClass: 'mdi mdi-filter text-danger', title: 'Clear All Filters', disabled: false, command: 'clear-filter' }, { - iconCssClass: 'fa fa-random', + iconCssClass: 'mdi mdi-flip-vertical', title: 'Toggle Filter Row', disabled: false, command: 'toggle-filter' @@ -108,16 +108,16 @@ For more info on all the available properties of the custom commands, you can re ### How to change an icon of all default commands? You can change any of the default command icon(s) by changing the `icon[X-command]`, for example, see below for the defaults. -```typescript +```ts this.gridOptions = { enableGridMenu: true, gridMenu: { - iconClearAllFiltersCommand: 'fa fa-filter text-danger' - iconClearAllSortingCommand: 'fa fa-unsorted text-danger', - iconExportCsvCommand: 'fa fa-download', - iconExportTextDelimitedCommand: 'fa fa-download', - iconRefreshDatasetCommand: 'fa fa-refresh', - iconToggleFilterCommand: 'fa fa-random', + iconClearAllFiltersCommand: 'mdi mdi-filter-remove-outline' + iconClearAllSortingCommand: 'mdi mdi-sort-variant-off', + iconExportCsvCommand: 'mdi mdi-download', + iconExportTextDelimitedCommand: 'mdi mdi-download', + iconRefreshDatasetCommand: 'mdi mdi-sync', + iconToggleFilterCommand: 'mdi-flip-vertical', }, }; ``` diff --git a/docs/grid-functionalities/grouping-aggregators.md b/docs/grid-functionalities/grouping-aggregators.md index e1b724f48..ef73f6266 100644 --- a/docs/grid-functionalities/grouping-aggregators.md +++ b/docs/grid-functionalities/grouping-aggregators.md @@ -213,21 +213,19 @@ To "Clear all Grouping", "Collapse all Groups" and "Expand all Groups", we can s ``` ### Styling (change icons) -The current icons are Font Awesome chevron (right/down), however if you wish to use +/- icons. You can simply update the SASS variables to use whichever icons (or even Font Family icon) you desire. The SASS variables you can change are +The current icons are chevron (right/down), however if you wish to use +/- icons. You can simply update the SASS variables to use whichever SVG icon paths. The SASS variables you can change are ```css -$icon-group-color: $primary-color; -$icon-group-expanded: "\f107"; -$icon-group-collapsed: "\f105"; -$icon-group-font-size: ($icon-font-size + 2px); -$icon-group-font-weight: bold; -$icon-group-margin-right: 2px; -$icon-group-height: 20px; -$icon-group-width: 14px; +$slick-icon-group-color: $primary-color; +$slick-icon-group-expanded-svg-path: "M19,19V5H5V19H19M19,3A2,2 0 0,1 21,5V19A2,2 0 0,1 19,21H5A2,2 0 0,1 3,19V5C3,3.89 3.9,3 5,3H19M11,7H13V11H17V13H13V17H11V13H7V11H11V7Z"; +$slick-icon-group-collapsed-svg-path: "M19,19V5H5V19H19M19,3A2,2 0 0,1 21,5V19A2,2 0 0,1 19,21H5A2,2 0 0,1 3,19V5C3,3.89 3.9,3 5,3H19M17,11V13H7V11H17Z"; +$slick-icon-group-font-size: 20px; +$slick-icon-group-font-weight: bold; +$slick-icon-group-margin-right: 2px; /* Grouping Totals Formatter */ -$group-totals-formatter-color: gray; -$group-totals-formatter-bgcolor: white; -$group-totals-formatter-font-size: 14px; +$slick-group-totals-formatter-color: gray; +$slick-group-totals-formatter-bgcolor: white; +$slick-group-totals-formatter-font-size: 14px; ``` For more info on SASS styling and variables, please read the [Wiki - SASS Styling](../styling/styling.md), diff --git a/docs/grid-functionalities/header-menu-header-buttons.md b/docs/grid-functionalities/header-menu-header-buttons.md index 5bef92b17..c8e5fe063 100644 --- a/docs/grid-functionalities/header-menu-header-buttons.md +++ b/docs/grid-functionalities/header-menu-header-buttons.md @@ -64,9 +64,9 @@ You can change any of the default command icon(s) by changing the `icon[X-comman this.gridOptions = { enableHeaderMenu: true, headerMenu: { - iconColumnHideCommand: 'fa fa-times' - iconSortAscCommand: 'fa fa-sort-asc' - iconSortDescCommand: 'fa fa-sort-desc', + iconColumnHideCommand: 'mdi mdi-close' + iconSortAscCommand: 'mdi mdi-sort-ascending' + iconSortDescCommand: 'mdi mdi-sort-descending', }, }; ``` diff --git a/docs/grid-functionalities/row-detail.md b/docs/grid-functionalities/row-detail.md index 782a9c78e..25358d21f 100644 --- a/docs/grid-functionalities/row-detail.md +++ b/docs/grid-functionalities/row-detail.md @@ -136,7 +136,7 @@ Most of the time we would get data asynchronously, during that time we can show ###### View (`preload.html`) ```html <template> - <h4><i class="fa fa-refresh fa-spin fa-2x fa-fw"></i>Loading...</h4> + <h4><i class="mdi mdi-sync mdi-spin-1s mdi-50px"></i>Loading...</h4> </template> ``` @@ -184,7 +184,7 @@ Same concept as the preload, we pass an Aurelia ViewModel to the `viewModel` tha <div class="row"> <div class="col-xs-3"><label>Start:</label> <span>${model.start | dateFormat: 'YYYY-MM-DD'}</span></div> <div class="col-xs-3"><label>Finish:</label> <span>${model.finish | dateFormat: 'YYYY-MM-DD'}</span></div> - <div class="col-xs-2"><label>Effort Driven:</label> <i class.bind="model.effortDriven ? 'fa fa-check' : ''"></i></div> + <div class="col-xs-2"><label>Effort Driven:</label> <i class.bind="model.effortDriven ? 'mdi mdi-check' : ''"></i></div> </div> <hr> @@ -192,7 +192,7 @@ Same concept as the preload, we pass an Aurelia ViewModel to the `viewModel` tha <h4> Find out who is the Assignee <small> - <button class="btn btn-primary btn-sm" click.delegate="alertAssignee(model.assignee)">Click Me</button> + <button class="btn btn-primary btn-sm btn-icon" click.delegate="alertAssignee(model.assignee)">Click Me</button> </small> </h4> </div> @@ -217,9 +217,9 @@ export class DetailViewCustomElement { bind(bindingContext, overrideContext) { if (bindingContext.model) { this.model = bindingContext.model; - } else if (overrideContext && overrideContext.bindingContext && overrideContext.bindingContext.model) { + } else if (overrideContext?.bindingContext?.model) { this.model = overrideContext.bindingContext.model; - } else if (overrideContext && overrideContext.parentOverrideContext && overrideContext.parentOverrideContext.bindingContext && overrideContext.parentOverrideContext.bindingContext.model) { + } else if (overrideContext?.parentOverrideContext?.bindingContext?.model) { this.model = overrideContext.parentOverrideContext.bindingContext.model; } } diff --git a/docs/localization/localization-with-custom-locales.md b/docs/localization/localization-with-custom-locales.md index ddc952782..8f8342219 100644 --- a/docs/localization/localization-with-custom-locales.md +++ b/docs/localization/localization-with-custom-locales.md @@ -62,6 +62,3 @@ export class MyGrid { #### 3. Use the lib (without I18N) There's nothing else to do, just use the library without defining or providing I18N and you're good to go. Read through the Wiki of the [HOWTO](../getting-started/quick-start.md) for basic grid samples. - -### Date Picker - Flatpickr Localization -If you use multiple locale, you will also need to import necessary Flatpickr Locale, for more info see this [Flatpickr Localization Wiki](../column-functionalities/filters/compound-filters.md#date-picker---flatpickr-localization) diff --git a/docs/localization/localization.md b/docs/localization/localization.md index c1988114d..faf23bd67 100644 --- a/docs/localization/localization.md +++ b/docs/localization/localization.md @@ -145,6 +145,3 @@ The final step is of course the actual translations. There's multiple ways to co "copy:i18n": "cross-env copyfiles -f node_modules/aurelia-slickgrid/i18n/*.json assets/i18n" ``` If you want to manually re-create the translation in your own files, the list of translations that you will need are displayed in the [asset i18n](https://github.com/ghiscoding/aurelia-slickgrid/tree/master/aurelia-slickgrid/assets/i18n) translation folder (from that file, you need all translations shown before the 'BILLING', the next few ones are for the demo page only). - -### Date Picker - Flatpickr Localization -If you use multiple locale, you will also need to import necessary Flatpickr Locale, for more info see this [Flatpickr Localization Wiki](../column-functionalities/filters/compound-filters.md#date-picker---flatpickr-localization) diff --git a/docs/styling/dark-mode.md b/docs/styling/dark-mode.md index 7fc0b211a..05445682a 100644 --- a/docs/styling/dark-mode.md +++ b/docs/styling/dark-mode.md @@ -83,7 +83,7 @@ export class MyDemo { }, // you can also change the icon and/or command name - iconToggleDarkModeCommand: 'fa fa-moon-o', + iconToggleDarkModeCommand: 'mdi mdi-brightness-4', commandLabels: { toggleDarkModeCommand: 'Toggle Dark Mode', }, diff --git a/docs/styling/styling.md b/docs/styling/styling.md index 8f4abf484..271ca45ff 100644 --- a/docs/styling/styling.md +++ b/docs/styling/styling.md @@ -2,7 +2,6 @@ - [Using Built-in Themes (CSS or SASS)](#csssass-styles) - [Using CSS Variables](#using-css-variables-instead-of-sass) - [Bootstrap & Other Frameworks](#bootstrap-support) -- [SVG Icons](#svg-icons) ### CSS/SASS Styles Load the default Bootstrap theme style or scroll down for SASS customization. @@ -12,39 +11,47 @@ Default compiled `css` (if you use the plain Bootstrap Theme CSS, you could simp ##### Aurelia-CLI ```html -<link rel="stylesheet" type="text/css" href="scripts/css/font-awesome.min.css"> -<link rel="stylesheet" type="text/css" href="../node_modules/flatpickr/dist/flatpickr.min.css"> - <!-- Slickgrid Bootstrap theme, unless you use SASS import --> <link rel="stylesheet" type="text/css" href="../node_modules/@slickgrid-universal/common/dist/styles/css/slickgrid-theme-bootstrap.css"> ``` ##### WebPack ```typescript import 'bootstrap/dist/css/bootstrap.css'; -import 'font-awesome/css/font-awesome.css'; -import 'flatpickr/dist/flatpickr.min.css'; // if you use CSS instead of SASS import '@slickgrid-universal/common/dist/styles/css/slickgrid-theme-bootstrap.css'; ``` -#### SASS (scss) -You could also compile the SASS files with your own customization, for that simply take any of the [_variables.scss](https://github.com/ghiscoding/aurelia-slickgrid/blob/master/aurelia-slickgrid/src/aurelia-slickgrid/styles/_variables.scss) (without the `!default` flag) variable from the file and make sure to import the Bootstrap Theme afterward. For example, you could modify your `style.scss` with the following changes: +### Using built-in Themes +The Material & Salesforce Themes are using SVGs internally for the icons used by the grid. Each built-in Themes have CSS and SASS files associated with each theme. To take benefit of this, just import whichever CSS/SASS file associated with the Theme you wish to use. + +##### with CSS +```scss +/* style.css */ +@import '@slickgrid-universal/common/dist/styles/css/slickgrid-theme-bootstrap.css'; + +// or other Themes +// @import '@slickgrid-universal/common/dist/styles/styles/css/slickgrid-theme-material.css'; +// @import '@slickgrid-universal/common/dist/styles/css/slickgrid-theme-salesforce.css'; +``` +##### with SASS ```scss -/* for example, let's change the mouse hover color */ +/* change any SASS variables before loading the theme */ +$slick-primary-color: green; $slick-cell-odd-background-color: lightyellow; $slick-row-mouse-hover-color: lightgreen; -/* make sure to add the @import the SlickGrid Bootstrap Theme AFTER the variables changes */ -@import '../node_modules/@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-bootstrap.scss'; - -/* or with */ +/* style.scss */ @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-bootstrap.scss'; + +// or other Themes +// @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-material.scss'; +// @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-salesforce.scss'; ``` ### Using CSS Variables _(instead of SASS)_ -You could change the SlickGrid styling with your own customization using [CSS Variables](https://developer.mozilla.org/en-US/docs/Web/CSS/Using_CSS_custom_properties). The variables that you can use (over 800 of them) are all predefined as SASS variables in the [_variables.scss](/ghiscoding/slickgrid-universal/blob/master/packages/common/src/styles/_variables.scss) file, you will simply have to rename the `$slick-` prefix with a `--slick-` prefix to the variable name to use them as CSS Variables. To be clear, you don't need SASS but the variables names were all declared as SASS and that is what the lib will use internally but you can optionally use them all as plain CSS Variables. +You could change the SlickGrid styling with your own customization using [CSS Variables](https://developer.mozilla.org/en-US/docs/Web/CSS/Using_CSS_custom_properties). The variables that you can use (over 800 of them) are all predefined as SASS variables in the [_variables.scss](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/styles/_variables.scss) file, you will simply have to rename the `$slick-` prefix with a `--slick-` prefix to the variable name to use them as CSS Variables. To be clear, you don't need SASS but the variables names were all declared as SASS and that is what the lib will use internally but you can optionally use them all as plain CSS Variables. For example, if we take the following 3 SASS variables (`$slick-header-menu-display`, `$slick-primary-color-dark` and `$slick-header-filter-row-border-bottom`) we can use the CSS Variables equivalent as the following @@ -57,25 +64,187 @@ For example, if we take the following 3 SASS variables (`$slick-header-menu-disp } ``` -**NOTE:** you could use `:host` to only change current grid styling, **however** there are many DOM elements that are appended to the Document `body` (Grid Menu, Column Picker, Select Filter/Editor, Context Menu, ...) and the style **will not** be applied with `:host` and so in most cases you would want to use `:root` to make a global change which will also work with elements appended to the `body`. +> **Note:** you could use `:host` to only change current grid styling, **however** there are many DOM elements that are appended to the DOM `body` (Grid Menu, Column Picker, Select Filter/Editor, Context Menu, ...) and the styles **will not** be applied when simply using `:host` and so in most cases you would want to use `:root` (if possible) to make a global change which will also work with elements appended to the `body`. Also note that `:root` is not available in Salesforce LWC and so you unfortunately won't be able to style everything in Salesforce. + +### Using Custom SVGs with SASS +You could use Custom SVGs and create your own Theme and/or a different set of SVG Icons, each of the icons used in Slickgrid-Universal has an associated SASS variables ending with the suffix `"icon-svg-path"` which allow you to override any of the SVG vector path. All SVG icons are generated by following AntFu's [icons in pure CSS](https://antfu.me/posts/icons-in-pure-css) approach. If you want create your own SVGs in pure CSS, you can use the `generateSvgStyle()` function from our [`sass-utilities.scss`](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/styles/sass-utilities.scss) (take a look at the [`slickgrid-icons.scss`](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/styles/slickgrid-icons.scss) on its usage) + +##### with SVG +```scss +$slick-primary-color: blue; +$slick-icon-group-color: $slick-primary-color; +$slick-icon-group-collapsed-svg-path: "M8.59,16.58L13.17,12L8.59,7.41L10,6L16,12L10,18L8.59,16.58Z"; +$slick-icon-group-expanded-svg-path: "M7.41,8.58L12,13.17L16.59,8.58L18,10L12,16L6,10L7.41,8.58Z"; +$slick-icon-group-font-size: 13px; + +// then on the last line, import the Theme that you wish to override +@import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-bootstrap.scss'; +``` + +> **Note** since the SVG are generated by a SASS function, you can easily override an SVG path in SASS but that is not the case with CSS variable. We still have a way to override an SVG via CSS variable but it requires to override the entire SVG content (not just its path) as can be seen below (also notice that the CSS variable is named without the `"-path"` suffix and also note that the URL must be encoded) + +```css +:root { + --slick-checkbox-icon-checked-svg: url('data:image/svg+xml;utf8,%3Csvg viewBox="0 0 24 24" display="inline-block" height="1em" width="1em" vertical-align="text-bottom" xmlns="http://www.w3.org/2000/svg" %3E%3Cpath fill="currentColor" d="M10,17L5,12L6.41,10.58L10,14.17L17.59,6.58L19,8M19,3H5C3.89,3 3,3.89 3,5V19A2,2 0 0,0 5,21H19A2,2 0 0,0 21,19V5C21,3.89 20.1,3 19,3Z"/%3E%3C/svg%3E'); +} +``` +the SASS equivalent is a lot easier to override +```scss +$slick-checkbox-icon-checked-svg-path: "M10,17L5,12L6.41,10.58L10,14.17L17.59,6.58L19,8M19,3H5C3.89,3 3,3.89 3,5V19A2,2 0 0,0 5,21H19A2,2 0 0,0 21,19V5C21,3.89 20.1,3 19,3Z" +``` + +### SVG icons +The project has a few built-in icons (sort, grouping, row detail, row move, row selection) and you can change them via SASS (or CSS with a bit more work). For that reason, all Styling Themes Since this release now has pure CSS SVG icons, I decided to delete any Font-Awesome references (mostly in the Bootstrap Theme) because all the built-in icons are now all SVG icons (sort, grouping, row detail, row move) (you can change them using SASS). However, there are a few plugins that use external icons via CSS classes (mostly all menu plugins like Header Menu, Grid Menu, Content Menu, ...) and for that reason **all Styling Themes now include default SVG icons** (even the Bootstrap Theme). + +What if you want to use your own font/SVG library? +This can be answered in 2 parts: +1. the built-in icons can only be changed via SASS (or CSS with extra work), see above on how to change them. +2. for all other area using icons via CSS classes (e.g. all menu plugins), you can use the "lite" Themes and then make sure to update all the menu plugins with the correct CSS classes, for example the global grid options of the Grid Menu is configured with the following CSS classes and you'll want to remap them with the correct CSS classes to fit your need: + +```ts +// default global grid options +export const GlobalGridOptions = { + gridMenu: { + iconCssClass: 'mdi mdi-menu', + iconClearAllFiltersCommand: 'mdi mdi-filter-remove-outline', + iconClearAllSortingCommand: 'mdi mdi-sort-variant-off', + iconClearFrozenColumnsCommand: 'mdi mdi-pin-off-outline', + iconExportCsvCommand: 'mdi mdi-download', + iconExportExcelCommand: 'mdi mdi-file-excel-outline', + iconExportTextDelimitedCommand: 'mdi mdi-download', + iconRefreshDatasetCommand: 'mdi mdi-sync', + iconToggleDarkModeCommand: 'mdi mdi-brightness-4', + iconToggleFilterCommand: 'mdi mdi-flip-vertical', + iconTogglePreHeaderCommand: 'mdi mdi-flip-vertical', + } +} +``` + +and here's the file size difference with the "lite" version -### Bootstrap support -The creation of `Aurelia-Slickgrid` works with `Bootstrap 4` and event the last `Bootstrap 5` version. -- [Bootstrap 4 demo](https://ghiscoding.github.io/aurelia-slickgrid-bs4-demo) / [examples repo](https://github.com/ghiscoding/aurelia-slickgrid-bs4-demo/tree/master/src/examples/slickgrid) -- [Bootstrap 5 demo](https://ghiscoding.github.io/aurelia-slickgrid) / [examples repo](https://github.com/ghiscoding/aurelia-slickgrid-demos/tree/master/webpack-bs5-demo) +![image](https://github.com/ghiscoding/slickgrid-universal/assets/643976/0edc9962-d881-49d2-bc47-1f698213ad5e) -### Other UI frameworks -Note that Bootstrap is totally optional, you could use any other UI framework, also 2 new themes were added in version `2.18.x`, first is a Material Design Theme and also a Salesforce Theme. -- Material Theme - [demo](https://ghiscoding.github.io/aurelia-slickgrid/#/slickgrid/example27) -- Salesforce Theme - [demo](https://ghiscoding.github.io/aurelia-slickgrid/#/slickgrid/example28) +### How to change SVG color? +#### The following works for both CSS and SASS +The new version 5.x of this project is now creating SVG icons as pure CSS, this mean that you can colorize the icons the same way that you would change a text color. We also provide a few different color CSS classes which start with the prefixes `$color-` or `$text-color-` (e.g. `$color-primary`). -For more demo, you can also take a look at my other repo (Slickgrid-Universal) [demos](https://ghiscoding.github.io/slickgrid-universal). Also, note that Bootstrap is completely optional (and has been for some time), the other demo that I mentioned was created using only the [Bulma](https://bulma.io/documentation) CSS framework, you will also notice that only the Material & Salesforce Themes were used across these multiple examples. +### SVG Colors - CSS Classes +Since SVG can now be colorize via the `color` the same as any other text, there isn't much to do. However a small subset of default colors is provided that can be used with the SVG icons or any text (basically took the same colors used by Bootstrap [here](https://getbootstrap.com/docs/4.5/utilities/colors/)). We also added a `light` and `dark` shades for of each colors (except `color-light`, `color-dark` since there's no need), they both use a 6% lighter/darker shades (you can override the shade with `$color-lighten-percentage` and the same for darken). These colors can be used with the `color-X` (for example `color-primary`), also note that the primary color will follow your `$slick-primary-color` that you might have already overriden (it could also be different in each styling theme, shown below is the Salesforce theme colors). If you find that the colors are not exactly the colors you're looking for, we've also took some colors taken from [UiKit](https://getuikit.com/) and tagged them as `color-alt-X`. -Each of these Styling Themes are compiled in CSS and created from a SASS file, so you can use either or. Both Themes are shown in each Tree Data demo -- **Note:** you might need to refresh the page to see the theme correctly since the styling is global and if you change page, the style will follow on the next page (unless you refresh). +**NOTE 1:** The `colors.scss` is **only** included in the Material and Salesforce Themes since those are the only 2 themes currently using SVGs. If you wish to use these colors then simply add the necessary css/scss file. -### SVG Icons -The 2 new Themes were created with only SVG icons, most of the icons were pulled from the [Material Design Icons](https://materialdesignicons.com/) set. If you wish to create your own set of SVG Icons, you can refer to the new [docs - SVG Icons](../styling/SVG-Icons.md) -- [docs - SVG Icons](../styling/SVG-Icons.md). +![image](https://github.com/ghiscoding/slickgrid-universal/assets/643976/986f16af-4e2b-4961-b2b5-32afc780b078) -**Note:** Just to point out that both the Fonts and SVG icons are supported, the default Bootstrap theme will keep Font-Awesome 4 so that it still works for everyone. You could however use SASS to override the Font and use SVG, again see the [docs - SVG Icons](../styling/SVG-Icons.md) for more details. +```scss +// SASS colors +$text-color-primary: $slick-primary-color; +$text-color-secondary: #6c757d; +$text-color-success: #28a745; +$text-color-danger: #dc3545; +$text-color-warning: #ffc107; +$text-color-info: #17a2b8; +$text-color-light: #f8f9fa; +$text-color-dark: #343a40; +$text-color-body: #212529; +$text-color-muted: #6c757d; +$text-color-white: #ffffff; +$text-color-alt-default: #1e87f0; +$text-color-alt-warning: #faa05a; +$text-color-alt-danger: #f0506e; +$text-color-alt-success: #32d296; +$text-color-se-primary: #3dcd58; +$text-color-se-link: #42b4e6; +$text-color-se-link-dark: #337ab7; +$text-color-se-danger: #b10043; +$text-color-se-secondary: #9fa0a4; +$text-color-se-warning: #e47f00; +$text-color-se-warning-light: #ffd100; + +// lighter/darker shades +$text-color-lighten-percentage: 6%; +$text-color-darken-percentage: 6%; +``` + +##### HTML Color Test +```html +<div> + <span class="text-color-primary"> text-color-primary <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-primary-light"> text-color-primary-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-primary-dark"> text-color-primary-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-secondary"> text-color-secondary <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-secondary-light"> text-color-secondary-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-secondary-dark"> text-color-secondary-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-success"> text-color-success <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-success-light"> text-color-success-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-success-dark"> text-color-success-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-danger"> text-color-danger <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-danger-light"> text-color-danger-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-danger-dark"> text-color-danger-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-warning"> text-color-warning <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-warning-light"> text-color-warning-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-warning-dark"> text-color-warning-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-info"> text-color-info <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-info-light"> text-color-info-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-info-dark"> text-color-info-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-body"> text-color-body <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-body-light"> text-color-body-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-body-dark"> text-color-body-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-muted"> text-color-muted <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-muted-light"> text-color-muted-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-muted-dark"> text-color-muted-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-dark"> text-color-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div style="background-color: rgb(34, 34, 34)"> + <span class="text-color-light"> text-color-light <i class="mdi mdi-help-circle"></i></span> +</div> +<div style="background-color: rgb(34, 34, 34)"> + <span class="text-color-white"> text-color-white <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-alt-default"> text-color-alt-default <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-alt-default-light"> text-color-alt-default-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-alt-default-dark"> text-color-alt-default-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-alt-warning"> text-color-alt-warning <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-alt-warning-light"> text-color-alt-warning-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-alt-warning-dark"> text-color-alt-warning-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-alt-success"> text-color-alt-success <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-alt-success-light"> text-color-alt-success-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-alt-success-dark"> text-color-alt-success-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div> + <span class="text-color-alt-danger"> text-color-alt-danger <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-alt-danger-light"> text-color-alt-danger-light <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-alt-danger-dark"> text-color-alt-danger-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div><span class="text-color-se-primary"> text-color-se-primary <i class="mdi mdi-help-circle"></i></span></div> +<div> + <span class="text-color-se-link"> text-color-se-link <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-se-link-dark"> text-color-se-link-dark <i class="mdi mdi-help-circle"></i></span> +</div> +<div><span class="text-color-se-secondary"> text-color-se-secondary <i class="mdi mdi-help-circle"></i></span></div> +<div><span class="text-color-se-danger"> text-color-se-danger <i class="mdi mdi-help-circle"></i></span></div> +<div> + <span class="text-color-se-warning"> text-color-se-warning <i class="mdi mdi-help-circle"></i></span> - + <span class="text-color-se-warning-light"> text-color-se-warning-light <i class="mdi mdi-help-circle"></i></span> +</div> +``` diff --git a/docs/styling/svg-icons.md b/docs/styling/svg-icons.md deleted file mode 100644 index 47513c62c..000000000 --- a/docs/styling/svg-icons.md +++ /dev/null @@ -1,213 +0,0 @@ -#### index -- [Using built-in Themes](#using-built-in-themes) -- [Bare and Lite versions](#bare-and-lite-versions) -- [Using SVG with SASS](#using-custom-svgs-with-sass) -- [How to change SVG color?](#how-to-change-svg-color) -- [List of included Material SVG Icons](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/styles/material-svg-icons.scss) - - We only included the most popular icons, about 100 out of the 4000 available [Material Design icons](https://materialdesignicons.com/) -- [SVG Colors CSS Classes](#svg-colors---css-classes) - - -### Description -Aurelia-Slickgrid was built with a Font set, mainly Font-Awesome 4, and if you use SASS it was easy enough to replace Font-Awesome to any other Font based set. The question is how do we use SVG instead of a Font? Most frameworks are switching to SVGs instead of Fonts (for smaller size and also efficiency). Aurelia-Slickgrid now has 2/3 Styling Themes that support SVGs which are Material Design & Salesforce Themes. These 2 new Themes use a subset of [Material Design Icons](https://materialdesignicons.com/) SVGs (even a portion of the Salesforce theme). There are no Font-Awesome 5, I wouldn't mind adding a new Theme for that and if you wish to contribute then please open a new issue. - -If you use SASS, you will find out that it's super easy to use either (Font) or (SVG), you simply have to replace the SASS necessary variables, more on that later. - -### Demo -- Material Theme - [demo](https://ghiscoding.github.io/aurelia-slickgrid/#/slickgrid/example27) -- Salesforce Theme - [demo](https://ghiscoding.github.io/aurelia-slickgrid/#/slickgrid/example28) - -### Using built-in Themes -The Material & Salesforce Themes are now using SVGs for the icons used by the grid. Each built-in Themes have CSS and SASS files associated with each theme. To take benefit of this, just import whichever CSS/SASS file associated with the Theme you wish to use. - -##### with CSS -```scss -/* style.css */ -@import '@slickgrid-universal/common/dist/styles/css/slickgrid-theme-bootstrap.css'; - -/* or other Themes */ -// @import '@slickgrid-universal/common/dist/styles/css/slickgrid-theme-material.css'; -// @import '@slickgrid-universal/common/dist/styles/css/slickgrid-theme-salesforce.css'; -``` - -##### with SASS -```scss -/* change any SASS variables before loading the theme */ -$slick-primary-color: green; - -/* style.scss */ -@import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-bootstrap.scss'; - -// or other Themes -// @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-material.scss'; -// @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-salesforce.scss'; -``` - -### Bare and Lite versions -If you wish to have a lighter CSS file and not include the `colors.scss` shown below, you could use the new `bare` versions which doesn't include any non-essential styling (it doesn't have any SVG/Color, Flatpickr & Multiple-Select styling, e.g. `slickgrid-theme-material.bare.css`), there's also a `lite` version which is roughly the same as the `bare` version except that it adds the SVG/Colors to it (e.g. `slickgrid-theme-material.lite.css`) while the regular version have it all that is (SVG/Color, Flatpickr & Multiple-Select styling, e.g.`slickgrid-theme-material.css`). - -### Using Custom SVGs with SASS -You could use Custom SVGs and create your own Theme and/or a different set of SVG Icons, each of the icons used in Aurelia-Slickgrid has an associated SASS variables which allow you to override any one of them. All of the icons are loaded with the `content` property of the `:before` pseudo (for example, see this [line](https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/styles/slick-bootstrap.scss#L351)) and the difference between Font and SVG is simple, if you want to use a Font then you use the Font Unicode but if you want an SVG then you use a `url` with `svg+xml` as shown below. - -##### with Font -```scss -$slick-primary-color: blue; -$slick-icon-sort-color: $slick-primary-color -$slick-icon-sort-asc: "\f0d8"; -$slick-icon-sort-desc: "\f0d7"; -$slick-icon-sort-font-size: 13px; -$slick-icon-sort-width: 13px; - -// then on the last line, import the Theme that you wish to override -@import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-bootstrap.scss'; -``` - -##### with SVG -```scss -// a simple utility that will encode a color with hash sign into a valid HTML URL (e.g. #red => %23red) -// you could also skip the use of this and simply manually change # symbol to %23 -@import '@slickgrid-universal/common/dist/styles/sass/sass-utilities'; - -$slick-primary-color: blue; - -$slick-icon-sort-color: $slick-primary-color -$slick-icon-sort-asc: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="#{encodecolor($slick-icon-sort-color)}" viewBox="0 0 24 24"><path d="M13,20H11V8L5.5,13.5L4.08,12.08L12,4.16L19.92,12.08L18.5,13.5L13,8V20Z"></path></svg>'); -$slick-icon-sort-desc: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="#{encodecolor($slick-icon-sort-color)}" viewBox="0 0 24 24"><path d="M11,4H13V16L18.5,10.5L19.92,11.92L12,19.84L4.08,11.92L5.5,10.5L11,16V4Z"></path></svg>'); -$slick-icon-sort-font-size: 13px; -$slick-icon-sort-width: 13px; - -// then on the last line, import the Theme that you wish to override -@import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-material.scss'; -``` - -### How to change SVG color? -#### The following works for both CSS and SASS -So there's a known caveat with using embedded SVG (which is what this lib does), you can only add color once with the `fill` property and for that I added SASS variables for each icon (for example `$slick-icon-sort-color` for the Sort icon color, or `$slick-icon-color` for all icons) but once you do that it will apply that same color across the document (want it or not). - -##### for CSS and SASS -After lot of research, I found a way to hack it via this SO answer [change any SVGs color via CSS `filter`](https://stackoverflow.com/a/53336754/1212166), for example if we wish to apply a red color on the `mdi-close` icon (for the Draggable Grouping feat), we'll have to do this `filter` -```css -.slick-groupby-remove.mdi-close { - /* close icon - red */ - filter: invert(32%) sepia(96%) saturate(7466%) hue-rotate(356deg) brightness(97%) contrast(120%); -} -``` -You might be thinking, like I did, but how to get this long `filter` calculation??? -For that you can visit the following blog post and use its **[color filter converter](https://dev.to/jsm91/css-filter-generator-to-convert-from-black-to-target-hex-color-188h)** that was posted to answer this SO [question](https://stackoverflow.com/q/42966641/1212166) - -##### for SASS only -There is also a SASS Mixin to convert the color using only SASS as posted [here](https://stackoverflow.com/a/62880368/1212166) in the same SO question. That will be part of the lib soon enough and we'll be able to use it this way (much cleaner): -```scss -.slick-groupby-remove.mdi-close { - /* close icon - red */ - @include recolor(#ff0000, 0.8); -} -``` -Note that even though the code looks smaller and more human readable, in reality the code produced will still be a `filter` - -`@include recolor(#ff0000, 0.8);` will in fact be converted to `filter: invert(32%) sepia(96%) saturate(7466%) hue-rotate(356deg) brightness(97%) contrast(120%);` - -### SVG Colors - CSS Classes -To help with all of this, we added a few icon colors (basically took the same colors used by Bootstrap [here](https://getbootstrap.com/docs/4.5/utilities/colors/) using CSS `filter` and we also added a `light` and `dark` shades for of each colors (except `color-light`, `color-dark` since there's no need), they both use a 6% lighter/darker shades (you can override the shade with `$color-lighten-percentage` and the same for darken). These colors can be used with the `color-X` (for example `color-primary`), also note that the primary color will follow your `$slick-primary-color` that you might have override (it could also be different in each styling theme, shown below is the Salesforce theme colors). If you find that the colors are not exactly the colors you're looking for, we've also took some colors taken from [UiKit](https://getuikit.com/) and tagged them as `color-alt-X`. - -**NOTE:** You can use these colors on Icon and/or Text **but** remember that we're using CSS `filter` here which is very different compare to using regular CSS `color` or `background-color`. - -**NOTE 2:** The `colors.scss` is **only** included in the Material and Salesforce Themes since those are the only 2 themes currently using SVGs. If you wish to use these colors then simply add the necessary css/scss file. - -![image](https://user-images.githubusercontent.com/643976/90325971-5b475280-df50-11ea-9791-f02ea33af2d8.png) - -```scss -// SASS colors -$color-primary: $slick-primary-color; -$color-secondary: #6c757d; -$color-success: #28a745; -$color-danger: #dc3545; -$color-warning: #ffc107; -$color-info: #17a2b8; -$color-light: #f8f9fa; -$color-dark: #343a40; -$color-body: #212529; -$color-muted: #6c757d; -$color-white: #ffffff; -$color-alt-default: #1e87f0; -$color-alt-warning: #faa05a; -$color-alt-danger: #f0506e; -$color-alt-success: #32d296; - -// lighter/darker shades -$color-lighten-percentage: 6%; -$color-darken-percentage: 6%; -``` - -##### HTML Color Test -```html -<div> - <span class="color-primary">color-primary <i class="mdi mdi-help-circle"></i></span> - - <span class="color-primary-light">color-primary-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-primary-dark">color-primary-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-secondary">color-secondary <i class="mdi mdi-help-circle"></i></span> - - <span class="color-secondary-light">color-secondary-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-secondary-dark">color-secondary-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-success">color-success <i class="mdi mdi-help-circle"></i></span> - - <span class="color-success-light">color-success-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-success-dark">color-success-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-danger">color-danger <i class="mdi mdi-help-circle"></i></span> - - <span class="color-danger-light">color-danger-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-danger-dark">color-danger-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-warning">color-warning <i class="mdi mdi-help-circle"></i></span> - - <span class="color-warning-light">color-warning-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-warning-dark">color-warning-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-info">color-info <i class="mdi mdi-help-circle"></i></span> - - <span class="color-info-light">color-info-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-info-dark">color-info-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-body">color-body <i class="mdi mdi-help-circle"></i></span> - - <span class="color-body-light">color-body-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-body-dark">color-body-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-muted">color-muted <i class="mdi mdi-help-circle"></i></span> - - <span class="color-muted-light">color-muted-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-muted-dark">color-muted-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-dark">color-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div style="background-color: rgb(34, 34, 34)"> - <span class="color-light">color-light <i class="mdi mdi-help-circle"></i></span> -</div> -<div style="background-color: rgb(34, 34, 34)"> - <span class="color-white">color-white <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-alt-default">color-alt-default <i class="mdi mdi-help-circle"></i></span> - - <span class="color-alt-default-light">color-alt-default-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-alt-default-dark">color-alt-default-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-alt-warning">color-alt-warning <i class="mdi mdi-help-circle"></i></span> - - <span class="color-alt-warning-light">color-alt-warning-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-alt-warning-dark">color-alt-warning-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-alt-success">color-alt-success <i class="mdi mdi-help-circle"></i></span> - - <span class="color-alt-success-light">color-alt-success-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-alt-success-dark">color-alt-success-dark <i class="mdi mdi-help-circle"></i></span> -</div> -<div> - <span class="color-alt-danger">color-alt-danger <i class="mdi mdi-help-circle"></i></span> - - <span class="color-alt-danger-light">color-alt-danger-light <i class="mdi mdi-help-circle"></i></span> - - <span class="color-alt-danger-dark">color-alt-danger-dark <i class="mdi mdi-help-circle"></i></span> -</div> -``` diff --git a/package.json b/package.json index c1650070a..477bf52c7 100644 --- a/package.json +++ b/package.json @@ -50,6 +50,7 @@ "@types/node": "^20.12.7", "cross-env": "^7.0.3", "cypress": "^13.8.1", + "cypress-real-events": "^1.12.0", "eslint": "^9.1.1", "eslint-plugin-cypress": "^3.0.2", "eslint-plugin-import": "^2.29.1", diff --git a/packages/aurelia-slickgrid/package.json b/packages/aurelia-slickgrid/package.json index bcce3553d..856e5039e 100644 --- a/packages/aurelia-slickgrid/package.json +++ b/packages/aurelia-slickgrid/package.json @@ -61,8 +61,9 @@ "@slickgrid-universal/utils": "~5.0.0-beta.1", "dequal": "^2.0.3", "isomorphic-dompurify": "^2.8.0", - "moment-mini": "^2.29.4", - "sortablejs": "^1.15.2" + "moment-tiny": "^2.30.3", + "sortablejs": "^1.15.2", + "vanilla-calendar-picker": "^2.11.4" }, "devDependencies": { "@types/dompurify": "^3.0.5", diff --git a/packages/aurelia-slickgrid/src/global-grid-options.ts b/packages/aurelia-slickgrid/src/global-grid-options.ts index b4c06a9fc..64d18ac58 100644 --- a/packages/aurelia-slickgrid/src/global-grid-options.ts +++ b/packages/aurelia-slickgrid/src/global-grid-options.ts @@ -47,8 +47,8 @@ export const GlobalGridOptions: Partial<GridOption> = { massUpdateStatusKey: 'ALL_X_RECORDS_SELECTED', saveButtonKey: 'SAVE', }, - resetEditorButtonCssClass: 'fa fa-repeat', - resetFormButtonIconCssClass: 'fa fa-repeat' + resetEditorButtonCssClass: 'mdi mdi-refresh mdi-15px', + resetFormButtonIconCssClass: 'mdi mdi-refresh mdi-16px mdi-flip-h', }, contextMenu: { autoAdjustDrop: true, @@ -64,13 +64,13 @@ export const GlobalGridOptions: Partial<GridOption> = { hideExportTextDelimitedCommand: true, hideMenuOnScroll: true, hideOptionSection: false, - iconCollapseAllGroupsCommand: 'fa fa-compress', - iconExpandAllGroupsCommand: 'fa fa-expand', - iconClearGroupingCommand: 'fa fa-times', - iconCopyCellValueCommand: 'fa fa-clone', - iconExportCsvCommand: 'fa fa-download', - iconExportExcelCommand: 'fa fa-file-excel-o text-success', - iconExportTextDelimitedCommand: 'fa fa-download', + iconCollapseAllGroupsCommand: 'mdi mdi-arrow-collapse', + iconExpandAllGroupsCommand: 'mdi mdi-arrow-expand', + iconClearGroupingCommand: 'mdi mdi-close', + iconCopyCellValueCommand: 'mdi mdi-content-copy', + iconExportCsvCommand: 'mdi mdi-download', + iconExportExcelCommand: 'mdi mdi-file-excel-outline text-success', + iconExportTextDelimitedCommand: 'mdi mdi-download', }, customFooterOptions: { dateFormat: 'YYYY-MM-DD, hh:mm a', @@ -185,17 +185,17 @@ export const GlobalGridOptions: Partial<GridOption> = { hideToggleDarkModeCommand: true, hideToggleFilterCommand: false, hideTogglePreHeaderCommand: false, - iconCssClass: 'fa fa-bars', - iconClearAllFiltersCommand: 'fa fa-filter', - iconClearAllSortingCommand: 'fa fa-unsorted', - iconClearFrozenColumnsCommand: 'fa fa-times', - iconExportCsvCommand: 'fa fa-download', - iconExportExcelCommand: 'fa fa-file-excel-o', - iconExportTextDelimitedCommand: 'fa fa-download', - iconRefreshDatasetCommand: 'fa fa-refresh', - iconToggleDarkModeCommand: 'fa fa-moon-o mdi mdi-brightness-4', - iconToggleFilterCommand: 'fa fa-random', - iconTogglePreHeaderCommand: 'fa fa-random', + iconCssClass: 'mdi mdi-menu', + iconClearAllFiltersCommand: 'mdi mdi-filter', + iconClearAllSortingCommand: 'mdi mdi-sort-variant-off', + iconClearFrozenColumnsCommand: 'mdi mdi-close', + iconExportCsvCommand: 'mdi mdi-download', + iconExportExcelCommand: 'mdi mdi-file-excel-outline', + iconExportTextDelimitedCommand: 'mdi mdi-download', + iconRefreshDatasetCommand: 'mdi mdi-sync', + iconToggleDarkModeCommand: 'mdi mdi-brightness-4 mdi mdi-brightness-4', + iconToggleFilterCommand: 'mdi mdi-flip-vertical', + iconTogglePreHeaderCommand: 'mdi mdi-flip-vertical', menuWidth: 16, resizeOnShowHeaderRow: true, headerColumnValueExtractor: pickerHeaderColumnValueExtractor @@ -204,13 +204,13 @@ export const GlobalGridOptions: Partial<GridOption> = { autoAlign: true, autoAlignOffset: 12, minWidth: 140, - iconClearFilterCommand: 'fa fa-filter', - iconClearSortCommand: 'fa fa-unsorted', - iconFreezeColumns: 'fa fa-thumb-tack', - iconSortAscCommand: 'fa fa-sort-amount-asc', - iconSortDescCommand: 'fa fa-sort-amount-desc', - iconColumnHideCommand: 'fa fa-times', - iconColumnResizeByContentCommand: 'fa fa-arrows-h', + iconClearFilterCommand: 'mdi mdi-filter-remove-outline', + iconClearSortCommand: 'mdi mdi-sort-variant-off', + iconFreezeColumns: 'mdi mdi-pin-outline', + iconSortAscCommand: 'mdi mdi-sort-ascending', + iconSortDescCommand: 'mdi mdi-flip-v mdi-sort-descending', + iconColumnHideCommand: 'mdi mdi-close', + iconColumnResizeByContentCommand: 'mdi mdi-arrow-expand-horizontal', hideColumnResizeByContentCommand: false, hideColumnHideCommand: false, hideClearFilterCommand: false, diff --git a/packages/demo/package.json b/packages/demo/package.json index a02b09646..fa4beb8e9 100644 --- a/packages/demo/package.json +++ b/packages/demo/package.json @@ -55,8 +55,8 @@ "aurelia-slickgrid": "workspace:*", "bootstrap": "^5.3.3", "i18next": "^23.11.2", - "isomorphic-dompurify": "^2.8.0", "i18next-fetch-backend": "^5.0.2", + "isomorphic-dompurify": "^2.8.0", "moment-mini": "^2.29.4", "rxjs": "^7.8.1" }, @@ -77,10 +77,10 @@ "css-loader": "^7.1.1", "dotenv-webpack": "^8.1.0", "fetch-jsonp": "^1.3.0", - "font-awesome": "^4.7.0", "html-webpack-plugin": "^5.6.0", "htmlhint": "^1.1.4", "isomorphic-fetch": "^3.0.0", + "multiple-select-vanilla": "^3.1.0", "npm-run-all2": "^6.1.2", "postcss": "^8.4.38", "postcss-loader": "^8.1.1", diff --git a/packages/demo/src/examples/slickgrid/example1.html b/packages/demo/src/examples/slickgrid/example1.html index 7e664bfd0..a80d02c05 100644 --- a/packages/demo/src/examples/slickgrid/example1.html +++ b/packages/demo/src/examples/slickgrid/example1.html @@ -3,7 +3,7 @@ <h2> <span class="float-end"> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example1.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -12,7 +12,8 @@ <h2> <h3> <div class="column"> <span class="mr-3">Grid 1</span> - <button class="btn btn-outline-secondary btn-sm ms-2" click.trigger="toggleDarkModeGrid1()" data-test="toggle-dark-mode"> + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="toggleDarkModeGrid1()" data-test="toggle-dark-mode"> + <i class="mdi mdi-theme-light-dark"></i> <span>Toggle Dark Mode</span> </button> </div> diff --git a/packages/demo/src/examples/slickgrid/example10.html b/packages/demo/src/examples/slickgrid/example10.html index 583d2532e..bab331278 100644 --- a/packages/demo/src/examples/slickgrid/example10.html +++ b/packages/demo/src/examples/slickgrid/example10.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example10.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -12,14 +12,14 @@ <h2> innerhtml.bind="subTitle"></div> <div class="row"> - <div class="col-sm-4" style="max-width: 175px;"> + <div class="col-sm-4" style="max-width: 205px;"> Pagination <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-first-page" click.trigger="goToGrid1FirstPage()"> - <i class="fa fa-caret-left fa-lg"></i> + <i class="mdi mdi-page-first"></i> </button> <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-last-page" click.trigger="goToGrid1LastPage()"> - <i class="fa fa-caret-right fa-lg"></i> + <i class="mdi mdi-page-last icon"></i> </button> </div> <div class="col-sm-8"> @@ -45,7 +45,7 @@ <h2> <hr class="col-md-6 offset-md-1"> <div class="row"> - <div class="col-sm-4 col-md-3" style="max-width: 190px;"> + <div class="col-sm-4 col-md-3" style="max-width: 215px;"> <label for="enableGrid2Pagination"> Pagination: <input type="checkbox" id="enableGrid2Pagination" @@ -55,11 +55,11 @@ <h2> <span style="margin-left: 5px" if.bind="isGrid2WithPagination"> <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-first-page" click.trigger="goToGrid2FirstPage()"> - <i class="fa fa-caret-left fa-lg"></i> + <i class="mdi mdi-page-first"></i> </button> <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-last-page" click.trigger="goToGrid2LastPage()"> - <i class="fa fa-caret-right fa-lg"></i> + <i class="mdi mdi-page-last icon"></i> </button> </span> </div> diff --git a/packages/demo/src/examples/slickgrid/example10.ts b/packages/demo/src/examples/slickgrid/example10.ts index 440cc1c34..7380874c5 100644 --- a/packages/demo/src/examples/slickgrid/example10.ts +++ b/packages/demo/src/examples/slickgrid/example10.ts @@ -63,7 +63,7 @@ export class Example10 { }, { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, type: FieldType.boolean, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, sortable: true, filterable: true, filter: { collection: [{ value: '', label: '' }, { value: true, label: 'true' }, { value: false, label: 'false' }], @@ -88,7 +88,7 @@ export class Example10 { }, { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, type: FieldType.boolean, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, sortable: true, filterable: true, filter: { collection: [{ value: '', label: '' }, { value: true, label: 'true' }, { value: false, label: 'false' }], diff --git a/packages/demo/src/examples/slickgrid/example11.html b/packages/demo/src/examples/slickgrid/example11.html index 3e7d9c308..0191c77bd 100644 --- a/packages/demo/src/examples/slickgrid/example11.html +++ b/packages/demo/src/examples/slickgrid/example11.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example11.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -14,26 +14,26 @@ <h2> <span> <label>Scroll: </label> <div class="btn-group" role="group" aria-label="..."> - <button class="btn btn-sm btn-outline-secondary" data-test="scroll-top-btn" click.trigger="scrollGridTop()"> - <i class="fa fa-arrow-up"></i> + <button class="btn btn-sm btn-outline-secondary btn-icon" data-test="scroll-top-btn" click.trigger="scrollGridTop()"> + <i class="mdi mdi-arrow-down mdi-rotate-180 icon"></i> </button> - <button class="btn btn-sm btn-outline-secondary" data-test="scroll-bottom-btn" + <button class="btn btn-sm btn-outline-secondary btn-icon" data-test="scroll-bottom-btn" click.trigger="scrollGridBottom()"> - <i class="fa fa-arrow-down"></i> + <i class="mdi mdi-arrow-down icon"></i> </button> </div> - <button class="btn btn-sm btn-outline-secondary" data-test="add-new-item-top-btn" + <button class="btn btn-sm btn-outline-secondary btn-icon" data-test="add-new-item-top-btn" click.trigger="addNewItem()">Add New Mocked Item (top)</button> - <button class="btn btn-sm btn-outline-secondary" data-test="add-new-item-bottom-btn" + <button class="btn btn-sm btn-outline-secondary btn-icon" data-test="add-new-item-bottom-btn" click.trigger="addNewItem('bottom')">Add New Mocked Item (bottom)</button> - <button class="btn btn-sm btn-outline-secondary" data-test="update-second-item-btn" + <button class="btn btn-sm btn-outline-secondary btn-icon" data-test="update-second-item-btn" click.trigger="updateSecondItem()"> Update 2nd Row Item with Random Duration </button> - <button class="btn btn-sm btn-outline-secondary" data-test="highlight-row5-btn" + <button class="btn btn-sm btn-outline-secondary btn-icon" data-test="highlight-row5-btn" click.trigger="highlighFifthRow()">Highlight 5th Row</button> - <button class="btn btn-sm btn-outline-secondary" data-test="highlight-duration40-btn" + <button class="btn btn-sm btn-outline-secondary btn-icon" data-test="highlight-duration40-btn" click.trigger="changeDurationBackgroundColor()"> Highlight Rows with Duration over 50 </button> diff --git a/packages/demo/src/examples/slickgrid/example11.ts b/packages/demo/src/examples/slickgrid/example11.ts index 7e37be452..ec4339043 100644 --- a/packages/demo/src/examples/slickgrid/example11.ts +++ b/packages/demo/src/examples/slickgrid/example11.ts @@ -70,7 +70,7 @@ export class Example11 { field: 'id', excludeFromHeaderMenu: true, formatter: Formatters.icon, - params: { iconCssClass: 'fa fa-trash pointer' }, + params: { iconCssClass: 'mdi mdi-trash-can pointer' }, minWidth: 30, maxWidth: 30, // use onCellClick OR grid.onClick.subscribe which you can see down below @@ -127,7 +127,7 @@ export class Example11 { }, { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.number, editor: { model: Editors.checkbox diff --git a/packages/demo/src/examples/slickgrid/example12.html b/packages/demo/src/examples/slickgrid/example12.html index 9c353ea6e..15ae0ed56 100644 --- a/packages/demo/src/examples/slickgrid/example12.html +++ b/packages/demo/src/examples/slickgrid/example12.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example12.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -14,8 +14,8 @@ <h2> <div class="row"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-sm" data-test="language-button" click.trigger="switchLanguage()"> - <i class="fa fa-language"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="language-button" click.trigger="switchLanguage()"> + <i class="mdi mdi-translate"></i> Switch Language </button> <label>Locale:</label> @@ -24,22 +24,22 @@ <h2> </span> <span style="margin-left: 20px"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="exportToFile('csv')"> - <i class="fa fa-download"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="exportToFile('csv')"> + <i class="mdi mdi-download"></i> Download to CSV </button> - <button class="btn btn-outline-secondary btn-sm" click.trigger="exportToFile('txt')"> - <i class="fa fa-download"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="exportToFile('txt')"> + <i class="mdi mdi-download"></i> Download to Text </button> - <button class="btn btn-outline-secondary btn-sm" click.trigger="exportToExcel()"> - <i class="fa fa-file-excel-o text-success"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="exportToExcel()"> + <i class="mdi mdi-file-excel-outline text-success"></i> Download to Excel </button> </span> <span style="margin-left: 10px"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="dynamicallyAddTitleHeader()"> - <i class="fa fa-plus"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="dynamicallyAddTitleHeader()"> + <i class="mdi mdi-shape-square-plus"></i> Dynamically Duplicate Title Column </button> </span> diff --git a/packages/demo/src/examples/slickgrid/example12.ts b/packages/demo/src/examples/slickgrid/example12.ts index e666263af..b7e6d9ecf 100644 --- a/packages/demo/src/examples/slickgrid/example12.ts +++ b/packages/demo/src/examples/slickgrid/example12.ts @@ -111,7 +111,7 @@ export class Example12 { { id: 'completedBool', name: 'Completed', field: 'completedBool', nameKey: 'COMPLETED', minWidth: 100, sortable: true, - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, exportCustomFormatter: Formatters.translateBoolean, filterable: true, filter: { diff --git a/packages/demo/src/examples/slickgrid/example13.html b/packages/demo/src/examples/slickgrid/example13.html index f2f846c81..5086f6aef 100644 --- a/packages/demo/src/examples/slickgrid/example13.html +++ b/packages/demo/src/examples/slickgrid/example13.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example13.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -12,24 +12,24 @@ <h2> <div class="row"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-xs" data-test="add-500-rows-btn" click.trigger="loadData(500)"> + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="add-500-rows-btn" click.trigger="loadData(500)"> 500 rows </button> - <button class="btn btn-outline-secondary btn-xs" data-test="add-50k-rows-btn" click.trigger="loadData(50000)"> + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="add-50k-rows-btn" click.trigger="loadData(50000)"> 50k rows </button> - <button class="btn btn-outline-secondary btn-xs" data-test="clear-grouping-btn" click.trigger="clearGrouping()"> - <i class="fa fa-times"></i> Clear grouping + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="clear-grouping-btn" click.trigger="clearGrouping()"> + <i class="mdi mdi-close"></i> Clear grouping </button> - <button class="btn btn-outline-secondary btn-xs" data-test="collapse-all-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="collapse-all-btn" click.trigger="collapseAllGroups()"> - <i class="fa fa-compress"></i> Collapse all groups + <i class="mdi mdi-arrow-collapse"></i> Collapse all groups </button> - <button class="btn btn-outline-secondary btn-xs" data-test="expand-all-btn" click.trigger="expandAllGroups()"> - <i class="fa fa-expand"></i> Expand all groups + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="expand-all-btn" click.trigger="expandAllGroups()"> + <i class="mdi mdi-arrow-expand"></i> Expand all groups </button> - <button class="btn btn-outline-secondary btn-xs" data-test="export-excel-btn" click.trigger="exportToExcel()"> - <i class="fa fa-file-excel-o text-success"></i> Export to Excel + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="export-excel-btn" click.trigger="exportToExcel()"> + <i class="mdi mdi-file-excel-outline text-success"></i> Export to Excel </button> </div> </div> @@ -38,31 +38,31 @@ <h2> <div class="row"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-xs" data-test="group-duration-sort-value-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="group-duration-sort-value-btn" click.trigger="groupByDuration()"> Group by Duration & sort groups by value </button> - <button class="btn btn-outline-secondary btn-xs" data-test="group-duration-sort-count-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="group-duration-sort-count-btn" click.trigger="groupByDurationOrderByCount(false)"> Group by Duration & sort groups by count </button> </div> <div class="row"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-xs" data-test="group-duration-sort-count-collapse-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="group-duration-sort-count-collapse-btn" click.trigger="groupByDurationOrderByCount(true)"> Group by Duration & sort groups by count, aggregate collapsed </button> - <button class="btn btn-outline-secondary btn-xs" data-test="group-duration-effort-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="group-duration-effort-btn" click.trigger="groupByDurationEffortDriven()"> Group by Duration then Effort-Driven </button> - <button class="btn btn-outline-secondary btn-xs" data-test="group-duration-effort-percent-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="group-duration-effort-percent-btn" click.trigger="groupByDurationEffortDrivenPercent()"> Group by Duration then Effort-Driven then Percent. </button> <span hidden.bind="!processing"> - <i class="fa fa-refresh fa-spin fa-lg fa-fw"></i> + <i class="mdi mdi-sync mdi-spin"></i> </span> </div> </div> diff --git a/packages/demo/src/examples/slickgrid/example13.ts b/packages/demo/src/examples/slickgrid/example13.ts index 0f9de67a6..0ca187d66 100644 --- a/packages/demo/src/examples/slickgrid/example13.ts +++ b/packages/demo/src/examples/slickgrid/example13.ts @@ -154,7 +154,7 @@ export class Example13 { minWidth: 30, width: 80, maxWidth: 90, cssClass: 'cell-effort-driven', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, sortable: true, filterable: true, filter: { diff --git a/packages/demo/src/examples/slickgrid/example14.html b/packages/demo/src/examples/slickgrid/example14.html index 5fd340a4b..7706bda24 100644 --- a/packages/demo/src/examples/slickgrid/example14.html +++ b/packages/demo/src/examples/slickgrid/example14.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example14.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -22,13 +22,13 @@ <h3>Grid 1 <small>(with Header Grouping & Colspan)</small></h3> <h3>Grid 2 <small>(with Header Grouping & Frozen/Pinned Columns)</small></h3> <div class="col-sm 12"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="setFrozenColumns2(-1)" + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="setFrozenColumns2(-1)" data-test="remove-frozen-column-button"> - <i class="fa fa-times fa-lg"></i> Remove Frozen Columns + <i class="mdi mdi-close"></i> Remove Frozen Columns </button> - <button class="btn btn-outline-secondary btn-sm" click.trigger="setFrozenColumns2(2)" + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="setFrozenColumns2(2)" data-test="set-3frozen-columns"> - <i class="fa fa-thumb-tack fa-lg"></i> Set 3 Frozen Columns + <i class="mdi mdi-pin-outline"></i> Set 3 Frozen Columns </button> </div> diff --git a/packages/demo/src/examples/slickgrid/example15.html b/packages/demo/src/examples/slickgrid/example15.html index f34871a45..5d720feb3 100644 --- a/packages/demo/src/examples/slickgrid/example15.html +++ b/packages/demo/src/examples/slickgrid/example15.html @@ -4,20 +4,20 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example15.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> <div class="subtitle" innerhtml.bind="subTitle"></div> -<button class="btn btn-outline-secondary btn-sm" data-test="reset-button" +<button class="btn btn-outline-secondary btn-sm btn-icon" data-test="reset-button" click.trigger="clearGridStateFromLocalStorage()"> - <i class="fa fa-times"></i> + <i class="mdi mdi-close"></i> Clear Grid State from Local Storage & Reset Grid </button> -<button class="btn btn-outline-secondary btn-sm" data-test="language-button" click.trigger="switchLanguage()"> - <i class="fa fa-language"></i> +<button class="btn btn-outline-secondary btn-sm btn-icon" data-test="language-button" click.trigger="switchLanguage()"> + <i class="mdi mdi-translate"></i> Switch Language </button> <strong>Locale:</strong> diff --git a/packages/demo/src/examples/slickgrid/example15.ts b/packages/demo/src/examples/slickgrid/example15.ts index 2ddf96eab..d51affe66 100644 --- a/packages/demo/src/examples/slickgrid/example15.ts +++ b/packages/demo/src/examples/slickgrid/example15.ts @@ -1,5 +1,6 @@ import { I18N } from '@aurelia/i18n'; import { resolve } from 'aurelia'; +import { type MultipleSelectOption } from 'multiple-select-vanilla'; import { type AureliaGridInstance, type Column, @@ -9,7 +10,6 @@ import { type GridOption, type GridState, type GridStateChange, - type MultipleSelectOption } from 'aurelia-slickgrid'; function randomBetween(min: number, max: number) { @@ -125,7 +125,7 @@ export class Example15 { type: FieldType.date, filterable: true, filter: { model: Filters.compoundDate } }, { - id: 'completed', field: 'completed', nameKey: 'COMPLETED', minWidth: 85, maxWidth: 85, formatter: Formatters.checkmark, width: 100, + id: 'completed', field: 'completed', nameKey: 'COMPLETED', minWidth: 85, maxWidth: 85, formatter: Formatters.checkmarkMaterial, width: 100, type: FieldType.boolean, sortable: true, filterable: true, diff --git a/packages/demo/src/examples/slickgrid/example16.html b/packages/demo/src/examples/slickgrid/example16.html index 3caf42b0e..59fea09e7 100644 --- a/packages/demo/src/examples/slickgrid/example16.html +++ b/packages/demo/src/examples/slickgrid/example16.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example16.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -13,31 +13,31 @@ <h2> <div class="row"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-sm" data-test="hide-duration-btn" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="hide-duration-btn" click.trigger="hideDurationColumnDynamically()"> - <i class="fa fa-eye-slash"></i> + <i class="mdi mdi-eye-off-outline"></i> Dynamically Hide "Duration" </button> - <button class="btn btn-outline-secondary btn-sm" data-test="disable-filters-btn" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="disable-filters-btn" click.trigger="disableFilters()"> - <i class="fa fa-times"></i> + <i class="mdi mdi-close"></i> Disable Filters </button> - <button class="btn btn-outline-secondary btn-sm" data-test="disable-sorting-btn" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="disable-sorting-btn" click.trigger="disableSorting()"> - <i class="fa fa-times"></i> + <i class="mdi mdi-close"></i> Disable Sorting </button> - <button class="btn btn-outline-secondary btn-sm" data-test="toggle-filtering-btn" click.trigger="toggleFilter()"> - <i class="fa fa-random"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="toggle-filtering-btn" click.trigger="toggleFilter()"> + <i class="mdi mdi-flip-vertical"></i> Toggle Filtering </button> - <button class="btn btn-outline-secondary btn-sm" data-test="toggle-sorting-btn" click.trigger="toggleSorting()"> - <i class="fa fa-random"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="toggle-sorting-btn" click.trigger="toggleSorting()"> + <i class="mdi mdi-flip-vertical"></i> Toggle Sorting </button> - <button class="btn btn-outline-secondary btn-sm" data-test="add-crud-columns-btn" click.trigger="addEditDeleteColumns()"> - <i class="fa fa-plus"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="add-crud-columns-btn" click.trigger="addEditDeleteColumns()"> + <i class="mdi mdi-shape-square-plus"></i> Add Edit/Delete Columns </button> </div> diff --git a/packages/demo/src/examples/slickgrid/example16.ts b/packages/demo/src/examples/slickgrid/example16.ts index 1d42740b1..ca0a39686 100644 --- a/packages/demo/src/examples/slickgrid/example16.ts +++ b/packages/demo/src/examples/slickgrid/example16.ts @@ -58,7 +58,7 @@ export class Example16 { }, { id: 'effort-driven', name: 'Completed', field: 'effortDriven', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, filterable: true, sortable: true, filter: { collection: [{ value: '', label: '' }, { value: true, label: 'True' }, { value: false, label: 'False' }], @@ -235,7 +235,7 @@ export class Example16 { excludeFromGridMenu: true, excludeFromHeaderMenu: true, formatter: Formatters.icon, - params: { iconCssClass: 'fa fa-pencil pointer' }, + params: { iconCssClass: 'mdi mdi-pencil pointer' }, minWidth: 30, maxWidth: 30, onCellClick: (_clickEvent: Event, args: OnEventArgs) => { @@ -248,7 +248,7 @@ export class Example16 { excludeFromGridMenu: true, excludeFromHeaderMenu: true, formatter: Formatters.icon, - params: { iconCssClass: 'fa fa-trash pointer' }, + params: { iconCssClass: 'mdi mdi-trash-can pointer' }, minWidth: 30, maxWidth: 30, onCellClick: (_e: Event, args: OnEventArgs) => { diff --git a/packages/demo/src/examples/slickgrid/example17.html b/packages/demo/src/examples/slickgrid/example17.html index 752003b2e..2cea606f5 100644 --- a/packages/demo/src/examples/slickgrid/example17.html +++ b/packages/demo/src/examples/slickgrid/example17.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example17.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -31,7 +31,7 @@ <h2> <div class="alert alert-warning col-md-6" role="alert" if.bind="loading"> - <i class="fa fa-refresh fa-spin fa-lg fa-fw"></i> + <i class="mdi mdi-sync mdi-spin"></i> <span>Loading...</span> </div> diff --git a/packages/demo/src/examples/slickgrid/example18.html b/packages/demo/src/examples/slickgrid/example18.html index cc87f823c..edf161d02 100644 --- a/packages/demo/src/examples/slickgrid/example18.html +++ b/packages/demo/src/examples/slickgrid/example18.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example18.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -13,51 +13,51 @@ <h2> <div class="form-inline"> <div class="row"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-xs" data-test="add-500-rows-btn" click.trigger="loadData(500)"> + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="add-500-rows-btn" click.trigger="loadData(500)"> 500 rows </button> - <button class="btn btn-outline-secondary btn-xs" data-test="add-50k-rows-btn" click.trigger="loadData(50000)"> + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="add-50k-rows-btn" click.trigger="loadData(50000)"> 50k rows </button> - <button class="btn btn-outline-secondary btn-xs" data-test="clear-grouping-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="clear-grouping-btn" click.trigger="clearGroupsAndSelects()"> - <i class="fa fa-times"></i> Clear grouping + <i class="mdi mdi-close"></i> Clear grouping </button> - <button class="btn btn-outline-secondary btn-xs" data-test="collapse-all-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="collapse-all-btn" click.trigger="collapseAllGroups()"> - <i class="fa fa-compress"></i> Collapse all groups + <i class="mdi mdi-arrow-collapse"></i> Collapse all groups </button> - <button class="btn btn-outline-secondary btn-xs" data-test="expand-all-btn" click.trigger="expandAllGroups()"> - <i class="fa fa-expand"></i> Expand all groups + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="expand-all-btn" click.trigger="expandAllGroups()"> + <i class="mdi mdi-arrow-expand"></i> Expand all groups </button> - <button class="btn btn-outline-secondary btn-xs" click.trigger="toggleDraggableGroupingRow()"> + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="toggleDraggableGroupingRow()"> Toggle Draggable Grouping Row </button> - <button class="btn btn-outline-secondary btn-xs" click.trigger="exportToExcel()"> - <i class="fa fa-file-excel-o text-success"></i> Export to Excel + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="exportToExcel()"> + <i class="mdi mdi-file-excel-outline text-success"></i> Export to Excel </button> </div> </div> <div class="row"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-xs" data-test="group-duration-sort-value-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="group-duration-sort-value-btn" click.trigger="groupByDurationOrderByCount(false)"> Group by duration & sort groups by value </button> - <button class="btn btn-outline-secondary btn-xs" data-test="group-duration-sort-count-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="group-duration-sort-count-btn" click.trigger="groupByDurationOrderByCount(true)"> Group by duration & sort groups by count </button> - <button class="btn btn-outline-secondary btn-xs" data-test="group-duration-effort-btn" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="group-duration-effort-btn" click.trigger="groupByDurationEffortDriven()"> Group by Duration then Effort-Driven </button> - <button class="btn btn-outline-secondary btn-xs" data-test="set-dynamic-filter" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="set-dynamic-filter" click.trigger="setFiltersDynamically()"> Set Filters Dynamically </button> - <button class="btn btn-outline-secondary btn-xs" data-test="set-dynamic-sorting" + <button class="btn btn-outline-secondary btn-xs btn-icon" data-test="set-dynamic-sorting" click.trigger="setSortingDynamically()"> Set Sorting Dynamically </button> diff --git a/packages/demo/src/examples/slickgrid/example18.ts b/packages/demo/src/examples/slickgrid/example18.ts index a4a479f47..6df0f9c1e 100644 --- a/packages/demo/src/examples/slickgrid/example18.ts +++ b/packages/demo/src/examples/slickgrid/example18.ts @@ -190,7 +190,7 @@ export class Example18 { collection: [{ value: '', label: '' }, { value: true, label: 'True' }, { value: false, label: 'False' }], model: Filters.singleSelect }, - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, grouping: { getter: 'effortDriven', formatter: (g) => `Effort-Driven: ${g.value ? 'True' : 'False'} <span style="color:green">(${g.count} items)</span>`, @@ -227,8 +227,8 @@ export class Example18 { }, draggableGrouping: { dropPlaceHolderText: 'Drop a column header here to group by the column', - // groupIconCssClass: 'fa fa-outdent', - deleteIconCssClass: 'fa fa-times', + // groupIconCssClass: 'mdi mdi-drag-vertical', + deleteIconCssClass: 'mdi mdi-close', onGroupChanged: (_e, args) => this.onGroupChanged(args), onExtensionRegistered: (extension) => this.draggableGroupingPlugin = extension, }, diff --git a/packages/demo/src/examples/slickgrid/example19-detail-view.html b/packages/demo/src/examples/slickgrid/example19-detail-view.html index 7bb4ff9df..4c5194b96 100644 --- a/packages/demo/src/examples/slickgrid/example19-detail-view.html +++ b/packages/demo/src/examples/slickgrid/example19-detail-view.html @@ -10,7 +10,7 @@ <h3>${model.title}</h3> <div class="row"> <div class="col-3"><label>Start:</label> <span>${model.start | dateFormat: 'YYYY-MM-DD'}</span></div> <div class="col-3"><label>Finish:</label> <span>${model.finish | dateFormat: 'YYYY-MM-DD'}</span></div> - <div class="col-2"><label>Effort Driven:</label> <i class.bind="model.effortDriven ? 'fa fa-check' : ''"></i> + <div class="col-2"><label>Effort Driven:</label> <i class.bind="model.effortDriven ? 'mdi mdi-check' : ''"></i> </div> </div> @@ -35,4 +35,4 @@ <h4> Call Parent Method </button> </div> -</div> \ No newline at end of file +</div> diff --git a/packages/demo/src/examples/slickgrid/example19-preload.ts b/packages/demo/src/examples/slickgrid/example19-preload.ts index ffc29d6d9..c73d6896e 100644 --- a/packages/demo/src/examples/slickgrid/example19-preload.ts +++ b/packages/demo/src/examples/slickgrid/example19-preload.ts @@ -4,7 +4,7 @@ import { customElement } from 'aurelia'; name: 'example19-preload', template: `<div class="container" style="margin-top: 10px"> <h4> - <i class="fa fa-refresh fa-spin fa-2x fa-fw"></i> + <i class="mdi mdi-sync mdi-spin mdi-50px"></i> Loading... </h4> </div>` diff --git a/packages/demo/src/examples/slickgrid/example19.html b/packages/demo/src/examples/slickgrid/example19.html index 1a994e740..938fec4f4 100644 --- a/packages/demo/src/examples/slickgrid/example19.html +++ b/packages/demo/src/examples/slickgrid/example19.html @@ -3,24 +3,24 @@ <h2> <span class="float-end"> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example19.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> <div class="subtitle" innerhtml.bind="subTitle"></div> <div class="col-sm-6"> - <button class="btn btn-outline-secondary btn-xs" click.trigger="changeEditableGrid()" data-test="editable-grid-btn"> + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="changeEditableGrid()" data-test="editable-grid-btn"> Make Grid Editable </button> - <button class="btn btn-outline-secondary btn-xs" click.trigger="closeAllRowDetail()" data-test="collapse-all-btn"> + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="closeAllRowDetail()" data-test="collapse-all-btn"> Close all Row Details </button> <label for="">Detail View Rows Shown: </label> <input type="number" value.bind="detailViewRowCount" style="height: 22px; width: 40px"> - <button class="btn btn-outline-secondary btn-xs" style="height: 26px;" click.trigger="changeDetailViewRowCount()" + <button class="btn btn-outline-secondary btn-xs btn-icon" style="height: 26px;" click.trigger="changeDetailViewRowCount()" data-test="set-count-btn"> Set </button> diff --git a/packages/demo/src/examples/slickgrid/example19.ts b/packages/demo/src/examples/slickgrid/example19.ts index 7cfbe5e30..0f3038f0f 100644 --- a/packages/demo/src/examples/slickgrid/example19.ts +++ b/packages/demo/src/examples/slickgrid/example19.ts @@ -68,7 +68,7 @@ export class Example19 { { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', minWidth: 100, - formatter: Formatters.checkmark, type: FieldType.boolean, + formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, filterable: true, sortable: true, filter: { collection: [{ value: '', label: '' }, { value: true, label: 'True' }, { value: false, label: 'False' }], diff --git a/packages/demo/src/examples/slickgrid/example2.html b/packages/demo/src/examples/slickgrid/example2.html index 923ec813c..1c94594bf 100644 --- a/packages/demo/src/examples/slickgrid/example2.html +++ b/packages/demo/src/examples/slickgrid/example2.html @@ -3,13 +3,13 @@ <h2> <span class="float-end"> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example2.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> <div class="subtitle" innerhtml.bind="subTitle"></div> -<button class="btn btn-outline-secondary btn-sm" click.trigger="togglePauseResizer()"> +<button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="togglePauseResizer()"> Pause auto-resize: <b>${resizerPaused}</b> </button> diff --git a/packages/demo/src/examples/slickgrid/example2.ts b/packages/demo/src/examples/slickgrid/example2.ts index 6f5913032..ac2e62777 100644 --- a/packages/demo/src/examples/slickgrid/example2.ts +++ b/packages/demo/src/examples/slickgrid/example2.ts @@ -23,13 +23,13 @@ interface DataItem { // create my custom Formatter with the Formatter type const myCustomCheckmarkFormatter: Formatter<DataItem> = (_row, _cell, value) => { // you can return a string of a object (of type FormatterResultObject), the 2 types are shown below - return value ? `<i class="fa fa-fire red" aria-hidden="true"></i>` : { text: '<i class="fa fa-snowflake-o" aria-hidden="true"></i>', addClasses: 'lightblue', toolTip: 'Freezing' }; + return value ? `<i class="mdi mdi-fire red" aria-hidden="true"></i>` : { text: '<i class="mdi mdi-snowflake" aria-hidden="true"></i>', addClasses: 'lightblue', toolTip: 'Freezing' }; }; const customEnableButtonFormatter: Formatter<DataItem> = (_row: number, _cell: number, value: any) => { return `<span style="margin-left: 5px"> - <button class="btn btn-xs btn-default"> - <i class="fa ${value ? 'fa-check-circle' : 'fa-circle-thin'} fa-lg" style="color: ${value ? 'black' : 'lavender'}"></i> + <button class="btn btn-xs btn-default btn-icon"> + <i class="mdi ${value ? 'mdi-check-circle' : 'mdi-circle'}" style="color: ${value ? 'black' : 'lavender'}"></i> </button> </span>`; }; diff --git a/packages/demo/src/examples/slickgrid/example20.html b/packages/demo/src/examples/slickgrid/example20.html index 1c2e1ed85..5a3f9b29c 100644 --- a/packages/demo/src/examples/slickgrid/example20.html +++ b/packages/demo/src/examples/slickgrid/example20.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example20.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -19,7 +19,7 @@ <h2> <label for="">Pinned Rows: </label> <input type="number" value.bind="frozenRowCount"> - <button class="btn btn-outline-secondary btn-xs" + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="changeFrozenRowCount()"> Set </button> @@ -28,7 +28,7 @@ <h2> <label for="">Pinned Columns: </label> <input type="number" value.bind="frozenColumnCount"> - <button class="btn btn-outline-secondary btn-xs" + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="changeFrozenColumnCount()"> Set </button> @@ -38,17 +38,17 @@ <h2> <div class="row mt-2"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="setFrozenColumns(-1)" + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="setFrozenColumns(-1)" data-test="remove-frozen-column-button"> - <i class="fa fa-times fa-lg"></i> Remove Frozen Columns + <i class="mdi mdi-close"></i> Remove Frozen Columns </button> - <button class="btn btn-outline-secondary btn-sm" click.trigger="setFrozenColumns(2)" + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="setFrozenColumns(2)" data-test="set-3frozen-columns"> - <i class="fa fa-thumb-tack fa-lg"></i> Set 3 Frozen Columns + <i class="mdi mdi-pin-outline"></i> Set 3 Frozen Columns </button> <span style="margin-left: 15px"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="toggleFrozenBottomRows()"> - <i class="fa fa-random fa-lg"></i> Toggle Pinned Rows + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="toggleFrozenBottomRows()"> + <i class="mdi mdi-flip-vertical"></i> Toggle Pinned Rows </button> <span style="font-weight: bold;">: ${ isFrozenBottom ? 'Bottom' : 'Top' }</span> </span> diff --git a/packages/demo/src/examples/slickgrid/example20.ts b/packages/demo/src/examples/slickgrid/example20.ts index 36db0914c..e1612780d 100644 --- a/packages/demo/src/examples/slickgrid/example20.ts +++ b/packages/demo/src/examples/slickgrid/example20.ts @@ -182,7 +182,7 @@ export class Example20 { { id: 'effortDriven', name: 'Effort Driven', field: 'effortDriven', minWidth: 100, width: 120, - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, filterable: true, filter: { collection: [{ value: '', label: '' }, { value: true, label: 'True' }, { value: false, label: 'False' }], diff --git a/packages/demo/src/examples/slickgrid/example21.html b/packages/demo/src/examples/slickgrid/example21.html index 0ea8768cc..d136bafe7 100644 --- a/packages/demo/src/examples/slickgrid/example21.html +++ b/packages/demo/src/examples/slickgrid/example21.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example21.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -44,7 +44,7 @@ <h2> value.bind="searchValue" /> <button class="btn btn-outline-secondary d-flex align-items-center pl-2 pr-2" data-test="clear-search-value" click.trigger="clearGridSearchInput()"> - <span class="fa fa-times"></span> + <span class="mdi mdi-close"></span> </button> </div> </div> diff --git a/packages/demo/src/examples/slickgrid/example21.ts b/packages/demo/src/examples/slickgrid/example21.ts index d6adb73eb..3a991d35f 100644 --- a/packages/demo/src/examples/slickgrid/example21.ts +++ b/packages/demo/src/examples/slickgrid/example21.ts @@ -74,7 +74,7 @@ export class Example21 { { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', width: 100, sortable: true, - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, type: FieldType.number } ]; diff --git a/packages/demo/src/examples/slickgrid/example22.html b/packages/demo/src/examples/slickgrid/example22.html index 9db8f9b0c..0f4c80355 100644 --- a/packages/demo/src/examples/slickgrid/example22.html +++ b/packages/demo/src/examples/slickgrid/example22.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example22.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> diff --git a/packages/demo/src/examples/slickgrid/example23.html b/packages/demo/src/examples/slickgrid/example23.html index 9fb3ddac2..89294c1a0 100644 --- a/packages/demo/src/examples/slickgrid/example23.html +++ b/packages/demo/src/examples/slickgrid/example23.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example23.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -19,25 +19,25 @@ <h2> <div class="row row-cols-lg-auto g-1 align-items-center"> <div class="col"> - <button class="btn btn-outline-secondary btn-sm" data-test="clear-filters" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="clear-filters" click.trigger="aureliaGrid.filterService.clearFilters()"> Clear Filters </button> </div> <div class="col"> - <button class="btn btn-outline-secondary btn-sm" data-test="clear-sorting" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="clear-sorting" click.trigger="aureliaGrid.sortService.clearSorting()"> Clear Sorting </button> </div> <div class="col"> - <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-filter" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-filter" click.trigger="setFiltersDynamically()"> Set Filters Dynamically </button> </div> <div class="col"> - <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-sorting" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-sorting" click.trigger="setSortingDynamically()"> Set Sorting Dynamically </button> @@ -55,8 +55,8 @@ <h2> <div class="row mt-2"> <div class="col"> - <button class="btn btn-outline-secondary btn-sm" data-test="language" click.trigger="switchLanguage()"> - <i class="fa fa-language"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="language" click.trigger="switchLanguage()"> + <i class="mdi mdi-translate"></i> Switch Language </button> <b>Locale:</b> <span style="font-style: italic" data-test="selected-locale">${selectedLanguage + '.json'}</span> diff --git a/packages/demo/src/examples/slickgrid/example23.ts b/packages/demo/src/examples/slickgrid/example23.ts index 25f733ba9..59581dd24 100644 --- a/packages/demo/src/examples/slickgrid/example23.ts +++ b/packages/demo/src/examples/slickgrid/example23.ts @@ -1,6 +1,7 @@ import { I18N } from '@aurelia/i18n'; // import { TOptions as I18NOptions } from 'i18next'; import moment from 'moment-mini'; +import { type MultipleSelectOption } from 'multiple-select-vanilla'; import { SlickCustomTooltip } from '@slickgrid-universal/custom-tooltip-plugin'; import { ExcelExportService } from '@slickgrid-universal/excel-export'; @@ -16,7 +17,6 @@ import { type GridOption, type GridStateChange, type Metrics, - type MultipleSelectOption, OperatorType, type SlickGrid, type SliderRangeOption, @@ -142,7 +142,7 @@ export class Example23 { }, { id: 'completed', name: 'Completed', field: 'completed', nameKey: 'COMPLETED', minWidth: 85, maxWidth: 90, - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, exportWithFormatter: true, // you can set this property in the column definition OR in the grid options, column def has priority over grid options filterable: true, filter: { diff --git a/packages/demo/src/examples/slickgrid/example24.html b/packages/demo/src/examples/slickgrid/example24.html index 89faf390e..934d4d9a9 100644 --- a/packages/demo/src/examples/slickgrid/example24.html +++ b/packages/demo/src/examples/slickgrid/example24.html @@ -1,13 +1,13 @@ <h2> ${title} - <button class="btn btn-outline-secondary btn-sm ms-2" click.trigger="toggleDarkMode()" data-test="toggle-dark-mode"> + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="toggleDarkMode()" data-test="toggle-dark-mode"> <span>Toggle Dark Mode</span> </button> <span class="float-end"> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example24.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -16,11 +16,11 @@ <h2> <div class="row"> <span class="context-menu"> <strong>Context Menu:</strong> - <button class="btn btn-outline-secondary btn-xs" click.trigger="showContextCommandsAndOptions(false)" + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="showContextCommandsAndOptions(false)" data-test="context-menu-priority-only-button"> Show Priority Options Only </button> - <button class="btn btn-outline-secondary btn-xs" click.trigger="showContextCommandsAndOptions(true)" + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="showContextCommandsAndOptions(true)" data-test="context-menu-commands-and-priority-button"> Show Commands & Priority Options </button> @@ -28,11 +28,11 @@ <h2> <span class="cell-menu"> <strong>Cell Menu:</strong> - <button class="btn btn-outline-secondary btn-xs" click.trigger="showCellMenuCommandsAndOptions(false)" + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="showCellMenuCommandsAndOptions(false)" data-test="cell-menu-commands-and-options-false-button"> Show Action Commands Only </button> - <button class="btn btn-outline-secondary btn-xs" click.trigger="showCellMenuCommandsAndOptions(true)" + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="showCellMenuCommandsAndOptions(true)" data-test="cell-menu-commands-and-options-true-button"> Show Actions Commands & Completed Options </button> @@ -41,8 +41,8 @@ <h2> <div class="row locale"> <div class="col-12"> - <button class="btn btn-outline-secondary btn-xs" click.trigger="switchLanguage()" data-test="language-button"> - <i class="fa fa-language"></i> + <button class="btn btn-outline-secondary btn-xs btn-icon" click.trigger="switchLanguage()" data-test="language-button"> + <i class="mdi mdi-translate"></i> Switch Language </button> <label>Locale:</label> diff --git a/packages/demo/src/examples/slickgrid/example24.ts b/packages/demo/src/examples/slickgrid/example24.ts index 736a9ac6c..7dfa0b198 100644 --- a/packages/demo/src/examples/slickgrid/example24.ts +++ b/packages/demo/src/examples/slickgrid/example24.ts @@ -19,9 +19,9 @@ import { resolve } from 'aurelia'; const actionFormatter: Formatter = (_row, _cell, _value, _columnDef, dataContext) => { if (dataContext.priority === 3) { // option 3 is High - return `<div class="fake-hyperlink">Action <i class="fa fa-caret-down"></i></div>`; + return `<div class="fake-hyperlink">Action <i class="mdi mdi-chevron-down"></i></div>`; } - return `<div class="disabled">Action <i class="fa fa-caret-down"></i></div>`; + return `<div class="disabled">Action <i class="mdi mdi-chevron-down"></i></div>`; }; const priorityFormatter: Formatter = (_row, _cell, value) => { @@ -31,7 +31,7 @@ const priorityFormatter: Formatter = (_row, _cell, value) => { let output = ''; const count = +(value >= 3 ? 3 : value); const color = count === 3 ? 'red' : (count === 2 ? 'orange' : 'yellow'); - const icon = `<i class="fa fa-star ${color}" aria-hidden="true"></i>`; + const icon = `<i class="mdi mdi-star ${color}" aria-hidden="true"></i>`; for (let i = 1; i <= count; i++) { output += icon; @@ -160,7 +160,7 @@ export class Example24 { { id: 'completed', nameKey: 'COMPLETED', field: 'completed', exportCustomFormatter: Formatters.translateBoolean, - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, sortable: true, filterable: true, filter: { collection: [{ value: '', label: '' }, { value: true, labelKey: 'TRUE' }, { value: false, labelKey: 'FALSE' }], @@ -204,7 +204,7 @@ export class Example24 { { command: 'command1', title: 'Command 1', cssClass: 'orange', positionOrder: 61 }, { command: 'delete-row', titleKey: 'DELETE_ROW', positionOrder: 64, - iconCssClass: 'fa fa-times', cssClass: 'red', textCssClass: 'bold', + iconCssClass: 'mdi mdi-close', cssClass: 'red', textCssClass: 'bold', // only show command to 'Delete Row' when the task is not completed itemVisibilityOverride: (args) => { return !args.dataContext.completed; @@ -218,7 +218,7 @@ export class Example24 { { command: 'help', titleKey: 'HELP', // use "title" without translation and "titleKey" with TranslateService - iconCssClass: 'fa fa-question-circle', + iconCssClass: 'mdi mdi-help-circle', positionOrder: 66, }, { command: 'something', titleKey: 'DISABLED_COMMAND', disabled: true, positionOrder: 67, }, @@ -255,8 +255,8 @@ export class Example24 { ], optionTitleKey: 'CHANGE_COMPLETED_FLAG', optionItems: [ - { option: true, titleKey: 'TRUE', iconCssClass: 'fa fa-check-square-o' }, - { option: false, titleKey: 'FALSE', iconCssClass: 'fa fa-square-o' }, + { option: true, titleKey: 'TRUE', iconCssClass: 'mdi mdi-check-box-outline' }, + { option: false, titleKey: 'FALSE', iconCssClass: 'mdi mdi-checkbox-blank-outline' }, { option: null, title: 'null', cssClass: 'italic', // you can use the "action" callback and/or use "onCallback" callback from the grid options, they both have the same arguments @@ -394,13 +394,13 @@ export class Example24 { commandTitleKey: 'COMMANDS', // this title is optional, you could also use "commandTitle" when not using I18N commandItems: [ { divider: true, command: '', positionOrder: 61 }, - { command: 'delete-row', titleKey: 'DELETE_ROW', iconCssClass: 'fa fa-times', cssClass: 'red', textCssClass: 'bold', positionOrder: 62 }, + { command: 'delete-row', titleKey: 'DELETE_ROW', iconCssClass: 'mdi mdi-close', cssClass: 'red', textCssClass: 'bold', positionOrder: 62 }, // you can pass divider as a string or an object with a boolean (if sorting by position, then use the object) // note you should use the "divider" string only when items array is already sorted and positionOrder are not specified // 'divider', { divider: true, command: '', positionOrder: 63 }, { - command: 'help', titleKey: 'HELP', iconCssClass: 'fa fa-question-circle', positionOrder: 64, + command: 'help', titleKey: 'HELP', iconCssClass: 'mdi mdi-help-circle', positionOrder: 64, // you can use the 'action' callback and/or subscribe to the 'onCallback' event, they both have the same arguments action: () => { // action callback.. do something @@ -462,15 +462,15 @@ export class Example24 { // action callback.. do something }, }, - { option: 1, iconCssClass: 'fa fa-star-o yellow', titleKey: 'LOW' }, - { option: 2, iconCssClass: 'fa fa-star-half-o orange', titleKey: 'MEDIUM' }, - { option: 3, iconCssClass: 'fa fa-star red', titleKey: 'HIGH' }, + { option: 1, iconCssClass: 'mdi mdi-star-outline yellow', titleKey: 'LOW' }, + { option: 2, iconCssClass: 'mdi mdi-star orange', titleKey: 'MEDIUM' }, + { option: 3, iconCssClass: 'mdi mdi-star red', titleKey: 'HIGH' }, // you can pass divider as a string or an object with a boolean (if sorting by position, then use the object) // note you should use the "divider" string only when items array is already sorted and positionOrder are not specified 'divider', // { divider: true, option: '', positionOrder: 3 }, { - option: 4, title: 'Extreme', iconCssClass: 'fa fa-fire', disabled: true, + option: 4, title: 'Extreme', iconCssClass: 'mdi mdi-fire', disabled: true, // only shown when the task is Not Completed itemVisibilityOverride: (args) => { const dataContext = args && args.dataContext; @@ -480,9 +480,9 @@ export class Example24 { { // we can also have multiple nested sub-menus option: null, title: 'Sub-Options (demo)', subMenuTitleKey: 'CHANGE_PRIORITY', optionItems: [ - { option: 1, iconCssClass: 'fa fa-star-o yellow', titleKey: 'LOW' }, - { option: 2, iconCssClass: 'fa fa-star-half-o orange', titleKey: 'MEDIUM' }, - { option: 3, iconCssClass: 'fa fa-star red', titleKey: 'HIGH' }, + { option: 1, iconCssClass: 'mdi mdi-star-outline yellow', titleKey: 'LOW' }, + { option: 2, iconCssClass: 'mdi mdi-star orange', titleKey: 'MEDIUM' }, + { option: 3, iconCssClass: 'mdi mdi-star red', titleKey: 'HIGH' }, ] } ], diff --git a/packages/demo/src/examples/slickgrid/example25.html b/packages/demo/src/examples/slickgrid/example25.html index 3381274da..f38c3257b 100644 --- a/packages/demo/src/examples/slickgrid/example25.html +++ b/packages/demo/src/examples/slickgrid/example25.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example25.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -15,7 +15,7 @@ <h2> <div class.bind="status.class" role="alert" data-test="status"> <strong>Status: </strong> ${status.text} <span hidden.bind="!processing"> - <i class="fa fa-refresh fa-spin fa-lg fa-fw"></i> + <i class="mdi mdi-sync mdi-spin"></i> </span> </div> </div> diff --git a/packages/demo/src/examples/slickgrid/example25.ts b/packages/demo/src/examples/slickgrid/example25.ts index 67d4d56ce..8f19a05c4 100644 --- a/packages/demo/src/examples/slickgrid/example25.ts +++ b/packages/demo/src/examples/slickgrid/example25.ts @@ -1,6 +1,7 @@ import { IHttpClient, json } from '@aurelia/fetch-client'; import { newInstanceOf, resolve } from '@aurelia/kernel'; import { GraphqlService, type GraphqlResult, type GraphqlServiceApi, } from '@slickgrid-universal/graphql'; +import { type MultipleSelectOption } from 'multiple-select-vanilla'; import { type AureliaGridInstance, type Column, @@ -8,7 +9,6 @@ import { Formatters, type GridOption, type Metrics, - type MultipleSelectOption, OperatorType, } from 'aurelia-slickgrid'; import './example25.scss'; // provide custom CSS/SASS styling diff --git a/packages/demo/src/examples/slickgrid/example26.html b/packages/demo/src/examples/slickgrid/example26.html index f4ac0d5ab..15ddef4e6 100644 --- a/packages/demo/src/examples/slickgrid/example26.html +++ b/packages/demo/src/examples/slickgrid/example26.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example26.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -30,8 +30,8 @@ <h2> </div> <div class="row"> <div class="col"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="undo()"> - <i class="fa fa-undo"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="undo()"> + <i class="mdi mdi-undo"></i> Undo last edit(s) </button> <label class="checkbox-inline control-label" for="autoCommitEdit"> @@ -44,9 +44,9 @@ <h2> </span> <div class="row" style="margin-top: 5px"> <div class="col"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="aureliaGrid.filterService.clearFilters()">Clear + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="aureliaGrid.filterService.clearFilters()">Clear Filters</button> - <button class="btn btn-outline-secondary btn-sm" click.trigger="aureliaGrid.sortService.clearSorting()">Clear + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="aureliaGrid.sortService.clearSorting()">Clear Sorting</button> </div> </div> diff --git a/packages/demo/src/examples/slickgrid/example26.ts b/packages/demo/src/examples/slickgrid/example26.ts index 473d4a711..734864694 100644 --- a/packages/demo/src/examples/slickgrid/example26.ts +++ b/packages/demo/src/examples/slickgrid/example26.ts @@ -194,7 +194,7 @@ export class Example26 { editor: { // We can also add HTML text to be rendered (any bad script will be sanitized) but we have to opt-in, else it will be sanitized enableRenderHtml: true, - collection: Array.from(Array(101).keys()).map(k => ({ value: k, label: k, symbol: '<i class="fa fa-percent" style="color:cadetblue"></i>' })), + collection: Array.from(Array(101).keys()).map(k => ({ value: k, label: k, symbol: '<i class="mdi mdi-percent-outline" style="color:cadetblue"></i>' })), customStructure: { value: 'value', label: 'label', diff --git a/packages/demo/src/examples/slickgrid/example27.html b/packages/demo/src/examples/slickgrid/example27.html index df668a482..b008bed50 100644 --- a/packages/demo/src/examples/slickgrid/example27.html +++ b/packages/demo/src/examples/slickgrid/example27.html @@ -12,28 +12,28 @@ <h2> <div class="row" style="margin-bottom: 4px;"> <div class="col-md-12"> - <button class="btn btn-outline-secondary btn-sm" data-test="add-500-rows-btn" click.trigger="loadData(500)"> + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="add-500-rows-btn" click.trigger="loadData(500)"> 500 rows </button> - <button class="btn btn-outline-secondary btn-sm" data-test="add-50k-rows-btn" click.trigger="loadData(25000)"> + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="add-50k-rows-btn" click.trigger="loadData(25000)"> 25k rows </button> - <button click.trigger="dynamicallyChangeFilter()" class="btn btn-outline-secondary btn-sm" + <button click.trigger="dynamicallyChangeFilter()" class="btn btn-outline-secondary btn-sm btn-icon" data-test="change-filter-dynamically"> <span class="mdi mdi-filter-outline"></span> <span>Dynamically Change Filter (% complete < 40)</span> </button> - <button click.trigger="collapseAllWithoutEvent()" class="btn btn-outline-secondary btn-sm" + <button click.trigger="collapseAllWithoutEvent()" class="btn btn-outline-secondary btn-sm btn-icon" data-test="collapse-all-noevent-btn"> <span class="mdi mdi-arrow-collapse"></span> <span>Collapse All (without triggering event)</span> </button> - <button click.trigger="dynamicallyToggledFirstParent()" class="btn btn-outline-secondary btn-sm" + <button click.trigger="dynamicallyToggledFirstParent()" class="btn btn-outline-secondary btn-sm btn-icon" data-test="dynamically-toggle-first-parent-btn"> <span>Dynamically Toggle First Parent</span> </button> <button click.trigger="reapplyToggledItems()" data-test="reapply-toggled-items-btn" - class="btn btn-outline-secondary btn-sm" + class="btn btn-outline-secondary btn-sm btn-icon" disabled.bind="hasNoExpandCollapseChanged"> <span class="mdi mdi-history"></span> <span>Reapply Previous Toggled Items</span> @@ -44,27 +44,27 @@ <h2> <div class="row"> <div class="col-md-12"> - <button click.trigger="addNewRow()" data-test="add-item-btn" class="btn btn-primary btn-sm"> + <button click.trigger="addNewRow()" data-test="add-item-btn" class="btn btn-primary btn-sm btn-icon"> <span class="mdi mdi-plus color-white"></span> <span>Add New Item (in 1st group)</span> </button> - <button click.trigger="updateFirstRow()" data-test="update-item-btn" class="btn btn-outline-secondary btn-sm"> + <button click.trigger="updateFirstRow()" data-test="update-item-btn" class="btn btn-outline-secondary btn-sm btn-icon"> <span class="icon mdi mdi-pencil"></span> <span>Update 1st Row Item</span> </button> - <button click.trigger="collapseAll()" data-test="collapse-all-btn" class="btn btn-outline-secondary btn-sm"> + <button click.trigger="collapseAll()" data-test="collapse-all-btn" class="btn btn-outline-secondary btn-sm btn-icon"> <span class="mdi mdi-arrow-collapse"></span> <span>Collapse All</span> </button> - <button click.trigger="expandAll()" data-test="expand-all-btn" class="btn btn-outline-secondary btn-sm"> + <button click.trigger="expandAll()" data-test="expand-all-btn" class="btn btn-outline-secondary btn-sm btn-icon"> <span class="mdi mdi-arrow-expand"></span> <span>Expand All</span> </button> - <button click.trigger="logFlatStructure()" class="btn btn-outline-secondary btn-sm" + <button click.trigger="logFlatStructure()" class="btn btn-outline-secondary btn-sm btn-icon" title="console.log of the Flat dataset"> <span>Log Flat Structure</span> </button> - <button click.trigger="logHierarchicalStructure()" class="btn btn-outline-secondary btn-sm" + <button click.trigger="logHierarchicalStructure()" class="btn btn-outline-secondary btn-sm btn-icon" title="console.log of the Hierarchical Tree dataset"> <span>Log Hierarchical Structure</span> </button> diff --git a/packages/demo/src/examples/slickgrid/example27.scss b/packages/demo/src/examples/slickgrid/example27.scss index 146545e90..e8c1de9f8 100644 --- a/packages/demo/src/examples/slickgrid/example27.scss +++ b/packages/demo/src/examples/slickgrid/example27.scss @@ -1,10 +1,10 @@ /* make sure to add the @import the SlickGrid Theme AFTER the variables changes */ -@import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-material.lite.scss'; +// @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-material.lite.scss'; -.icon { - align-items: center; +#grid27 { + .slick-cell { display: inline-flex; - justify-content: center; - height: 1.5rem; - width: 1.5rem; + align-items: center; + gap: 4px; + } } diff --git a/packages/demo/src/examples/slickgrid/example27.ts b/packages/demo/src/examples/slickgrid/example27.ts index 9a19c251e..b4840b1ee 100644 --- a/packages/demo/src/examples/slickgrid/example27.ts +++ b/packages/demo/src/examples/slickgrid/example27.ts @@ -14,12 +14,6 @@ export class Example27 { <li>If you do not have the Tree Level (indent), you could call "convertParentChildArrayToHierarchicalView()" then call "convertHierarchicalViewToParentChildArray()"</li> <li>You could also pass the result of "convertParentChildArrayToHierarchicalView()" to "dataset-hierarchical.bind" as defined in the next Hierarchical Example</li> </ul> - <li><b>Styling - Material Theme</b></li> - <ul> - <li>The Material Theme was created with SASS and compiled in CSS (<a href="https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/styles/slickgrid-theme-material.scss" target="_blank">slickgrid-theme-material.scss</a>), you can override any of its SASS variables</li> - <li>We use a small subset of <a href="https://materialdesignicons.com/" target="_blank">Material Design Icons</a></li> - <li>you might need to refresh the page to clear the browser cache and see the correct theme</li> - </ul> </ul>`; aureliaGrid!: AureliaGridInstance; gridOptions!: GridOption; @@ -73,7 +67,7 @@ export class Example27 { { id: 'effortDriven', name: 'Effort Driven', width: 80, minWidth: 20, maxWidth: 80, cssClass: 'cell-effort-driven', field: 'effortDriven', exportWithFormatter: false, - formatter: Formatters.checkmark, cannotTriggerInsert: true, + formatter: Formatters.checkmarkMaterial, cannotTriggerInsert: true, filterable: true, filter: { collection: [{ value: '', label: '' }, { value: true, label: 'True' }, { value: false, label: 'False' }], diff --git a/packages/demo/src/examples/slickgrid/example28.html b/packages/demo/src/examples/slickgrid/example28.html index 6fcc835f3..d5dceecb5 100644 --- a/packages/demo/src/examples/slickgrid/example28.html +++ b/packages/demo/src/examples/slickgrid/example28.html @@ -16,27 +16,27 @@ <h2> <span class="mdi mdi-plus color-white"></span> <span>Add New Pop Song</span> </button> - <button click.trigger="deleteFile()" data-test="remove-item-btn" class="btn btn-outline-secondary btn-sm" disabled.bind="isRemoveLastInsertedPopSongDisabled"> + <button click.trigger="deleteFile()" data-test="remove-item-btn" class="btn btn-outline-secondary btn-sm btn-icon" disabled.bind="isRemoveLastInsertedPopSongDisabled"> <span class="mdi mdi-minus"></span> <span>Remove Last Inserted Pop Song</span> </button> - <button click.trigger="collapseAll()" data-test="collapse-all-btn" class="btn btn-outline-secondary btn-sm"> + <button click.trigger="collapseAll()" data-test="collapse-all-btn" class="btn btn-outline-secondary btn-sm btn-icon"> <span class="mdi mdi-arrow-collapse"></span> <span>Collapse All</span> </button> - <button click.trigger="expandAll()" data-test="expand-all-btn" class="btn btn-outline-secondary btn-sm"> + <button click.trigger="expandAll()" data-test="expand-all-btn" class="btn btn-outline-secondary btn-sm btn-icon"> <span class="mdi mdi-arrow-expand"></span> <span>Expand All</span> </button> - <button class="btn btn-outline-secondary btn-sm" data-test="clear-filters-btn" click.trigger="clearFilters()"> + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="clear-filters-btn" click.trigger="clearFilters()"> <span class="mdi mdi-close"></span> <span>Clear Filters</span> </button> - <button click.trigger="logFlatStructure()" class="btn btn-outline-secondary btn-sm" + <button click.trigger="logFlatStructure()" class="btn btn-outline-secondary btn-sm btn-icon" title="console.log of the Flat dataset"> <span>Log Flat Structure</span> </button> - <button click.trigger="logHierarchicalStructure()" class="btn btn-outline-secondary btn-sm" + <button click.trigger="logHierarchicalStructure()" class="btn btn-outline-secondary btn-sm btn-icon" title="console.log of the Hierarchical Tree dataset"> <span>Log Hierarchical Structure</span> </button> diff --git a/packages/demo/src/examples/slickgrid/example28.scss b/packages/demo/src/examples/slickgrid/example28.scss index 82e711cc3..d6aeedff2 100644 --- a/packages/demo/src/examples/slickgrid/example28.scss +++ b/packages/demo/src/examples/slickgrid/example28.scss @@ -1,61 +1,54 @@ -/* make sure to add the @import the SlickGrid Theme AFTER the variables changes */ -@import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-salesforce.lite.scss'; +// @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-salesforce.scss'; -.avg-total { - color: #ac76ff; -} -.bold { - font-weight: bold; -} -.total-suffix { - margin-left: 10px; -} -.hidden { - display: none; -} - -/* - www.OnlineWebFonts.Com - You must credit the author Copy this link on your web - <div>Font made from <a href="http://www.onlinewebfonts.com">oNline Web Fonts</a>is licensed by CC BY 3.0</div> -*/ -@font-face { - font-family: "SalesforceSans-Regular"; - src: url("https://db.onlinewebfonts.com/t/0fadaa21fcac88ceee0bb8da992c221b.eot"); /* IE9*/ - src: url("https://db.onlinewebfonts.com/t/0fadaa21fcac88ceee0bb8da992c221b.eot?#iefix") format("embedded-opentype"), /* IE6-IE8 */ - url("https://db.onlinewebfonts.com/t/0fadaa21fcac88ceee0bb8da992c221b.woff2") format("woff2"), /* chrome firefox */ - url("https://db.onlinewebfonts.com/t/0fadaa21fcac88ceee0bb8da992c221b.woff") format("woff"), /* chrome firefox */ - url("https://db.onlinewebfonts.com/t/0fadaa21fcac88ceee0bb8da992c221b.ttf") format("truetype"), /* chrome firefox opera Safari, Android, iOS 4.2+*/ - url("https://db.onlinewebfonts.com/t/0fadaa21fcac88ceee0bb8da992c221b.svg#SalesforceSans-Regular") format("svg"); /* iOS 4.1- */ -} - -.icon { - align-items: center; +#grid28 { + .slick-cell { display: inline-flex; - justify-content: center; - height: 1.5rem; - width: 1.5rem; -} + align-items: center; + gap: 4px; + } -/** You can use the following code OR use the .color-x CSS classes */ + .avg-total { + color: #ac76ff; + } + .bold { + font-weight: bold; + } + .total-suffix { + margin-left: 10px; + } + .hidden { + display: none; + } -// .icon.mdi-file-pdf-outline { -// /** 1. use `filter` color */ -// // filter: invert(62%) sepia(93%) saturate(5654%) hue-rotate(325deg) brightness(100%) contrast(90%); + .mdi-file-pdf-outline { + color: #f14668; + opacity: 0.9; + } -// /** 2. or use the SASS @mixin (from Aurelia-Slickgrid "sass-utilities.scss") that will produce the `filter` color */ -// @include recolor(#f14668, 0.9); -// } + .mdi-folder, .mdi-folder-open { + color: #ffa500; + opacity: 0.9; + } + .mdi-file-music-outline { + color: #3298dc; + opacity: 0.9; + } + .mdi-file-excel-outline { + color: #1E9F75; + opacity: 0.9; + } + .mdi-file-document-outline, + .mdi-file-question-outline { + color: #686868; + opacity: 0.9; + } -// .icon.mdi-folder, .icon.mdi-folder-open { -// @include recolor(#ffa500, 0.9); -// } -// .icon.mdi-file-music-outline { -// @include recolor(#3298dc, 0.9); -// } -// .icon.mdi-file-excel-outline { -// @include recolor(#1E9F75, 0.9); -// } -// .icon.mdi-file-document-outline { -// @include recolor(#686868, 0.9); -// } + .display-inline-block { + display: inline-block; + } +} + +// create a few 15px indentation multiplied by level number +@for $i from 1 through 6 { + .width-#{$i*15}px { width: #{$i * 15}px; } +} diff --git a/packages/demo/src/examples/slickgrid/example28.ts b/packages/demo/src/examples/slickgrid/example28.ts index 0609c3f53..918aabedd 100644 --- a/packages/demo/src/examples/slickgrid/example28.ts +++ b/packages/demo/src/examples/slickgrid/example28.ts @@ -20,15 +20,12 @@ import './example28.scss'; // provide custom CSS/SASS styling export class Example28 { title = 'Example 28: Tree Data with Aggregators <small> <span class="mdi mdi-file-tree mdi-27px"></span> (from a Hierarchical Dataset - <a href="https://ghiscoding.gitbook.io/aurelia-slickgrid/grid-functionalities/tree-data-grid" target="_blank">Wiki</a>)</small>'; subTitle = `<ul> - <li><b>NOTE #1:</b> The grid will automatically sort Ascending with the column that has the Tree Data, you could add a "sortByFieldId" in your column "treeData" option if you wish to sort on a different column</li> - <li><b>NOTE #2:</b> Tree Totals are only calculated once and are <b>NOT</b> recalculated while filtering data, if you do want that feature then you will need to enable <code>autoRecalcTotalsOnFilterChange</code> <i>(see checkbox below)</i></li> - <li><b>Styling - Salesforce Theme</b></li> + <li>It is assumed that your dataset will have Parent/Child references AND also Tree Level (indent) property.</li> <ul> - <li>The Salesforce Theme was created with SASS and compiled in CSS (<a href="https://github.com/ghiscoding/slickgrid-universal/blob/master/packages/common/src/styles/slickgrid-theme-salesforce.scss" target="_blank">slickgrid-theme-salesforce.scss</a>), you can override any of its SASS variables</li> - <li>We use a small subset of <a href="https://materialdesignicons.com/" target="_blank">Material Design Icons</a></li> - <li>you might need to refresh the page to clear the browser cache and see the correct theme</li> + <li>If you do not have the Tree Level (indent), you could call "convertParentChildArrayToHierarchicalView()" then call "convertHierarchicalViewToParentChildArray()"</li> + <li>You could also pass the result of "convertParentChildArrayToHierarchicalView()" to "dataset-hierarchical.bind" as defined in the next Hierarchical Example</li> </ul> - `; + </ul>`; aureliaGrid!: AureliaGridInstance; gridOptions!: GridOption; columnDefinitions: Column[] = []; @@ -164,34 +161,6 @@ export class Example28 { // we can also preset collapsed items via Grid Presets (parentId: 4 => is the "pdf" folder) presets: { treeData: { toggledItems: [{ itemId: 4, isCollapsed: true }] }, - }, - // use Material Design SVG icons - contextMenu: { - iconCollapseAllGroupsCommand: 'mdi mdi-arrow-collapse', - iconExpandAllGroupsCommand: 'mdi mdi-arrow-expand', - iconClearGroupingCommand: 'mdi mdi-close', - iconCopyCellValueCommand: 'mdi mdi-content-copy', - iconExportCsvCommand: 'mdi mdi-download', - iconExportExcelCommand: 'mdi mdi-file-excel-outline', - iconExportTextDelimitedCommand: 'mdi mdi-download', - }, - gridMenu: { - iconCssClass: 'mdi mdi-menu', - iconClearAllFiltersCommand: 'mdi mdi-filter-remove-outline', - iconClearAllSortingCommand: 'mdi mdi-swap-vertical', - iconExportCsvCommand: 'mdi mdi-download', - iconExportExcelCommand: 'mdi mdi-file-excel-outline', - iconExportTextDelimitedCommand: 'mdi mdi-download', - iconRefreshDatasetCommand: 'mdi mdi-sync', - iconToggleFilterCommand: 'mdi mdi-flip-vertical', - iconTogglePreHeaderCommand: 'mdi mdi-flip-vertical', - }, - headerMenu: { - iconClearFilterCommand: 'mdi mdi mdi-filter-remove-outline', - iconClearSortCommand: 'mdi mdi-swap-vertical', - iconSortAscCommand: 'mdi mdi-sort-ascending', - iconSortDescCommand: 'mdi mdi-flip-v mdi-sort-descending', - iconColumnHideCommand: 'mdi mdi-close', } }; } diff --git a/packages/demo/src/examples/slickgrid/example29.html b/packages/demo/src/examples/slickgrid/example29.html index 0be030d7b..d40dfe2cb 100644 --- a/packages/demo/src/examples/slickgrid/example29.html +++ b/packages/demo/src/examples/slickgrid/example29.html @@ -5,7 +5,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example29.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> diff --git a/packages/demo/src/examples/slickgrid/example3.html b/packages/demo/src/examples/slickgrid/example3.html index 501bedd24..1549c9b42 100644 --- a/packages/demo/src/examples/slickgrid/example3.html +++ b/packages/demo/src/examples/slickgrid/example3.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example3.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -40,8 +40,8 @@ <h2> </div> <div class="row col-sm-12"> <span> - <button class="btn btn-outline-secondary btn-sm" click.trigger="undo()" data-test="undo-btn"> - <i class="fa fa-undo"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="undo()" data-test="undo-btn"> + <i class="mdi mdi-undo"></i> Undo last edit(s) </button> <label class="checkbox-inline control-label" @@ -58,9 +58,9 @@ <h2> </span> <div class="row" style="margin-top: 5px"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="aureliaGrid.filterService.clearFilters()">Clear + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="aureliaGrid.filterService.clearFilters()">Clear Filters</button> - <button class="btn btn-outline-secondary btn-sm" click.trigger="aureliaGrid.sortService.clearSorting()">Clear + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="aureliaGrid.sortService.clearSorting()">Clear Sorting</button> <button class="btn btn-outline-primary btn-sm" data-test="add-item-btn" click.trigger="addItem()" title="Clear Filters & Sorting to see it better"> @@ -72,14 +72,14 @@ <h2> </div> <div class="row" style="margin-top: 5px"> <div class="col-sm-12"> - <button class="btn btn-outline-secondary btn-sm" data-test="add-title-column" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="add-title-column" click.trigger="dynamicallyAddTitleHeader()"> - <i class="fa fa-plus"></i> + <i class="mdi mdi-shape-square-plus"></i> Dynamically Duplicate Title Column </button> - <button class="btn btn-outline-secondary btn-sm" data-test="remove-title-column" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="remove-title-column" click.trigger="dynamicallyRemoveLastColumn()"> - <i class="fa fa-minus"></i> + <i class="mdi mdi-minus"></i> Dynamically Remove Last Column </button> </div> diff --git a/packages/demo/src/examples/slickgrid/example3.ts b/packages/demo/src/examples/slickgrid/example3.ts index ca42d07bf..ff3d8ecf3 100644 --- a/packages/demo/src/examples/slickgrid/example3.ts +++ b/packages/demo/src/examples/slickgrid/example3.ts @@ -100,7 +100,7 @@ export class Example3 { excludeFromGridMenu: true, excludeFromHeaderMenu: true, formatter: Formatters.icon, - params: { iconCssClass: 'fa fa-pencil pointer' }, + params: { iconCssClass: 'mdi mdi-pencil pointer' }, minWidth: 30, maxWidth: 30, // use onCellClick OR grid.onClick.subscribe which you can see down below @@ -117,7 +117,7 @@ export class Example3 { excludeFromGridMenu: true, excludeFromHeaderMenu: true, formatter: Formatters.icon, - params: { iconCssClass: 'fa fa-trash pointer' }, + params: { iconCssClass: 'mdi mdi-trash-can pointer' }, minWidth: 30, maxWidth: 30, // use onCellClick OR grid.onClick.subscribe which you can see down below @@ -170,7 +170,10 @@ export class Example3 { minWidth: 100, sortable: true, type: FieldType.number, - filter: { model: Filters.slider, filterOptions: { hideSliderNumber: false } }, + filter: { + model: Filters.slider, + filterOptions: { hideSliderNumber: false } + }, editor: { model: Editors.slider, minValue: 0, @@ -199,7 +202,7 @@ export class Example3 { editor: { // We can also add HTML text to be rendered (any bad script will be sanitized) but we have to opt-in, else it will be sanitized enableRenderHtml: true, - collection: Array.from(Array(101).keys()).map(k => ({ value: k, label: k, symbol: '<i class="fa fa-percent" style="color:cadetblue"></i>' })), + collection: Array.from(Array(101).keys()).map(k => ({ value: k, label: k, symbol: '<i class="mdi mdi-percent-outline" style="color:cadetblue"></i>' })), customStructure: { value: 'value', label: 'label', @@ -254,7 +257,6 @@ export class Example3 { editor: { model: Editors.date, // override any of the calendar options through "filterOptions" - // please note that there's no TSlint on this property since it's generic for any filter, so make sure you entered the correct filter option(s) editorOptions: { range: { min: 'today' } } as VanillaCalendarOption }, }, { @@ -346,7 +348,7 @@ export class Example3 { model: Filters.singleSelect, collection: [{ value: '', label: '' }, { value: true, label: 'True' }, { value: false, label: 'False' }] }, - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, editor: { model: Editors.checkbox, }, @@ -499,7 +501,7 @@ export class Example3 { // mock a dataset const tempDataset: any[] = []; for (let i = startingIndex; i < (startingIndex + itemCount); i++) { - const randomYear = 2000 + Math.floor(Math.random() * 10); + const randomYear = 2000 + this.randomBetween(4, 15); const randomFinishYear = (new Date().getFullYear() - 3) + Math.floor(Math.random() * 10); // use only years not lower than 3 years ago const randomMonth = Math.floor(Math.random() * 11); const randomDay = Math.floor((Math.random() * 29)); @@ -524,6 +526,10 @@ export class Example3 { return tempDataset; } + randomBetween(min: number, max: number): number { + return Math.floor(Math.random() * (max - min + 1) + min); + } + onCellChanged(_e: Event, args: any) { console.log('onCellChange', args); this.updatedObject = { ...args.item }; diff --git a/packages/demo/src/examples/slickgrid/example30.html b/packages/demo/src/examples/slickgrid/example30.html index 18df2abdf..26593422b 100644 --- a/packages/demo/src/examples/slickgrid/example30.html +++ b/packages/demo/src/examples/slickgrid/example30.html @@ -1,13 +1,13 @@ <h2> ${title} - <button class="btn btn-outline-secondary btn-sm ms-2" click.trigger="toggleDarkMode()" data-test="toggle-dark-mode"> + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="toggleDarkMode()" data-test="toggle-dark-mode"> <span>Toggle Dark Mode</span> </button> <span class="float-end"> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example30.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -15,50 +15,50 @@ <h2> <div class="mb-2"> <div class="btn-group btn-group-sm" role="group" aria-label="Basic Editing Commands"> - <button type="button" class="btn btn-outline-secondary" data-test="toggle-readonly-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="toggle-readonly-btn" click.trigger="toggleGridEditReadonly()"> - <i class="fa fa-table"></i> Toggle Edit/Readonly Grid + <i class="mdi mdi-table-edit"></i> Toggle Edit/Readonly Grid </button> - <button type="button" class="btn btn-outline-secondary" data-test="undo-last-edit-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="undo-last-edit-btn" click.trigger="undoLastEdit()"> - <i class="fa fa-undo"></i> Undo Last Edit + <i class="mdi mdi-undo"></i> Undo Last Edit </button> - <button type="button" class="btn btn-outline-secondary" data-test="undo-open-editor-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="undo-open-editor-btn" click.trigger="undoLastEdit(true)"> - <i class="fa fa-undo"></i> Undo Last Edit & Open Editor + <i class="mdi mdi-undo"></i> Undo Last Edit & Open Editor </button> - <button type="button" class="btn btn-outline-secondary" data-test="undo-all-edits-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="undo-all-edits-btn" click.trigger="undoAllEdits()"> - <i class="fa fa-history"></i> Undo All Edits + <i class="mdi mdi-history"></i> Undo All Edits </button> - <button type="button" class="btn btn-outline-secondary" data-test="save-all-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="save-all-btn" click.trigger="saveAll()"> - <i class="fa fa-save"></i> Save All + <span>Save All</span> </button> </div> </div> <div class="mb-3"> <div class="btn-group btn-group-sm" role="group" aria-label="Basic example"> - <button type="button" class="btn btn-outline-secondary" data-test="open-modal-create-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="open-modal-create-btn" click.trigger="openCompositeModal('create')" disabled.bind="isCompositeDisabled"> - <i class="fa fa-plus"></i> Item Create + <i class="mdi mdi-shape-square-plus"></i> Item Create </button> - <button type="button" class="btn btn-outline-secondary" data-test="open-modal-clone-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="open-modal-clone-btn" click.trigger="openCompositeModal('clone')" disabled.bind="isCompositeDisabled"> - <i class="fa fa-clone"></i> Item Clone + <i class="mdi mdi-content-copy"></i> Item Clone </button> - <button type="button" class="btn btn-outline-secondary" data-test="open-modal-edit-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="open-modal-edit-btn" click.trigger="openCompositeModal('edit')" disabled.bind="isCompositeDisabled"> - <i class="fa fa-pencil"></i> Item Edit + <i class="mdi mdi-pencil"></i> Item Edit </button> - <button type="button" class="btn btn-outline-secondary" data-test="open-modal-mass-update-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="open-modal-mass-update-btn" click.trigger="openCompositeModal('mass-update')" disabled.bind="isCompositeDisabled"> - <i class="fa fa-pencil-square-o"></i> Mass Update + <i class="mdi mdi-pencil-box-multiple-outline"></i> Mass Update </button> - <button type="button" class="btn btn-outline-secondary" data-test="open-modal-mass-selection-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="open-modal-mass-selection-btn" click.trigger="openCompositeModal('mass-selection')" disabled.bind="isMassSelectionDisabled"> - <i class="fa fa-check-square-o"></i> Update Selected + <i class="mdi mdi-check-box-outline"></i> Update Selected </button> </div> </div> diff --git a/packages/demo/src/examples/slickgrid/example30.ts b/packages/demo/src/examples/slickgrid/example30.ts index 2e47043d8..37c4bceeb 100644 --- a/packages/demo/src/examples/slickgrid/example30.ts +++ b/packages/demo/src/examples/slickgrid/example30.ts @@ -127,7 +127,7 @@ export class Example30 { defineGrids() { this.columnDefinitions = [ { - id: 'title', name: '<span title="Task must always be followed by a number" class="color-warning-dark fa fa-exclamation-triangle"></span> Title <span title="Title is always rendered as UPPERCASE" class="fa fa-info-circle"></span>', + id: 'title', name: '<span title="Task must always be followed by a number" class="text-warning mdi mdi-alert-outline"></span> Title <span title="Title is always rendered as UPPERCASE" class="mdi mdi-information-outline"></span>', field: 'title', sortable: true, type: FieldType.string, minWidth: 75, cssClass: 'text-uppercase fw-bold', columnGroup: 'Common Factor', filterable: true, filter: { model: Filters.compoundInputText }, @@ -225,7 +225,7 @@ export class Example30 { { id: 'completed', name: 'Completed', field: 'completed', width: 80, minWidth: 75, maxWidth: 100, sortable: true, filterable: true, columnGroup: 'Period', - cssClass: 'text-center', formatter: Formatters.checkmark, + cssClass: 'text-center', formatter: Formatters.checkmarkMaterial, exportWithFormatter: false, filter: { collection: [{ value: '', label: '' }, { value: true, label: 'True' }, { value: false, label: 'False' }], @@ -244,7 +244,7 @@ export class Example30 { model: Editors.date, editorOptions: { range: { min: 'today' }, - + // if we want to preload the date picker with a different date, // we could do it by assigning settings.seleted.dates // NOTE: vanilla-calendar doesn't automatically focus the picker to the year/month and you need to do it yourself @@ -330,7 +330,7 @@ export class Example30 { { id: 'action', name: 'Action', field: 'action', width: 70, minWidth: 70, maxWidth: 70, excludeFromExport: true, - formatter: () => `<div class="button-style margin-auto" style="width: 35px;"><span class="fa fa-chevron-down text-primary"></span></div>`, + formatter: () => `<div class="button-style margin-auto" style="width: 35px;"><span class="mdi mdi-chevron-down text-primary"></span></div>`, cellMenu: { hideCloseButton: false, commandTitle: 'Commands', @@ -338,21 +338,21 @@ export class Example30 { { command: 'edit', title: 'Edit Row', - iconCssClass: 'fa fa-pencil', + iconCssClass: 'mdi mdi-pencil', positionOrder: 66, action: () => this.openCompositeModal('edit'), }, { command: 'clone', title: 'Clone Row', - iconCssClass: 'fa fa-clone', + iconCssClass: 'mdi mdi-content-copy', positionOrder: 66, action: () => this.openCompositeModal('clone'), }, 'divider', { command: 'delete-row', title: 'Delete Row', positionOrder: 64, - iconCssClass: 'fa fa-times color-danger', cssClass: 'red', textCssClass: 'text-italic color-danger-light', + iconCssClass: 'mdi mdi-close color-danger', cssClass: 'red', textCssClass: 'text-italic color-danger-light', // only show command to 'Delete Row' when the task is not completed itemVisibilityOverride: (args) => { return !args.dataContext?.completed; @@ -549,9 +549,9 @@ export class Example30 { handleOnCellClicked(e: Event, args: any) { console.log(e, args); - // if (eventData.target.classList.contains('fa-question-circle-o')) { + // if (eventData.target.classList.contains('mdi-help-circle-outline')) { // alert('please HELP!!!'); - // } else if (eventData.target.classList.contains('fa-chevron-down')) { + // } else if (eventData.target.classList.contains('mdi-chevron-down')) { // alert('do something else...'); // } } @@ -631,7 +631,7 @@ export class Example30 { // viewColumnLayout: 2, // responsive layout, choose from 'auto', 1, 2, or 3 (defaults to 'auto') showFormResetButton: true, // showResetButtonOnEachEditor: true, - resetFormButtonIconCssClass: 'fa fa-undo', + resetFormButtonIconCssClass: 'mdi mdi-undo', onClose: () => Promise.resolve(confirm('You have unsaved changes, are you sure you want to close this window?')), onError: (error) => alert(error.message), onRendered: (modalElm) => { @@ -879,81 +879,57 @@ export class Example30 { /** List of icons that are supported in this lib Material Design Icons */ getRandomIcon(iconIndex?: number) { const icons = [ - 'fa-500px', - 'fa-address-book', - 'fa-address-book-o', - 'fa-address-card', - 'fa-address-card-o', - 'fa-adjust', - 'fa-adn', - 'fa-align-center', - 'fa-align-justify', - 'fa-align-left', - 'fa-align-right', - 'fa-amazon', - 'fa-ambulance', - 'fa-american-sign-language-interpreting', - 'fa-anchor', - 'fa-android', - 'fa-angellist', - 'fa-angle-double-down', - 'fa-angle-double-left', - 'fa-angle-double-right', - 'fa-angle-double-up', - 'fa-angle-down', - 'fa-angle-left', - 'fa-angle-right', - 'fa-angle-up', - 'fa-apple', - 'fa-archive', - 'fa-area-chart', - 'fa-arrow-circle-down', - 'fa-arrow-circle-left', - 'fa-arrow-circle-o-down', - 'fa-arrow-circle-o-left', - 'fa-arrow-circle-o-right', - 'fa-arrow-circle-o-up', - 'fa-arrow-circle-right', - 'fa-arrow-circle-up', - 'fa-arrow-down', - 'fa-arrow-left', - 'fa-arrow-right', - 'fa-arrow-up', - 'fa-arrows', - 'fa-arrows-alt', - 'fa-arrows-h', - 'fa-arrows-v', - 'fa-assistive-listening-systems', - 'fa-asterisk', - 'fa-at', - 'fa-audio-description', - 'fa-backward', - 'fa-balance-scale', - 'fa-ban', - 'fa-bandcamp', - 'fa-bank (alias)', - 'fa-bar-chart', - 'fa-barcode', - 'fa-bars', - 'fa-bath', - 'fa-battery-empty', - 'fa-battery-full', - 'fa-battery-half', - 'fa-battery-quarter', - 'fa-battery-three-quarters', - 'fa-bed', - 'fa-beer', - 'fa-behance', - 'fa-behance-square', - 'fa-bell', - 'fa-bell-o', - 'fa-bell-slash', - 'fa-bell-slash-o', - 'fa-bicycle', - 'fa-binoculars', - 'fa-birthday-cake', - 'fa-bitbucket', - 'fa-bitbucket-square', + 'mdi-arrow-collapse', + 'mdi-arrow-expand', + 'mdi-cancel', + 'mdi-check', + 'mdi-checkbox-blank-outline', + 'mdi-check-box-outline', + 'mdi-checkbox-marked', + 'mdi-close', + 'mdi-close-circle', + 'mdi-close-circle-outline', + 'mdi-close-thick', + 'mdi-content-copy', + 'mdi-database-refresh', + 'mdi-download', + 'mdi-file-document-outline', + 'mdi-file-excel-outline', + 'mdi-file-music-outline', + 'mdi-file-pdf-outline', + 'mdi-filter-remove-outline', + 'mdi-flip-vertical', + 'mdi-folder', + 'mdi-folder-open', + 'mdi-help-circle', + 'mdi-help-circle-outline', + 'mdi-history', + 'mdi-information', + 'mdi-information-outline', + 'mdi-link', + 'mdi-link-variant', + 'mdi-menu', + 'mdi-microsoft-excel', + 'mdi-minus', + 'mdi-page-first', + 'mdi-page-last', + 'mdi-paperclip', + 'mdi-pin-off-outline', + 'mdi-pin-outline', + 'mdi-playlist-plus', + 'mdi-playlist-remove', + 'mdi-plus', + 'mdi-redo', + 'mdi-refresh', + 'mdi-shape-square-plus', + 'mdi-sort-ascending', + 'mdi-sort-descending', + 'mdi-swap-horizontal', + 'mdi-swap-vertical', + 'mdi-sync', + 'mdi-table-edit', + 'mdi-table-refresh', + 'mdi-undo', ]; const randomNumber = Math.floor((Math.random() * icons.length - 1)); return icons[iconIndex ?? randomNumber]; @@ -967,7 +943,7 @@ export class Example30 { </div> <div> <span class="autocomplete-top-left"> - <span class="fa ${item.itemTypeName === 'I' ? 'fa-info-circle' : 'fa-copy'}"></span> + <span class="fa ${item.itemTypeName === 'I' ? 'mdi-information-outline' : 'mdi-content-copy'}"></span> ${item.itemName} </span> <div> @@ -985,7 +961,7 @@ export class Example30 { </div> <div> <span class="autocomplete-top-left"> - <span class="fa ${item.itemTypeName === 'I' ? 'fa-info-circle' : 'fa-copy'}"></span> + <span class="fa ${item.itemTypeName === 'I' ? 'mdi-information-outline' : 'mdi-content-copy'}"></span> ${item.itemName} </span> <span class="autocomplete-top-right">${formatNumber(item.listPrice, 2, 2, false, '$')}</span> diff --git a/packages/demo/src/examples/slickgrid/example31.html b/packages/demo/src/examples/slickgrid/example31.html index bd60dd017..ed7cdda62 100644 --- a/packages/demo/src/examples/slickgrid/example31.html +++ b/packages/demo/src/examples/slickgrid/example31.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example31.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -12,20 +12,20 @@ <h2> <div class="row"> <div class="col-md-12" aria-label="Basic Editing Commands"> - <button class="btn btn-outline-secondary btn-sm" data-test="clear-filters-sorting" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="clear-filters-sorting" click.trigger="clearAllFiltersAndSorts()" title="Clear all Filters & Sorts"> <span class="mdi mdi-close"></span> <span>Clear all Filter & Sorts</span> </button> - <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-filter" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-filter" click.trigger="setFiltersDynamically()"> Set Filters Dynamically </button> - <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-sorting" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-sorting" click.trigger="setSortingDynamically()"> Set Sorting Dynamically </button> - <button class="btn btn-outline-secondary btn-sm" style="margin-left: 10px" data-test="add-gender-button" + <button class="btn btn-outline-secondary btn-sm btn-icon" style="margin-left: 10px" data-test="add-gender-button" click.trigger="addOtherGender()" disabled.bind="isOtherGenderAdded"> Add Other Gender via RxJS </button> @@ -38,10 +38,10 @@ <h2> <span> <label>Programmatically go to first/last page:</label> <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-first-page" click.trigger="goToFirstPage()"> - <i class="fa fa-caret-left fa-lg"></i> + <i class="mdi mdi-page-first"></i> </button> <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-last-page" click.trigger="goToLastPage()"> - <i class="fa fa-caret-right fa-lg"></i> + <i class="mdi mdi-page-last icon"></i> </button> </span> diff --git a/packages/demo/src/examples/slickgrid/example31.scss b/packages/demo/src/examples/slickgrid/example31.scss index 8a86595f3..4f68c9768 100644 --- a/packages/demo/src/examples/slickgrid/example31.scss +++ b/packages/demo/src/examples/slickgrid/example31.scss @@ -1,2 +1,2 @@ /* make sure to add the @import the SlickGrid Theme AFTER the variables changes */ -@import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-salesforce.lite.scss'; +// @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-salesforce.lite.scss'; diff --git a/packages/demo/src/examples/slickgrid/example31.ts b/packages/demo/src/examples/slickgrid/example31.ts index 854e1230e..06ff89868 100644 --- a/packages/demo/src/examples/slickgrid/example31.ts +++ b/packages/demo/src/examples/slickgrid/example31.ts @@ -161,6 +161,7 @@ export class Example31 { // we do this because Filter(s) are shown at all time, while on Editor it's unnecessary since they are only shown when opening them if (filterCollectionAsync?.next) { filterCollectionAsync.next(editorCollection); + filterCollectionAsync.complete(); } } } diff --git a/packages/demo/src/examples/slickgrid/example32.html b/packages/demo/src/examples/slickgrid/example32.html index fbb13d16b..ba336ac7e 100644 --- a/packages/demo/src/examples/slickgrid/example32.html +++ b/packages/demo/src/examples/slickgrid/example32.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example32.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -15,41 +15,41 @@ <h4 class="ml-3">Container Width (950px)</h4> <div class="row"> <div class="ml-2 mb-2 mr-2"> <div class="btn-group btn-group-toggle" data-bs-toggle="buttons"> - <label class="btn btn-sm btn-outline-secondary" class.bind="isUsingDefaultResize ? 'active' : ''" + <label class="btn btn-sm btn-outline-secondary btn-icon" class.bind="isUsingDefaultResize ? 'active' : ''" data-test="autosize-columns-btn"> <input type="radio" class="btn-check" name="options" checked.bind="isUsingDefaultResize" click.trigger="handleDefaultResizeColumns()"> - <i class="fa fa-expand"></i> (default resize) by "autosizeColumns" + <i class="mdi mdi-arrow-expand"></i> (default resize) by "autosizeColumns" </label> - <label class="btn btn-sm btn-outline-secondary" class.bind="isUsingDefaultResize ? '' : 'active'" + <label class="btn btn-sm btn-outline-secondary btn-icon" class.bind="isUsingDefaultResize ? '' : 'active'" data-test="resize-by-content-btn"> <input type="radio" class="btn-check" name="options" checked.bind="!isUsingDefaultResize" click.trigger="handleNewResizeColumns()"> - <i class="fa fa-expand"></i> Resize by Cell Content + <i class="mdi mdi-arrow-expand"></i> Resize by Cell Content </label> </div> </div> <div class="mb-2"> <div class="btn-group btn-group-sm" role="group" aria-label="Basic Editing Commands"> - <button type="button" class="btn btn-outline-secondary" click.trigger="setSelectedRowIds()" + <button type="button" class="btn btn-outline-secondary btn-icon" click.trigger="setSelectedRowIds()" data-test="set-dynamic-rows-btn" title="Change Row Selection across multiple pages"> <span>Change Row Selection</span> </button> - <button type="button" class="btn btn-outline-secondary" data-test="toggle-readonly-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="toggle-readonly-btn" click.trigger="toggleGridEditReadonly()"> - <i class="fa fa-table"></i> Toggle Readonly + <i class="mdi mdi-table-edit"></i> Toggle Readonly </button> - <button type="button" class="btn btn-outline-secondary" data-test="undo-last-edit-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="undo-last-edit-btn" click.trigger="undoLastEdit()"> - <i class="fa fa-undo"></i> Undo Last Edit + <i class="mdi mdi-undo"></i> Undo Last Edit </button> - <button type="button" class="btn btn-outline-secondary" data-test="save-all-btn" + <button type="button" class="btn btn-outline-secondary btn-icon" data-test="save-all-btn" click.trigger="saveAll()"> - <i class="fa fa-save"></i> Save All + <span>Save All</span> </button> </div> </div> diff --git a/packages/demo/src/examples/slickgrid/example32.ts b/packages/demo/src/examples/slickgrid/example32.ts index 20957e9f8..2ceab7ea2 100644 --- a/packages/demo/src/examples/slickgrid/example32.ts +++ b/packages/demo/src/examples/slickgrid/example32.ts @@ -187,7 +187,7 @@ export class Example32 { { id: 'completed', name: 'Completed', field: 'completed', width: 80, minWidth: 75, maxWidth: 100, cssClass: 'text-center', columnGroup: 'Period', - formatter: Formatters.checkmark, + formatter: Formatters.checkmarkMaterial, exportWithFormatter: false, filterable: true, sortable: true, filter: { @@ -282,7 +282,7 @@ export class Example32 { { id: 'action', name: 'Action', field: 'action', width: 70, minWidth: 70, maxWidth: 70, excludeFromExport: true, - formatter: () => `<div class="button-style margin-auto" style="width: 35px;"><span class="fa fa-chevron-down text-primary"></span></div>`, + formatter: () => `<div class="button-style margin-auto" style="width: 35px;"><span class="mdi mdi-chevron-down text-primary"></span></div>`, cellMenu: { hideCloseButton: false, commandTitle: 'Commands', @@ -290,14 +290,14 @@ export class Example32 { { command: 'help', title: 'Help!', - iconCssClass: 'fa fa-question-circle', + iconCssClass: 'mdi mdi-help-circle', positionOrder: 66, action: () => alert('Please Help!'), }, 'divider', { command: 'delete-row', title: 'Delete Row', positionOrder: 64, - iconCssClass: 'fa fa-times color-danger', cssClass: 'red', textCssClass: 'text-italic color-danger-light', + iconCssClass: 'mdi mdi-close color-danger', cssClass: 'red', textCssClass: 'text-italic color-danger-light', // only show command to 'Delete Row' when the task is not completed itemVisibilityOverride: (args) => { return !args.dataContext?.completed; @@ -709,81 +709,57 @@ export class Example32 { /** List of icons that are supported in this lib Material Design Icons */ getRandomIcon(iconIndex?: number) { const icons = [ - 'fa-500px', - 'fa-address-book', - 'fa-address-book-o', - 'fa-address-card', - 'fa-address-card-o', - 'fa-adjust', - 'fa-adn', - 'fa-align-center', - 'fa-align-justify', - 'fa-align-left', - 'fa-align-right', - 'fa-amazon', - 'fa-ambulance', - 'fa-american-sign-language-interpreting', - 'fa-anchor', - 'fa-android', - 'fa-angellist', - 'fa-angle-double-down', - 'fa-angle-double-left', - 'fa-angle-double-right', - 'fa-angle-double-up', - 'fa-angle-down', - 'fa-angle-left', - 'fa-angle-right', - 'fa-angle-up', - 'fa-apple', - 'fa-archive', - 'fa-area-chart', - 'fa-arrow-circle-down', - 'fa-arrow-circle-left', - 'fa-arrow-circle-o-down', - 'fa-arrow-circle-o-left', - 'fa-arrow-circle-o-right', - 'fa-arrow-circle-o-up', - 'fa-arrow-circle-right', - 'fa-arrow-circle-up', - 'fa-arrow-down', - 'fa-arrow-left', - 'fa-arrow-right', - 'fa-arrow-up', - 'fa-arrows', - 'fa-arrows-alt', - 'fa-arrows-h', - 'fa-arrows-v', - 'fa-assistive-listening-systems', - 'fa-asterisk', - 'fa-at', - 'fa-audio-description', - 'fa-backward', - 'fa-balance-scale', - 'fa-ban', - 'fa-bandcamp', - 'fa-bank (alias)', - 'fa-bar-chart', - 'fa-barcode', - 'fa-bars', - 'fa-bath', - 'fa-battery-empty', - 'fa-battery-full', - 'fa-battery-half', - 'fa-battery-quarter', - 'fa-battery-three-quarters', - 'fa-bed', - 'fa-beer', - 'fa-behance', - 'fa-behance-square', - 'fa-bell', - 'fa-bell-o', - 'fa-bell-slash', - 'fa-bell-slash-o', - 'fa-bicycle', - 'fa-binoculars', - 'fa-birthday-cake', - 'fa-bitbucket', - 'fa-bitbucket-square', + 'mdi-arrow-collapse', + 'mdi-arrow-expand', + 'mdi-cancel', + 'mdi-check', + 'mdi-checkbox-blank-outline', + 'mdi-check-box-outline', + 'mdi-checkbox-marked', + 'mdi-close', + 'mdi-close-circle', + 'mdi-close-circle-outline', + 'mdi-close-thick', + 'mdi-content-copy', + 'mdi-database-refresh', + 'mdi-download', + 'mdi-file-document-outline', + 'mdi-file-excel-outline', + 'mdi-file-music-outline', + 'mdi-file-pdf-outline', + 'mdi-filter-remove-outline', + 'mdi-flip-vertical', + 'mdi-folder', + 'mdi-folder-open', + 'mdi-help-circle', + 'mdi-help-circle-outline', + 'mdi-history', + 'mdi-information', + 'mdi-information-outline', + 'mdi-link', + 'mdi-link-variant', + 'mdi-menu', + 'mdi-microsoft-excel', + 'mdi-minus', + 'mdi-page-first', + 'mdi-page-last', + 'mdi-paperclip', + 'mdi-pin-off-outline', + 'mdi-pin-outline', + 'mdi-playlist-plus', + 'mdi-playlist-remove', + 'mdi-plus', + 'mdi-redo', + 'mdi-refresh', + 'mdi-shape-square-plus', + 'mdi-sort-ascending', + 'mdi-sort-descending', + 'mdi-swap-horizontal', + 'mdi-swap-vertical', + 'mdi-sync', + 'mdi-table-edit', + 'mdi-table-refresh', + 'mdi-undo', ]; const randomNumber = Math.floor((Math.random() * icons.length - 1)); return icons[iconIndex ?? randomNumber]; @@ -797,7 +773,7 @@ export class Example32 { </div> <div> <span class="autocomplete-top-left"> - <span class="mdfai ${item.itemTypeName === 'I' ? 'fa-info-circle' : 'fa-copy'}"></span> + <span class="fa ${item.itemTypeName === 'I' ? 'mdi-information-outline' : 'mdi-content-copy'}"></span> ${item.itemName} </span> <div> @@ -815,7 +791,7 @@ export class Example32 { </div> <div> <span class="autocomplete-top-left"> - <span class="fa ${item.itemTypeName === 'I' ? 'fa-info-circle' : 'fa-copy'}"></span> + <span class="fa ${item.itemTypeName === 'I' ? 'mdi-information-outline' : 'mdi-content-copy'}"></span> ${item.itemName} </span> <span class="autocomplete-top-right">${formatNumber(item.listPrice, 2, 2, false, '$')}</span> diff --git a/packages/demo/src/examples/slickgrid/example33.html b/packages/demo/src/examples/slickgrid/example33.html index 4bc76e77f..ddca24983 100644 --- a/packages/demo/src/examples/slickgrid/example33.html +++ b/packages/demo/src/examples/slickgrid/example33.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example33.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> diff --git a/packages/demo/src/examples/slickgrid/example33.ts b/packages/demo/src/examples/slickgrid/example33.ts index b57df478b..0c002d10e 100644 --- a/packages/demo/src/examples/slickgrid/example33.ts +++ b/packages/demo/src/examples/slickgrid/example33.ts @@ -76,7 +76,7 @@ export class Example33 { // example 2 (async): // when using async, the `formatter` will contain the loading spinner // you will need to provide an `asyncPost` function returning a Promise and also `asyncPostFormatter` formatter to display the result once the Promise resolves - formatter: () => `<div><span class="fa fa-spinner fa-pulse fa-fw"></span> loading...</div>`, + formatter: () => `<div><span class="mdi mdi-load mdi-spin"></span> loading...</div>`, asyncProcess: () => new Promise(resolve => { setTimeout(() => resolve({ ratio: Math.random() * 10 / 10, lifespan: Math.random() * 100 }), this.serverApiDelay); }), @@ -275,7 +275,7 @@ export class Example33 { }, { id: 'action', name: 'Action', field: 'action', width: 70, minWidth: 70, maxWidth: 70, - formatter: () => `<div class="button-style margin-auto" style="width: 35px;"><span class="fa fa-chevron-down text-primary"></span></div>`, + formatter: () => `<div class="button-style margin-auto" style="width: 35px;"><span class="mdi mdi-chevron-down text-primary"></span></div>`, excludeFromExport: true, cellMenu: { hideCloseButton: false, @@ -486,7 +486,7 @@ export class Example33 { } for (let i = 0; i < iconCount; i++) { const iconColor = iconCount === 5 ? 'text-success' : iconCount >= 3 ? 'text-warning' : 'text-secondary'; - output += `<span class="fa fa-check-circle-o ${iconColor}"></span>`; + output += `<span class="mdi mdi-check-circle-outline ${iconColor}"></span>`; } return output; } diff --git a/packages/demo/src/examples/slickgrid/example34.html b/packages/demo/src/examples/slickgrid/example34.html index 66c871e51..b2319976c 100644 --- a/packages/demo/src/examples/slickgrid/example34.html +++ b/packages/demo/src/examples/slickgrid/example34.html @@ -3,7 +3,7 @@ <h2> <span class="float-end"> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example34.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -20,13 +20,13 @@ <h2> </span> </div> <span class="ms-3 me-1"> - <button class="btn btn-outline-secondary btn-sm" data-test="start-btn" click.trigger="startSimulation()"> - <li class="fa fa-play"></li> Start Simulation + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="start-btn" click.trigger="startSimulation()"> + <li class="mdi mdi-play-circle-outline"></li> Start Simulation </button> </span> <span class="me-3"> - <button class="btn btn-outline-secondary btn-sm" data-test="stop-btn" click.trigger="stopSimulation()"> - <li class="fa fa-stop"></li> Stop Simulation + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="stop-btn" click.trigger="stopSimulation()"> + <li class="mdi mdi-stop-circle-outline"></li> Stop Simulation </button> </span> <span class="mx-1"> @@ -40,8 +40,8 @@ <h2> <input type="number" id="highlight-input" data-test="highlight-input" value.bind="highlightDuration"> </span> <div class="ms-auto"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="toggleFullScreen()"> - <li class.bind="isFullScreen ? 'fa fa-compress' : 'fa fa-arrows-alt'"></li> Toggle Full-Screen + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="toggleFullScreen()"> + <li class.bind="isFullScreen ? 'mdi mdi-arrow-collapse' : 'mdi mdi-arrow-expand'"></li> Toggle Full-Screen </button> </div> </div> diff --git a/packages/demo/src/examples/slickgrid/example34.ts b/packages/demo/src/examples/slickgrid/example34.ts index 3ddc4b170..439ec03fa 100644 --- a/packages/demo/src/examples/slickgrid/example34.ts +++ b/packages/demo/src/examples/slickgrid/example34.ts @@ -23,7 +23,7 @@ const priceFormatter: Formatter = (_cell, _row, value, _col, dataContext) => { const direction = dataContext.priceChange >= 0 ? 'up' : 'down'; const fragment = new DocumentFragment(); const spanElm = document.createElement('span'); - spanElm.className = `fa fa-arrow-${direction} text-${direction === 'up' ? 'success' : 'danger'}`; + spanElm.className = `mdi mdi-arrow-${direction} text-${direction === 'up' ? 'success' : 'danger'}`; fragment.appendChild(spanElm); if (value instanceof HTMLElement) { fragment.appendChild(value); @@ -32,7 +32,7 @@ const priceFormatter: Formatter = (_cell, _row, value, _col, dataContext) => { }; const transactionTypeFormatter: Formatter = (_row, _cell, value: string) => - `<span <span class="fa fa-${value === 'Buy' ? 'plus' : 'minus'}-circle ${value === 'Buy' ? 'text-info' : 'text-warning'}"></span> ${value}`; + `<span class="mdi mdi-16px mdi-v-align-sub mdi-${value === 'Buy' ? 'plus' : 'minus'}-circle ${value === 'Buy' ? 'text-info' : 'text-warning'}"></span> ${value}`; const historicSparklineFormatter: Formatter = (_row, _cell, _value, _col, dataContext: any) => { const svgElem = document.createElementNS('http://www.w3.org/2000/svg', 'svg'); @@ -181,7 +181,7 @@ export class Example34 { }, draggableGrouping: { dropPlaceHolderText: 'Drop a column header here to group by any of these available columns: Currency, Market or Type', - deleteIconCssClass: 'fa fa-times', + deleteIconCssClass: 'mdi mdi-close', }, enableDraggableGrouping: true, createPreHeaderPanel: true, diff --git a/packages/demo/src/examples/slickgrid/example35.html b/packages/demo/src/examples/slickgrid/example35.html index 6ee8ba515..a5bf2eee8 100644 --- a/packages/demo/src/examples/slickgrid/example35.html +++ b/packages/demo/src/examples/slickgrid/example35.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example35.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -49,14 +49,14 @@ <h2> <div class="row mb-4"> <div class="col-sm-8"> <button - class="btn btn-outline-secondary btn-sm" + class="btn btn-outline-secondary btn-sm btn-icon" data-test="single-multi-toggle" click.trigger="toggleSingleMultiRowEdit()" > Toggle Single/Multi Row Edit </button> - <button class="btn btn-outline-secondary btn-sm" data-test="toggle-language" click.trigger="switchLanguage()"> - <i class="fa fa-language"></i> + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="toggle-language" click.trigger="switchLanguage()"> + <i class="mdi mdi-translate"></i> Switch Language for Action column buttons </button> <label>Locale:</label> diff --git a/packages/demo/src/examples/slickgrid/example35.ts b/packages/demo/src/examples/slickgrid/example35.ts index 517eddd37..9039ffe8f 100644 --- a/packages/demo/src/examples/slickgrid/example35.ts +++ b/packages/demo/src/examples/slickgrid/example35.ts @@ -171,28 +171,28 @@ export class Example35 { maxWidth: 100, }, actionButtons: { - editButtonClassName: 'button-style margin-auto px-2 me-1', - iconEditButtonClassName: 'fa fa-pencil', + editButtonClassName: 'button-style margin-auto btn-icon px-2 me-1', + iconEditButtonClassName: 'mdi mdi-pencil', // since no title and no titleKey is provided, it will fallback to the default text provided by the plugin // if the title is provided but no titleKey, it will override the default text // last but not least if a titleKey is provided, it will use the translation key to translate the text // editButtonTitle: 'Edit row', - cancelButtonClassName: 'button-style px-2', + cancelButtonClassName: 'button-style btn-icon px-2', cancelButtonTitle: 'Cancel row', cancelButtonTitleKey: 'RBE_BTN_CANCEL', - iconCancelButtonClassName: 'fa fa-undo text-danger', + iconCancelButtonClassName: 'mdi mdi-undo text-danger', cancelButtonPrompt: 'Are you sure you want to cancel your changes?', - updateButtonClassName: 'button-style px-2 me-1', + updateButtonClassName: 'button-style btn-icon px-2 me-1', updateButtonTitle: 'Update row', updateButtonTitleKey: 'RBE_BTN_UPDATE', - iconUpdateButtonClassName: 'fa fa-check text-success', + iconUpdateButtonClassName: 'mdi mdi-check text-success', updateButtonPrompt: 'Save changes?', - deleteButtonClassName: 'button-style px-2', + deleteButtonClassName: 'button-style btn-icon px-2', deleteButtonTitle: 'Delete row', - iconDeleteButtonClassName: 'fa fa-trash-o text-danger', + iconDeleteButtonClassName: 'mdi mdi-trash-can text-danger', deleteButtonPrompt: 'Are you sure you want to delete this row?', }, }, diff --git a/packages/demo/src/examples/slickgrid/example4.html b/packages/demo/src/examples/slickgrid/example4.html index 62af8079e..fd05bce16 100644 --- a/packages/demo/src/examples/slickgrid/example4.html +++ b/packages/demo/src/examples/slickgrid/example4.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example4.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -18,27 +18,27 @@ <h2> </span> <div class="btn-group" role="group" aria-label="..."> - <button class="btn btn-sm btn-outline-secondary" data-test="scroll-top-btn" click.trigger="scrollGridTop()"> - <i class="fa fa-arrow-up"></i> + <button class="btn btn-sm btn-outline-secondary btn-icon" data-test="scroll-top-btn" click.trigger="scrollGridTop()"> + <i class="mdi mdi-arrow-down mdi-rotate-180 icon"></i> </button> - <button class="btn btn-sm btn-outline-secondary" data-test="scroll-bottom-btn" click.trigger="scrollGridBottom()"> - <i class="fa fa-arrow-down"></i> + <button class="btn btn-sm btn-outline-secondary btn-icon" data-test="scroll-bottom-btn" click.trigger="scrollGridBottom()"> + <i class="mdi mdi-arrow-down icon"></i> </button> </div> -<button class="btn btn-outline-secondary btn-sm" data-test="clear-filters" +<button class="btn btn-outline-secondary btn-sm btn-icon" data-test="clear-filters" click.trigger="aureliaGrid.filterService.clearFilters()"> Clear Filters </button> -<button class="btn btn-outline-secondary btn-sm" data-test="clear-sorting" +<button class="btn btn-outline-secondary btn-sm btn-icon" data-test="clear-sorting" click.trigger="aureliaGrid.sortService.clearSorting()"> Clear Sorting </button> -<button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-filter" +<button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-filter" click.trigger="setFiltersDynamically()"> Set Filters Dynamically </button> -<button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-sorting" +<button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-sorting" click.trigger="setSortingDynamically()"> Set Sorting Dynamically </button> diff --git a/packages/demo/src/examples/slickgrid/example4.ts b/packages/demo/src/examples/slickgrid/example4.ts index e3952ae6a..3e7c89963 100644 --- a/packages/demo/src/examples/slickgrid/example4.ts +++ b/packages/demo/src/examples/slickgrid/example4.ts @@ -1,6 +1,8 @@ import { IHttpClient } from '@aurelia/fetch-client'; import { newInstanceOf, resolve } from '@aurelia/kernel'; import { ExcelExportService } from '@slickgrid-universal/excel-export'; +import { type MultipleSelectOption } from 'multiple-select-vanilla'; + import { CustomInputFilter } from './custom-inputFilter'; import { type AureliaGridInstance, @@ -11,7 +13,6 @@ import { type GridOption, type GridStateChange, type Metrics, - type MultipleSelectOption, OperatorType, type VanillaCalendarOption, } from 'aurelia-slickgrid'; @@ -165,7 +166,6 @@ export class Example4 { filter: { model: Filters.compoundDate, // override any of the calendar options through "filterOptions" - // please note that there's no TSlint on this property since it's generic for any filter, so make sure you entered the correct filter option(s) filterOptions: { range: { min: 'today' } } as VanillaCalendarOption } }, @@ -177,14 +177,14 @@ export class Example4 { // to pass multiple formatters, use the params property // also these formatters are executed in sequence, so if you want the checkmark to work correctly, it has to be the last formatter defined formatter: Formatters.multiple, - params: { formatters: [Formatters.complexObject, Formatters.checkmark] }, + params: { formatters: [Formatters.complexObject, Formatters.checkmarkMaterial] }, // when the "field" string includes the dot "." notation, the library will consider this to be a complex object and Filter accordingly filterable: true, filter: { // We can also add HTML text to be rendered (any bad script will be sanitized) but we have to opt-in, else it will be sanitized // enableRenderHtml: true, - // collection: [{ value: '', label: '' }, { value: true, label: 'True', labelPrefix: `<i class="fa fa-check"></i> ` }, { value: false, label: 'False' }], + // collection: [{ value: '', label: '' }, { value: true, label: 'True', labelPrefix: `<i class="mdi mdi-check"></i> ` }, { value: false, label: 'False' }], collection: ['', 'True', 'False'], model: Filters.singleSelect, diff --git a/packages/demo/src/examples/slickgrid/example5.html b/packages/demo/src/examples/slickgrid/example5.html index 5532a315c..42d8c109a 100644 --- a/packages/demo/src/examples/slickgrid/example5.html +++ b/packages/demo/src/examples/slickgrid/example5.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example5.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -24,7 +24,7 @@ <h2> <div class.bind="status.class" role="alert" data-test="status"> <strong>Status: </strong> ${status.text} <span hidden.bind="!processing"> - <i class="fa fa-refresh fa-spin fa-lg fa-fw"></i> + <i class="mdi mdi-sync mdi-spin"></i> </span> </div> </div> @@ -37,11 +37,11 @@ <h2> <div class="row"> <div class="col-sm-4"> - <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-filter" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-filter" click.trigger="setFiltersDynamically()"> Set Filters Dynamically </button> - <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-sorting" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-sorting" click.trigger="setSortingDynamically()"> Set Sorting Dynamically </button> @@ -93,10 +93,10 @@ <h2> <span class="ms-2"> <label>Programmatically go to first/last page:</label> <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-first-page" click.trigger="goToFirstPage()"> - <i class="fa fa-caret-left fa-lg"></i> + <i class="mdi mdi-page-first"></i> </button> <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-last-page" click.trigger="goToLastPage()"> - <i class="fa fa-caret-right fa-lg"></i> + <i class="mdi mdi-page-last"></i> </button> </span> </div> diff --git a/packages/demo/src/examples/slickgrid/example6.html b/packages/demo/src/examples/slickgrid/example6.html index 67c59efe1..c662b985b 100644 --- a/packages/demo/src/examples/slickgrid/example6.html +++ b/packages/demo/src/examples/slickgrid/example6.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example6.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> @@ -15,26 +15,26 @@ <h2> <div class.bind="status.class" role="alert" data-test="status"> <strong>Status: </strong> ${status.text} <span hidden.bind="!processing"> - <i class="fa fa-refresh fa-spin fa-lg fa-fw"></i> + <i class="mdi mdi-sync mdi-spin"></i> </span> </div> <div class="row"> <div class="col-md-12"> - <button class="btn btn-outline-secondary btn-sm" data-test="clear-filters-sorting" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="clear-filters-sorting" click.trigger="clearAllFiltersAndSorts()" title="Clear all Filters & Sorts"> - <i class="fa fa-filter text-danger"></i> + <i class="mdi mdi-filter text-danger"></i> Clear all Filter & Sorts </button> - <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-filter" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-filter" click.trigger="setFiltersDynamically()"> Set Filters Dynamically </button> - <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-sorting" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="set-dynamic-sorting" click.trigger="setSortingDynamically()"> Set Sorting Dynamically </button> - <button class="btn btn-outline-secondary btn-sm" data-test="reset-presets" + <button class="btn btn-outline-secondary btn-sm btn-icon" data-test="reset-presets" click.trigger="resetToOriginalPresets()"> Reset Original Presets </button> @@ -49,9 +49,9 @@ <h2> <div class="row"> <div class="col-md-12"> - <button class="btn btn-outline-secondary btn-sm" click.trigger="switchLanguage()" + <button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="switchLanguage()" data-test="language-button"> - <i class="fa fa-language"></i> + <i class="mdi mdi-translate"></i> Switch Language </button> <b>Locale:</b> @@ -84,10 +84,10 @@ <h2> <div class="col-md-12"> <label>Programmatically go to first/last page:</label> <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-first-page" click.trigger="goToFirstPage()"> - <i class="fa fa-caret-left fa-lg"></i> + <i class="mdi mdi-page-first"></i> </button> <button class="btn btn-outline-secondary btn-xs px-2" data-test="goto-last-page" click.trigger="goToLastPage()"> - <i class="fa fa-caret-right fa-lg"></i> + <i class="mdi mdi-page-last icon"></i> </button> </div> </div> diff --git a/packages/demo/src/examples/slickgrid/example6.ts b/packages/demo/src/examples/slickgrid/example6.ts index 14c9522df..fdf529b17 100644 --- a/packages/demo/src/examples/slickgrid/example6.ts +++ b/packages/demo/src/examples/slickgrid/example6.ts @@ -1,6 +1,7 @@ import { I18N } from '@aurelia/i18n'; import { GraphqlService, type GraphqlPaginatedResult, type GraphqlServiceApi, type GraphqlServiceOption } from '@slickgrid-universal/graphql'; import moment from 'moment-mini'; +import { type MultipleSelectOption } from 'multiple-select-vanilla'; import { type AureliaGridInstance, type Column, @@ -11,7 +12,6 @@ import { type GridOption, type GridStateChange, type Metrics, - type MultipleSelectOption, OperatorType, SortDirection, } from 'aurelia-slickgrid'; diff --git a/packages/demo/src/examples/slickgrid/example7.html b/packages/demo/src/examples/slickgrid/example7.html index c93a8b262..8b4900820 100644 --- a/packages/demo/src/examples/slickgrid/example7.html +++ b/packages/demo/src/examples/slickgrid/example7.html @@ -4,7 +4,7 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example7.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> diff --git a/packages/demo/src/examples/slickgrid/example7.ts b/packages/demo/src/examples/slickgrid/example7.ts index 4074f7617..249939027 100644 --- a/packages/demo/src/examples/slickgrid/example7.ts +++ b/packages/demo/src/examples/slickgrid/example7.ts @@ -98,13 +98,13 @@ export class Example7 { const command = args.command; if (command === 'toggle-highlight') { - if (button.cssClass === 'fa fa-circle red') { + if (button.cssClass === 'mdi mdi-lightbulb-on text-danger') { if (gridNo === 1) { delete columns1WithHighlightingById[column.id]; } else { delete columns2WithHighlightingById[column.id]; } - button.cssClass = 'fa fa-circle-o red faded'; + button.cssClass = 'mdi mdi-lightbulb-outline text-warning faded'; button.tooltip = 'Highlight negative numbers.'; } else { if (gridNo === 1) { @@ -112,7 +112,7 @@ export class Example7 { } else { columns2WithHighlightingById[column.id] = true; } - button.cssClass = 'fa fa-circle red'; + button.cssClass = 'mdi mdi-lightbulb-on text-danger'; button.tooltip = 'Remove highlight.'; } this[`aureliaGrid${gridNo}`].slickGrid.invalidate(); @@ -142,7 +142,7 @@ export class Example7 { header: { buttons: [ { - cssClass: 'fa fa-circle-o red faded', + cssClass: 'mdi mdi-lightbulb-outline text-warning faded', command: 'toggle-highlight', tooltip: 'Highlight negative numbers.', itemVisibilityOverride: (args) => { @@ -169,25 +169,25 @@ export class Example7 { cols[0].header = { buttons: [ { - cssClass: 'fa fa-tag', + cssClass: 'mdi mdi-message-text', handler: () => { alert('Tag'); } }, { - cssClass: 'fa fa-comment', + cssClass: 'mdi mdi-forum-outline', handler: () => { alert('Comment'); } }, { - cssClass: 'fa fa-info-circle', + cssClass: 'mdi mdi-information', handler: () => { alert('Info'); } }, { - cssClass: 'fa fa-question-circle', + cssClass: 'mdi mdi-help-circle', handler: () => { alert('Help'); } @@ -205,7 +205,7 @@ export class Example7 { cols[1].header = { buttons: [ { - cssClass: 'fa fa-question-circle', + cssClass: 'mdi mdi-help-circle', showOnHover: true, tooltip: 'This button only appears on hover.', handler: () => { diff --git a/packages/demo/src/examples/slickgrid/example8.html b/packages/demo/src/examples/slickgrid/example8.html index 83c08491b..3d476b574 100644 --- a/packages/demo/src/examples/slickgrid/example8.html +++ b/packages/demo/src/examples/slickgrid/example8.html @@ -4,14 +4,14 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example8.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> <div class="subtitle" innerhtml.bind="subTitle"></div> -<button class="btn btn-outline-secondary btn-sm" click.trigger="switchLanguage()"> - <i class="fa fa-language"></i> +<button class="btn btn-outline-secondary btn-sm btn-icon" click.trigger="switchLanguage()"> + <i class="mdi mdi-translate"></i> Switch Language </button> <b>Locale:</b> <span style="font-style: italic" data-test="selected-locale">${selectedLanguage + '.json'}</span> diff --git a/packages/demo/src/examples/slickgrid/example8.scss b/packages/demo/src/examples/slickgrid/example8.scss index aa6ef2fcd..95c9c56d1 100644 --- a/packages/demo/src/examples/slickgrid/example8.scss +++ b/packages/demo/src/examples/slickgrid/example8.scss @@ -1,9 +1,8 @@ -$slick-header-menu-button-border: 1px solid #cfcfcf; -$slick-header-menu-button-border-width: 0px 1px; -$slick-header-menu-button-icon: "\f0d7"; -$slick-header-menu-button-width: 16px; -$slick-header-menu-button-padding: 10px 0 0 3px; -$slick-sort-indicator-hint-opacity: 0; +$slick-header-menu-button-border-width: 0px 1px; +$slick-header-menu-button-icon-svg-path: "M12,2A10,10 0 0,1 22,12A10,10 0 0,1 12,22A10,10 0 0,1 2,12A10,10 0 0,1 12,2M7,10L12,15L17,10H7Z"; +$slick-header-menu-button-icon-size: 16px; +$slick-header-menu-button-padding: 10px 0 0 3px; +$slick-sort-indicator-hint-opacity: 0; /* make sure to add the @import the SlickGrid Bootstrap Theme AFTER the variables changes */ @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-bootstrap.scss'; diff --git a/packages/demo/src/examples/slickgrid/example8.ts b/packages/demo/src/examples/slickgrid/example8.ts index cdc383b15..f4676b89e 100644 --- a/packages/demo/src/examples/slickgrid/example8.ts +++ b/packages/demo/src/examples/slickgrid/example8.ts @@ -62,7 +62,7 @@ export class Example8 { { id: 'percentComplete', name: '% Complete', field: 'percentComplete', nameKey: 'PERCENT_COMPLETE', sortable: true }, { id: 'start', name: 'Start', field: 'start', nameKey: 'START' }, { id: 'finish', name: 'Finish', field: 'finish', nameKey: 'FINISH' }, - { id: 'completed', name: 'Completed', field: 'completed', nameKey: 'COMPLETED', formatter: Formatters.checkmark } + { id: 'completed', name: 'Completed', field: 'completed', nameKey: 'COMPLETED', formatter: Formatters.checkmarkMaterial } ]; this.columnDefinitions.forEach((columnDef) => { @@ -74,7 +74,7 @@ export class Example8 { // also note that the internal custom commands are in the positionOrder range of 50-60, // if you want yours at the bottom then start with 61, below 50 will make your command(s) show on top { - iconCssClass: 'fa fa-question-circle', + iconCssClass: 'mdi mdi-help-circle', // you can disable a command with certain logic // HOWEVER note that if you use "itemUsabilityOverride" has precedence when it is defined @@ -154,7 +154,7 @@ export class Example8 { headerMenu: { hideSortCommands: false, hideColumnHideCommand: false, - subItemChevronClass: 'fa fa-chevron-right', + subItemChevronClass: 'mdi mdi-chevron-down mdi-rotate-270', // you can use the "onCommand" (in Grid Options) and/or the "action" callback (in Column Definition) onCommand: (_e, args) => { // e.preventDefault(); // preventing default event would keep the menu open after the execution diff --git a/packages/demo/src/examples/slickgrid/example9.html b/packages/demo/src/examples/slickgrid/example9.html index cc06cb262..0bdab4cab 100644 --- a/packages/demo/src/examples/slickgrid/example9.html +++ b/packages/demo/src/examples/slickgrid/example9.html @@ -4,19 +4,19 @@ <h2> <a style="font-size: 18px" target="_blank" href="https://github.com/ghiscoding/aurelia-slickgrid/blob/master/packages/demo/src/examples/slickgrid/example9.ts"> - <span class="fa fa-link"></span> code + <span class="mdi mdi-link-variant"></span> code </a> </span> </h2> <div class="subtitle" innerhtml.bind="subTitle"></div> -<button class="btn btn-outline-secondary btn-sm" data-test="external-gridmenu" +<button class="btn btn-outline-secondary btn-sm btn-icon" data-test="external-gridmenu" click.trigger="toggleGridMenu($event)"> - <i class="fa fa-bars"></i> + <i class="mdi mdi-menu"></i> Grid Menu </button> -<button class="btn btn-outline-secondary btn-sm" data-test="language" click.trigger="switchLanguage()"> - <i class="fa fa-language"></i> +<button class="btn btn-outline-secondary btn-sm btn-icon" data-test="language" click.trigger="switchLanguage()"> + <i class="mdi mdi-translate"></i> Switch Language </button> <b>Locale:</b> <span style="font-style: italic" data-test="selected-locale">${selectedLanguage + '.json'}</span> diff --git a/packages/demo/src/examples/slickgrid/example9.scss b/packages/demo/src/examples/slickgrid/example9.scss index 102e0bf12..27edccf97 100644 --- a/packages/demo/src/examples/slickgrid/example9.scss +++ b/packages/demo/src/examples/slickgrid/example9.scss @@ -1,12 +1,8 @@ -$slick-column-picker-checkbox-icon-unchecked: "\f00c" !default; -$slick-column-picker-checkbox-icon-checked: "\f00c" !default; -$slick-column-picker-checkbox-opacity: 0.2 !default; -$slick-column-picker-checkbox-opacity-hover: 0.35 !default; - -$slick-grid-menu-checkbox-icon-unchecked: "\f096"; -$slick-grid-menu-checkbox-icon-checked: "\f046"; -$slick-grid-menu-checkbox-opacity: 0.7; -$slick-grid-menu-checkbox-opacity-hover: 1; +$slick-column-picker-icon-checked-svg-path: "M19,3H5A2,2 0 0,0 3,5V19A2,2 0 0,0 5,21H19A2,2 0 0,0 21,19V5A2,2 0 0,0 19,3M19,5V19H5V5H19M10,17L6,13L7.41,11.58L10,14.17L16.59,7.58L18,9"; +$slick-column-picker-icon-unchecked-svg-path: "M19,3H5C3.89,3 3,3.89 3,5V19A2,2 0 0,0 5,21H19A2,2 0 0,0 21,19V5C21,3.89 20.1,3 19,3M19,5V19H5V5H19Z"; +$slickcolumn-picker-checkbox-opacity: 0.2; +$slickcolumn-picker-checkbox-opacity-hover: 0.35; +$slick-column-picker-icon-font-size: 16px; /* make sure to add the @import the SlickGrid Bootstrap Theme AFTER the variables changes */ @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-bootstrap.scss'; diff --git a/packages/demo/src/examples/slickgrid/example9.ts b/packages/demo/src/examples/slickgrid/example9.ts index a8efd7997..6430f8a4a 100644 --- a/packages/demo/src/examples/slickgrid/example9.ts +++ b/packages/demo/src/examples/slickgrid/example9.ts @@ -19,12 +19,12 @@ export class Example9 { This example demonstrates using the <b>Slick.Controls.GridMenu</b> plugin to easily add a Grid Menu (aka hamburger menu) on the top right corner of the grid.<br/> (<a href="https://ghiscoding.gitbook.io/aurelia-slickgrid/grid-functionalities/grid-menu" target="_blank">Wiki docs</a>) <ul> - <li>You can change the Grid Menu icon, for example "fa-ellipsis-v" <span class="fa fa-ellipsis-v"></span> (which is shown in this example)</li> - <li>By default the Grid Menu shows all columns which you can show/hide them</li> - <li>You can configure multiple custom "commands" to show up in the Grid Menu and use the "onGridMenuCommand()" callback</li> - <li>Doing a "right+click" over any column header will also provide a way to show/hide a column (via the Column Picker Plugin)</li> - <li>You can change the icons of both picker via SASS variables as shown in this demo (check all SASS variables)</li> - <li><i class="fa fa-arrow-down"></i> You can also show the Grid Menu anywhere on your page</li> + <li>You can change the Grid Menu icon, for example "mdi-dots-vertical" <span class="mdi mdi-dots-vertical"></span> (which is shown in this example)</li> + <li>By default the Grid Menu shows all columns which you can show/hide them</li> + <li>You can configure multiple custom "commands" to show up in the Grid Menu and use the "onGridMenuCommand()" callback</li> + <li>Doing a "right + click" over any column header will also provide a way to show/hide a column (via the Column Picker Plugin)</li> + <li>You can change the icons of both picker via SASS variables as shown in this demo (check all SASS variables)</li> + <li><i class="mdi mdi-arrow-down icon"></i> You can also show the Grid Menu anywhere on your page</li> </ul> `; @@ -70,7 +70,7 @@ export class Example9 { { id: 'start', name: 'Start', field: 'start', nameKey: 'START', filterable: true, type: FieldType.dateUs, filter: { model: Filters.compoundDate } }, { id: 'finish', name: 'Finish', field: 'finish', nameKey: 'FINISH', filterable: true, type: FieldType.dateUs, filter: { model: Filters.compoundDate } }, { - id: 'completed', name: 'Completed', field: 'completed', nameKey: 'COMPLETED', maxWidth: 80, formatter: Formatters.checkmark, + id: 'completed', name: 'Completed', field: 'completed', nameKey: 'COMPLETED', maxWidth: 80, formatter: Formatters.checkmarkMaterial, type: FieldType.boolean, minWidth: 100, sortable: true, @@ -105,20 +105,20 @@ export class Example9 { // all titles optionally support translation keys, if you wish to use that feature then use the title properties with the 'Key' suffix (e.g: titleKey) // example "commandTitle" for a plain string OR "commandTitleKey" to use a translation key commandTitleKey: 'CUSTOM_COMMANDS', - iconCssClass: 'fa fa-ellipsis-v', // defaults to "fa-bars" + iconCssClass: 'mdi mdi-dots-vertical', // defaults to "mdi-menu" hideForceFitButton: true, hideSyncResizeButton: true, hideToggleFilterCommand: false, // show/hide internal custom commands menuWidth: 17, resizeOnShowHeaderRow: true, - subItemChevronClass: 'fa fa-chevron-right', + subItemChevronClass: 'mdi mdi-chevron-down mdi-rotate-270', commandItems: [ // add Custom Items Commands which will be appended to the existing internal custom items // you cannot override an internal items but you can hide them and create your own // also note that the internal custom commands are in the positionOrder range of 50-60, // if you want yours at the bottom then start with 61, below 50 will make your command(s) show on top { - iconCssClass: 'fa fa-question-circle', + iconCssClass: 'mdi mdi-help-circle', titleKey: 'HELP', disabled: false, command: 'help', @@ -135,7 +135,7 @@ export class Example9 { command: 'command1', positionOrder: 91, cssClass: 'orange', - iconCssClass: 'fa fa-warning', + iconCssClass: 'mdi mdi-alert', // you can use the "action" callback and/or use "onCallback" callback from the grid options, they both have the same arguments action: (_e, args) => alert(args.command), itemUsabilityOverride: (args) => { diff --git a/packages/demo/src/main.ts b/packages/demo/src/main.ts index 28e709c63..0742ef401 100644 --- a/packages/demo/src/main.ts +++ b/packages/demo/src/main.ts @@ -52,7 +52,7 @@ Aurelia })) .register(AureliaSlickGridConfiguration.customize(config => { // change any of the default global options - config.options.gridMenu!.iconCssClass = 'fa fa-bars'; + config.options.gridMenu!.iconCssClass = 'mdi mdi-menu'; })) .register(DecimalValueConverter, StringifyValueConverter, DateFormatValueConverter) .app(MyApp) diff --git a/packages/demo/src/my-app.html b/packages/demo/src/my-app.html index daaef2d33..7a953775c 100644 --- a/packages/demo/src/my-app.html +++ b/packages/demo/src/my-app.html @@ -1,7 +1,7 @@ <div class="container-fluid"> <nav class="navbar navbar-expand-md navbar-dark bg-dark fixed-top"> <a class="navbar-brand ms-2" href="https://github.com/ghiscoding/aurelia-slickgrid"> - <i class="fa fa-github"></i> + <i class="mdi mdi-github"></i> <span>Aurelia-Slickgrid</span> </a> <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-target="#navbarContent" @@ -29,7 +29,7 @@ target="_blank">Aurelia-Bootstrap-Plugins</a> </li> <li class="loader" if.bind="router.isNavigating"> - <i class="fa fa-spinner fa-spin fa-2x"></i> + <i class="mdi mdi-sync mdi-spin mdi-20px"></i> </li> </ul> </div> @@ -40,7 +40,7 @@ <ul class="well nav nav-pills nav-stacked"> <li class="nav-item fw-bold nav-docs"> <a class="nav-link" href="https://ghiscoding.gitbook.io/aurelia-slickgrid/" target="_blank"> - <i class="fa fa-book"></i> Documentation + 📘 Documentation </a> </li> <li repeat.for="r of routes" class="nav-item"> diff --git a/packages/demo/src/my-app.ts b/packages/demo/src/my-app.ts index a0fa12d50..ff399d724 100644 --- a/packages/demo/src/my-app.ts +++ b/packages/demo/src/my-app.ts @@ -1,5 +1,5 @@ import 'bootstrap/dist/css/bootstrap.min.css'; -import 'font-awesome/css/font-awesome.css'; + import './styles.scss'; export class MyApp { diff --git a/packages/demo/src/styles.scss b/packages/demo/src/styles.scss index fd42a59ba..e0b237692 100644 --- a/packages/demo/src/styles.scss +++ b/packages/demo/src/styles.scss @@ -1,5 +1,7 @@ $slick-input-focus-box-shadow: 0 0 0 0.25rem #0d6efd40; $slick-button-border-color: #ababab !default; +$navbar-height: 56px; +$side-menu-width: 250px; /* make sure to add the @import the SlickGrid Bootstrap Theme AFTER the variables changes */ @import '@slickgrid-universal/common/dist/styles/sass/slickgrid-theme-bootstrap.scss'; @@ -13,8 +15,11 @@ $slick-button-border-color: #ababab !default; font-size: 12px; } -$navbar-height: 56px; -$side-menu-width: 250px; +.btn-icon { + display: inline-flex; + align-items: center; + gap: 4px; +} body { margin: 0; @@ -26,10 +31,10 @@ body { font-style: italic; } .faded { - opacity: 0.2; + opacity: 0.7; } .faded:hover { - opacity: 0.5; + opacity: 1; } .btn { padding: 5px; @@ -57,12 +62,6 @@ body { margin-bottom: 10px; } -.faded { - opacity: 0.2; -} -.faded:hover { - opacity: 0.5; -} .btn:focus, .btn:active:focus, .btn.active:focus { outline: 0 none; } diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 852d86736..244c58c35 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -41,6 +41,9 @@ importers: cypress: specifier: ^13.8.1 version: 13.8.1 + cypress-real-events: + specifier: ^1.12.0 + version: 1.12.0(cypress@13.8.1) eslint: specifier: ^9.1.1 version: 9.1.1 @@ -137,12 +140,15 @@ importers: isomorphic-dompurify: specifier: ^2.8.0 version: 2.8.0 - moment-mini: - specifier: ^2.29.4 - version: 2.29.4 + moment-tiny: + specifier: ^2.30.3 + version: 2.30.3 sortablejs: specifier: ^1.15.2 version: 1.15.2 + vanilla-calendar-picker: + specifier: ^2.11.4 + version: 2.11.4 devDependencies: '@types/dompurify': specifier: ^3.0.5 @@ -292,9 +298,6 @@ importers: fetch-jsonp: specifier: ^1.3.0 version: 1.3.0 - font-awesome: - specifier: ^4.7.0 - version: 4.7.0 html-webpack-plugin: specifier: ^5.6.0 version: 5.6.0(webpack@5.91.0) @@ -304,6 +307,9 @@ importers: isomorphic-fetch: specifier: ^3.0.0 version: 3.0.0 + multiple-select-vanilla: + specifier: ^3.1.0 + version: 3.1.0 npm-run-all2: specifier: ^6.1.2 version: 6.1.2 @@ -3761,6 +3767,14 @@ packages: dependencies: rrweb-cssom: 0.6.0 + /cypress-real-events@1.12.0(cypress@13.8.1): + resolution: {integrity: sha512-oiy+4kGKkzc2PT36k3GGQqkGxNiVypheWjMtfyi89iIk6bYmTzeqxapaLHS3pnhZOX1IEbTDUVxh8T4Nhs1tyQ==} + peerDependencies: + cypress: ^4.x || ^5.x || ^6.x || ^7.x || ^8.x || ^9.x || ^10.x || ^11.x || ^12.x || ^13.x + dependencies: + cypress: 13.8.1 + dev: true + /cypress@13.8.1: resolution: {integrity: sha512-Uk6ovhRbTg6FmXjeZW/TkbRM07KPtvM5gah1BIMp4Y2s+i/NMxgaLw0+PbYTOdw1+egE0FP3mWRiGcRkjjmhzA==} engines: {node: ^16.0.0 || ^18.0.0 || >=20.0.0} @@ -4979,11 +4993,6 @@ packages: optional: true dev: true - /font-awesome@4.7.0: - resolution: {integrity: sha512-U6kGnykA/6bFmg1M/oT9EkFeIYv7JlX3bozwQJWiiLz6L0w3F5vBVPxHlwyX/vtNq1ckcpRKOB9f2Qal/VtFpg==} - engines: {node: '>=0.10.3'} - dev: true - /for-each@0.3.3: resolution: {integrity: sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==} dependencies: @@ -7316,6 +7325,10 @@ packages: /moment-mini@2.29.4: resolution: {integrity: sha512-uhXpYwHFeiTbY9KSgPPRoo1nt8OxNVdMVoTBYHfSEKeRkIkwGpO+gERmhuhBtzfaeOyTkykSrm2+noJBgqt3Hg==} + /moment-tiny@2.30.3: + resolution: {integrity: sha512-FgTYWVw+j63lHaUex7u1W0ix+2K5r4xEpGkLwkdIfuvl4g1v7NJgCQMHCi7BsSp3IcFdXOnCoroRUPRPlJGr5w==} + dev: false + /mrmime@2.0.0: resolution: {integrity: sha512-eu38+hdgojoyq63s+yTpN4XMBdt5l8HhMhc4VKLO9KM5caLIBvUm4thi7fFaxyTmCKeNnXZ5pAlBwCUnhA09uw==} engines: {node: '>=10'} @@ -7340,6 +7353,12 @@ packages: thunky: 1.1.0 dev: true + /multiple-select-vanilla@3.1.0: + resolution: {integrity: sha512-2UtPlinsO+dYH6bLisLLlvcsMAd1A6LnWpbiPNBT+97xSYSPnipEqlAQTwkxg9MoekpvG2jMZrthAHuZwki+vA==} + dependencies: + '@types/trusted-types': 2.0.7 + dev: true + /multiple-select-vanilla@3.1.3: resolution: {integrity: sha512-EcnBCgI/j5ilM3w+TcB3HhVixsN4yncXKi/Wv9EZnPy9PeLMasD0doyj/wxrlvmH0omaS0y9y1rdIZt2nbJaaw==} dependencies: diff --git a/test/cypress/e2e/example01.cy.ts b/test/cypress/e2e/example01.cy.ts index 98c7432a1..e2459891b 100644 --- a/test/cypress/e2e/example01.cy.ts +++ b/test/cypress/e2e/example01.cy.ts @@ -222,8 +222,8 @@ describe('Example 1 - Basic Grids', () => { .children('li') .each(($child, index) => { if (index <= 5) { - const $input = $child.children('input'); - const $label = $child.children('label'); + const $input = $child.find('input'); + const $label = $child.find('span.checkbox-label'); expect($input.prop('checked')).to.eq(true); expect($label.text()).to.eq(fullTitles[index]); } @@ -270,8 +270,8 @@ describe('Example 1 - Basic Grids', () => { .children('li') .each(($child, index) => { if (index <= 5) { - const $input = $child.children('input'); - const $label = $child.children('label'); + const $input = $child.find('input'); + const $label = $child.find('span.checkbox-label'); expect($input.prop('checked')).to.eq(true); expect($label.text()).to.eq(fullTitles[index]); } @@ -309,8 +309,8 @@ describe('Example 1 - Basic Grids', () => { .children('li') .each(($child, index) => { if (index <= 5) { - const $input = $child.children('input'); - const $label = $child.children('label'); + const $input = $child.find('input'); + const $label = $child.find('span.checkbox-label'); if ($label.text() === 'Title') { expect($input.attr('checked')).to.eq(undefined); } else { @@ -400,8 +400,8 @@ describe('Example 1 - Basic Grids', () => { .children('li') .each(($child, index) => { if (index <= 5) { - const $input = $child.children('input'); - const $label = $child.children('label'); + const $input = $child.find('input'); + const $label = $child.find('span.checkbox-label'); expect($input.prop('checked')).to.eq(true); expect($label.text()).to.eq(fullTitles[index]); } @@ -436,8 +436,8 @@ describe('Example 1 - Basic Grids', () => { .children('li') .each(($child, index) => { if (index <= 5) { - const $input = $child.children('input'); - const $label = $child.children('label'); + const $input = $child.find('input'); + const $label = $child.find('span.checkbox-label'); if ($label.text() === 'Title' || $label.text() === 'Start') { expect($input.attr('checked')).to.eq(undefined); } else { diff --git a/test/cypress/e2e/example03.cy.ts b/test/cypress/e2e/example03.cy.ts index c03f96e41..039ab5272 100644 --- a/test/cypress/e2e/example03.cy.ts +++ b/test/cypress/e2e/example03.cy.ts @@ -148,8 +148,7 @@ describe('Example 3 - Grid with Editors', () => { cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(11)`).click(); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(11) > input.editor-checkbox.editor-effort-driven`).check().blur(); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(10)`).click(); // the blur seems to not always work, so just click on another cell - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(11)`).find('.fa-check.checkmark-icon'); - + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(11)`).find('.mdi-check.checkmark-icon'); cy.get('.slick-viewport.slick-viewport-top.slick-viewport-left') .scrollTo('top'); }); diff --git a/test/cypress/e2e/example04.cy.ts b/test/cypress/e2e/example04.cy.ts index aaccacd63..5921e363a 100644 --- a/test/cypress/e2e/example04.cy.ts +++ b/test/cypress/e2e/example04.cy.ts @@ -9,7 +9,7 @@ describe('Example 4 - Client Side Sort/Filter Grid', () => { describe('Load Grid with Presets', () => { const presetDurationValues = [98, 10]; - const presetUsDateShort = '04/20/25'; + const presetUsDateShort = '4/20/25'; it('should have some metrics shown in the grid footer but make sure the first number is below 1500 items', () => { cy.get('#slickGridContainer-grid4') diff --git a/test/cypress/e2e/example07.cy.ts b/test/cypress/e2e/example07.cy.ts index f508c12eb..140c28b24 100644 --- a/test/cypress/e2e/example07.cy.ts +++ b/test/cypress/e2e/example07.cy.ts @@ -27,12 +27,12 @@ describe('Example 7 - Header Button Plugin', () => { cy.get('#grid7-1 .slick-header-columns') .children('.slick-header-column:nth(2)') - .find('.slick-header-button.fa.fa-circle-o.red.faded') + .find('.slick-header-button.mdi-lightbulb-outline.text-warning.faded') .click(); cy.get('#grid7-1 .slick-header-columns') .children('.slick-header-column:nth(2)') - .find('.slick-header-button.fa.fa-circle-o.red.faded') + .find('.slick-header-button.mdi-lightbulb-outline.text-warning.faded') .should('not.exist'); // shouldn't be faded anymore cy.window().then((win) => { @@ -83,13 +83,13 @@ describe('Example 7 - Header Button Plugin', () => { cy.get('#grid7-1 .slick-header-columns') .children('.slick-header-column:nth(9)') - .find('.slick-header-button.slick-header-button-disabled.fa.fa-circle-o.red.faded') + .find('.slick-header-button.slick-header-button-disabled.mdi-lightbulb-outline.text-warning.faded') .should('exist') .click(); cy.get('#grid7-1 .slick-header-columns') .children('.slick-header-column:nth(9)') - .find('.slick-header-button.slick-header-button-disabled.fa.fa-circle-o.red.faded') + .find('.slick-header-button.slick-header-button-disabled.mdi-lightbulb-outline.text-warning.faded') .should('exist'); // should still be faded after previous click cy.get('#grid7-1 .slick-row') @@ -170,7 +170,7 @@ describe('Example 7 - Header Button Plugin', () => { .children('.slick-header-column:nth(1)') .find('.slick-header-button.slick-header-button-hidden') .should('be.hidden') - .should('have.css', 'width', '0px'); + .should('have.css', 'visibility', 'hidden'); }); }); @@ -188,12 +188,12 @@ describe('Example 7 - Header Button Plugin', () => { cy.get('#grid7-2 .slick-header-columns') .children('.slick-header-column:nth(2)') - .find('.slick-header-button.fa.fa-circle-o.red.faded') + .find('.slick-header-button.mdi-lightbulb-outline.text-warning.faded') .click({ force: true }); cy.get('#grid7-2 .slick-header-columns') .children('.slick-header-column:nth(2)') - .find('.slick-header-button.fa.fa-circle-o.red.faded') + .find('.slick-header-button.mdi-lightbulb-outline.text-warning.faded') .should('not.exist'); // shouldn't be faded anymore cy.window().then((win) => { @@ -244,13 +244,13 @@ describe('Example 7 - Header Button Plugin', () => { cy.get('#grid7-2 .slick-header-columns') .children('.slick-header-column:nth(9)') - .find('.slick-header-button.slick-header-button-disabled.fa.fa-circle-o.red.faded') + .find('.slick-header-button.slick-header-button-disabled.mdi-lightbulb-outline.text-warning.faded') .should('exist') .click({ force: true }); cy.get('#grid7-2 .slick-header-columns') .children('.slick-header-column:nth(9)') - .find('.slick-header-button.slick-header-button-disabled.fa.fa-circle-o.red.faded') + .find('.slick-header-button.slick-header-button-disabled.mdi-lightbulb-outline.text-warning.faded') .should('exist'); // should still be faded after previous click cy.get('#grid7-2 .slick-row') @@ -330,8 +330,7 @@ describe('Example 7 - Header Button Plugin', () => { cy.get('#grid7-2 .slick-header-columns') .children('.slick-header-column:nth(1)') .find('.slick-header-button.slick-header-button-hidden') - .should('be.hidden'); - // .should('have.css', 'width', '0px'); + .should('have.css', 'visibility', 'hidden'); }); it('should filter "Column C" with positive number only and not expect any more red values', () => { diff --git a/test/cypress/e2e/example08.cy.ts b/test/cypress/e2e/example08.cy.ts index 05eb04e63..51f132cff 100644 --- a/test/cypress/e2e/example08.cy.ts +++ b/test/cypress/e2e/example08.cy.ts @@ -37,6 +37,9 @@ describe('Example 8 - Header Menu Plugin', () => { cy.get('.slick-menu-item .slick-menu-content') .contains('Hide Column') .should('exist'); + + cy.get('[data-test=selected-locale]') + .click(); }); it(`should be still be able to click on the Help command of 2nd column "Duration" and expect an alert`, () => { diff --git a/test/cypress/e2e/example16.cy.ts b/test/cypress/e2e/example16.cy.ts index 834296fc0..850ab5d7b 100644 --- a/test/cypress/e2e/example16.cy.ts +++ b/test/cypress/e2e/example16.cy.ts @@ -419,13 +419,13 @@ describe('Example 16 - Row Move & Checkbox Selector Selector Plugins', () => { cy.get('.slick-row') .first() .children('.slick-cell') - .children('.fa.fa-pencil') + .children('.mdi.mdi-pencil') .should('have.length', 1); cy.get('.slick-row') .first() .children('.slick-cell:nth(1)') - .children('.fa.fa-trash') + .children('.mdi.mdi-trash-can') .should('have.length', 1); }); }); diff --git a/test/cypress/e2e/example24.cy.ts b/test/cypress/e2e/example24.cy.ts index de2643d74..ffcc6042c 100644 --- a/test/cypress/e2e/example24.cy.ts +++ b/test/cypress/e2e/example24.cy.ts @@ -23,11 +23,11 @@ describe('Example 24 - Cell Menu & Context Menu Plugins', () => { cy.get('#grid24') .find('.slick-row .slick-cell:nth(5)') - .find('.fa-star.yellow'); + .find('.mdi-star.yellow'); cy.get('#grid24') .find('.slick-row .slick-cell:nth(6)') - .find('.fa-check.checkmark-icon'); + .find('.mdi-check.checkmark-icon'); cy.get('#grid24') .find('.slick-row .slick-cell:nth(7) .disabled') @@ -391,7 +391,7 @@ describe('Example 24 - Cell Menu & Context Menu Plugins', () => { cy.get('#grid24') .find('.slick-row .slick-cell:nth(5)') - .find('.fa-star.orange'); + .find('.mdi-star.orange'); cy.get('#grid24') .find('.slick-row .slick-cell:nth(7) .disabled') @@ -714,7 +714,7 @@ describe('Example 24 - Cell Menu & Context Menu Plugins', () => { .click(); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] .slick-cell:nth(5)`) - .find('.fa-star.red'); + .find('.mdi-star.red'); }); it('should be able to open Context Menu from any other cell and click on Export->Text and expect alert triggered with Text Export', () => { diff --git a/test/cypress/e2e/example30.cy.ts b/test/cypress/e2e/example30.cy.ts index 3c8f7a9da..270b6e6a6 100644 --- a/test/cypress/e2e/example30.cy.ts +++ b/test/cypress/e2e/example30.cy.ts @@ -35,14 +35,14 @@ describe('Example 30 Composite Editor Modal', () => { it('should display 2 different tooltips when hovering icons on "Title" column', () => { cy.get('.slick-column-name').as('title-column'); cy.get('@title-column') - .find('.fa-exclamation-triangle') + .find('.mdi-alert-outline') .trigger('mouseover'); cy.get('.slick-custom-tooltip').should('be.visible'); cy.get('.slick-custom-tooltip .tooltip-body').contains('Task must always be followed by a number'); cy.get('@title-column') - .find('.fa-info-circle') + .find('.mdi-information-outline') .trigger('mouseover'); cy.get('.slick-custom-tooltip').should('be.visible'); @@ -277,7 +277,7 @@ describe('Example 30 Composite Editor Modal', () => { cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(2)`).should('contain', '22 days'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(4)`).should('contain', '5'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(5).editable-field`).should('have.length', 1); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(9)`).should('contain', 'Tasty Granite Table'); @@ -311,7 +311,7 @@ describe('Example 30 Composite Editor Modal', () => { cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(2)`).should('contain', '33 days'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(4)`).should('contain', '17'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(5).editable-field`).should('have.length', 1); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('not.exist'); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('not.exist'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(8)`).should('be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(9)`).should('contain', 'Tasty Granite Table'); @@ -357,25 +357,25 @@ describe('Example 30 Composite Editor Modal', () => { it('should have updated values in the entire grid', () => { cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(4)`).should('contain', '51'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(5)`).should('contain', 'Straightforward'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(10)`).should('contain', 'Belgium'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(4)`).should('contain', '51'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(5)`).should('contain', 'Straightforward'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(10)`).should('contain', 'Belgium'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(4)`).should('contain', '51'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(5)`).should('contain', 'Straightforward'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(10)`).should('contain', 'Belgium'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(4)`).should('contain', '51'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(5)`).should('contain', 'Straightforward'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(10)`).should('contain', 'Belgium'); }); @@ -474,22 +474,22 @@ describe('Example 30 Composite Editor Modal', () => { it('should have updated all the changed values BUT only on the 2 selected rows', () => { cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(4)`).should('contain', '51'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(10)`).should('contain', 'Belgium'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(4)`).should('contain', '77'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(10)`).should('contain', 'Belize'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(4)`).should('contain', '77'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 2}px;"] > .slick-cell:nth(10)`).should('contain', 'Belize'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(4)`).should('contain', '51'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 3}px;"] > .slick-cell:nth(10)`).should('contain', 'Belgium'); }); @@ -555,7 +555,7 @@ describe('Example 30 Composite Editor Modal', () => { cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(1)`).contains('TASK 8899', { matchCase: false }); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(2)`).should('contain', '33 days'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(4)`).should('contain', '51'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(10)`).should('contain', 'Belgium'); }); @@ -589,7 +589,7 @@ describe('Example 30 Composite Editor Modal', () => { cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(1)`).contains('TASK 9999', { matchCase: false }); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(2)`).should('contain', '44 days'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(4)`).should('contain', '17'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 0); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 0); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(8)`).should('be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(10)`).should('contain', 'Belgium'); }); @@ -598,7 +598,7 @@ describe('Example 30 Composite Editor Modal', () => { cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(1)`).should('contain', '8899'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(2)`).should('contain', '33 days'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(4)`).should('contain', '51'); - cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(7)`).find('.fa.fa-check.checkmark-icon').should('have.length', 1); + cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(7)`).find('.mdi.mdi-check.checkmark-icon').should('have.length', 1); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(8)`).should('not.be.empty'); cy.get(`[style="top: ${GRID_ROW_HEIGHT * 1}px;"] > .slick-cell:nth(10)`).should('contain', 'Belgium'); }); diff --git a/test/cypress/e2e/example31.cy.ts b/test/cypress/e2e/example31.cy.ts index 2069f8952..3bb0369df 100644 --- a/test/cypress/e2e/example31.cy.ts +++ b/test/cypress/e2e/example31.cy.ts @@ -694,7 +694,7 @@ describe('Example 31 - OData Grid using RxJS', () => { cy.get(`[style="top: ${GRID_ROW_HEIGHT * 0}px;"] > .slick-cell:nth(2)`) .should('contain', 'male') - .type('{enter}'); + .click(); cy.get('[data-name="editor-gender"].ms-drop') .find('li:visible') diff --git a/test/cypress/e2e/example33.cy.ts b/test/cypress/e2e/example33.cy.ts index 214634a98..9b2dff8b4 100644 --- a/test/cypress/e2e/example33.cy.ts +++ b/test/cypress/e2e/example33.cy.ts @@ -87,7 +87,7 @@ describe('Example 33 - Regular & Custom Tooltips', () => { cy.get('.tooltip-2cols-row:nth(2)').find('div:nth(1)').should('be.empty'); cy.get('.tooltip-2cols-row:nth(3)').find('div:nth(0)').contains('Completion:'); - cy.get('.tooltip-2cols-row:nth(3)').find('div:nth(1)').find('.fa-check-circle-o').should('exist'); + cy.get('.tooltip-2cols-row:nth(3)').find('div:nth(1)').find('.mdi-check-circle-outline').should('exist'); cy.get('@start6-cell').trigger('mouseout'); }); @@ -133,7 +133,7 @@ describe('Example 33 - Regular & Custom Tooltips', () => { cy.get('.tooltip-2cols-row:nth(2)').find('div:nth(1)').should('be.empty'); cy.get('.tooltip-2cols-row:nth(3)').find('div:nth(0)').contains('Completion:'); - cy.get('.tooltip-2cols-row:nth(3)').find('div:nth(1)').find('.fa-check-circle-o').should('exist'); + cy.get('.tooltip-2cols-row:nth(3)').find('div:nth(1)').find('.mdi-check-circle-outline').should('exist'); cy.get('@duration2-cell').trigger('mouseout'); }); diff --git a/test/cypress/support/commands.ts b/test/cypress/support/commands.ts index 8e8a4c1a6..01c51d966 100644 --- a/test/cypress/support/commands.ts +++ b/test/cypress/support/commands.ts @@ -23,6 +23,7 @@ // // -- This will overwrite an existing command -- import '@4tw/cypress-drag-drop'; +import 'cypress-real-events'; import { convertPosition } from './common'; declare global { diff --git a/test/tsconfig.json b/test/tsconfig.json index cb86e5f87..b84815f02 100644 --- a/test/tsconfig.json +++ b/test/tsconfig.json @@ -2,7 +2,6 @@ "compilerOptions": { "target": "es2021", "lib": ["es5", "dom"], - "types": ["jest", "node"], "allowJs": true, "skipLibCheck": true, "esModuleInterop": true, @@ -13,6 +12,12 @@ "resolveJsonModule": true, "isolatedModules": true, "baseUrl": ".", + "types": [ + "cypress-real-events", + "jest", + "jest-extended", + "node" + ], "typeRoots": [ "../node_modules/@types" ]