Page Menu
Home
Sealhub
Search
Configure Global Search
Log In
Files
F1262139
component-input.tsx
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
3 KB
Referenced Files
None
Subscribers
None
component-input.tsx
View Options
import
type
{
TableData
}
from
"@sealcode/jdd"
;
import
{
ComponentArguments
,
Enum
,
Image
,
List
,
Structured
,
Table
}
from
"@sealcode/jdd"
;
import
type
{
ComponentArgument
}
from
"@sealcode/jdd"
;
import
type
{
StatefulPage
}
from
"@sealcode/sealgen"
;
import
{
TempstreamJSX
}
from
"tempstream"
;
import
type
{
ComponentPreviewState
}
from
"../components.sreact.js"
;
import
{
ComponentInputEnum
}
from
"./component-input-enum.js"
;
import
{
ComponentInputImage
}
from
"./component-input-image.js"
;
import
{
ComponentInputList
}
from
"./component-input-list.js"
;
import
{
ComponentInputStructured
}
from
"./component-input-structured.js"
;
import
{
ComponentInputTable
}
from
"./component-input-table.js"
;
import
{
printArgPath
}
from
"./print-arg-path.js"
;
import
type
{
ComponentPreviewActions
}
from
"./component-preview-actions.js"
;
import
{
is
,
predicates
}
from
"@sealcode/ts-predicates"
;
export
const
actionName
=
"Components"
;
const
absoluteUrlPattern
=
"http(s?)(://)((www.)?)(([^.]+).)?([a-zA-z0-9-_]+)"
;
export
function
ComponentInput
<
State
extends
ComponentPreviewState
,
T
>
({
state
,
arg_path
,
arg
,
value
,
page
,
}
:
{
state
:
State
;
arg_path
:
string
[];
arg
:
ComponentArgument
<
T
>
;
value
:
T
;
page
:
StatefulPage
<
ComponentPreviewState
,
typeof
ComponentPreviewActions
>
;
})
{
if
(
value
===
undefined
)
{
value
=
arg
.
getEmptyValue
();
}
if
(
arg
instanceof
List
)
{
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
return
ComponentInputList
({
state
,
arg_path
,
arg
,
value
:
value
as
T
[],
page
});
}
const
argType
=
arg
.
getTypeName
();
const
isUrlAbsolute
=
arg
instanceof
ComponentArguments
.
URL
&&
arg
.
urlType
===
"absolute"
;
const
inputType
=
isUrlAbsolute
?
"url"
:
"text"
;
if
(
arg
instanceof
Structured
)
{
return
ComponentInputStructured
({
state
,
arg_path
,
arg
,
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
value
:
value
as
Record
<
string
,
unknown
>
,
page
,
});
}
if
(
arg
instanceof
Enum
)
{
return
ComponentInputEnum
({
state
,
arg_path
,
arg
,
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
value
:
value
as
string
,
onchange
:
page
.
rerender
(),
});
}
if
(
arg
instanceof
Image
)
{
return
ComponentInputImage
({
state
,
arg_path
,
arg
,
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
value
:
value
as
string
,
page
,
});
}
if
(
arg
instanceof
Table
)
{
return
ComponentInputTable
({
state
,
arg_path
,
arg
,
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
value
:
value
as
TableData
<
unknown
,
unknown
>
,
page
,
});
}
return
(
<
div
>
<
label
>
{
arg_path
.
at
(
-
1
)
||
""
}
{
argType
==
"markdown"
?
(
<
textarea
name
=
{
`$.component_args
${
printArgPath
(
arg_path
)
}
`
}
onblur
=
{
page
.
rerender
()}
cols
=
"40"
>
{
is
(
value
,
predicates
.
string
)
?
value
:
""
}
<
/textarea>
)
:
(
<
input
type
=
{
inputType
}
name
=
{
`$.component_args
${
printArgPath
(
arg_path
)
}
`
}
value
=
{
is
(
value
,
predicates
.
string
)
?
value
:
""
}
size
=
"40"
pattern
=
{
isUrlAbsolute
?
absoluteUrlPattern
:
undefined
}
/>
)}
<
/label>
<
/div>
);
}
File Metadata
Details
Attached
Mime Type
text/x-java
Expires
Thu, Jan 23, 19:19 (14 h, 8 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
598675
Default Alt Text
component-input.tsx (3 KB)
Attached To
Mode
rREWRITE Configurable rewriter
Attached
Detach File
Event Timeline
Log In to Comment