Skip to content

Commit

Permalink
chore: remove before create for rating input
Browse files Browse the repository at this point in the history
  • Loading branch information
ingmar-stipriaan committed Jan 15, 2025
1 parent 5e2ccc6 commit fc570c7
Show file tree
Hide file tree
Showing 6 changed files with 26 additions and 318 deletions.
3 changes: 3 additions & 0 deletions src/prefabs/helpers/getKindsByType.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ export type InputType =
| 'phone'
| 'price'
| 'radio'
| 'rating'
| 'richText'
| 'select'
| 'text'
Expand Down Expand Up @@ -50,6 +51,7 @@ const inputTypeToAllowedKinds = {
phone: ['PHONE_NUMBER'],
price: ['INTEGER', 'PRICE', 'PRICE_EXPRESSION'],
radio: ['LIST', 'BELONGS_TO', 'OBJECT'],
rating: ['DECIMAL'],
richText: ['RICH_TEXT'],
select: ['LIST', 'BELONGS_TO'],
text: ['TEXT', 'URL', 'IBAN', 'STRING'],
Expand All @@ -76,6 +78,7 @@ const inputTypeToActionInputVariableKind = {
phone: TEXT,
price: NUMBER,
radio: NUMBER,
rating: NUMBER,
richText: TEXT,
select: NUMBER,
text: TEXT,
Expand Down
8 changes: 7 additions & 1 deletion src/prefabs/hiddeninput.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import {
optionTemplateOptions,
option,
optionActionSetVariable,
CreateActionInputVariableKind,
} from '@betty-blocks/component-sdk';

const attributes = {
Expand All @@ -25,8 +26,13 @@ const options = {

const addChildOptions = optionTemplateOptions({
actionVariableId: option('ACTION_JS_VARIABLE', {
label: 'Action input variable',
label: 'Action input variable (number)',
value: '',
configuration: {
createActionInputVariable: {
type: CreateActionInputVariableKind.NUMBER,
},
},
}),
});

Expand Down
316 changes: 2 additions & 314 deletions src/prefabs/ratingInput.tsx
Original file line number Diff line number Diff line change
@@ -1,323 +1,11 @@
import * as React from 'react';
import { prefab, Icon, BeforeCreateArgs } from '@betty-blocks/component-sdk';
import { prefab, Icon } from '@betty-blocks/component-sdk';

import { RatingInput } from './structures/RatingInput';

const beforeCreate = ({
close,
components: {
Content,
Field,
Footer,
Header,
FormField,
Toggle,
PropertySelector,
Label,
TextInput: Text,
CircleQuestion,
BBTooltip,
},
prefab: originalPrefab,
save,
helpers,
}: BeforeCreateArgs) => {
const {
BettyPrefabs,
prepareInput,
useModelIdSelector,
useActionIdSelector,
usePrefabSelector,
usePropertyQuery,
setOption,
createUuid,
useModelQuery,
createBlacklist,
useModelRelationQuery,
} = helpers;

const [propertyPath, setProperty] = React.useState<any>('');
const [variableInput, setVariableInput] = React.useState(null);
const modelId = useModelIdSelector();
const actionId = useActionIdSelector();
const selectedPrefab = usePrefabSelector();
const [model, setModel] = React.useState<any>(null);
const [propertyBased, setPropertyBased] = React.useState(!!modelId);
const [prefabSaved, setPrefabSaved] = React.useState(false);

const [validationMessage, setValidationMessage] = React.useState('');
const modelRequest = useModelQuery({
variables: { id: modelId },
onCompleted: (result) => {
setModel(result.model);
},
});

const validate = () => {
if (modelRequest.loading) {
setValidationMessage(
'Model details are still loading, please try submitting again.',
);
return false;
}

return true;
};

let name: string | undefined;
let propertyKind;
let propertyModelId;
const componentId = createUuid();

function isProperty(path: string) {
return (
typeof path !== 'string' &&
typeof path === 'object' &&
!Array.isArray(path)
);
}

let propertyId: string;
if (isProperty(propertyPath)) {
const { id } = propertyPath;
propertyId = Array.isArray(id) ? id[id.length - 1] : id;
} else {
propertyId = propertyPath;
}

const propertyResponse = usePropertyQuery(propertyId);

if (!(propertyResponse.loading || propertyResponse.error)) {
if (propertyResponse.data) {
name = propertyResponse.data.property.label;
propertyKind = propertyResponse.data.property.kind;
propertyModelId = propertyResponse.data.property.referenceModel?.id;
}
}

const modelRelationResponse = useModelRelationQuery(propertyModelId);

let relationalProperties;
let modelProperty;
if (!(modelRelationResponse.loading || modelRelationResponse.error)) {
if (modelRelationResponse.data) {
relationalProperties = modelRelationResponse.data.model.properties;
modelProperty = relationalProperties.find(
(property) => property.name === 'id',
);
}
}

const unsupportedKinds = createBlacklist(['DECIMAL']);

const structure = originalPrefab.structure[0];

if (structure.type !== 'COMPONENT')
return <div>expected component prefab, found {structure.type}</div>;

const handlePropertyChange = (propertyOrId): void => {
setProperty(propertyOrId);
};

if (!actionId && !prefabSaved) {
setPrefabSaved(true);
save(originalPrefab);
}

const actionVariableOptionType = structure.options.find(
(option: { type: string }) => option.type === 'ACTION_JS_VARIABLE',
);

const actionVariableOption = actionVariableOptionType?.key || null;
const labelOptionKey = 'label';
const nameOptionKey = 'actionVariableId';

return (
<>
<Header onClose={close} title="Configure form input field" />
<Content>
{modelId && (
<Field label="Property based input">
<FormField onClick={(): void => setPropertyBased(!propertyBased)}>
<Toggle
color="purple"
checked={propertyBased}
onChange={(): void => {}}
/>
</FormField>
</Field>
)}
{propertyBased ? (
<Field
label="Property"
error={
validationMessage && (
<Text color="#e82600">{validationMessage}</Text>
)
}
>
<PropertySelector
allowRelations
disabledNames={['created_at', 'updated_at']}
disabledKinds={unsupportedKinds}
showFormat={false}
size="large"
onChange={handlePropertyChange}
value={propertyPath}
modelId={modelId}
/>
</Field>
) : (
<Field>
<Label>
Action input variable
<CircleQuestion
color="grey500"
size="medium"
data-tip="You can use this action input variable in the action itself."
data-for="variable-tooltip"
/>
</Label>
<BBTooltip
id="variable-tooltip"
place="top"
type="dark"
effect="solid"
/>
<Text
onChange={(e): void => setVariableInput(e.target.value)}
color="orange"
/>
</Field>
)}
</Content>
<Footer
onClose={close}
canSave={(propertyPath && !!name) || variableInput}
onSave={async (): Promise<void> => {
// eslint-disable-next-line no-param-reassign
structure.id = componentId;

const kind = propertyKind || 'DECIMAL';

const variableName = variableInput || name;
const result = await prepareInput(
actionId,
variableName,
kind,
propertyKind,
propertyResponse?.data?.property,
);

const newPrefab = { ...originalPrefab };
if (newPrefab.structure[0].type !== 'COMPONENT') {
throw new Error('expected Component');
}
setOption(newPrefab.structure[0], actionVariableOption, (option) => ({
...option,
value: variableName,
configuration: {
condition: {
type: 'SHOW',
option: 'property',
comparator: 'EQ',
value: '',
},
},
}));
setOption(newPrefab.structure[0], labelOptionKey, (option) => ({
...option,
value: [variableName],
}));

setOption(newPrefab.structure[0], nameOptionKey, (option) => ({
...option,
value: result.variable.variableId,
}));
if (propertyBased) {
setOption(newPrefab.structure[0], 'property', (option) => ({
...option,
value: {
id:
result.isRelational && !result.isMultiRelational
? [propertyId, modelProperty.id]
: propertyId,
type: 'PROPERTY',
name:
result.isRelational && !result.isMultiRelational
? `{{ ${model?.name}.${name}.id }}`
: `{{ ${model?.name}.${name} }}`,
},
configuration: {
allowedKinds: ['DECIMAL'],
disabled: true,
condition: {
type: 'HIDE',
option: 'property',
comparator: 'EQ',
value: '',
},
},
}));
setOption(newPrefab.structure[0], 'label', (option: any) => ({
...option,
value: [
{
id:
result.isRelational && !result.isMultiRelational
? [propertyId, modelProperty.id]
: propertyId,
type: 'PROPERTY_LABEL',
name:
result.isRelational && !result.isMultiRelational
? `{{ ${model?.name}.${name}.id }}`
: `{{ ${model?.name}.${name} }}`,
},
],
}));
}
if (validate()) {
if (
(selectedPrefab?.name === BettyPrefabs.UPDATE_FORM ||
selectedPrefab?.name === BettyPrefabs.CREATE_FORM ||
selectedPrefab?.name === BettyPrefabs.FORM ||
selectedPrefab?.name === BettyPrefabs.LOGIN_FORM) &&
propertyId
) {
const valueOptions = [
{
id:
result.isRelational && !result.isMultiRelational
? [propertyId, modelProperty.id]
: propertyId,
type: 'PROPERTY',
name:
result.isRelational && !result.isMultiRelational
? `{{ ${model?.name}.${name}.id }}`
: `{{ ${model?.name}.${name} }}`,
},
];

setOption(newPrefab.structure[0], 'value', (option) => ({
...option,
value:
option.type === 'VARIABLE'
? valueOptions
: (propertyId as any),
}));
}
}
save({ ...originalPrefab, structure: [newPrefab.structure[0]] });
}}
/>
</>
);
};

const attributes = {
category: 'FORM',
icon: Icon.RatingIcon,
keywords: ['FORM', 'INPUT', 'RATING'],
};

export default prefab('Rating', attributes, beforeCreate, [RatingInput({})]);
export default prefab('Rating', attributes, undefined, [RatingInput({})]);
Loading

0 comments on commit fc570c7

Please sign in to comment.