Skip to content
Permalink
master
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Go to file
 
 
Cannot retrieve contributors at this time
import { PropertyType } from '../../adapters/property/base-property'
/**
* Options passed to a given property
*/
export default interface PropertyOptions {
/**
* if given property should be visible. It can be either boolean for all possible views, or
* you can verify which view in particular should be hidden/shown.
*/
isVisible?: boolean | {
show?: boolean;
list?: boolean;
edit?: boolean;
filter?: boolean;
};
/**
* List of possible overridden components for given property.
*/
components?: {
show?: string;
list?: string;
edit?: string;
filter?: string;
};
/**
* Property type
*/
type?: PropertyType;
/**
* Indicates if property should be treated as an ID
*/
isId?: boolean;
/**
* One of given property should be treated as an "title property". Title property is "clickable"
* when user sees the record in a list or show views.
*/
isTitle?: boolean;
/**
* Indicates if given property should be treated as array of elements.
* @new In version 3.3
*/
isArray?: boolean;
/**
* Indicates if array elements should be draggable when editing.
* It is only usable if the property is an array.
* @new In version 3.5
*/
isDraggable?: boolean;
/**
* position of the field in a list,
* title field (isTitle) gets position -1 by default other
* fields gets position = 100.
*/
position?: number;
/**
* If options should be limited to finite set. After setting this
* in the UI you will see select box instead of the input
*/
availableValues?: Array<{
value: string | number;
label: string;
}>;
/**
* Custom properties passed to the frontend in {@link PropertyJSON}
*/
custom?: {
[key: string]: any;
};
/**
* Additional props passed to the actual React component rendering given property in Edit
* component.
*
* @new in version 3.3
*/
props?: {
[key: string]: any;
};
/**
* Whether given property should be editable or not.
*/
isDisabled?: boolean;
/**
* Whether given property should be sortable on list or not.
*/
isSortable?: boolean;
/**
* Whether given property should be marked as required.
*/
isRequired?: boolean;
/**
* Whether label should be hidden - false by default
*/
hideLabel?: boolean;
/**
* Name of the resource to which this property should be a reference.
* If set - {@link PropertyOptions.type} always returns `reference`
* @new In version 3.3
*/
reference?: string;
/**
* Description of field. Shown as hoverable hint after label.
*
* To use translations provide it in locale with specified options key from resource
* @example
* ```js
* new AdminJS({
* resources: [
* {
* resource: myResource,
* options: {
* properties: {
* myAwesomeProperty: {
* description: "Plane description" || "awesomeHint", // <- message key in locale
* },
* },
* },
* },
* ],
* locale: {
* translations: {
* resources: {
* myResource: {
* messages: {
* awesomeHint: "Locale description",
* },
* },
* },
* },
* },
* });
* ```
* @new In version 5.6
*/
description?: string;
}