-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
JelteMX
committed
Jan 20, 2020
0 parents
commit 8406849
Showing
46 changed files
with
24,721 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
const base = require("@mendix/pluggable-widgets-tools/configs/eslint.ts.base.json"); | ||
|
||
module.exports = { | ||
...base, | ||
rules: { | ||
"@typescript-eslint/ban-ts-ignore": "warn", | ||
"@typescript-eslint/no-empty-interface": "off", | ||
"react/no-find-dom-node": "off", | ||
"react/no-deprecated": "warn" | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
* text=auto | ||
*.ts text eol=lf | ||
*.tsx text eol=lf | ||
*.js text eol=lf | ||
*.jsx text eol=lf | ||
*.css text eol=lf | ||
*.scss text eol=lf | ||
*.json text eol=lf | ||
*.xml text eol=lf | ||
*.md text eol=lf | ||
*.gitattributes eol=lf | ||
*.gitignore eol=lf | ||
*.png binary | ||
*.jpg binary | ||
*.gif binary |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
dist/ | ||
node_modules/ | ||
*.log | ||
.env | ||
.vscode | ||
.DS_Store |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
The Apache License v2.0 | ||
|
||
Copyright Jelte Lagendijk 2019 | ||
|
||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
|
||
http://www.apache.org/licenses/LICENSE-2.0 | ||
|
||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,128 @@ | ||
[data:image/s3,"s3://crabby-images/87f0f/87f0f246b897c8dc2400c7964b09ddad3469bee6" alt="Build Status"](https://travis-ci.org/JelteMX/mendix-dynamic-table) | ||
[data:image/s3,"s3://crabby-images/1fa1a/1fa1ace28cbce771fb7172616cf50a5c18490e72" alt="Coverage Status"](https://coveralls.io/github/JelteMX/mendix-dynamic-table?branch=master) | ||
[data:image/s3,"s3://crabby-images/e52df/e52df76fab50728fd861d0a651ad72f9f8684fbd" alt="Dependencies"]([https://david-dm.org/JelteMX/mendix-dynamic-table](https://david-dm.org/JelteMX/mendix-dynamic-table)) | ||
[data:image/s3,"s3://crabby-images/e47bd/e47bda70c902b529c34642af9246ae146ab1c147" alt="DevDependencies"]([https://david-dm.org/JelteMX/mendix-dynamic-table?type=dev](https://david-dm.org/JelteMX/mendix-dynamic-table?type=dev)) | ||
[data:image/s3,"s3://crabby-images/be45e/be45ecbb8011d52437db0234c22927ad6a6a0b4f" alt="Support"-orange.svg)](https://docs.mendix.com/developerportal/app-store/app-store-content-support) | ||
[data:image/s3,"s3://crabby-images/e033b/e033be9048915763138bb258b678691824872431" alt="Studio"](https://appstore.home.mendix.com/link/modeler/) | ||
[data:image/s3,"s3://crabby-images/e457a/e457a797c64f46a107b75bc07d7329c8a58884f0" alt="GitHub release"](https://github.com/JelteMX/mendix-dynamic-table/releases/latest) | ||
[data:image/s3,"s3://crabby-images/f5987/f59871b7233122f09f1f55c91cc80bd100470867" alt="GitHub issues"](https://github.com/JelteMX/mendix-dynamic-table/issues) | ||
|
||
## Dynamic (Tree) Table for Mendix | ||
|
||
Mendix Dynamic (Tree) Table using [Ant Design Table](https://ant.design/components/table/) (MIT License). This is inspired on the [Tree Table widget](https://appstore.home.mendix.com/link/app/111095/), but takes objects in the columns as well. | ||
|
||
data:image/s3,"s3://crabby-images/2d7da/2d7da79097b896f7e0248d86a775ca706ce90495" alt="logo" | ||
|
||
Show a reference table. Rows & Columns are Mendix objects, Entry objects are in between. | ||
|
||
data:image/s3,"s3://crabby-images/4ee62/4ee62882b6e6a3da1c7f9c6b6c02555a19c77758" alt="screenshot" | ||
|
||
> See test-project [https://dynamictabletest-sandbox.mxapps.io/](https://dynamictabletest-sandbox.mxapps.io/) for a live demo! On the bottom of this page there is a short explanation of the Domain model that is used. | ||
> Missing features? See TODO at the bottom to see which items are still on the TODO list. If you find other bugs, please report this as an issue [here](https://github.com/JelteMX/mendix-dynamic-table/issues) | ||
## Features | ||
|
||
- Display a tree structure in a table | ||
- Data Sources: XPath, Microflow, Nanoflow | ||
- Children: Get over reference, Microflow, Nanoflow | ||
- Selection of rows (single, multi) | ||
- Events: Click/Double click on Row, Column, Entry or empty field | ||
|
||
> This widget is about 850Kb uncompressed, so in your cloud deployment this widget should take about 220 Kb of network resources | ||
Tested: | ||
|
||
- IE11 & Edge | ||
- Chrome | ||
- Firefox | ||
- Safari | ||
|
||
## Basic Configuration | ||
|
||
### 1. Row | ||
|
||
data:image/s3,"s3://crabby-images/4924a/4924a2bb29a2cb092b4b353fc419b5d21026e13e" alt="settings" | ||
|
||
- Rows can be retrieved over XPath, Microflows and Nanoflows | ||
- Your title can be purely text or HTML, either through the attribute or Nanoflow. Make sure you sanitize any user input to prevent XSS issues. | ||
|
||
### 2. Row Children | ||
|
||
data:image/s3,"s3://crabby-images/be376/be376b6d69c2d5a44a9929864b798f0a0b6620ef" alt="settings" | ||
|
||
- This is totally optional. If you want to do a tree structure, please configure the children | ||
- You can either get these over a Child reference (see bottom for explanation) or through a Microflow/Nanoflow when using a hasChildren attribute | ||
|
||
### 3. Column | ||
|
||
data:image/s3,"s3://crabby-images/c4234/c4234d812d375db67e5760a3d7713fd5efab2845" alt="settings" | ||
|
||
- Columns can be retrieved over XPath, Microflows and Nanoflows | ||
- Your title can be purely text or HTML, either through the attribute or Nanoflow. Make sure you sanitize any user input to prevent XSS issues. | ||
|
||
### 4. Entries | ||
|
||
data:image/s3,"s3://crabby-images/116f4/116f4ba4a41d48727e406161fa24f9b3e586f014" alt="settings" | ||
|
||
- An Entry is an object that is linked to 1 row and 1 column | ||
- An Entry has a title (see Column/Row title, same principle) | ||
- In order to retrieve entries, you will need to use a Data Helper (see next) | ||
|
||
### 5. Data Helper | ||
|
||
data:image/s3,"s3://crabby-images/88022/880222cd9ca4d796a3969f80012228018922259f" alt="settings" | ||
|
||
- See explanation in the settings screen | ||
|
||
### 6. Selection | ||
|
||
data:image/s3,"s3://crabby-images/89b3c/89b3cda5f5823ae18b54ab9e4419bff02de9ccfb" alt="settings" | ||
|
||
### 7. Events | ||
|
||
data:image/s3,"s3://crabby-images/c85c9/c85c93c94f9f57bfa451314b1f3098cffc5ca415" alt="settings" | ||
|
||
### 8. UI Settings | ||
|
||
data:image/s3,"s3://crabby-images/7f85a/7f85a8f3a21df0359cd32d17c14e9e5db40b819a" alt="settings" | ||
|
||
## Demo project | ||
|
||
[https://dynamictabletest-sandbox.mxapps.io/](https://dynamictabletest-sandbox.mxapps.io/) | ||
|
||
### Domain Model | ||
|
||
This demo uses the following domain model: | ||
|
||
data:image/s3,"s3://crabby-images/9e45d/9e45da4a7ef27caee155a44ef9d4339d3fc98a56" alt="domain model" | ||
|
||
Short explanation: | ||
|
||
- A table is placed inside a data view with a `View` object | ||
- For the first rows, it will get all `Rows` that have a reference to `View` and `_Root = true` | ||
- Every row might have children. You either get these over a reference `Children`, or when you use a Microflow and `_hasChildren = true` | ||
- `Column` Objects also have a reference to View, although it is not entirely necessary | ||
- When loading `Entry` object, the widget will create a `EntryHelper` object that has references to the shown Rows&Columns. This helper is passed down to a microflow/nanoflow | ||
- When the `Entry` objects are loaded, the widget will place these in the correct field based on the reference to a Column/Row | ||
- The `SelectionHelper` is used for selections, but this is based on the test-project and can be disregarded here. | ||
|
||
## Issues, suggestions and feature requests | ||
|
||
Please report your issues [here](https://github.com/JelteMX/mendix-dynamic-table/issues) | ||
|
||
## TODO | ||
|
||
The following things need to be further tested and/or fixed. Please don't report this as a bug if this is in the TODO list: | ||
|
||
- Basic WebModeler preview + settings | ||
- Add Icon attribute (from Tree Table) | ||
- Add config for when context changes (reload rows?) | ||
- Column overflow (first column) | ||
- Header height | ||
- Left column lock issue with header. This is when locking the left column, it can get out of sync with the header. | ||
- Unit tests | ||
|
||
## License | ||
|
||
Apache 2 |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.