@roqua/quby-frontend 0.4.3 → 0.5.0
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/CHANGELOG.md +9 -0
- package/lib/components/AnswerPage.js +26 -49
- package/lib/components/AnswerPage.js.map +1 -1
- package/lib/components/MainLabel.js +6 -14
- package/lib/components/MainLabel.js.map +1 -1
- package/lib/components/Paginator.js +29 -53
- package/lib/components/Paginator.js.map +1 -1
- package/lib/components/PanelContent.js +8 -17
- package/lib/components/PanelContent.js.map +1 -1
- package/lib/components/PanelItem.js +8 -15
- package/lib/components/PanelItem.js.map +1 -1
- package/lib/components/ProgressBar.js +10 -18
- package/lib/components/ProgressBar.js.map +1 -1
- package/lib/components/Quby.d.ts +2 -2
- package/lib/components/Quby.d.ts.map +1 -1
- package/lib/components/Quby.js +9 -16
- package/lib/components/Quby.js.map +1 -1
- package/lib/components/QuestionDescription.js +3 -10
- package/lib/components/QuestionDescription.js.map +1 -1
- package/lib/components/QuestionWrapper.js +10 -28
- package/lib/components/QuestionWrapper.js.map +1 -1
- package/lib/components/ValidationErrors.js +10 -30
- package/lib/components/ValidationErrors.js.map +1 -1
- package/lib/components/index.js +2 -14
- package/lib/components/index.js.map +1 -1
- package/lib/components/items/HtmlItem.js +4 -12
- package/lib/components/items/HtmlItem.js.map +1 -1
- package/lib/components/items/QuestionItem.js +34 -42
- package/lib/components/items/QuestionItem.js.map +1 -1
- package/lib/components/items/UnknownItem.js +3 -11
- package/lib/components/items/UnknownItem.js.map +1 -1
- package/lib/components/questions/CheckBoxQuestion.js +33 -43
- package/lib/components/questions/CheckBoxQuestion.js.map +1 -1
- package/lib/components/questions/DatePartsQuestion.js +18 -26
- package/lib/components/questions/DatePartsQuestion.js.map +1 -1
- package/lib/components/questions/FloatQuestion.js +16 -24
- package/lib/components/questions/FloatQuestion.js.map +1 -1
- package/lib/components/questions/IntegerQuestion.js +16 -24
- package/lib/components/questions/IntegerQuestion.js.map +1 -1
- package/lib/components/questions/RadioQuestion.js +32 -42
- package/lib/components/questions/RadioQuestion.js.map +1 -1
- package/lib/components/questions/ScaleQuestion.js +31 -41
- package/lib/components/questions/ScaleQuestion.js.map +1 -1
- package/lib/components/questions/SelectQuestion.js +21 -31
- package/lib/components/questions/SelectQuestion.js.map +1 -1
- package/lib/components/questions/SliderQuestion.js +59 -67
- package/lib/components/questions/SliderQuestion.js.map +1 -1
- package/lib/components/questions/StringQuestion.js +16 -24
- package/lib/components/questions/StringQuestion.js.map +1 -1
- package/lib/components/questions/TextareaQuestion.js +15 -23
- package/lib/components/questions/TextareaQuestion.js.map +1 -1
- package/lib/core/index.d.ts +1 -0
- package/lib/core/index.d.ts.map +1 -1
- package/lib/core/index.js +5 -16
- package/lib/core/index.js.map +1 -1
- package/lib/core/mock_helpers.js +11 -17
- package/lib/core/mock_helpers.js.map +1 -1
- package/lib/core/questionnaire.js +8 -13
- package/lib/core/questionnaire.js.map +1 -1
- package/lib/core/questionnaire_json.d.ts +5 -3
- package/lib/core/questionnaire_json.d.ts.map +1 -1
- package/lib/core/questionnaire_json.js +2 -2
- package/lib/core/questionnaire_json.js.map +1 -1
- package/lib/core/response.d.ts +13 -5
- package/lib/core/response.d.ts.map +1 -1
- package/lib/core/response.js +72 -78
- package/lib/core/response.js.map +1 -1
- package/lib/core/response_json.d.ts +11 -0
- package/lib/core/response_json.d.ts.map +1 -0
- package/lib/core/response_json.js +68 -0
- package/lib/core/response_json.js.map +1 -0
- package/lib/core/validators.js +56 -169
- package/lib/core/validators.js.map +1 -1
- package/lib/core/visibility_rules.js +37 -90
- package/lib/core/visibility_rules.js.map +1 -1
- package/lib/i18n.js +7 -12
- package/lib/i18n.js.map +1 -1
- package/lib/index.js +3 -15
- package/lib/index.js.map +1 -1
- package/package.json +3 -2
package/CHANGELOG.md
CHANGED
|
@@ -1,70 +1,47 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
finally {
|
|
11
|
-
try {
|
|
12
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
13
|
-
}
|
|
14
|
-
finally { if (e) throw e.error; }
|
|
15
|
-
}
|
|
16
|
-
return ar;
|
|
17
|
-
};
|
|
18
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
19
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
20
|
-
};
|
|
21
|
-
exports.__esModule = true;
|
|
22
|
-
exports.AnswerPage = void 0;
|
|
23
|
-
var react_1 = __importDefault(require("react"));
|
|
24
|
-
var PanelContent_1 = require("./PanelContent");
|
|
25
|
-
var Paginator_1 = require("./Paginator");
|
|
26
|
-
var AnswerPage = function (props) {
|
|
27
|
-
var _a = __read(react_1["default"].useState(0), 2), _ = _a[0], setCounter = _a[1];
|
|
28
|
-
var displayMode = props.displayOptions.displayMode;
|
|
29
|
-
var handleChange = function (response) { return setCounter(function (number) { return number + 1; }); };
|
|
30
|
-
var questionRefs = new Map();
|
|
31
|
-
react_1["default"].useEffect(function () {
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { PanelContent } from "./PanelContent";
|
|
3
|
+
import { Paginator } from "./Paginator";
|
|
4
|
+
export const AnswerPage = props => {
|
|
5
|
+
const [_, setCounter] = React.useState(0);
|
|
6
|
+
const displayMode = props.displayOptions.displayMode;
|
|
7
|
+
const handleChange = (response) => setCounter(number => number + 1);
|
|
8
|
+
const questionRefs = new Map();
|
|
9
|
+
React.useEffect(() => {
|
|
32
10
|
props.response.onChange(handleChange);
|
|
33
|
-
return
|
|
11
|
+
return () => props.response.offChange(handleChange);
|
|
34
12
|
});
|
|
35
|
-
|
|
36
|
-
|
|
13
|
+
const beforeNext = (panelIndex) => {
|
|
14
|
+
const panel = props.questionnaire.panels[panelIndex];
|
|
37
15
|
props.response.touchPanelFields(panel);
|
|
38
|
-
|
|
16
|
+
const firstError = props.response.firstNotValidQuestionInPanel(panel);
|
|
39
17
|
if (firstError) {
|
|
40
|
-
|
|
18
|
+
const ref = questionRefs.get(firstError);
|
|
41
19
|
if (!ref)
|
|
42
|
-
throw (
|
|
20
|
+
throw (`Could not find ref for ${props.questionnaire.key}.${firstError}`);
|
|
43
21
|
scrollToAndFocus(ref);
|
|
44
22
|
}
|
|
45
23
|
return firstError === null;
|
|
46
24
|
};
|
|
47
|
-
|
|
25
|
+
const onDone = () => {
|
|
48
26
|
props.response.touchAllFields();
|
|
49
|
-
|
|
27
|
+
const firstError = props.response.firstNotValidQuestion();
|
|
50
28
|
if (firstError) {
|
|
51
|
-
|
|
29
|
+
const ref = questionRefs.get(firstError);
|
|
52
30
|
if (!ref)
|
|
53
|
-
throw (
|
|
31
|
+
throw (`Could not find ref for ${props.questionnaire.key}.${firstError}`);
|
|
54
32
|
scrollToAndFocus(ref);
|
|
55
33
|
}
|
|
56
34
|
else {
|
|
57
35
|
props.onSave();
|
|
58
36
|
}
|
|
59
37
|
};
|
|
60
|
-
|
|
38
|
+
const setQuestionRef = (key, ref) => {
|
|
61
39
|
questionRefs.set(key, ref);
|
|
62
40
|
};
|
|
63
|
-
return (
|
|
64
|
-
|
|
65
|
-
|
|
41
|
+
return (React.createElement("div", null,
|
|
42
|
+
React.createElement("form", { className: "paged", onSubmit: event => event.preventDefault() },
|
|
43
|
+
React.createElement(Paginator, { beforeNext: beforeNext, displayMode: displayMode, panels: props.questionnaire.panels.map(panel => (React.createElement(PanelContent, { questionnaire: props.questionnaire, panel: panel, response: props.response, setQuestionRef: setQuestionRef }))), onDone: onDone, onFocus: () => props.response.setActiveQuestion(null) }))));
|
|
66
44
|
};
|
|
67
|
-
exports.AnswerPage = AnswerPage;
|
|
68
45
|
// const DISPLAY_MODES = ["paged", "single_page"];
|
|
69
46
|
// const DisplayModeSelector = ({ displayMode, onChange }) => {
|
|
70
47
|
// return (
|
|
@@ -77,12 +54,12 @@ exports.AnswerPage = AnswerPage;
|
|
|
77
54
|
// };
|
|
78
55
|
// Scrolls the ref into view (usually the question wrapper).
|
|
79
56
|
// Focusses the first focusable element.
|
|
80
|
-
|
|
81
|
-
|
|
57
|
+
const scrollToAndFocus = (ref) => {
|
|
58
|
+
const el = ref === null || ref === void 0 ? void 0 : ref.current;
|
|
82
59
|
if (!el)
|
|
83
60
|
return;
|
|
84
61
|
el.scrollIntoView();
|
|
85
|
-
|
|
62
|
+
const firstInput = el.querySelector('input, select, textarea, [tabindex]:not([tabindex="-1"])');
|
|
86
63
|
if (firstInput instanceof HTMLElement) {
|
|
87
64
|
firstInput.focus();
|
|
88
65
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AnswerPage.js","sourceRoot":"","sources":["../../src/components/AnswerPage.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AnswerPage.js","sourceRoot":"","sources":["../../src/components/AnswerPage.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,22 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
exports.__esModule = true;
|
|
6
|
-
exports.MainLabel = void 0;
|
|
7
|
-
var react_1 = __importDefault(require("react"));
|
|
1
|
+
import React from "react";
|
|
8
2
|
// TODO: title_insert (input field directly inside the question title)
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
var labelFor = "answer_".concat(question.key);
|
|
3
|
+
export const MainLabel = ({ question }) => {
|
|
4
|
+
const titleText = question.title;
|
|
5
|
+
const labelFor = `answer_${question.key}`;
|
|
13
6
|
if (titleText && titleText !== "") {
|
|
14
|
-
return (
|
|
15
|
-
|
|
7
|
+
return (React.createElement("div", { className: "main" },
|
|
8
|
+
React.createElement("label", { htmlFor: labelFor, dangerouslySetInnerHTML: { __html: titleText } })));
|
|
16
9
|
}
|
|
17
10
|
else {
|
|
18
11
|
return null;
|
|
19
12
|
}
|
|
20
13
|
};
|
|
21
|
-
exports.MainLabel = MainLabel;
|
|
22
14
|
//# sourceMappingURL=MainLabel.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MainLabel.js","sourceRoot":"","sources":["../../src/components/MainLabel.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MainLabel.js","sourceRoot":"","sources":["../../src/components/MainLabel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAO1B,sEAAsE;AACtE,MAAM,CAAC,MAAM,SAAS,GAAmC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;IACxE,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC;IACjC,MAAM,QAAQ,GAAG,UAAU,QAAQ,CAAC,GAAG,EAAE,CAAC;IAE1C,IAAI,SAAS,IAAI,SAAS,KAAK,EAAE,EAAE;QACjC,OAAO,CACL,6BAAK,SAAS,EAAC,MAAM;YACnB,+BAAO,OAAO,EAAE,QAAQ,EAAE,uBAAuB,EAAE,EAAC,MAAM,EAAE,SAAS,EAAC,GAAI,CACtE,CACP,CAAC;KACH;SAAM;QACL,OAAO,IAAI,CAAC;KACb;AACH,CAAC,CAAC"}
|
|
@@ -1,36 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
}
|
|
9
|
-
catch (error) { e = { error: error }; }
|
|
10
|
-
finally {
|
|
11
|
-
try {
|
|
12
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
13
|
-
}
|
|
14
|
-
finally { if (e) throw e.error; }
|
|
15
|
-
}
|
|
16
|
-
return ar;
|
|
17
|
-
};
|
|
18
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
19
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
20
|
-
};
|
|
21
|
-
exports.__esModule = true;
|
|
22
|
-
exports.Paginator = void 0;
|
|
23
|
-
var react_1 = __importDefault(require("react"));
|
|
24
|
-
var react_i18next_1 = require("react-i18next");
|
|
25
|
-
var ProgressBar_1 = require("./ProgressBar");
|
|
26
|
-
var Paginator = function (props) {
|
|
27
|
-
var _a = __read(react_1["default"].useState(0), 2), activeIndex = _a[0], setActiveIndex = _a[1];
|
|
28
|
-
var callbacks = {
|
|
29
|
-
prev: activeIndex > 0 ? function () { return setActiveIndex(function (idx) { return idx - 1; }); } : undefined,
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { useTranslation } from "react-i18next";
|
|
3
|
+
import { ProgressBar } from "./ProgressBar";
|
|
4
|
+
export const Paginator = props => {
|
|
5
|
+
const [activeIndex, setActiveIndex] = React.useState(0);
|
|
6
|
+
const callbacks = {
|
|
7
|
+
prev: activeIndex > 0 ? () => setActiveIndex(idx => idx - 1) : undefined,
|
|
30
8
|
next: activeIndex < props.panels.length - 1 && props.displayMode !== "single_page"
|
|
31
|
-
?
|
|
9
|
+
? () => {
|
|
32
10
|
if (props.beforeNext(activeIndex)) {
|
|
33
|
-
setActiveIndex(
|
|
11
|
+
setActiveIndex(idx => idx + 1);
|
|
34
12
|
}
|
|
35
13
|
}
|
|
36
14
|
: undefined,
|
|
@@ -39,41 +17,40 @@ var Paginator = function (props) {
|
|
|
39
17
|
};
|
|
40
18
|
switch (props.displayMode) {
|
|
41
19
|
case "paged": {
|
|
42
|
-
return (
|
|
20
|
+
return (React.createElement(PagedPanel, { panelCount: props.panels.length, panelIndex: activeIndex, navigate: callbacks }, props.panels[activeIndex]));
|
|
43
21
|
}
|
|
44
22
|
case "single_page": {
|
|
45
|
-
return (
|
|
23
|
+
return (React.createElement(React.Fragment, null, props.panels.map((content, index) => (React.createElement("fieldset", { className: "panel", key: index },
|
|
46
24
|
content,
|
|
47
|
-
index === props.panels.length - 1 ?
|
|
25
|
+
index === props.panels.length - 1 ? React.createElement(Buttons, { firstPanel: false, lastPanel: true, navigate: callbacks }) : null)))));
|
|
48
26
|
}
|
|
49
27
|
default: {
|
|
50
28
|
return null;
|
|
51
29
|
}
|
|
52
30
|
}
|
|
53
31
|
};
|
|
54
|
-
exports.Paginator = Paginator;
|
|
55
32
|
function isFirstOrLastPanel(count, index) {
|
|
56
33
|
return {
|
|
57
34
|
firstPanel: index <= 0,
|
|
58
35
|
lastPanel: index >= count - 1
|
|
59
36
|
};
|
|
60
37
|
}
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
return (
|
|
64
|
-
|
|
38
|
+
const PagedPanel = props => {
|
|
39
|
+
const { firstPanel, lastPanel } = isFirstOrLastPanel(props.panelCount, props.panelIndex);
|
|
40
|
+
return (React.createElement("fieldset", { className: "panel" },
|
|
41
|
+
React.createElement(Hotkeys, null),
|
|
65
42
|
props.children,
|
|
66
|
-
|
|
67
|
-
|
|
43
|
+
React.createElement(ProgressBar, { max: props.panelCount, current: props.panelIndex }),
|
|
44
|
+
React.createElement(Buttons, { firstPanel: firstPanel, lastPanel: lastPanel, navigate: props.navigate })));
|
|
68
45
|
};
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
return (
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
?
|
|
76
|
-
:
|
|
46
|
+
const Buttons = props => {
|
|
47
|
+
const { t } = useTranslation();
|
|
48
|
+
return (React.createElement("div", { className: "buttons" },
|
|
49
|
+
React.createElement("div", { className: "prev" }, props.navigate.prev && React.createElement(Button, { onClick: props.navigate.prev, value: t("previous"), onFocus: props.navigate.onFocus })),
|
|
50
|
+
React.createElement("div", { className: "abort" }, props.navigate.abort && React.createElement(Button, { onClick: props.navigate.abort, value: t("abort"), onFocus: props.navigate.onFocus })),
|
|
51
|
+
React.createElement("div", { className: "next" }, props.navigate.next
|
|
52
|
+
? React.createElement(Button, { onClick: props.navigate.next, value: t("next"), onFocus: props.navigate.onFocus })
|
|
53
|
+
: React.createElement(Button, { onClick: props.navigate.done, value: t("done"), onFocus: props.navigate.onFocus }))));
|
|
77
54
|
// .buttons
|
|
78
55
|
// - if panel_counter == 0 and @questionnaire.enable_previous_questionnaire_button
|
|
79
56
|
// .back
|
|
@@ -95,16 +72,15 @@ var Buttons = function (props) {
|
|
|
95
72
|
// - if panel_counter == panels.length - 1
|
|
96
73
|
// = render :partial => 'quby/v1/shared/pdf_button'
|
|
97
74
|
};
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
return react_1["default"].createElement("button", { onClick: onClick, onFocus: onFocus }, value);
|
|
75
|
+
const Button = ({ value, onClick, onFocus }) => {
|
|
76
|
+
return React.createElement("button", { onClick: onClick, onFocus: onFocus }, value);
|
|
101
77
|
};
|
|
102
78
|
// TODO:
|
|
103
79
|
// .panel-action-links
|
|
104
80
|
// = render :partial => "quby/v1/hotkey_dialog"
|
|
105
81
|
// - if panel_counter == 0 && @questionnaire.allow_switch_to_bulk
|
|
106
82
|
// = render :partial => "quby/v1/switch_to_bulk"
|
|
107
|
-
|
|
83
|
+
const Hotkeys = () => {
|
|
108
84
|
return null;
|
|
109
85
|
};
|
|
110
86
|
//# sourceMappingURL=Paginator.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Paginator.js","sourceRoot":"","sources":["../../src/components/Paginator.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Paginator.js","sourceRoot":"","sources":["../../src/components/Paginator.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,22 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { PanelItem } from "./PanelItem";
|
|
3
|
+
export const PanelContent = ({ questionnaire, panel, response, setQuestionRef }) => {
|
|
4
|
+
return (React.createElement(React.Fragment, null,
|
|
5
|
+
React.createElement(Title, { title: panel.title }),
|
|
6
|
+
panel.items.map((item, idx) => (React.createElement(PanelItem, { key: idx, questionnaire: questionnaire, item: item, response: response, setQuestionRef: setQuestionRef })))));
|
|
4
7
|
};
|
|
5
|
-
|
|
6
|
-
exports.PanelContent = void 0;
|
|
7
|
-
var react_1 = __importDefault(require("react"));
|
|
8
|
-
var PanelItem_1 = require("./PanelItem");
|
|
9
|
-
var PanelContent = function (_a) {
|
|
10
|
-
var questionnaire = _a.questionnaire, panel = _a.panel, response = _a.response, setQuestionRef = _a.setQuestionRef;
|
|
11
|
-
return (react_1["default"].createElement(react_1["default"].Fragment, null,
|
|
12
|
-
react_1["default"].createElement(Title, { title: panel.title }),
|
|
13
|
-
panel.items.map(function (item, idx) { return (react_1["default"].createElement(PanelItem_1.PanelItem, { key: idx, questionnaire: questionnaire, item: item, response: response, setQuestionRef: setQuestionRef })); })));
|
|
14
|
-
};
|
|
15
|
-
exports.PanelContent = PanelContent;
|
|
16
|
-
var Title = function (_a) {
|
|
17
|
-
var title = _a.title;
|
|
8
|
+
const Title = ({ title }) => {
|
|
18
9
|
if (title) {
|
|
19
|
-
return
|
|
10
|
+
return React.createElement("h1", null, title);
|
|
20
11
|
}
|
|
21
12
|
else {
|
|
22
13
|
return null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PanelContent.js","sourceRoot":"","sources":["../../src/components/PanelContent.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PanelContent.js","sourceRoot":"","sources":["../../src/components/PanelContent.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AASxC,MAAM,CAAC,MAAM,YAAY,GAAmC,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,EAAE,EAAE;IACjH,OAAO,CACL,oBAAC,KAAK,CAAC,QAAQ;QACb,oBAAC,KAAK,IAAC,KAAK,EAAE,KAAK,CAAC,KAAK,GAAI;QAC5B,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,CAC9B,oBAAC,SAAS,IAAC,GAAG,EAAE,GAAG,EAAE,aAAa,EAAE,aAAa,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,cAAc,EAAE,cAAc,GAAI,CACtH,CAAC,CACa,CAClB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,KAAK,GAAqD,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;IAC5E,IAAI,KAAK,EAAE;QACT,OAAO,gCAAK,KAAK,CAAM,CAAC;KACzB;SAAM;QACL,OAAO,IAAI,CAAC;KACb;AACH,CAAC,CAAC"}
|
|
@@ -1,27 +1,20 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
exports.__esModule = true;
|
|
6
|
-
exports.PanelItem = void 0;
|
|
7
|
-
var react_1 = __importDefault(require("react"));
|
|
8
|
-
var HtmlItem_1 = require("./items/HtmlItem");
|
|
9
|
-
var QuestionItem_1 = require("./items/QuestionItem");
|
|
10
|
-
var UnknownItem_1 = require("./items/UnknownItem");
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { HtmlItem } from "./items/HtmlItem";
|
|
3
|
+
import { QuestionItem } from "./items/QuestionItem";
|
|
4
|
+
import { UnknownItem } from "./items/UnknownItem";
|
|
11
5
|
// TODO: raw_content
|
|
12
|
-
|
|
6
|
+
export const PanelItem = props => {
|
|
13
7
|
switch (props.item.type) {
|
|
14
8
|
case "html": {
|
|
15
|
-
return
|
|
9
|
+
return React.createElement(HtmlItem, { item: props.item, response: props.response });
|
|
16
10
|
}
|
|
17
11
|
case "question": {
|
|
18
|
-
return
|
|
12
|
+
return React.createElement(QuestionItem, { questionnaire: props.questionnaire, response: props.response, fieldKey: props.item.key, setQuestionRef: props.setQuestionRef });
|
|
19
13
|
}
|
|
20
14
|
default: {
|
|
21
|
-
return
|
|
15
|
+
return React.createElement(UnknownItem, { item: props.item });
|
|
22
16
|
return null;
|
|
23
17
|
}
|
|
24
18
|
}
|
|
25
19
|
};
|
|
26
|
-
exports.PanelItem = PanelItem;
|
|
27
20
|
//# sourceMappingURL=PanelItem.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PanelItem.js","sourceRoot":"","sources":["../../src/components/PanelItem.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PanelItem.js","sourceRoot":"","sources":["../../src/components/PanelItem.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AASlD,oBAAoB;AAEpB,MAAM,CAAC,MAAM,SAAS,GAAmC,KAAK,CAAC,EAAE;IAC/D,QAAQ,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE;QACvB,KAAK,MAAM,CAAC,CAAC;YACX,OAAO,oBAAC,QAAQ,IAAC,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,GAAI,CAAC;SACjE;QACD,KAAK,UAAU,CAAC,CAAC;YACf,OAAO,oBAAC,YAAY,IAAC,aAAa,EAAE,KAAK,CAAC,aAAa,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,EAAE,KAAK,CAAC,cAAc,GAAI,CAAC;SACvJ;QACD,OAAO,CAAC,CAAC;YACP,OAAO,oBAAC,WAAW,IAAC,IAAI,EAAE,KAAK,CAAC,IAAI,GAAI,CAAA;YACxC,OAAO,IAAI,CAAC;SACb;KACF;AACH,CAAC,CAAC"}
|
|
@@ -1,31 +1,23 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
}
|
|
5
|
-
|
|
6
|
-
exports.ProgressBar = void 0;
|
|
7
|
-
var react_1 = __importDefault(require("react"));
|
|
8
|
-
var classnames_1 = __importDefault(require("classnames"));
|
|
9
|
-
var react_i18next_1 = require("react-i18next");
|
|
10
|
-
var ProgressBar = function (_a) {
|
|
11
|
-
var max = _a.max, current = _a.current;
|
|
12
|
-
var t = (0, react_i18next_1.useTranslation)().t;
|
|
1
|
+
import React from "react";
|
|
2
|
+
import classNames from "classnames";
|
|
3
|
+
import { useTranslation } from "react-i18next";
|
|
4
|
+
export const ProgressBar = ({ max, current }) => {
|
|
5
|
+
const { t } = useTranslation();
|
|
13
6
|
if (max <= 1) {
|
|
14
7
|
return null;
|
|
15
8
|
}
|
|
16
|
-
return (
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
return (
|
|
9
|
+
return (React.createElement("div", { className: "progress-bar" },
|
|
10
|
+
React.createElement("div", { className: "progress-wrapper" },
|
|
11
|
+
React.createElement("div", { className: classNames("progress-slider", { "long-list": max > 25 }) }, Array.from({ length: max }, (x, i) => {
|
|
12
|
+
return (React.createElement("span", { key: i, className: classNames("progress-stop", `step-${i + 1}`, {
|
|
20
13
|
active: i <= current,
|
|
21
14
|
"first-child": i === 0,
|
|
22
15
|
"last-child": i === max - 1,
|
|
23
16
|
current: i === current
|
|
24
17
|
}) }, i + 1));
|
|
25
18
|
})),
|
|
26
|
-
|
|
19
|
+
React.createElement("div", { className: "progress-details" }, t("step_i_of_n", { i: current + 1, n: max })))));
|
|
27
20
|
};
|
|
28
|
-
exports.ProgressBar = ProgressBar;
|
|
29
21
|
// - if panels.length > 1
|
|
30
22
|
// - current = panel_counter + 1
|
|
31
23
|
// .progress-bar{ 'data-panel-number' => current, 'data-panel-length' => panels.length }
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProgressBar.js","sourceRoot":"","sources":["../../src/components/ProgressBar.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ProgressBar.js","sourceRoot":"","sources":["../../src/components/ProgressBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,UAAU,MAAM,YAAY,CAAC;AAEpC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAO/C,MAAM,CAAC,MAAM,WAAW,GAAmC,CAAC,EAC1D,GAAG,EACH,OAAO,EACR,EAAE,EAAE;IACH,MAAM,EAAE,CAAC,EAAE,GAAG,cAAc,EAAE,CAAC;IAE/B,IAAI,GAAG,IAAI,CAAC,EAAE;QACZ,OAAO,IAAI,CAAC;KACb;IAED,OAAO,CACL,6BAAK,SAAS,EAAC,cAAc;QAC3B,6BAAK,SAAS,EAAC,kBAAkB;YAC/B,6BACE,SAAS,EAAE,UAAU,CAAC,iBAAiB,EAAE,EAAE,WAAW,EAAE,GAAG,GAAG,EAAE,EAAE,CAAC,IAElE,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBACpC,OAAO,CACL,8BACE,GAAG,EAAE,CAAC,EACN,SAAS,EAAE,UAAU,CAAC,eAAe,EAAE,QAAQ,CAAC,GAAG,CAAC,EAAE,EAAE;wBACtD,MAAM,EAAE,CAAC,IAAI,OAAO;wBACpB,aAAa,EAAE,CAAC,KAAK,CAAC;wBACtB,YAAY,EAAE,CAAC,KAAK,GAAG,GAAG,CAAC;wBAC3B,OAAO,EAAE,CAAC,KAAK,OAAO;qBACvB,CAAC,IAED,CAAC,GAAG,CAAC,CACD,CACR,CAAC;YACJ,CAAC,CAAC,CACE;YACN,6BAAK,SAAS,EAAC,kBAAkB,IAC7B,CAAC,CAAC,aAAa,EAAE,EAAC,CAAC,EAAE,OAAO,GAAG,CAAC,EAAE,CAAC,EAAE,GAAG,EAAC,CAAC,CACxC,CACF,CACF,CACP,CAAC;AACJ,CAAC,CAAC;AACF,yBAAyB;AACzB,gCAAgC;AAChC,wFAAwF;AACxF,sBAAsB;AACtB,wEAAwE;AACxE,qCAAqC;AACrC,yBAAyB;AACzB,wCAAwC;AACxC,4DAA4D;AAC5D,sDAAsD;AACtD,kEAAkE;AAClE,4DAA4D;AAC5D,0DAA0D;AAC1D,wBAAwB;AACxB,2EAA2E"}
|
package/lib/components/Quby.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { Response } from "../core";
|
|
2
|
+
import { Response, IResponseJson } from "../core";
|
|
3
3
|
export interface Props {
|
|
4
4
|
questionnaireJson: any;
|
|
5
|
-
responseJson:
|
|
5
|
+
responseJson: IResponseJson;
|
|
6
6
|
displayMode: string;
|
|
7
7
|
onSave: (response: Response) => void;
|
|
8
8
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Quby.d.ts","sourceRoot":"","sources":["../../src/components/Quby.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"Quby.d.ts","sourceRoot":"","sources":["../../src/components/Quby.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAiB,QAAQ,EAAmB,aAAa,EAAkC,MAAM,SAAS,CAAC;AAElH,MAAM,WAAW,KAAK;IACpB,iBAAiB,EAAE,GAAG,CAAC;IACvB,YAAY,EAAE,aAAa,CAAC;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,IAAI,CAAC;CACtC;AAED,eAAO,MAAM,IAAI,EAAE,KAAK,CAAC,iBAAiB,CAAC,KAAK,CAS/C,CAAA"}
|
package/lib/components/Quby.js
CHANGED
|
@@ -1,20 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
var core_1 = require("../core");
|
|
10
|
-
var Quby = function (props) {
|
|
11
|
-
var questionnaire = new core_1.Questionnaire(props.questionnaireJson);
|
|
12
|
-
var response = new core_1.Response(questionnaire, props.responseJson);
|
|
13
|
-
var displayOptions = { displayMode: props.displayMode };
|
|
14
|
-
var handleSave = function () {
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { AnswerPage } from "./AnswerPage";
|
|
3
|
+
import { Questionnaire, Response, convertAndValidateResponseJson } from "../core";
|
|
4
|
+
export const Quby = (props) => {
|
|
5
|
+
const questionnaire = new Questionnaire(props.questionnaireJson);
|
|
6
|
+
const response = new Response(questionnaire, convertAndValidateResponseJson(props.responseJson, questionnaire));
|
|
7
|
+
const displayOptions = { displayMode: props.displayMode };
|
|
8
|
+
const handleSave = () => {
|
|
15
9
|
props.onSave(response);
|
|
16
10
|
};
|
|
17
|
-
return
|
|
11
|
+
return React.createElement(AnswerPage, { questionnaire: questionnaire, response: response, displayOptions: displayOptions, onSave: handleSave });
|
|
18
12
|
};
|
|
19
|
-
exports.Quby = Quby;
|
|
20
13
|
//# sourceMappingURL=Quby.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Quby.js","sourceRoot":"","sources":["../../src/components/Quby.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Quby.js","sourceRoot":"","sources":["../../src/components/Quby.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAkC,8BAA8B,EAAE,MAAM,SAAS,CAAC;AASlH,MAAM,CAAC,MAAM,IAAI,GAAmC,CAAC,KAAK,EAAE,EAAE;IAC5D,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;IACjE,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,aAAa,EAAE,8BAA8B,CAAC,KAAK,CAAC,YAAY,EAAE,aAAa,CAAC,CAAC,CAAC;IAChH,MAAM,cAAc,GAAG,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW,EAAqB,CAAC;IAC7E,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACzB,CAAC,CAAA;IAED,OAAO,oBAAC,UAAU,IAAC,aAAa,EAAE,aAAa,EAAE,QAAQ,EAAE,QAAQ,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,GAAI,CAAA;AAC7H,CAAC,CAAA"}
|
|
@@ -1,14 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
exports.__esModule = true;
|
|
6
|
-
exports.QuestionDescription = void 0;
|
|
7
|
-
var react_1 = __importDefault(require("react"));
|
|
8
|
-
var QuestionDescription = function (props) {
|
|
1
|
+
import React from "react";
|
|
2
|
+
export const QuestionDescription = (props) => {
|
|
9
3
|
if (!props.question.description)
|
|
10
4
|
return null;
|
|
11
|
-
return
|
|
5
|
+
return React.createElement("div", { className: "description", dangerouslySetInnerHTML: { __html: props.question.description } });
|
|
12
6
|
};
|
|
13
|
-
exports.QuestionDescription = QuestionDescription;
|
|
14
7
|
//# sourceMappingURL=QuestionDescription.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QuestionDescription.js","sourceRoot":"","sources":["../../src/components/QuestionDescription.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"QuestionDescription.js","sourceRoot":"","sources":["../../src/components/QuestionDescription.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAU1B,MAAM,CAAC,MAAM,mBAAmB,GAAmC,CAAC,KAAK,EAAE,EAAE;IAC3E,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW;QAAE,OAAO,IAAI,CAAC;IAE7C,OAAO,6BAAK,SAAS,EAAC,aAAa,EAAC,uBAAuB,EAAE,EAAC,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,WAAW,EAAC,GAAI,CAAA;AACvG,CAAC,CAAA"}
|
|
@@ -1,37 +1,19 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
t[p] = s[p];
|
|
8
|
-
}
|
|
9
|
-
return t;
|
|
10
|
-
};
|
|
11
|
-
return __assign.apply(this, arguments);
|
|
12
|
-
};
|
|
13
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
14
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
|
-
};
|
|
16
|
-
exports.__esModule = true;
|
|
17
|
-
exports.QuestionWrapper = void 0;
|
|
18
|
-
var react_1 = __importDefault(require("react"));
|
|
19
|
-
var classnames_1 = __importDefault(require("classnames"));
|
|
20
|
-
var ValidationErrors_1 = require("./ValidationErrors");
|
|
21
|
-
var QuestionWrapper = function (props) {
|
|
22
|
-
var question = props.question, fieldState = props.fieldState, setQuestionRef = props.setQuestionRef;
|
|
23
|
-
var questionRef = react_1["default"].useRef(null);
|
|
1
|
+
import React from "react";
|
|
2
|
+
import classNames from "classnames";
|
|
3
|
+
import { ValidationErrors } from "./ValidationErrors";
|
|
4
|
+
export const QuestionWrapper = props => {
|
|
5
|
+
const { question, fieldState, setQuestionRef } = props;
|
|
6
|
+
const questionRef = React.useRef(null);
|
|
24
7
|
setQuestionRef(question.key, questionRef);
|
|
25
|
-
|
|
8
|
+
const className = classNames("item", question.type, question.presentation, question.questionGroup, question.as, props.className, {
|
|
26
9
|
errors: fieldState.beenActive && fieldState.errors.length > 0,
|
|
27
10
|
active: fieldState.isActiveQuestion
|
|
28
11
|
});
|
|
29
|
-
return (
|
|
30
|
-
|
|
12
|
+
return (React.createElement("div", { className: className, ref: questionRef, style: { ...(fieldState.isActiveQuestion && activeStyles) } },
|
|
13
|
+
React.createElement(ValidationErrors, { fieldState: fieldState }),
|
|
31
14
|
props.children));
|
|
32
15
|
};
|
|
33
|
-
|
|
34
|
-
var activeStyles = {
|
|
16
|
+
const activeStyles = {
|
|
35
17
|
backgroundColor: '#fbfbff'
|
|
36
18
|
};
|
|
37
19
|
//# sourceMappingURL=QuestionWrapper.js.map
|