galhui
Version:
UI library using galho framework
880 lines • 82.1 kB
JavaScript
import { Component, G, clearEvent, div, g, m, onfocusout } from "galho";
import orray, { extend } from "galho/orray.js";
import { assign, byKey, call, def, filter, is, isA, isO, isS, isU, l } from "galho/util.js";
import { $, busy, cancel, confirm, errorMessage, ibt, icon, icons, label, menuitem, modal, selectRoot, setValue, tip, w, close } from "./galhui.js";
import { anyProp, arrayToDic } from "./util.js";
export const bot = (src, call) => assign(src, { srcs: {}, call });
export const error = (tp, msg, params) => ({ tp, params, render: () => msg });
export const req = () => error("req" /* ErrorType.required */, w.required);
export function setupbots(container) {
if (container.p.bots)
for (let bot of container.p.bots) {
let srcs = bot.srcs = {}; //, cb = bot.at(-1) as BotCallback<T>;
for (let field of bot)
srcs[field] = container.input(field).value;
setTimeout(bot.call, 0, srcs, container);
}
// if (bots) {
// // let calc = (input?: Input | void) => input ?
// // srcs[input.name] = input.value :
// // cb(srcs, container);
// for (let bot of bots) {
// let srcs: AnyDic = {}, cb = bot.at(-1) as BotCallback<T>;
// container.on("input", (input) => bot.includes(input.name) && calc(cb, input));
// // for (let i = 0; i < bot.length - 1; i++) {
// // let src = bot[i] as str;
// // let inp = container.input(src);
// // srcs[src] = inp.value;
// // inp.onset(["value", "off"], calc);
// // }
// setTimeout(calc, 0, cb);
// }
// }
}
/** */
export class FormBase extends Component {
inputs;
constructor(p, inputs) {
if (isA(p)) {
inputs = p;
p = {};
}
super(p);
this.inputs = filter(inputs);
// checkBot(this, i.bots);
}
view() { throw 1; }
get isDef() {
for (let input of this.inputs)
if (!input.isDef())
return false;
return true;
}
input(key) {
for (let input of this.inputs)
if (input.name == key || (is(input, CompostIn) && (input = input.input(key))))
return input;
}
errors = {};
setErrors(key, errors) {
this.errors[key] = errors;
this.input(key)?.error(!!errors);
}
valid(omit, focus = !omit) {
if (omit)
return !this.inputs.some(i => i.invalid(i.value, true));
for (let input of this.inputs) {
let inv = input.invalid(input.value, omit, focus);
this.setErrors(input.name, inv);
if (inv && focus) {
input.focus();
focus = false;
}
}
//use isto para incluir erros não gerados por inputs direitamente
return !anyProp(this.errors, e => e && l(e));
}
focus() {
for (let input of this.inputs)
if (!input.p.off) {
input.focus();
break;
}
return this;
}
// get def() {
// let r: Dic = {};
// for (let { key, def } of this.inputs)
// r[key] = def;
// return r;
// }
// /**default data */
// def(): Dic;
// def(value: Dic): this;
// def(value: null): this;
// def(v?: Dic) {
// if (isU(v)) {
// let r: Dic = {};
// for (let { key, def } of this.inputs)
// r[key] = def;
// return r;
// } else this.inputs.forEach(i => v ?
// i.key in v && i.set("def", v?.[i.key]) :
// i.set("def", null)
// );
// }
fill(value, setAsDefault) {
this
.emit("fill", value).inputs
.forEach(i => i.fill(value, setAsDefault));
return this;
}
reset(...fields) {
for (let i of l(fields) ? this.inputs.filter(i => fields.includes(i.name)) : this.inputs) {
i.visited = false;
i.value = i.def;
}
return this;
}
// clear(...fields: str[]) {
// for (let i of l(fields) ? this.inputs.filter(i => fields.includes(i.key)) : this.inputs)
// i.value(i.null);
// return this;
// }
/**
* get value of form
* @param edited se true only return fields that heve a value
* @param req se true fields required with default value will be returned too
*/
data(edited, req) {
let inputs = this.inputs;
let r = assign({}, this.p.hidden);
for (let input of edited ? inputs.filter(i => (req && i.p.req) || !i.isDef()) : inputs)
input.p.off || input.submit(r, edited, req);
this.emit("submit", r);
return r;
}
formData(edited, required) {
let r = new FormData(), data = this.data(edited, required);
for (let key in data)
r.append(key, data[key]);
return r;
}
}
export async function dataAsync(form, edited, req) {
let inputs = form.inputs;
let r = assign({}, form.p.hidden);
for (let input of edited ? inputs.filter(i => (req && i.p.req) || !i.isDef()) : inputs)
input.p.off || await input.submit(r, edited, req);
form.emit("submit", r);
return r;
}
function renderErrors(inputs, errs) {
let result = [];
for (let key in errs) {
let i = byKey(inputs, key, "name");
result.push(errs[key]?.map(err => div([i && [g("b", 0, i.p.text), ": "], err])));
// {
// (isS(error)) && (error = { tp: error });
// result.push(div([
// i && [g("b", 0, i.i.text), ": "],
// errors[error.tp](),
// error.info && g("sub", 0, error.info),
// ]));
// }
}
return result;
}
export const onOffHide = (e, isOff) => e.c("off", isOff);
export const onOffDisable = (e, isOff) => e.c("off", isOff);
export class Form extends FormBase {
errDiv;
constructor(p, inputs) {
super(p, inputs);
this.errDiv = (p = this.p).errorDiv || errorMessage();
if (p.outline == null)
p.outline = $.oform;
this.inputs.forEach(this.addInput, this);
this.on("input", (input) => {
if (p.bots)
for (let bot of p.bots)
if (bot.includes(input.name)) {
bot.call(assign(bot.srcs, { [input.name]: input.value }), this);
}
});
setupbots(this);
// this.p.labelSz ||= 40;
// this.on('input', (input: Input) => {
// let e = input.field(this).attr("edited", !input.isDef());
// (p as iForm).offFN?.(e, !!input.p.off)
// });
}
addInput(input) {
input.form = this;
input
.onset(["value", "off"], () => {
input.visited && this.setErrors(input.name, input.invalid(input.value));
let e = input.field(this.p).attr("edited", !input.isDef());
this.p.offFN?.(e, !!input.p.off);
this.emit("input", input);
})
.observeVisited(i => this.setErrors(i.name, i.invalid(i.value)));
}
view() {
let { p: i, inputs: inp } = this;
return g(i.tag || 'form', "_ form", [
inp.map(i => i.field(this.p)),
this.errDiv
]);
}
setErrors(key, errors) {
super.setErrors(key, errors);
this.errDiv.set(renderErrors(this.inputs, this.errors));
}
}
// export function mdform(hd: Label, inputs: Input[], cb?: (dt: Dic, form: FormBase) => Task<unk>, confirm?: S<HTMLButtonElement>, noCancel?: bool, sz?: Size): Promise<Dic>
// export function mdform(hd: Label, form: FormBase, cb?: (dt: Dic, form: FormBase) => Task<unk>, confirm?: S<HTMLButtonElement>, noCancel?: bool, sz?: Size): Promise<Dic>
/**modal form */
export function mdform(hd, form, cb, ok = confirm(), noCancel, sz) {
if (isA(form))
form = new Form(form);
return new Promise(res => {
modal(hd, g(form.set("tag", "div"), "bd"), (cl, md) => [
ok.p({ type: "submit" }).on("click", e => {
e.preventDefault();
if (form.valid()) {
clearEvent(e);
busy(md, async () => {
let dt = form.data();
res((await cb?.(dt, form)) || dt);
cl();
});
}
}),
noCancel || cancel(() => { cl(); res(null); })
], sz, !noCancel);
form.focus();
});
}
export function field(bd, i, container, sz = container.labelSz) {
let o = def(container.outline, i.outline);
let t = div("_ " + (o ? "oi" : "ii"), [
(!o || i.text) && g('label', "hd", [
i.text,
i.tip && tip(icon(icons.info), i.tip)
]).css("width", `${sz}%`).attr({ for: i.name }),
bd = g(bd, "bd").css("width", `${100 - sz}%`),
!!i.req && g("span", "req", "*"),
]);
if (i.off)
container.offFN?.(bd, true);
return t;
}
export function expand(form, ...main) {
for (let input of form.inputs)
g(input).c("sd" /* C.side */, !main.includes(input.name));
g(form).add(m(div(`ft _${"sd" /* C.side */}`, [
g("span", 0, "Mostrar todos"),
ibt(icons.down, null)
]), div(`ft ${"sd" /* C.side */}`, [
g("span", 0, "Mostrar principais"),
ibt(icons.up, null),
])).on("click", () => g(form).tcls("expand")));
}
export function valid(e) {
for (let c = 0; c < e.length; c++) {
let i = e[c];
if (!i.validity.valid)
return false;
}
return true;
}
export function value(e) {
let r = {};
for (let c = 0; c < e.length; c++) {
let i = e[c];
if (i.name)
switch (i.type) {
case 'radio':
if (i.checked)
r[i.name] = i.value;
break;
case 'checkbox':
r[i.name] = i.checked;
break;
case 'date':
case 'time':
case 'week':
r[i.name] = i.valueAsDate;
break;
case 'number':
case 'range':
r[i.name] = i.valueAsNumber;
break;
case 'submit':
break;
default:
r[i.name] = i.value;
break;
}
}
return r;
}
// export const text = (v: str) => v && (v[0].toUpperCase() + v.slice(1).replace(/_/g, ' '));
export const up = (v) => v && def(w[v], (v[0].toUpperCase() + v.slice(1).replace(/_/g, ' ')));
export class Input extends Component {
constructor(p) {
super(p);
if (isU(p.text))
p.text = up(p.name);
if (isU(p.value))
p.value = this.def;
}
get name() { return this.p.name; }
get value() { return def(this.p.value, this.null); }
set value(v) { this.set("value", v); }
fill(src, setAsDefault) {
let k = this.p.name;
if (k in src) {
if (setAsDefault)
this.set("def", src[k]);
this.value = src[k];
}
}
get def() { return def(this.p.def, this.null); }
isDef(value = this.value, def = this.def) {
return def === value;
}
isNull(value = this.value) { return this.isDef(value, this.null); }
visited;
observeVisited(handler) {
onfocusout(g(this), () => {
this.visited = true;
handler(this);
});
}
/**show or hide errors */
error(state) {
g(this).c("error", state);
return this;
}
invalid(value, omit, focus) {
if (this.p.off)
return null;
let v = this.validate(value, omit, focus);
return l(v) ? v : null;
}
validate(value) {
return (this.p.req && this.isNull(value)) ? [req()] : [];
}
#f;
field(container, sz) {
return this.#f ||= field(this, this.p, container, sz);
}
submit(data) {
let { name, value, submit } = this.p;
if (submit)
submit(data);
else
data[name] = value;
}
/**null value used for clear method */
get null() { return null; }
}
export class TextIn extends Input {
view() {
let p = this.p, r;
if (p.input == 'ta') {
r = g('textarea', "_ in v")
.on('keydown', (e) => {
if (e.key == "Enter") {
if (e.ctrlKey)
e.preventDefault();
else
e.stopPropagation();
}
});
}
else
r = g("input", "_ in").p('type', p.input || 'text');
r.p({
minLength: p.length || p.min, maxLength: p.length || p.max,
name: p.name, id: p.name,
placeholder: p.ph || ''
})
.on({
input: () => {
this.emit("input", r.v());
this.set("value", r.v() || null);
},
focus() { r.e.select(); }
});
// if (p.min) r.e.minLength = p.min;
// if (p.max) r.e.maxLength = p.max;
return this.bind(r, () => r.e.value = p.value || '', "value");
}
validate(value) {
let p = this.p;
let errs = [];
if (value) {
if (p.pattern && !p.pattern.test(value))
errs.push(error("invalid_format" /* ErrorType.invalidFormat */, w.invalidFmt));
if (p.max && value.length > p.max)
errs.push(error("text_too_long" /* ErrorType.textTooLong */, "", { max: p.max }));
if (p.min && value.length < p.min)
errs.push(error("text_too_short" /* ErrorType.textTooShort */, "", { min: p.min }));
}
else if (p.req)
errs.push(req());
return errs;
}
}
/**text input */
export const textIn = (k, req, input) => new TextIn({ name: k, req, input });
export class NumbIn extends Input {
view() {
let i = this.p, inp = g("input", {
type: 'number',
placeholder: i.ph || '',
step: i.integer ? 1 : 'any',
name: i.name, id: i.name, value: i.value,
min: (i.min ?? i.omin), max: (i.max ?? i.omax),
oninput: () => this.value = inp.v() ? inp.e.valueAsNumber : null,
onfocus() { inp.e.select(); }
});
this.onset(["value", "off"], () => {
inp.v(i.value);
inp.e.disabled = !!i.off;
});
return (i.unit ? g("span", 0, [inp, i.unit]) : inp).c("_ in");
}
validate(value) {
return validateNumber(this.p, value);
}
// calc(...values: number[]) {
// var r = 0;
// for (let value of values)
// r += value || 0;
// return r;
// }
focus() {
let { $, p: i } = this;
(i.unit ? $.first : $).focus();
return this;
}
}
export const numbIn = (k, req, text, unit) => new NumbIn({ name: k, req, text, unit });
export function validateNumber(p, value) {
let errs = [];
if (value == null) {
if (p.req)
errs.push(req());
}
else {
if (p.integer && Math.floor(value) != value)
errs.push(error("is_decimal" /* ErrorType.isDecimal */));
//if (i.unsigned && value < 0)
// errs.push({ type: form.ErrorType.isNegative, key });
let { min, max, omin, omax } = p;
if ((max != null) && value > max)
errs.push(error("number_too_big" /* ErrorType.numberTooBig */, "", { max }));
else if (omax != null && value >= omax)
errs.push(error("number_too_big" /* ErrorType.numberTooBig */, "", { max: omax }));
if ((min != null) && value < min)
errs.push(error("number_too_small" /* ErrorType.numberTooSmall */, "", { min }));
else if (omin != null && value <= omin)
errs.push(error("number_too_small" /* ErrorType.numberTooSmall */, "", { min: omin }));
}
return errs;
}
export class CheckIn extends Input {
view() {
let i = this.p;
switch (i.fmt) {
case "y" /* CBFmt.yesNo */:
return this.bind(div(null, [
g('label', `${"cb" /* C.checkbox */} i`, [
g("input", {
type: 'radio',
value: 1,
name: i.name,
oninput: () => {
this.set('value', true);
}
}),
'Sim'
]),
g('label', `${"cb" /* C.checkbox */} i`, [
g("input", {
type: 'radio',
name: i.name,
value: 0,
oninput: () => {
this.set('value', false);
}
}),
'No'
])
]), (s) => {
s.child(i.value ? 0 : 1).first.p('checked', true);
}, 'value');
default:
let inp = g("input", {
type: 'checkbox',
name: i.name, id: i.name,
checked: i.value,
onclick: i.clear && ((e) => {
if (e.altKey)
setTimeout(() => this.set('value', null));
}),
oninput: () => this.set('value', inp.p('checked'))
}).c("sw" /* C.switch */, i.fmt != "c" /* CBFmt.checkbox */);
return this.bind(inp, s => s.p({
checked: i.value,
placeholder: i.ph || (i.value == null ? '' : i.value ? w.yes : w.no)
}), 'value');
}
}
}
export class TimeIn extends Input {
view() {
let _this = this, i = this.p;
return this.bind(g("input").p({
type: 'time',
name: i.name, id: i.name,
placeholder: i.ph,
}).on('input', function () {
_this.set('value', this.value + ':00');
}), (s) => s.p('value', i.value && i.value.slice(0, 5)), 'value');
}
}
export class DateIn extends Input {
view() {
let i = this.p;
let inp = g("input", "_ in").p({
type: "date",
name: i.name, id: i.name,
placeholder: i.ph,
value: i.value
});
this.onset("value", () => inp.e.value = i.value);
return inp.on("input", () => this.set("value", inp.e.value || null));
}
get def() {
return this.p.def == "now" ? new Date().toISOString().slice(0, 10) : null;
}
fill(src, setAsDefault) {
let k = this.p.name;
if (k in src) {
let v = src[k];
this.value = v ? new Date(v).toISOString().slice(0, 10) : null;
if (setAsDefault)
this.set("def", v);
}
}
}
const monthV = (v) => v?.slice(0, 7) || null;
const dateDefV = (v) => monthV(v == "now" ? new Date().toISOString() : v);
export class MonthIn extends Input {
view() {
let i = this.p;
let inp = g("input", "_ in").p({
type: "month",
name: i.name, id: i.name,
placeholder: i.ph,
value: monthV(i.value),
});
;
// this.onset("value", () =>);
return this.bind(inp, (_, p) => {
if ("max" in p)
inp.e.max = p.max;
if ("min" in p)
inp.e.min = p.min;
if ("value" in p)
inp.e.value = monthV(i.value);
}).on("input", () => this.set("value", inp.e.value || null));
}
get def() { return dateDefV(this.p.def); }
isDef(value = this.value, def = this.def) {
return dateDefV(def) === monthV(value);
}
submit(data) {
data[this.p.name] = this.value ? this.value + "-01" : null;
}
}
/**date & time input */
export class DTIn extends Input {
view() {
let i = this.p, inp = g("input", "_ in").p({
type: "datetime-local",
name: i.name, id: i.name,
placeholder: i.ph
}).on("input", () => {
this.set("value", inp.v() || null);
});
return this.bind(inp, () => inp.v(i.value || ""));
}
}
export class SelectIn extends Input {
options;
get active() { return byKey(this.options, this.p.value, this.options.key); }
constructor(i, options, key = 0) {
super(i);
i.item ||= v => def(v[1], v[key]);
this.options = extend(options, {
key, parse: e => isO(e) ? e : { [key]: e }
});
}
get value() { return this.p.value; }
set value(v) { this.p.value === v || this.set("value", v); }
view() {
let { p, options } = this;
let label = g("span");
let items = options.bind(g("table"), {
insert: v => {
let t = p.item(v);
return (is(t, G) && t.is("tr") ? t : menuitem(v.i, t)).d(v[options.key]);
},
tag(active, i, p, tag) {
let s = p.child(i);
s.c(tag, active);
if (active) {
menu.e.scroll({ top: s.p('offsetTop') - menu.p('clientHeight') / 2 + s.p('clientHeight') / 2 });
}
}
}).on("click", ({ currentTarget: ct, target: t }) => ct != t && (this.set("open", false).value = g(t).closest("tr").d()));
let menu = div("_ menu", items);
let root = selectRoot(this, options, label, menu, v => this.value = v).attr({ name: p.name });
setValue(this, label);
this.on(e => ("value" in e) && setValue(this, label));
return root;
}
option(k) { return this.options.find(k); }
}
export class MSelectIn extends Input {
options;
constructor(p, options, key = 0) {
super(p);
p.item ||= v => def(v[1], v[key]);
(p.value = orray(p.def).on(() => this.set(["value"])))
.parse = v => p.value.has(v) ? void 0 : v;
this.options = extend(options, { key, parse: e => isO(e) ? e : { [key]: e } });
}
option(k) { return this.options.find(k); }
view() {
let { p, options } = this;
let label = p.value.bind(div(), {
insert: k => g("span", "i", [p.item(this.option(k)), close(() => p.value.remove(k))]),
empty: v => label.c("ph", v).set(v && p.ph)
});
let items = g("table").on("click", ({ currentTarget: ct, target: t }) => {
if (ct != t) {
this.set("open", false);
p.value.push(g(t).closest("tr").d());
}
});
let menu = div("_ menu", items);
let root = selectRoot(this, options, label, menu, v => this.value.push(v)).attr({ name: p.name });
options.bind(items, {
insert: v => {
let t = p.item(v);
return (is(t, G) && t.is("tr") ? t : menuitem(v.i, t)).d(v[options.key]);
},
tag(active, i, p, tag) {
let s = p.child(i);
s.c(tag, active);
if (active) {
menu.e.scroll({ top: s.p('offsetTop') - menu.p('clientHeight') / 2 + s.p('clientHeight') / 2 });
}
}
});
return root;
}
get value() { return this.p.value; }
set value(v) { this.p.value.set(v); }
isDef(val = this.value, def = this.def || []) {
return l(val) == l(def) && val.every(v => def.includes(v));
}
}
export class MobSelectIn extends Input {
options;
okey;
constructor(i, options, okey) {
super(i);
this.options = options;
this.okey = okey;
}
view() {
let { p, options, okey } = this;
return g("select", "_ in", options.map(v => g("option", { value: v[okey] }, p.item(v))))
.p("name", p.name);
}
}
export class RadioIn extends Input {
view() {
let i = this.p, o = i.options.map(v => isS(v) ? [v] : v);
i.layout ||= l(o) > 3 ? "column" : "wrap";
return this.bind(g("span", i.layout == 'column' ? "_ col" : '', o.map(([key, text, ico]) => g('label', "cb" /* C.checkbox */, [
g("input", {
type: 'radio',
value: key,
name: i.name,
checked: key == i.value,
oninput: () => { this.set('value', key); }
}),
ico && icon(ico),
text || key
]))).on('click', e => {
if (e.altKey) {
g(e.currentTarget).queryAll('input').p('checked', false);
this.set('value', null);
}
}), (s) => {
s.queryAll('input').forEach(input => {
input.checked = input.value == i.value;
});
}, 'value').css('position', 'relative');
}
}
export class ChecklistIn extends Input {
view() {
let p = this.p, v = p.value;
return g("span", "_ col", p.options.map(v => isS(v) ? [v] : v).map(([key, text, ico]) => g('label', "cb" /* C.checkbox */, [
call(g("input", {
type: 'checkbox',
name: `${p.name}_${key}`,
checked: v.includes(key),
}), i => i.on("input", () => {
i.e.checked ? v.push(key) : v.splice(v.indexOf(key), 1);
this.set(['value']);
})),
ico && icon(ico),
text || key
])));
}
get def() { return []; }
}
/**password input */
export class PWIn extends Input {
view() {
let i = this.p, inp = g("input", "_ in").p({
type: 'password', name: i.name,
placeholder: i.ph
}).attr('autocomplete', i.auto || false);
return inp.on("input", () => this.set("value", inp.e.value));
}
validate(value) {
var i = this.p,
// key = i.key,
errs = [];
if (i.req && !value)
errs.push(req());
return errs;
}
}
export class CustomIn extends Input {
view;
constructor(i, view) {
super(i);
this.view = view;
if (i.submit)
this.submit = i.submit;
if (i.isDef)
this.isDef = i.isDef;
if (i.validate)
this.validate = i.validate;
if (i.fill)
this.fill = i.fill;
}
}
export class CompostIn extends Input {
#f;
get form() { return this.#f; }
set form(v) {
this.#f = v;
for (let i of this.inputs)
i.form = v;
}
subfield(input) {
return g(input); //.field(container);
}
constructor(p, inputs) {
p.value = null;
super(p);
for (let input of this.inputs = filter(inputs))
input.onset(["value", "off"], () => {
// input.visited && this.setErrors(input.name, input.invalid);
let f = this.form;
let e = this.subfield(input, f.p).attr("edited", !input.isDef());
f.p.offFN?.(e, !!input.p.off);
f.emit("input", input);
this.set(["value"]);
if (p.bots)
for (let bot of p.bots)
if (bot.includes(input.name)) {
bot.call(assign(bot.srcs, { [input.name]: input.value }), this);
}
});
setupbots(this);
}
inputs;
get def() { return arrayToDic(this.inputs, v => [v.name, v.def]); }
get value() { return arrayToDic(this.inputs, v => [v.name, v.value]); }
set value(v) {
this.inputs.forEach(i => i.name in v && (i.value = v ? v[i.name] : i.null));
}
view() {
for (let input of this.inputs)
input.onset('value', () => this.set(['value']));
return g("span", "_ join", this.inputs);
}
fill(value, setAsDefault) {
if (this.p.sub)
if (!(value = value[this.p.name]))
return;
for (let i of this.inputs)
i.fill(value, setAsDefault);
}
validate(_v, omit, focus) {
let err = [];
for (let input of this.inputs) {
let inv = input.invalid(input.value, omit, focus);
inv && err.push(...inv);
if (inv && focus) {
input.focus();
focus = false;
}
}
return err;
}
focus() {
this.inputs[0]?.focus();
return this;
}
submit(data, edited, req) {
let { inputs, p: i } = this;
if (i.sub)
data = data[i.name] = i.sub == "array" ? [] : {};
for (let inp of edited && !i.sub ? inputs.filter(i => (req && i.p.req) || !i.isDef()) : inputs)
inp.p.off || inp.submit(data, edited, req);
}
input(key) {
for (let input of this.inputs)
if (input.name == key || (is(input, CompostIn) && (input = input.input(key))))
return input;
}
isDef(v = this.value, def = this.def) {
for (let i of this.inputs)
if (!i.isDef(v[i.name], def[i.name]))
return false;
return true;
}
}
export function fieldGroup(title, inputs, form, sz) {
return g("fieldset", "_ formg", [
//TODO: remove sub element in label
g("legend", 0, label(title)),
inputs.map(i => i.field(form.p, sz))
]);
}
export class GroupIn extends CompostIn {
view() { throw 1; }
subfield(input, container) {
let p = this.p;
return input.field(p.row ? { offFN: p.offFN, outline: true } : container, p.labelSz);
}
field(container) {
let { p, inputs } = this;
return this.$ ||= g("fieldset", "_ formg " + (p.row ? "row" : ""), [
//TODO: remove sub element in label
g("legend", 0, label(p.text)),
inputs.map(i => this.subfield(i, container))
]); //fieldGroup(this.p.text, this.inputs, form, this.p.labelSz);
}
observeVisited(handler) {
for (let i of this.inputs)
i.observeVisited(handler);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.js","sourceRoot":"","sources":["form.ts"],"names":[],"mappings":"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