editorjs-form-builder
Version:
A notion like form builder
87 lines • 5.57 kB
JavaScript
var __assign = (this && this.__assign) || function () {
__assign = Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import ReactDOM from "react-dom";
var NumberQuestion = /** @class */ (function () {
function NumberQuestion(_a) {
var data = _a.data;
this.wrapper = undefined;
this.settings = [
{
name: "required",
icon: "<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 480 512\" class=\"w-3 h-3\"><!-- Font Awesome Pro 5.15.4 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) --><path d=\"M471.99 334.43L336.06 256l135.93-78.43c7.66-4.42 10.28-14.2 5.86-21.86l-32.02-55.43c-4.42-7.65-14.21-10.28-21.87-5.86l-135.93 78.43V16c0-8.84-7.17-16-16.01-16h-64.04c-8.84 0-16.01 7.16-16.01 16v156.86L56.04 94.43c-7.66-4.42-17.45-1.79-21.87 5.86L2.15 155.71c-4.42 7.65-1.8 17.44 5.86 21.86L143.94 256 8.01 334.43c-7.66 4.42-10.28 14.21-5.86 21.86l32.02 55.43c4.42 7.65 14.21 10.27 21.87 5.86l135.93-78.43V496c0 8.84 7.17 16 16.01 16h64.04c8.84 0 16.01-7.16 16.01-16V339.14l135.93 78.43c7.66 4.42 17.45 1.8 21.87-5.86l32.02-55.43c4.42-7.65 1.8-17.43-5.86-21.85z\"/></svg>",
},
];
this.data = {
label: data.label || "",
help: data.help || "",
placeholder: data.placeholder || "",
required: data.required !== undefined ? data.required : true,
};
}
Object.defineProperty(NumberQuestion, "toolbox", {
get: function () {
return {
icon: "<svg xmlns=\"http://www.w3.org/2000/svg\" class=\"h-5 w-5\" viewBox=\"0 0 20 20\" fill=\"currentColor\">\n <path fill-rule=\"evenodd\" d=\"M9.243 3.03a1 1 0 01.727 1.213L9.53 6h2.94l.56-2.243a1 1 0 111.94.486L14.53 6H17a1 1 0 110 2h-2.97l-1 4H15a1 1 0 110 2h-2.47l-.56 2.242a1 1 0 11-1.94-.485L10.47 14H7.53l-.56 2.242a1 1 0 11-1.94-.485L5.47 14H3a1 1 0 110-2h2.97l1-4H5a1 1 0 110-2h2.47l.56-2.243a1 1 0 011.213-.727zM9.03 8l-1 4h2.938l1-4H9.031z\" clip-rule=\"evenodd\" />\n </svg>",
title: "Number Question",
};
},
enumerable: false,
configurable: true
});
NumberQuestion.prototype.save = function (block) {
return __assign(__assign({}, this.data), { label: block.firstElementChild.firstElementChild
.firstElementChild.value, placeholder: block.firstElementChild.childNodes[1]
.value, help: block.firstElementChild.lastElementChild
.value });
};
NumberQuestion.prototype.renderSettings = function () {
var _this = this;
var wrapper = document.createElement("div");
this.settings.forEach(function (tune) {
var button = document.createElement("div");
button.classList.add("cdx-settings-button");
button.classList.toggle("cdx-settings-button--active", _this.data[tune.name]);
button.innerHTML = tune.icon;
wrapper.appendChild(button);
button.addEventListener("click", function () {
_this._toggleTune(tune.name);
button.classList.toggle("cdx-settings-button--active");
});
});
return wrapper;
};
/**
* @private
* Click on the Settings Button
* @param {string} tune — tune name from this.settings
*/
NumberQuestion.prototype._toggleTune = function (tune) {
this.wrapper.classList.toggle(tune.name, !!this.data[tune.name]);
if (tune === "required") {
this.data.required = !this.data.required;
this.wrapper.childNodes[0].childNodes[0].childNodes[1].textContent = this
.data.required
? "*"
: "";
}
};
NumberQuestion.prototype.render = function () {
this.wrapper = document.createElement("div");
var toolView = (_jsxs("div", __assign({ className: "pb-5" }, { children: [_jsxs("div", __assign({ className: "relative font-bold leading-7 text-gray-800 text-md sm:truncate" }, { children: [_jsx("input", { type: "text", id: "label", defaultValue: this.data.label, className: "w-full p-0 border-0 border-transparent ring-0 focus:ring-0 placeholder:text-gray-300", placeholder: "Your Question" }), _jsx("div", __assign({ className: "absolute inset-y-0 right-0 flex items-center pr-3 text-red-500 pointer-events-none" }, { children: "*" }))] })), _jsx("input", { type: "text", className: "block w-full max-w-sm mt-1 text-sm text-gray-400 border-gray-300 rounded-md shadow-sm placeholder:text-gray-300", placeholder: "optional placeholder", defaultValue: this.data.placeholder }), _jsx("input", { type: "text", id: "help-text", defaultValue: this.data.help, className: "block w-full max-w-sm p-0 mt-2 text-sm font-light text-gray-500 border-0 border-transparent ring-0 focus:ring-0 placeholder:text-gray-300", placeholder: "optional help text" })] })));
ReactDOM.render(toolView, this.wrapper);
return this.wrapper;
};
return NumberQuestion;
}());
export default NumberQuestion;
//# sourceMappingURL=NumberQuestion.js.map