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 CHANGED
@@ -1,8 +1,5 @@
1
- ![SurveyJS Analytics](https://raw.githubusercontent.com/surveyjs/survey-analytics/master/docs/images/survey-analytics-note.png)
2
-
3
1
  # SurveyJS Analytics
4
2
 
5
-
6
3
  [![Build Status](https://dev.azure.com/SurveyJS/SurveyJS%20Integration%20Tests/_apis/build/status/SurveyJS%20Library?branchName=master)](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 library allows to render survey results as charts or tables
18
-
19
- ## Main Features
14
+ SurveyJS Analytics visualizes survey results and allows users to analyze them.
20
15
 
21
- - Count answers and render results as charts for the select type questions
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
+ ![SurveyJS Analytics](docs/images/survey-analytics-note.png)
27
17
 
28
- ## Examples
18
+ ## Features
29
19
 
30
- You may review the [analytics example](https://surveyjstest.azurewebsites.net/Examples/Library/?id=analytics-nps) or check this standalone plnkr [example](https://plnkr.co/edit/bCk64wdvOLShXkPyvGfk?p=preview).
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
- Other live examples:
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
- Unlike SurveyJS Library itself, this library is distributed under commercial license. Please read more about licensing on our [license page](https://surveyjstest.azurewebsites.net/Licenses#Analytics).
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
- ## Support
40
+ ## Resources
41
41
 
42
- If you feel that we have missed some important functionality or found a bug, please write us [here](https://github.com/surveyjs/survey-analytics/issues) on our [support desk](https://surveyjs.answerdesk.io/).
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
- ## Building survey-analytics from sources
47
+ ## Build SurveyJS Analytics from Sources
45
48
 
46
- To build library yourself:
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
- 2. **Acquire build dependencies.** Make sure you have [Node.js](http://nodejs.org/) installed on your workstation. You need a version of Node.js greater than 6.0.0 and npm greater than 2.7.0. This is only needed to _build_ surveyjs from sources.
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
- 3. **Build the library**
63
+ 1. **Build the library**
62
64
 
63
65
  ```
64
66
  npm run build_prod
65
67
  ```
66
68
 
67
- After that you should have the library at 'packages' directory.
69
+ You can find the built scripts and style sheets in the `packages` folder.
68
70
 
69
- 4. **Run samples**
71
+ 1. **Run test examples**
70
72
 
71
73
  ```
72
74
  npm start
73
75
  ```
74
76
 
75
- This command will run local http server at the http://localhost:7777
77
+ This command runs a local HTTP server at http://localhost:8080/.
76
78
 
77
- You can open http://localhost:7777/examples/examples
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
- - Implement data providing server side prototype
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
- - SurveyJS Analytics doesn't support objects as values (e.g. of dropdown, radiogroup and other select question items)
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
- "testcafe_file": "concurrently \"http-server --silent\" \"testcafe chrome testCafe/summary/basetests.js --selector-timeout 1500 --reporter minimal --debug-mode\"",
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.30",
19
+ "version": "1.9.33",
20
20
  "name": "survey-analytics",
21
21
  "description": "SurveyJS analytics Library.",
22
22
  "main": "survey.analytics.js",
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * surveyjs - SurveyJS Analytics library v1.9.30
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":";;;;;AAKA;EACE,uCAAuC;EACvC,qBAAqB;EACrB,gBAAgB;EAChB,WAAW;;AAGb;EACE,gBAAgB;;AAGlB;EACE,qBAAqB;EACrB,oBAAoB;EACpB,eAAe;EACf,cAAc;EACd,iBAAiB;EACjB,sBAAsB;EACtB,SAAS;;AAGX;EACE,gBAAgB;;ACzBlB;EACE,aAAa;;AAGf;EACE,kBAAkB;;AAGpB;EACE,WAAW;EACX,sBAAsB;EACtB;IAHF;MAII,UAAU,IAEb;;AAED;EACE,qBAAqB;EACrB,WAAW;EACX,mBAAmB;EACnB,sBAAsB;EACtB,gBAAgB;EAChB,YAAY;;AAGd;EACE,kBAAkB;EAElB;IAHF;MAII,sBAAsB,IAEzB;;AAED;EACE,yBCpBwB;EDqBxB,aAAa;;AAGf;EACE,iBAAiB;EACjB,oBAAoB;EACpB,eAAe;EACf,iBAAiB;EACjB,cCjCkB;EDkClB,SAAS;EACT,kBAAkB;;AAGpB;EACE,YAAY;EADd;IAGI,YAAY;IACZ,cAAc;IACd,YAAY;IACZ,WAAW;IACX,YAAY;IACZ,0VAA0V;;AAI9V;EACE,uCAAuC;EACvC,eAAe;EACf,cCrDkB;EDsDlB,iBAAiB;EACjB,mBAAmB;EALrB;IAOI,iBAAiB;;AAIrB;EACE,uCAAuC;EACvC,eAAe;EACf,YAAY;EACZ,sBAAsB;EACtB,eAAe;EACf,6BAA6B;EAK7B,cAAc;EAXhB;IAQI,qBC7DkB;ID8DlB,6BAA6B;EATjC;IAaI,cAAc;EAblB;IAgBI,eAAe;;AAInB;EACE,WAAW;EACX,YAAY;EACZ,UAAU;EACV,YAAY;EACZ,aAAa;EACb,yBAAyB;EACzB,eAAe;EAPjB;IASI,8BC9EoB;EDqExB;IAaM,aCjFmB;EDoEzB;IAiBI,WAAW;IACX,YAAY;;AAIhB;EACE,YAAY;;AAId;EACE,kBAAkB;EAClB,qBAAqB;EACrB,gBAAgB;EAChB,gBAAgB;EAJlB;IAOI,WAAW;IACX,cAAc;IACd,kBAAkB;IAClB,gBAAgB;IAChB,wBAAwB;IACxB,qBAAqB;IACrB,kBAAkB;IAClB,gBC3HqB;ID4HrB,qBCnHkB;IDoHlB,YClHsB;IDmHtB,0BAA0B;IAC1B,oBAAoB;IAlBxB;MAqBM,aAAa;IArBnB;MAyBM,UAAU;MACV,gBAAgB;IA1BtB;MA8BM,cCjJkB;EDmHxB;IAmCI,gBAAgB;IAChB,QAAQ;IACR,WAAW;IACX,UAAU;IACV,WAAW;IACX,kBAAkB;IAClB,UAAU;IACV,WAAW;IACX,+BCvJgB;IDwJhB,gCCxJgB;IDyJhB,wBAAwB;IACxB,uBAAuB;;AAK3B;EACE,qBAAqB;EACrB,cAAc;;AAGhB;EACE,sBAAsB;EACtB,eAAe;;AAGjB;EACE,eAAe;EACf,wBAAwB;EAF1B;IAII,WAAW;IACX,YAAY;IACZ,aC3LgB;;AD8LpB;EACE,iBAAiB;EACjB,qBAAqB;EACrB,cCjMkB;;ADmMpB;EACE,mBAAmB;;AAGrB;AACA;EACE,sBAAsB;EACtB,kBAAkB;EAClB,gBAAgB;EAChB,4IAEmB;EACnB,mHAC+C;;AAEjD;AACA;EACE,sBAAsB;EACtB,kBAAkB;EAClB,gBAAgB;EAChB,0IAEmB;EACnB,yKAEgB;;AAElB;AACA;EACE,sBAAsB;EACtB,kBAAkB;EAClB,gBAAgB;EAChB,kJAEmB;EACnB,mHAC+C;;AAEjD;AACA;EACE,sBAAsB;EACtB,kBAAkB;EAClB,gBAAgB;EAChB,gJAEmB;EACnB,yKAEgB;;AEjPlB;EACE,WAAW;EACX,iBAAiB;EACjB,iBAAiB;EACjB,cAAc;;AAGhB;EACE,WAAW;EACX,uCAAuC;EACvC,eAAe;EACf,cDDkB;ECElB,iBAAiB;EAClB,yBAAyB;EACxB,yBDAwB;;ACG1B;EACC,iBAAiB;EACjB,YAAY;EACZ,mBAAmB;EACnB,qBDHqB;ECIpB,yBDRwB;ECSxB,gBDHwB;;AEpB1B;EACE,WAAW;EACX,iBAAiB;EACjB,iBAAiB;EACjB,cAAc;;AAGhB;EACE,WAAW;EACX,uCAAuC;EACvC,eAAe;EACf,cFDkB;EEGlB,yBFCwB;;AEE1B;EACC,iBAAiB;EACjB,YAAY;EACZ,mBAAmB;EACnB,qBFFqB;EEGpB,yBFPwB;EEQxB,gBFFwB;;AEK1B;EACE,iBAAiB;EACjB,eAAe;;AAGjB;EACE,iBAAiB;;AAGnB;EACE,gBAAgB;EAChB,YAAY;EACZ,yBFvCkB;;AEyCpB;EACE,YAAY;EACZ,yBF3CkB","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":""}*/
@@ -1,4 +1,4 @@
1
- /*Type definitions for SurveyJS Analytics library v1.9.30
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
- * VisualizationPanel is responsible for visualizing an array of survey questions
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
- * options:
370
- * allowDynamicLayout - set it to false to disable items drag/drop reordering and dynamic layouting,
371
- * labelTruncateLength - the length of the label where the truncation starts. Set to -1 to disable truncate. Default is 27.
372
- * allowHideQuestions - set it to false to deny user to hide/show individual questions,
373
- * allowMakeQuestionsPrivate - set it to true to allow make elements private/public also see persmissions property,
374
- * seriesValues - an array of series values in data to group data by series,
375
- * seriesLabels - labels for series to display, if not passed the seriesValues are used as labels,
376
- * survey - pass survey instance to use localses from the survey JSON,
377
- * dataProvider - dataProvider for this visualizer,
378
- * layoutEngine - layout engine to be used for layouting inner visualizers
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, _columns?: Array<ITableColumn>);
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, _columns?: Array<any>);
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 survey: SurveyModel;
1031
+ protected _survey: SurveyModel;
844
1032
  protected data: Array<Object>;
845
- protected options: ITableOptions;
846
- protected _columns: Array<ITableColumn>;
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
- constructor(survey: SurveyModel, data: Array<Object>, options?: ITableOptions, _columns?: Array<ITableColumn>);
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
- protected buildColumns: (survey: SurveyModel) => ITableColumn[];
875
- isColumnVisible(column: ITableColumn): boolean;
876
- get columns(): Array<ITableColumn>;
877
- set columns(columns: Array<ITableColumn>);
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): ITableColumn;
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 ITableColumn {
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?: ITableColumn[];
1176
+ elements?: IColumnData[];
976
1177
  pageSize?: number;
977
1178
  }
978
1179
  export interface IPermission {
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * surveyjs - SurveyJS Analytics library v1.9.30
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
  */