survey-analytics 1.9.30 → 1.9.33
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +36 -45
- package/package.json +2 -2
- package/survey.analytics.css +3 -2
- package/survey.analytics.d.ts +240 -39
- package/survey.analytics.datatables.css +1 -1
- package/survey.analytics.datatables.js +507 -132
- package/survey.analytics.datatables.min.css +1 -1
- package/survey.analytics.datatables.min.js +2 -2
- package/survey.analytics.js +57 -45
- package/survey.analytics.min.css +2 -2
- package/survey.analytics.min.js +3 -3
- package/survey.analytics.tabulator.css +1 -1
- package/survey.analytics.tabulator.js +517 -143
- package/survey.analytics.tabulator.min.css +1 -1
- package/survey.analytics.tabulator.min.js +2 -2
package/README.md
CHANGED
|
@@ -1,8 +1,5 @@
|
|
|
1
|
-

|
|
2
|
-
|
|
3
1
|
# SurveyJS Analytics
|
|
4
2
|
|
|
5
|
-
|
|
6
3
|
[](https://dev.azure.com/SurveyJS/SurveyJS%20Integration%20Tests/_build/latest?definitionId=7&branchName=master)
|
|
7
4
|
<a href="https://github.com/DevExpress/testcafe">
|
|
8
5
|
<img alt="Tested with TestCafe" src="https://img.shields.io/badge/tested%20with-TestCafe-2fa4cf.svg">
|
|
@@ -14,83 +11,77 @@
|
|
|
14
11
|
<img alt="Closed issues" title="Closed issues" src="https://img.shields.io/github/issues-closed/surveyjs/survey-analytics.svg">
|
|
15
12
|
</a>
|
|
16
13
|
|
|
17
|
-
SurveyJS Analytics
|
|
18
|
-
|
|
19
|
-
## Main Features
|
|
14
|
+
SurveyJS Analytics visualizes survey results and allows users to analyze them.
|
|
20
15
|
|
|
21
|
-
-
|
|
22
|
-
- Count answers and render results as gauge for range type question
|
|
23
|
-
- Three different types of charts: bar, pie and line
|
|
24
|
-
- Wordcloud for text questions representation
|
|
25
|
-
- Interactive filtering for the select type questions
|
|
26
|
-
- Flexible layout and customizable colors
|
|
16
|
+

|
|
27
17
|
|
|
28
|
-
##
|
|
18
|
+
## Features
|
|
29
19
|
|
|
30
|
-
|
|
20
|
+
- Supported chart types:
|
|
21
|
+
- Bar
|
|
22
|
+
- Pie
|
|
23
|
+
- Line
|
|
24
|
+
- Gauge
|
|
25
|
+
- Bullet
|
|
26
|
+
- Scatter
|
|
27
|
+
- Word cloud
|
|
28
|
+
- Interactive filtering
|
|
29
|
+
- Customizable colors
|
|
30
|
+
- Dynamic layout
|
|
31
|
+
- Chart reordering via drag and drop
|
|
31
32
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
- [how to show chanrt for the one question](https://next.plnkr.co/edit/3yIIFnbcn8RMJQHY?preview).
|
|
35
|
-
|
|
36
|
-
## Licensing
|
|
33
|
+
## Get Started
|
|
37
34
|
|
|
38
|
-
|
|
35
|
+
- [Angular](https://surveyjs.io/Documentation/Analytics?id=get-started-angular)
|
|
36
|
+
- [Vue](https://surveyjs.io/Documentation/Analytics?id=get-started-vue)
|
|
37
|
+
- [React](https://surveyjs.io/Documentation/Analytics?id=get-started-react)
|
|
38
|
+
- [Knockout / jQuery](https://surveyjs.io/Documentation/Analytics?id=get-started-knockout-jquery)
|
|
39
39
|
|
|
40
|
-
##
|
|
40
|
+
## Resources
|
|
41
41
|
|
|
42
|
-
|
|
42
|
+
- [Website](https://surveyjs.io/)
|
|
43
|
+
- [Documentation](https://surveyjs.io/Documentation/Analytics)
|
|
44
|
+
- [Live Examples](https://surveyjs.io/Examples/Analytics)
|
|
45
|
+
- [What's New](https://surveyjs.io/WhatsNew)
|
|
43
46
|
|
|
44
|
-
##
|
|
47
|
+
## Build SurveyJS Analytics from Sources
|
|
45
48
|
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
1. **Clone the repo from GitHub**
|
|
49
|
+
1. **Clone the repo**
|
|
49
50
|
|
|
50
51
|
```
|
|
51
52
|
git clone https://github.com/surveyjs/survey-analytics.git
|
|
52
53
|
cd survey-analytics
|
|
53
54
|
```
|
|
54
55
|
|
|
55
|
-
|
|
56
|
+
1. **Install dependencies**
|
|
57
|
+
Make sure that you have Node.js v6.0.0 or later and npm v2.7.0 or later installed.
|
|
56
58
|
|
|
57
59
|
```
|
|
58
60
|
npm install
|
|
59
61
|
```
|
|
60
62
|
|
|
61
|
-
|
|
63
|
+
1. **Build the library**
|
|
62
64
|
|
|
63
65
|
```
|
|
64
66
|
npm run build_prod
|
|
65
67
|
```
|
|
66
68
|
|
|
67
|
-
|
|
69
|
+
You can find the built scripts and style sheets in the `packages` folder.
|
|
68
70
|
|
|
69
|
-
|
|
71
|
+
1. **Run test examples**
|
|
70
72
|
|
|
71
73
|
```
|
|
72
74
|
npm start
|
|
73
75
|
```
|
|
74
76
|
|
|
75
|
-
This command
|
|
77
|
+
This command runs a local HTTP server at http://localhost:8080/.
|
|
76
78
|
|
|
77
|
-
|
|
79
|
+
1. **Run unit tests**
|
|
78
80
|
|
|
79
|
-
5. **Run unit tests**
|
|
80
81
|
```
|
|
81
82
|
npm test
|
|
82
83
|
```
|
|
83
|
-
This command will run unit tests
|
|
84
|
-
|
|
85
|
-
## Nearest plans
|
|
86
|
-
|
|
87
|
-
Our task list of Survey Analytics pack:
|
|
88
84
|
|
|
89
|
-
|
|
90
|
-
- Introduce (or use 3rd party) data processing engine for survey analytics
|
|
91
|
-
- Support high load scenario - process at least billion records
|
|
92
|
-
|
|
93
|
-
## Limitations
|
|
85
|
+
## Licensing
|
|
94
86
|
|
|
95
|
-
|
|
96
|
-
- WordCloud visualizer is too slow for large texts and significant answers count
|
|
87
|
+
SurveyJS Analytics is **not available for free commercial usage**. If you want to integrate it into your application, you must purchase a [commercial license](/Licenses#SurveyCreator).
|
package/package.json
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
"test_debug": "node --inspect-brk ./node_modules/jest/bin/jest.js --runInBand",
|
|
7
7
|
"testcafe": "concurrently \"http-server\" \"testcafe chrome testCafe/\"",
|
|
8
8
|
"testcafe_ci": "http-server --silent & testcafe chrome:headless testCafe/ --reporter minimal,dashboard",
|
|
9
|
-
"
|
|
9
|
+
"testcafe:file": "concurrently \"http-server --silent\" \"testcafe chrome testCafe/tabulator/basetests.js --selector-timeout 1500 --reporter minimal --debug-mode\"",
|
|
10
10
|
"release": "standard-version --message \"Release: %s [skip ci]\" ",
|
|
11
11
|
"doc_gen": "node doc_generator/lib_docgenerator.js src/index.ts",
|
|
12
12
|
"doc_update": "chmod +x ./docupdate_npm.sh && ./docupdate_npm.sh",
|
|
@@ -16,7 +16,7 @@
|
|
|
16
16
|
"lint": "eslint ./src --quiet",
|
|
17
17
|
"pre-push-check": "npm run lint && npm run test"
|
|
18
18
|
},
|
|
19
|
-
"version": "1.9.
|
|
19
|
+
"version": "1.9.33",
|
|
20
20
|
"name": "survey-analytics",
|
|
21
21
|
"description": "SurveyJS analytics Library.",
|
|
22
22
|
"main": "survey.analytics.js",
|
package/survey.analytics.css
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*!
|
|
2
|
-
* surveyjs - SurveyJS Analytics library v1.9.
|
|
2
|
+
* surveyjs - SurveyJS Analytics library v1.9.33
|
|
3
3
|
* Copyright (c) 2015-2022 Devsoft Baltic OÜ - http://surveyjs.io/
|
|
4
4
|
* License: MIT (http://www.opensource.org/licenses/mit-license.php)
|
|
5
5
|
*/
|
|
@@ -90,6 +90,7 @@
|
|
|
90
90
|
vertical-align: middle;
|
|
91
91
|
cursor: pointer;
|
|
92
92
|
border: 1px solid transparent;
|
|
93
|
+
white-space: nowrap;
|
|
93
94
|
margin: 0 10px; }
|
|
94
95
|
.sa-toolbar__button:hover {
|
|
95
96
|
border-color: #e7e7e7;
|
|
@@ -274,4 +275,4 @@
|
|
|
274
275
|
background-color: #1ab394; }
|
|
275
276
|
|
|
276
277
|
|
|
277
|
-
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://[pc-name]/./src/visualizerBase.scss","webpack://[pc-name]/./src/visualizationPanel.scss","webpack://[pc-name]/./src/_globals.scss","webpack://[pc-name]/./src/text.scss","webpack://[pc-name]/./src/choices-table.scss"],"names":[],"mappings":"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","file":"survey.analytics.css","sourcesContent":["@import \"globals\";\n\n.sa-visualizer__toolbar {\n}\n\n.sa-visualizer__content {\n  font-family: SegoeUI, Arial, sans-serif;\n  display: inline-block;\n  overflow: hidden;\n  width: 100%;\n}\n\n.sa-visualizer__footer {\n  margin-top: 10px;\n}\n\n.sa-visualizer__footer-title {\n  display: inline-block;\n  font-family: Raleway;\n  font-size: 14px;\n  color: #404040;\n  line-height: 34px;\n  vertical-align: middle;\n  margin: 0;\n}\n\n.sa-visualizer__footer-content {\n  margin-top: 10px;\n}\n","@import \"globals\";\n\n.sa-panel__header {\n  margin: 0 1em;\n}\n\n.sa-grid {\n  position: relative;\n}\n\n.sa-grid__grid-sizer {\n  width: 100%;\n  box-sizing: border-box;\n  @media screen and (min-width: 1400px) {\n    width: 50%;\n  }\n}\n\n.sa-question {\n  display: inline-block;\n  width: 100%;\n  vertical-align: top;\n  box-sizing: border-box;\n  overflow: hidden;\n  padding: 1em;\n}\n\n.sa-question-layouted {\n  position: absolute;\n\n  @media screen and (min-width: 1400px) {\n    width: calc(50% - 1px);\n  }\n}\n\n.sa-question__content {\n  background-color: $background-color;\n  padding: 20px;\n}\n\n.sa-question__title {\n  margin-left: 30px;\n  font-family: Raleway;\n  font-size: 18px;\n  font-weight: bold;\n  color: $text-color;\n  margin: 0;\n  margin-bottom: 1em;\n}\n\n.sa-question__title--draggable {\n  cursor: move;\n  &:after {\n    content: \" \";\n    display: block;\n    float: right;\n    width: 15px;\n    height: 15px;\n    background-image: url(\"data:image/svg+xml,%3Csvg version='1.1' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cg%3E%3Cpolygon style='fill: %231ab394' points='13,5 12,6 13,7 9,7 9,3 10,4 11,3 8,0 5,3 6,4 7,3 7,7 3,7 4,6 3,5 0,8 3,11 4,10 3,9 7,9 7,13 6,12 5,13 8,16 11,13 10,12 9,13 9,9 13,9 12,10 13,11 16,8 '/%3E%3C/g%3E%3C/svg%3E \");\n  }\n}\n\n.sa-toolbar {\n  font-family: SegoeUI, Arial, sans-serif;\n  font-size: 14px;\n  color: $text-color;\n  line-height: 34px;\n  margin-bottom: 25px;\n  & > *:not(:first-child) {\n    margin-left: 10px;\n  }\n}\n\n.sa-toolbar__button {\n  font-family: SegoeUI, Arial, sans-serif;\n  font-size: 14px;\n  padding: 8px;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid transparent;\n  &:hover {\n    border-color: $border-color;\n    background-blend-mode: darken;\n  }\n  margin: 0 10px;\n  &:first-child {\n    margin-left: 0;\n  }\n  &:last-child {\n    margin-right: 0;\n  }\n}\n\n.sa-toolbar__svg-button {\n  width: 15px;\n  height: 15px;\n  padding: 0;\n  border: none;\n  outline: none;\n  background-color: inherit;\n  cursor: pointer;\n  use {\n    fill: $svg-color;\n  }\n  &:hover {\n    use {\n      fill: $svg-hover-color;\n    }\n  }\n  svg {\n    width: 15px;\n    height: 15px;\n  }\n}\n\n.sa-toolbar__button--right {\n  float: right;\n}\n\n// custom select\n.sa-question__select-wrapper {\n  position: relative;\n  display: inline-block;\n  min-width: 200px;\n  max-width: 300px;\n\n  .sa-question__select {\n    width: 100%;\n    display: block;\n    position: relative;\n    appearance: none;\n    -webkit-appearance: none;\n    -moz-appearance: none;\n    border-radius: 2px;\n    background: $text-color-inverse;\n    border-color: $border-color;\n    height: $form-element-height;\n    padding: 5px 23px 5px 15px;\n    line-height: initial;\n\n    &::-ms-expand {\n      display: none;\n    }\n\n    &:focus {\n      outline: 0;\n      box-shadow: none;\n    }\n\n    &:disabled {\n      color: $disabled-color;\n    }\n  }\n\n  &:before {\n    margin-top: -4px;\n    top: 50%;\n    right: 10px;\n    z-index: 1;\n    content: \"\";\n    position: absolute;\n    width: 4px;\n    height: 4px;\n    border-right: 2px solid $text-color;\n    border-bottom: 2px solid $text-color;\n    transform: rotate(45deg);\n    box-sizing: content-box;\n  }\n}\n// EO custom select\n\n.sa-question__filter {\n  display: inline-block;\n  padding: 0 1em;\n}\n\n.sa-question__filter-text {\n  vertical-align: middle;\n  margin-top: 1px;\n}\n\n.sa-commercial {\n  font-size: 12px;\n  padding: 1em 0 0.5em 2em;\n  svg {\n    width: 20px;\n    height: 20px;\n    fill: $main-color;\n  }\n}\n.sa-commercial__text {\n  font-weight: bold;\n  text-decoration: none;\n  color: $main-color;\n}\n.sa-commercial__product {\n  padding-left: 0.5em;\n}\n\n/* latin-ext */\n@font-face {\n  font-family: \"Raleway\";\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Raleway\"), local(\"Raleway-Regular\"),\n    url(https://fonts.gstatic.com/s/raleway/v14/1Ptug8zYS_SKggPNyCMIT5lu.woff2)\n      format(\"woff2\");\n  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB,\n    U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;\n}\n/* latin */\n@font-face {\n  font-family: \"Raleway\";\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Raleway\"), local(\"Raleway-Regular\"),\n    url(https://fonts.gstatic.com/s/raleway/v14/1Ptug8zYS_SKggPNyC0ITw.woff2)\n      format(\"woff2\");\n  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,\n    U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215,\n    U+FEFF, U+FFFD;\n}\n/* latin-ext */\n@font-face {\n  font-family: \"Raleway\";\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Raleway Bold\"), local(\"Raleway-Bold\"),\n    url(https://fonts.gstatic.com/s/raleway/v14/1Ptrg8zYS_SKggPNwJYtWqhPAMif.woff2)\n      format(\"woff2\");\n  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB,\n    U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;\n}\n/* latin */\n@font-face {\n  font-family: \"Raleway\";\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Raleway Bold\"), local(\"Raleway-Bold\"),\n    url(https://fonts.gstatic.com/s/raleway/v14/1Ptrg8zYS_SKggPNwJYtWqZPAA.woff2)\n      format(\"woff2\");\n  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,\n    U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215,\n    U+FEFF, U+FFFD;\n}\n","$main-color: #1ab394;\n$auxiliary-color: #ff9814;\n$auxiliary-color-1: #666666;\n$auxiliary-color-2: #1948b3;\n$danger-color: #d9534f;\n$disabled-color: #b0b0b0;\n\n$blue-color: #394cff;\n$purple-color: #aa42d0;\n$green-color: #41c02c;\n\n$text-color-inverse: #fff;\n$text-color: #404040;\n\n$content-max-width: 1170px;\n\n$background-color: #f7f7f7;\n$background-color-dark: #eeeeee;\n$background-disabled-color: #b7b7b7;\n\n$border-color: #e7e7e7;\n\n$form-element-height: 34px;\n\n$svg-color: rgba(#9f9f9f, 0.4);\n$svg-hover-color: #9f9f9f;\n","@import \"globals\";\n\n.sa-text-table__container {\n  width: 100%;\n  min-height: 200px;\n  max-height: 500px;\n  overflow: auto;\n}\n\n.sa-text-table {\n  width: 100%;\n  font-family: SegoeUI, Arial, sans-serif;\n  font-size: 14px;\n  color: $text-color;\n  border-width: 1px;\n\tborder-collapse: collapse;\n  background-color: $background-color;\n}\n\n.sa-text-table__cell {\n\tborder-width: 1px;\n\tpadding: 8px;\n\tborder-style: solid;\n\tborder-color: $border-color;\n  background-color: $background-color;\n  min-height: $form-element-height;\n}\n","@import \"globals\";\n\n.sa-choices-table__container {\n  width: 100%;\n  min-height: 200px;\n  max-height: 500px;\n  overflow: auto;\n}\n\n.sa-choices-table {\n  width: 100%;\n  font-family: SegoeUI, Arial, sans-serif;\n  font-size: 14px;\n  color: $text-color;\n\t// border-collapse: collapse;\n  background-color: $background-color;\n}\n\n.sa-choices-table__cell {\n\tborder-width: 1px;\n\tpadding: 8px;\n\tborder-style: solid;\n\tborder-color: $border-color;\n  background-color: $background-color;\n  min-height: $form-element-height;\n}\n\n.sa-choices-table__cell-value {\n  text-align: right;\n  min-width: 30px;\n}\n\n.sa-choices-table__cell-header {\n  font-weight: bold;\n}\n\n.sa-choices-sparkline {\n  min-width: 100px;\n  height: 24px;\n  border: 1px solid $main-color;\n}\n.sa-choices-sparkline-value {\n  height: 100%;\n  background-color: $main-color;\n}"],"sourceRoot":""}*/
|
|
278
|
+
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://[pc-name]/./src/visualizerBase.scss","webpack://[pc-name]/./src/visualizationPanel.scss","webpack://[pc-name]/./src/_globals.scss","webpack://[pc-name]/./src/text.scss","webpack://[pc-name]/./src/choices-table.scss"],"names":[],"mappings":"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","file":"survey.analytics.css","sourcesContent":["@import \"globals\";\n\n.sa-visualizer__toolbar {\n}\n\n.sa-visualizer__content {\n  font-family: SegoeUI, Arial, sans-serif;\n  display: inline-block;\n  overflow: hidden;\n  width: 100%;\n}\n\n.sa-visualizer__footer {\n  margin-top: 10px;\n}\n\n.sa-visualizer__footer-title {\n  display: inline-block;\n  font-family: Raleway;\n  font-size: 14px;\n  color: #404040;\n  line-height: 34px;\n  vertical-align: middle;\n  margin: 0;\n}\n\n.sa-visualizer__footer-content {\n  margin-top: 10px;\n}\n","@import \"globals\";\n\n.sa-panel__header {\n  margin: 0 1em;\n}\n\n.sa-grid {\n  position: relative;\n}\n\n.sa-grid__grid-sizer {\n  width: 100%;\n  box-sizing: border-box;\n  @media screen and (min-width: 1400px) {\n    width: 50%;\n  }\n}\n\n.sa-question {\n  display: inline-block;\n  width: 100%;\n  vertical-align: top;\n  box-sizing: border-box;\n  overflow: hidden;\n  padding: 1em;\n}\n\n.sa-question-layouted {\n  position: absolute;\n\n  @media screen and (min-width: 1400px) {\n    width: calc(50% - 1px);\n  }\n}\n\n.sa-question__content {\n  background-color: $background-color;\n  padding: 20px;\n}\n\n.sa-question__title {\n  margin-left: 30px;\n  font-family: Raleway;\n  font-size: 18px;\n  font-weight: bold;\n  color: $text-color;\n  margin: 0;\n  margin-bottom: 1em;\n}\n\n.sa-question__title--draggable {\n  cursor: move;\n  &:after {\n    content: \" \";\n    display: block;\n    float: right;\n    width: 15px;\n    height: 15px;\n    background-image: url(\"data:image/svg+xml,%3Csvg version='1.1' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cg%3E%3Cpolygon style='fill: %231ab394' points='13,5 12,6 13,7 9,7 9,3 10,4 11,3 8,0 5,3 6,4 7,3 7,7 3,7 4,6 3,5 0,8 3,11 4,10 3,9 7,9 7,13 6,12 5,13 8,16 11,13 10,12 9,13 9,9 13,9 12,10 13,11 16,8 '/%3E%3C/g%3E%3C/svg%3E \");\n  }\n}\n\n.sa-toolbar {\n  font-family: SegoeUI, Arial, sans-serif;\n  font-size: 14px;\n  color: $text-color;\n  line-height: 34px;\n  margin-bottom: 25px;\n  & > *:not(:first-child) {\n    margin-left: 10px;\n  }\n}\n\n.sa-toolbar__button {\n  font-family: SegoeUI, Arial, sans-serif;\n  font-size: 14px;\n  padding: 8px;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid transparent;\n  white-space: nowrap;\n\n  &:hover {\n    border-color: $border-color;\n    background-blend-mode: darken;\n  }\n  margin: 0 10px;\n  &:first-child {\n    margin-left: 0;\n  }\n  &:last-child {\n    margin-right: 0;\n  }\n}\n\n.sa-toolbar__svg-button {\n  width: 15px;\n  height: 15px;\n  padding: 0;\n  border: none;\n  outline: none;\n  background-color: inherit;\n  cursor: pointer;\n  use {\n    fill: $svg-color;\n  }\n  &:hover {\n    use {\n      fill: $svg-hover-color;\n    }\n  }\n  svg {\n    width: 15px;\n    height: 15px;\n  }\n}\n\n.sa-toolbar__button--right {\n  float: right;\n}\n\n// custom select\n.sa-question__select-wrapper {\n  position: relative;\n  display: inline-block;\n  min-width: 200px;\n  max-width: 300px;\n\n  .sa-question__select {\n    width: 100%;\n    display: block;\n    position: relative;\n    appearance: none;\n    -webkit-appearance: none;\n    -moz-appearance: none;\n    border-radius: 2px;\n    background: $text-color-inverse;\n    border-color: $border-color;\n    height: $form-element-height;\n    padding: 5px 23px 5px 15px;\n    line-height: initial;\n\n    &::-ms-expand {\n      display: none;\n    }\n\n    &:focus {\n      outline: 0;\n      box-shadow: none;\n    }\n\n    &:disabled {\n      color: $disabled-color;\n    }\n  }\n\n  &:before {\n    margin-top: -4px;\n    top: 50%;\n    right: 10px;\n    z-index: 1;\n    content: \"\";\n    position: absolute;\n    width: 4px;\n    height: 4px;\n    border-right: 2px solid $text-color;\n    border-bottom: 2px solid $text-color;\n    transform: rotate(45deg);\n    box-sizing: content-box;\n  }\n}\n// EO custom select\n\n.sa-question__filter {\n  display: inline-block;\n  padding: 0 1em;\n}\n\n.sa-question__filter-text {\n  vertical-align: middle;\n  margin-top: 1px;\n}\n\n.sa-commercial {\n  font-size: 12px;\n  padding: 1em 0 0.5em 2em;\n  svg {\n    width: 20px;\n    height: 20px;\n    fill: $main-color;\n  }\n}\n.sa-commercial__text {\n  font-weight: bold;\n  text-decoration: none;\n  color: $main-color;\n}\n.sa-commercial__product {\n  padding-left: 0.5em;\n}\n\n/* latin-ext */\n@font-face {\n  font-family: \"Raleway\";\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Raleway\"), local(\"Raleway-Regular\"),\n    url(https://fonts.gstatic.com/s/raleway/v14/1Ptug8zYS_SKggPNyCMIT5lu.woff2)\n      format(\"woff2\");\n  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB,\n    U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;\n}\n/* latin */\n@font-face {\n  font-family: \"Raleway\";\n  font-style: normal;\n  font-weight: 400;\n  src: local(\"Raleway\"), local(\"Raleway-Regular\"),\n    url(https://fonts.gstatic.com/s/raleway/v14/1Ptug8zYS_SKggPNyC0ITw.woff2)\n      format(\"woff2\");\n  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,\n    U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215,\n    U+FEFF, U+FFFD;\n}\n/* latin-ext */\n@font-face {\n  font-family: \"Raleway\";\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Raleway Bold\"), local(\"Raleway-Bold\"),\n    url(https://fonts.gstatic.com/s/raleway/v14/1Ptrg8zYS_SKggPNwJYtWqhPAMif.woff2)\n      format(\"woff2\");\n  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB,\n    U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;\n}\n/* latin */\n@font-face {\n  font-family: \"Raleway\";\n  font-style: normal;\n  font-weight: 700;\n  src: local(\"Raleway Bold\"), local(\"Raleway-Bold\"),\n    url(https://fonts.gstatic.com/s/raleway/v14/1Ptrg8zYS_SKggPNwJYtWqZPAA.woff2)\n      format(\"woff2\");\n  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,\n    U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215,\n    U+FEFF, U+FFFD;\n}\n","$main-color: #1ab394;\n$auxiliary-color: #ff9814;\n$auxiliary-color-1: #666666;\n$auxiliary-color-2: #1948b3;\n$danger-color: #d9534f;\n$disabled-color: #b0b0b0;\n\n$blue-color: #394cff;\n$purple-color: #aa42d0;\n$green-color: #41c02c;\n\n$text-color-inverse: #fff;\n$text-color: #404040;\n\n$content-max-width: 1170px;\n\n$background-color: #f7f7f7;\n$background-color-dark: #eeeeee;\n$background-disabled-color: #b7b7b7;\n\n$border-color: #e7e7e7;\n\n$form-element-height: 34px;\n\n$svg-color: rgba(#9f9f9f, 0.4);\n$svg-hover-color: #9f9f9f;\n","@import \"globals\";\n\n.sa-text-table__container {\n  width: 100%;\n  min-height: 200px;\n  max-height: 500px;\n  overflow: auto;\n}\n\n.sa-text-table {\n  width: 100%;\n  font-family: SegoeUI, Arial, sans-serif;\n  font-size: 14px;\n  color: $text-color;\n  border-width: 1px;\n\tborder-collapse: collapse;\n  background-color: $background-color;\n}\n\n.sa-text-table__cell {\n\tborder-width: 1px;\n\tpadding: 8px;\n\tborder-style: solid;\n\tborder-color: $border-color;\n  background-color: $background-color;\n  min-height: $form-element-height;\n}\n","@import \"globals\";\n\n.sa-choices-table__container {\n  width: 100%;\n  min-height: 200px;\n  max-height: 500px;\n  overflow: auto;\n}\n\n.sa-choices-table {\n  width: 100%;\n  font-family: SegoeUI, Arial, sans-serif;\n  font-size: 14px;\n  color: $text-color;\n\t// border-collapse: collapse;\n  background-color: $background-color;\n}\n\n.sa-choices-table__cell {\n\tborder-width: 1px;\n\tpadding: 8px;\n\tborder-style: solid;\n\tborder-color: $border-color;\n  background-color: $background-color;\n  min-height: $form-element-height;\n}\n\n.sa-choices-table__cell-value {\n  text-align: right;\n  min-width: 30px;\n}\n\n.sa-choices-table__cell-header {\n  font-weight: bold;\n}\n\n.sa-choices-sparkline {\n  min-width: 100px;\n  height: 24px;\n  border: 1px solid $main-color;\n}\n.sa-choices-sparkline-value {\n  height: 100%;\n  background-color: $main-color;\n}"],"sourceRoot":""}*/
|
package/survey.analytics.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*Type definitions for SurveyJS Analytics library v1.9.
|
|
1
|
+
/*Type definitions for SurveyJS Analytics library v1.9.33
|
|
2
2
|
Copyright (c) 2015-2022 Devsoft Baltic OÜ - http://surveyjs.io/
|
|
3
3
|
Definitions by: Devsoft Baltic OÜ <https://github.com/surveyjs/>
|
|
4
4
|
*/
|
|
@@ -8,10 +8,10 @@ Definitions by: Devsoft Baltic OÜ <https://github.com/surveyjs/>
|
|
|
8
8
|
|
|
9
9
|
import { Event } from "survey-core";
|
|
10
10
|
import { Question } from "survey-core";
|
|
11
|
+
import { SurveyModel } from "survey-core";
|
|
11
12
|
import { IQuestion } from "survey-core";
|
|
12
13
|
import { QuestionMatrixDropdownModel } from "survey-core";
|
|
13
14
|
import { ItemValue } from "survey-core";
|
|
14
|
-
import { SurveyModel } from "survey-core";
|
|
15
15
|
import Plotly from "plotly.js-dist-min";
|
|
16
16
|
import { QuestionMatrixModel } from "survey-core";
|
|
17
17
|
import { QuestionBooleanModel } from "survey-core";
|
|
@@ -73,6 +73,10 @@ export var surveyStrings: {
|
|
|
73
73
|
filter: string;
|
|
74
74
|
resetFilter: string;
|
|
75
75
|
changeLocale: string;
|
|
76
|
+
en: string;
|
|
77
|
+
fr: string;
|
|
78
|
+
ru: string;
|
|
79
|
+
de: string;
|
|
76
80
|
clearButton: string;
|
|
77
81
|
addElement: string;
|
|
78
82
|
defaultOrder: string;
|
|
@@ -292,7 +296,7 @@ export class VisualizerBase implements IDataInfo {
|
|
|
292
296
|
/**
|
|
293
297
|
* Renders visualizer in the given container.
|
|
294
298
|
*/
|
|
295
|
-
render(targetElement: HTMLElement): void;
|
|
299
|
+
render(targetElement: HTMLElement | string): void;
|
|
296
300
|
/**
|
|
297
301
|
* Redraws visualizer and all inner content.
|
|
298
302
|
*/
|
|
@@ -358,24 +362,209 @@ export interface IVisualizerPanelRenderedElement extends IVisualizerPanelElement
|
|
|
358
362
|
renderedElement?: HTMLElement;
|
|
359
363
|
}
|
|
360
364
|
/**
|
|
361
|
-
*
|
|
362
|
-
*
|
|
363
|
-
* constructor parameters:
|
|
364
|
-
* questions - an array of survey questions to visualize,
|
|
365
|
-
* data - an array of answers in format of survey result,
|
|
366
|
-
* options - object with the following options,
|
|
367
|
-
* elements - list of visual element descriptions
|
|
365
|
+
* Visualization Panel configuration. Pass it as the third argument to the `VisualizationPanel` constructor:
|
|
368
366
|
*
|
|
369
|
-
*
|
|
370
|
-
*
|
|
371
|
-
*
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
367
|
+
* ```js
|
|
368
|
+
* const vizPanel = new SurveyAnalytics.VisualizationPanel(surveyQuestions, surveyResults, vizPanelOptions);
|
|
369
|
+
* ```
|
|
370
|
+
*/
|
|
371
|
+
export interface IVisualizationPanelOptions {
|
|
372
|
+
/**
|
|
373
|
+
* The number of label characters after which truncation starts.
|
|
374
|
+
* Set this property to -1 to disable truncation.
|
|
375
|
+
*
|
|
376
|
+
* Default value: 27
|
|
377
|
+
*/
|
|
378
|
+
labelTruncateLength?: number;
|
|
379
|
+
allowMakeQuestionsPrivate?: boolean;
|
|
380
|
+
seriesValues?: string[];
|
|
381
|
+
seriesLabels?: string[];
|
|
382
|
+
useValuesAsLabels?: boolean;
|
|
383
|
+
/**
|
|
384
|
+
* Pass a survey instance to use survey locales in the Visualization Panel.
|
|
385
|
+
*/
|
|
386
|
+
survey?: SurveyModel;
|
|
387
|
+
/**
|
|
388
|
+
* A common data provider for all visualizers.
|
|
389
|
+
*/
|
|
390
|
+
dataProvider?: DataProvider;
|
|
391
|
+
/**
|
|
392
|
+
* Allows users to change the visibility of individual charts.
|
|
393
|
+
* This property adds a Hide button to each chart.
|
|
394
|
+
*
|
|
395
|
+
* Default value: `true`
|
|
396
|
+
*/
|
|
397
|
+
allowHideQuestions?: boolean;
|
|
398
|
+
/**
|
|
399
|
+
* Specifies whether to arrange charts based on the available screen space and allow users to reorder them via drag and drop.
|
|
400
|
+
* If this property is disabled, charts are displayed one under the other, and users cannot reorder them.
|
|
401
|
+
*
|
|
402
|
+
* Default value: `true`
|
|
403
|
+
*
|
|
404
|
+
* [View the "Disable the Layout Engine" example](https://surveyjs.io/Examples/Analytics?id=custom-layout)
|
|
405
|
+
*
|
|
406
|
+
* @see layoutEngine
|
|
407
|
+
*/
|
|
408
|
+
allowDynamicLayout?: boolean;
|
|
409
|
+
/**
|
|
410
|
+
* A layout engine used to arrange charts on the Visualization Panel.
|
|
411
|
+
* You can use this property to integrate a third-party layout engine with SurveyJS Analytics.
|
|
412
|
+
*
|
|
413
|
+
* @see allowDynamicLayout
|
|
414
|
+
*/
|
|
415
|
+
layoutEngine?: LayoutEngine;
|
|
416
|
+
/**
|
|
417
|
+
* Allows users to switch between absolute and percentage values in bar charts.
|
|
418
|
+
* This property adds a Show Percentages button to each bar chart.
|
|
419
|
+
*
|
|
420
|
+
* Default value: `false`
|
|
421
|
+
*
|
|
422
|
+
* @see showPercentages
|
|
423
|
+
* @see showOnlyPercentages
|
|
424
|
+
* @see percentagePrecision
|
|
425
|
+
*/
|
|
426
|
+
allowShowPercentages?: boolean;
|
|
427
|
+
/**
|
|
428
|
+
* Specifies whether bar charts display percentages in addition to absolute values.
|
|
429
|
+
* Users can change this property value if you enable the `allowShowPercentages` property.
|
|
430
|
+
*
|
|
431
|
+
* Default value: `false`
|
|
432
|
+
*
|
|
433
|
+
* @see allowShowPercentages
|
|
434
|
+
* @see showOnlyPercentages
|
|
435
|
+
* @see percentagePrecision
|
|
436
|
+
*/
|
|
437
|
+
showPercentages?: boolean;
|
|
438
|
+
/**
|
|
439
|
+
* Specifies whether bar charts display only percentages, without absolute values.
|
|
440
|
+
* Applies only if the `allowShowPercentages` or `showPercentages` property is enables.
|
|
441
|
+
*
|
|
442
|
+
* Default value: `false`
|
|
443
|
+
*
|
|
444
|
+
* @see allowShowPercentages
|
|
445
|
+
* @see showPercentages
|
|
446
|
+
* @see percentagePrecision
|
|
447
|
+
*/
|
|
448
|
+
showOnlyPercentages?: boolean;
|
|
449
|
+
/**
|
|
450
|
+
* Specifies percentage precision.
|
|
451
|
+
*
|
|
452
|
+
* Default value: 0
|
|
453
|
+
*
|
|
454
|
+
* @see allowShowPercentages
|
|
455
|
+
* @see showPercentages
|
|
456
|
+
* @see showOnlyPercentages
|
|
457
|
+
*/
|
|
458
|
+
percentagePrecision?: number;
|
|
459
|
+
/**
|
|
460
|
+
* Removes the Free Trial bar.
|
|
461
|
+
* **IMPORTANT**: You can enable this property only if you have a SurveyJS Analytics commercial license. It is illegal to enable this property without a license.
|
|
462
|
+
*/
|
|
463
|
+
haveCommercialLicense?: boolean;
|
|
464
|
+
/**
|
|
465
|
+
* Allows users to sort answers by answer count. Applies only to bar and scatter charts.
|
|
466
|
+
* This property adds a Sorting dropdown to each bar and scatter chart.
|
|
467
|
+
*
|
|
468
|
+
* Default value: `true`
|
|
469
|
+
*
|
|
470
|
+
* @see answersOrder
|
|
471
|
+
*/
|
|
472
|
+
allowChangeAnswersOrder?: boolean;
|
|
473
|
+
/**
|
|
474
|
+
* Specifies how to sort answers in bar and scatter charts.
|
|
475
|
+
* Accepted values:
|
|
476
|
+
*
|
|
477
|
+
* - `"default"` (default) - Do not sort answers.
|
|
478
|
+
* - `"asc"` - Sort answers by ascending answer count.
|
|
479
|
+
* - `"desc"` - Sort answers by descending answer count.
|
|
480
|
+
*
|
|
481
|
+
* Users can change this property value if you enable the `allowChangeAnswersOrder` property.
|
|
482
|
+
*
|
|
483
|
+
* @see allowChangeAnswersOrder
|
|
484
|
+
*/
|
|
485
|
+
answersOrder?: "default" | "asc" | "desc";
|
|
486
|
+
/**
|
|
487
|
+
* Allows users to hide answers with zero count in bar and scatter charts.
|
|
488
|
+
* This property adds a Hide Empty Answers button to each bar and scatter chart.
|
|
489
|
+
*
|
|
490
|
+
* Default value: `false`
|
|
491
|
+
*/
|
|
492
|
+
allowHideEmptyAnswers?: boolean;
|
|
493
|
+
/**
|
|
494
|
+
* Hides answers with zero count in bar and scatter charts.
|
|
495
|
+
* Users can change this property value if you enable the `allowHideEmptyAnswers` property.
|
|
496
|
+
*
|
|
497
|
+
* Default value: `false`
|
|
498
|
+
*
|
|
499
|
+
* @see allowHideEmptyAnswers
|
|
500
|
+
*/
|
|
501
|
+
hideEmptyAnswers?: boolean;
|
|
502
|
+
/**
|
|
503
|
+
* Allows users to select whether to show top 5, 10, or 20 answers by answer count.
|
|
504
|
+
* This property adds a Top N Answers dropdown to each chart.
|
|
505
|
+
*
|
|
506
|
+
* Default value: `false`
|
|
507
|
+
*/
|
|
508
|
+
allowTopNAnswers?: boolean;
|
|
509
|
+
/**
|
|
510
|
+
* Allows users to show the number of respondents who did not answer a particular question.
|
|
511
|
+
* This property adds a Show Missing Answers button to each chart.
|
|
512
|
+
*
|
|
513
|
+
* Default value: `false`
|
|
514
|
+
*/
|
|
515
|
+
allowShowMissingAnswers?: boolean;
|
|
516
|
+
allowExperimentalFeatures?: boolean;
|
|
517
|
+
/**
|
|
518
|
+
* Default chart type.
|
|
519
|
+
*
|
|
520
|
+
* Accepted values depend on the question type as follows:
|
|
521
|
+
*
|
|
522
|
+
* - Boolean: `"bar"` | `"pie"` | `"doughnut"`
|
|
523
|
+
* - Date, Number: `"bar"` | `"scatter"`
|
|
524
|
+
* - Matrix: `"bar"` | `"pie"` | `"doughnut"` | `"stackedbar"`
|
|
525
|
+
* - Rating: `"bar"` | `"scatter"` | `"gauge"` | `"bullet"`
|
|
526
|
+
* - Radiogroup, Checkbox, Dropdown, Image Picker: `"bar"` | `"pie"` | `"doughnut"` | `"scatter"`
|
|
527
|
+
*
|
|
528
|
+
* To set a type for an individual chart, access this chart in the `visualizers` array and set its `chartType` property to one of the values described above:
|
|
529
|
+
*
|
|
530
|
+
* ```js
|
|
531
|
+
* const vizPanel = new SurveyAnalytics.VisualizationPanel( ... );
|
|
532
|
+
* vizPanel.visualizers[0].chartType = "stackedbar";
|
|
533
|
+
* ```
|
|
534
|
+
*
|
|
535
|
+
*/
|
|
536
|
+
defaultChartType?: string;
|
|
537
|
+
/**
|
|
538
|
+
* Allows users to transpose a visualized matrix question.
|
|
539
|
+
* This property adds a Transpose button to charts that visualize matrixes. When users select Per Values, matrix rows go to chart arguments, and matrix columns form chart series. When users select Per Columns, matrix rows form chart series, and matrix columns go to chart arguments.
|
|
540
|
+
*
|
|
541
|
+
* Default value: `false`
|
|
542
|
+
*/
|
|
543
|
+
allowTransposeData?: boolean;
|
|
544
|
+
/**
|
|
545
|
+
* Allows users to cross-filter charts. The filter applies when users selects a series point.
|
|
546
|
+
*
|
|
547
|
+
* Default value: `true`
|
|
548
|
+
*/
|
|
549
|
+
allowSelection?: boolean;
|
|
550
|
+
renderContent?: Function;
|
|
551
|
+
destroyContent?: Function;
|
|
552
|
+
/**
|
|
553
|
+
* Removes HTML tags from survey element titles.
|
|
554
|
+
* Survey element titles can contain HTML markup and are specified by users. An attacker can inject malicious code into the titles. To guard against it, keep this property set to `true`.
|
|
555
|
+
*
|
|
556
|
+
* Default value: `true`
|
|
557
|
+
*/
|
|
558
|
+
stripHtmlFromTitles?: boolean;
|
|
559
|
+
}
|
|
560
|
+
/**
|
|
561
|
+
* VisualizationPanel is responsible for visualizing an array of survey questions
|
|
562
|
+
* <br/>
|
|
563
|
+
* <br/> constructor parameters:
|
|
564
|
+
* <br/> questions - an array of survey questions to visualize,
|
|
565
|
+
* <br/> data - an array of answers in format of survey result,
|
|
566
|
+
* <br/> options - object of the IVisualizationPanelOptions type, @see IVisualizationPanelOptions
|
|
567
|
+
* <br/> elements - list of visual element descriptions
|
|
379
568
|
*
|
|
380
569
|
*/
|
|
381
570
|
export class VisualizationPanel extends VisualizerBase {
|
|
@@ -384,9 +573,7 @@ export class VisualizationPanel extends VisualizerBase {
|
|
|
384
573
|
visualizers: Array<VisualizerBase>;
|
|
385
574
|
constructor(questions: Array<any>, data: Array<{
|
|
386
575
|
[index: string]: any;
|
|
387
|
-
}>, options?:
|
|
388
|
-
[index: string]: any;
|
|
389
|
-
}, _elements?: Array<IVisualizerPanelRenderedElement>);
|
|
576
|
+
}>, options?: IVisualizationPanelOptions, _elements?: Array<IVisualizerPanelRenderedElement>);
|
|
390
577
|
protected showElement(elementName: string): void;
|
|
391
578
|
protected hideElement(elementName: string): void;
|
|
392
579
|
protected makeElementPrivate(element: IVisualizerPanelElement): void;
|
|
@@ -597,7 +784,7 @@ export class DataTables extends Table {
|
|
|
597
784
|
onColumnsReorder: Event<(sender: DataTables, options: any) => any, any>;
|
|
598
785
|
static initJQuery($: any): void;
|
|
599
786
|
static set haveCommercialLicense(val: boolean);
|
|
600
|
-
constructor(survey: SurveyModel, data: Array<Object>, options: DataTablesOptions,
|
|
787
|
+
constructor(survey: SurveyModel, data: Array<Object>, options: DataTablesOptions, _columnsData?: Array<IColumnData>);
|
|
601
788
|
destroy(): void;
|
|
602
789
|
setColumnVisibility(columnName: string, isVisible: boolean): void;
|
|
603
790
|
setColumnLocation(columnName: string, location: QuestionLocation): void;
|
|
@@ -607,7 +794,7 @@ export class DataTables extends Table {
|
|
|
607
794
|
setPageSize(value: number): void;
|
|
608
795
|
setPageNumber(value: number): void;
|
|
609
796
|
getPageNumber(): number;
|
|
610
|
-
render(targetNode: HTMLElement): void;
|
|
797
|
+
render(targetNode: HTMLElement | string): void;
|
|
611
798
|
getColumns(): Array<any>;
|
|
612
799
|
layout(): void;
|
|
613
800
|
}
|
|
@@ -639,9 +826,9 @@ interface ITabulatorOptions extends ITableOptions {
|
|
|
639
826
|
}
|
|
640
827
|
export class Tabulator extends Table {
|
|
641
828
|
static set haveCommercialLicense(val: boolean);
|
|
642
|
-
constructor(survey: SurveyModel, data: Array<Object>, options: ITabulatorOptions,
|
|
829
|
+
constructor(survey: SurveyModel, data: Array<Object>, options: ITabulatorOptions, _columnsData?: Array<IColumnData>);
|
|
643
830
|
tabulatorTables: any;
|
|
644
|
-
render(targetNode: HTMLElement): void;
|
|
831
|
+
render(targetNode: HTMLElement | string): void;
|
|
645
832
|
destroy: () => void;
|
|
646
833
|
getColumns(): Array<any>;
|
|
647
834
|
setColumnVisibility(columnName: string, isVisible: boolean): void;
|
|
@@ -801,6 +988,7 @@ export class SelectBase extends VisualizerBase implements IVisualizerWithSelecti
|
|
|
801
988
|
set showMissingAnswers(value: boolean);
|
|
802
989
|
refreshContent(): void;
|
|
803
990
|
onDataItemSelected: (selectedValue: any, selectedText: string) => void;
|
|
991
|
+
get showValuesInOriginalOrder(): boolean;
|
|
804
992
|
valuesSource(): Array<ItemValue>;
|
|
805
993
|
getValues(): Array<any>;
|
|
806
994
|
getLabels(): Array<string>;
|
|
@@ -840,15 +1028,16 @@ export interface ITableOptions {
|
|
|
840
1028
|
}) => void;
|
|
841
1029
|
}
|
|
842
1030
|
export abstract class Table {
|
|
843
|
-
protected
|
|
1031
|
+
protected _survey: SurveyModel;
|
|
844
1032
|
protected data: Array<Object>;
|
|
845
|
-
protected
|
|
846
|
-
protected
|
|
1033
|
+
protected _options: ITableOptions;
|
|
1034
|
+
protected _columnsData: Array<IColumnData>;
|
|
847
1035
|
static showFilesAsImages: boolean;
|
|
848
1036
|
static haveCommercialLicense: boolean;
|
|
849
1037
|
protected tableData: any;
|
|
850
1038
|
protected extensions: TableExtensions;
|
|
851
|
-
|
|
1039
|
+
protected _columns: Array<IColumn>;
|
|
1040
|
+
constructor(_survey: SurveyModel, data: Array<Object>, _options?: ITableOptions, _columnsData?: Array<IColumnData>);
|
|
852
1041
|
protected renderResult: HTMLElement;
|
|
853
1042
|
protected currentPageSize: number;
|
|
854
1043
|
protected currentPageNumber: number;
|
|
@@ -859,10 +1048,12 @@ export abstract class Table {
|
|
|
859
1048
|
onRowRemoved: Event<(sender: Table, options: any) => any, any>;
|
|
860
1049
|
renderDetailActions: (container: HTMLElement, row: TableRow) => HTMLElement;
|
|
861
1050
|
getData(): Object[];
|
|
1051
|
+
get survey(): SurveyModel;
|
|
1052
|
+
get options(): ITableOptions;
|
|
862
1053
|
abstract applyFilter(value: string): void;
|
|
863
1054
|
abstract applyColumnFilter(columnName: string, value: string): void;
|
|
864
1055
|
abstract sortByColumn(columnName: string, direction: string): void;
|
|
865
|
-
render(targetNode: HTMLElement): void;
|
|
1056
|
+
render(targetNode: HTMLElement | string): void;
|
|
866
1057
|
enableColumnReorder(): void;
|
|
867
1058
|
disableColumnReorder(): void;
|
|
868
1059
|
getPageNumber(): number;
|
|
@@ -871,14 +1062,15 @@ export abstract class Table {
|
|
|
871
1062
|
setPageSize(value: number): void;
|
|
872
1063
|
getCreatedRows(): TableRow[];
|
|
873
1064
|
clearCreatedRows(): void;
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
1065
|
+
get useNamesAsTitles(): boolean;
|
|
1066
|
+
protected buildColumns: (survey: SurveyModel) => IColumn[];
|
|
1067
|
+
isColumnVisible(column: IColumn): boolean;
|
|
1068
|
+
get columns(): Array<IColumn>;
|
|
1069
|
+
set columns(columns: Array<IColumn>);
|
|
878
1070
|
protected initTableData(data: Array<any>): void;
|
|
879
1071
|
moveColumn(from: number, to: number): void;
|
|
880
1072
|
setColumnLocation(columnName: string, location: QuestionLocation): void;
|
|
881
|
-
getColumnByName(columnName: string):
|
|
1073
|
+
getColumnByName(columnName: string): IColumn;
|
|
882
1074
|
setColumnVisibility(columnName: string, isVisible: boolean): void;
|
|
883
1075
|
setColumnWidth(columnName: string, width: string | number): void;
|
|
884
1076
|
removeRow(row: TableRow): void;
|
|
@@ -960,7 +1152,11 @@ export enum ColumnDataType {
|
|
|
960
1152
|
FileLink = 1,
|
|
961
1153
|
Image = 2
|
|
962
1154
|
}
|
|
963
|
-
export interface
|
|
1155
|
+
export interface ICellData {
|
|
1156
|
+
question: Question;
|
|
1157
|
+
displayValue: any;
|
|
1158
|
+
}
|
|
1159
|
+
export interface IColumnData {
|
|
964
1160
|
name: string;
|
|
965
1161
|
displayName: string;
|
|
966
1162
|
dataType: ColumnDataType;
|
|
@@ -970,9 +1166,14 @@ export interface ITableColumn {
|
|
|
970
1166
|
width?: string | number;
|
|
971
1167
|
isComment?: boolean;
|
|
972
1168
|
}
|
|
1169
|
+
export interface IColumn extends IColumnData {
|
|
1170
|
+
visibleIndex?: number;
|
|
1171
|
+
fromJSON(json: any): void;
|
|
1172
|
+
getCellData(table: Table, data: any): ICellData;
|
|
1173
|
+
}
|
|
973
1174
|
export interface ITableState {
|
|
974
1175
|
locale?: string;
|
|
975
|
-
elements?:
|
|
1176
|
+
elements?: IColumnData[];
|
|
976
1177
|
pageSize?: number;
|
|
977
1178
|
}
|
|
978
1179
|
export interface IPermission {
|