Skip to content
Toggle navigation
Toggle navigation
This project
Loading...
Sign in
Luciano Barletta
/
mini-web
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Pipelines
Graphs
Issues
0
Merge Requests
0
Wiki
Network
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Network
Compare
Branches
Tags
Commit 0bef61b1
authored
2019-11-26 11:31:25 -0300
by
Georgina Mondino
Browse Files
Options
Browse Files
Tag
Download
Plain Diff
Merge branch 'master' of
http://git.anacsoft.com/Lusho/mini-web
2 parents
7cecb102
a7db7f62
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
82 additions
and
46 deletions
Luciano/static/Scripts/construct.js
Luciano/templates/generate.html
Luciano/static/Scripts/construct.js
View file @
0bef61b
/**
* Lambdas
*/
var
accessNumber
=
e
=>
{
if
(
e
.
childElementCount
==
0
)
return
0
;
if
(
e
.
children
[
0
].
childElementCount
==
0
)
return
0
;
return
e
.
children
[
0
].
children
[
0
];
}
var
getAncestorByAttribute
=
(
elem
,
attr
,
val
)
=>
{
while
(
elem
.
getAttribute
(
attr
)
!=
val
||
elem
==
null
)
elem
=
elem
.
parentElement
;
return
elem
;
}
var
getDescendantByAttribute
=
(
elem
,
attr
,
val
)
=>
{
if
(
elem
==
null
||
elem
.
getAttribute
(
attr
)
==
val
)
return
elem
;
return
Array
.
from
(
elem
.
children
).
reduce
(
(
a
,
b
)
=>
{
let
x
=
getDescendantByAttribute
(
a
,
attr
,
val
);
let
y
=
getDescendantByAttribute
(
b
,
attr
,
val
);
return
x
==
null
?
y
:
x
;
},
null
);
}
/**
* Armado de formulario
*/
function
removeField
(
b
){
while
(
b
.
getAttribute
(
"name"
)
!=
"Field"
)
b
=
b
.
parentElement
;
if
(
b
.
nodeElement
==
"body"
)
return
;
b
.
parentElement
.
removeChild
(
b
);
function
removeTab
(
button
){
let
tabs
=
document
.
getElementById
(
'tabs'
)
tabs
.
removeChild
(
getAncestorByAttribute
(
button
,
'name'
,
'Tab'
)
)
if
(
tabs
.
childElementCount
==
0
){
document
.
getElementById
(
"ContinuarText"
).
style
.
display
=
'none'
;
document
.
getElementById
(
"ContinuarButton"
).
style
.
display
=
'none'
;
}
}
function
addField
(
b
){
function
addField
(
b
,
n
){
let
newfield
=
document
.
createElement
(
"div"
);
newfield
.
setAttribute
(
"name"
,
"Field"
);
newfield
.
innerHTML
=
document
.
getElementById
(
"fieldTemplate"
).
innerHTML
;
let
tab
=
b
.
parentElement
;
accessNumber
(
newfield
).
setAttribute
(
"value"
,
n
)
;
// swap
tab
.
removeChild
(
b
);
tab
.
appendChild
(
newfield
);
tab
.
appendChild
(
b
);
}
function
removeTab
(
b
){
while
(
b
.
getAttribute
(
"name"
)
!=
"Tab"
)
b
=
b
.
parentElement
;
if
(
b
.
nodeElement
==
"body"
)
return
;
b
.
parentElement
.
removeChild
(
b
);
let
container
=
b
.
parentElement
;
container
.
appendChild
(
newfield
);
container
.
appendChild
(
b
);
}
function
addTab
(
t
){
function
addTab
(
t
,
n
){
document
.
getElementById
(
"ContinuarText"
).
style
.
display
=
'block'
;
document
.
getElementById
(
"ContinuarButton"
).
style
.
display
=
'block'
;
let
newtab
=
document
.
createElement
(
"div"
);
newtab
.
setAttribute
(
"name"
,
"Tab"
);
newtab
.
innerHTML
=
document
.
getElementById
(
"tabTemplate"
).
innerHTML
;
accessNumber
(
newtab
).
setAttribute
(
"value"
,
n
);
t
.
appendChild
(
newtab
);
}
/**
* Lectura de información y formateado
*/
function
processField
(
field
){
let
data
=
field
.
children
[
0
];
return
{
'Title'
:
field
.
children
[
0
]
,
'Input'
:
field
.
children
[
1
].
selectedOptions
[
0
].
value
,
'Required'
:
field
.
children
[
2
].
checked
,
'Title'
:
data
.
children
[
1
].
value
,
'Input'
:
data
.
children
[
2
].
selectedOptions
[
0
].
value
,
'Required'
:
data
.
children
[
3
].
checked
,
};
}
function
processTab
(
tab
){
let
dict
=
{};
for
(
let
i
=
0
;
i
<
tab
.
children
.
length
;
i
++
){
if
(
tab
.
children
[
i
].
getAttribute
(
"name"
)
==
"Field"
){
dict
[
i
]
=
processField
(
tab
.
children
[
i
]);
let
dict
=
[];
let
container
=
getDescendantByAttribute
(
tab
,
"name"
,
"Field"
).
parentElement
;
for
(
let
i
=
0
;
i
<
container
.
children
.
length
;
i
++
){
if
(
container
.
children
[
i
].
getAttribute
(
"name"
)
==
"Field"
)
{
dict
.
push
(
processField
(
container
.
children
[
i
]));
}
}
return
dict
;
}
function
generate
(
tabs
){
let
dict
=
{};
for
(
let
i
=
0
;
i
<
tabs
.
children
.
length
;
i
++
){
if
(
tabs
.
children
[
i
].
getAttribute
(
"name"
)
==
"Tab"
){
dict
[
i
]
=
processTab
(
tabs
.
children
[
i
]);
let
dict
=
[];
for
(
let
i
=
0
;
i
<
tabs
.
children
.
length
;
i
++
)
{
let
c
=
tabs
.
children
[
i
];
if
(
c
.
getAttribute
(
"name"
)
==
"Tab"
)
{
dict
.
push
({
"Title"
:
getDescendantByAttribute
(
c
,
"class"
,
"TabTitle"
).
value
,
"Fields"
:
processTab
(
c
),
});
}
}
console
.
log
(
JSON
.
stringify
(
dict
));
}
function
sortTabs
(){
let
tabs
=
document
.
getElementById
(
"tabs"
);
Array
.
from
(
tabs
.
children
).
sort
(
(
a
,
b
)
=>
a
.
children
[
0
].
value
<
b
.
children
[
0
].
value
?
-
1
:
a
.
children
[
0
].
value
>
b
.
children
[
0
].
value
?
1
:
0
function
sortChildren
(
container
,
number
){
let
fixinput
=
a
=>
number
(
a
).
nodeName
==
"INPUT"
&&
number
(
a
).
type
==
"number"
?
parseInt
(
number
(
a
).
value
)
:
Infinity
;
Array
.
from
(
container
.
children
).
sort
(
(
a
,
b
)
=>
fixinput
(
a
)
<
fixinput
(
b
)
?
-
1
:
fixinput
(
a
)
>
fixinput
(
b
)
?
1
:
0
).
forEach
(
c
=>
tabs
.
appendChild
(
c
)
c
=>
container
.
appendChild
(
c
)
)
}
function
sortFields
(
tab
){
Array
.
from
(
tab
.
children
).
sort
(
(
a
,
b
)
=>
a
.
children
[
0
].
value
<
b
.
children
[
0
].
value
?
-
1
:
a
.
children
[
0
].
value
>
b
.
children
[
0
].
value
?
1
:
0
).
forEach
(
c
=>
tabs
.
appendChild
(
c
)
)
function
maxChild
(
container
,
number
){
let
fixinput
=
a
=>
number
(
a
).
nodeName
==
"INPUT"
&&
number
(
a
).
type
==
"number"
?
parseInt
(
number
(
a
).
value
)
:
0
;
if
(
container
.
childElementCount
==
0
)
return
0
;
let
max
=
Array
.
from
(
container
.
children
).
reduce
(
(
a
,
b
)
=>
fixinput
(
a
)
>
fixinput
(
b
)
?
a
:
b
);
return
fixinput
(
max
);
}
\ No newline at end of file
Luciano/templates/generate.html
View file @
0bef61b
...
...
@@ -18,25 +18,28 @@
<br>
<div
id=
"tabs"
></div>
<div
style=
"text-align: center;"
>
<button
class=
"NewTabButton"
onclick=
"addTab(document.getElementById('tabs'))"
>
<button
class=
"NewTabButton"
onclick=
"let t = document.getElementById('tabs'); addTab(t, maxChild(t, accessNumber) + 1)"
>
+
</button>
</div>
<h3
id=
"ContinuarText"
>
Cuando se encuentre conforme con el formulario presione Continuar
</h3>
<button
id=
"ContinuarButton"
>
Continuar
</button>
<button
id=
"ContinuarButton"
onclick=
"generate(document.getElementById('tabs'))"
>
Continuar
</button>
</body>
<!-- templates -->
<template
id=
"tabTemplate"
>
<div
class=
"TabCards"
>
<input
type=
"number"
class=
"TabNumber"
>
<input
type=
"number"
class=
"TabNumber"
onchange=
"sortChildren(getAncestorByAttribute(this,'name','Tab').parentElement, accessNumber)"
>
<input
class=
"TabTitle"
placeholder=
"Titulo del Tab"
type=
"text"
>
<button
class=
"RemoveTabButton"
onclick=
"removeTab(this)"
>
X
</button>
</button>
<br>
<div
style=
"text-align: center;"
>
<button
class=
"NewInputButton"
onclick=
"addField(this)"
>
<button
class=
"NewInputButton"
onclick=
"addField(this, maxChild(this.parentElement,accessNumber) + 1)"
>
+
</button>
</div>
...
...
@@ -46,7 +49,8 @@
<template
id=
"fieldTemplate"
>
<div
class=
"InputContainer"
>
<input
type=
"number"
class=
"InputNumber"
>
<input
type=
"number"
class=
"InputNumber"
onchange=
"sortChildren(getAncestorByAttribute(this,'name','Field').parentElement, accessNumber)"
>
<input
type=
"text"
id=
"Titulo"
class=
"Input"
placeholder=
"Título"
>
<select
name=
"input"
class=
"Input"
>
...
...
@@ -61,7 +65,8 @@
<option
id=
"checkbox"
value=
"checkbox"
>
Selección
</option>
</select>
Obligatorio :
<input
type=
"checkbox"
>
<button
class=
"RemoveInputButton"
onclick=
"removeField(this)"
>
<button
class=
"RemoveInputButton"
onclick=
"let f = getAncestorByAttribute(this,'name','Field'); f.parentElement.removeChild(f)"
>
-
</button>
</div>
...
...
Write
Preview
Styling with
Markdown
is supported
Attach a file
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to post a comment