UNPKG

@print-one/grapesjs

Version:

Free and Open Source Web Builder Framework

153 lines (137 loc) 5.04 kB
export interface SelectorManagerConfig { /** * Style prefix. * @default 'clm-' */ stylePrefix?: string; /** * Specify the element to use as a container, string (query) or HTMLElement. * With the empty value, nothing will be rendered. * @default '' */ appendTo?: string | HTMLElement; /** * Default selectors. * @default [] */ selectors?: any[]; /** * Default states. * @default [{ name: 'hover' }, { name: 'active' }, { name: 'nth-of-type(2n)' }] */ states?: any[]; /** * Custom selector name escaping strategy. * @example * escapeName: name => name.replace(' ', '_'), */ escapeName?: (name: string) => string; /** * Custom selected name strategy (the string you see after 'Selected'). * @example * selectedName: ({ result, state, target }) => `${result} - ID: ${target.getId()}`, */ selectedName?: (props: { result: string; state: any; target: any }) => string; /** * Icon used to add new selector */ iconAdd?: string; /** * Icon used to sync styles. */ iconSync?: string; /** * Icon to show when the selector is enabled. */ iconTagOn?: string; /** * Icon to show when the selector is disabled. */ iconTagOff?: string; /** * Icon used to remove the selector. */ iconTagRemove?: string; /** * Custom render function for the Selector Manager. * @example * render: ({ el, labelHead, labelStates, labelInfo, }) => { * // You can use the default `el` to extend/edit the current * // DOM element of the Selector Manager * const someEl = document.createElement('div'); * // ... * el.appendChild(someEl); * // no need to return anything from the function * * // Create and return a new DOM element * const newEl = document.createElement('div'); * // ... * return newEl; * * // Return an HTML string for a completely different layout. * // Use `data-*` attributes to make the module recognize some elements: * // `data-states` - Where to append state `<option>` elements (or just write yours) * // `data-selectors` - Where to append selectors * // `data-input` - Input element which is used to add new selectors * // `data-add` - Element which triggers the add of a new selector on click * // `data-sync-style` - Element which triggers the sync of styles (visible with `componentFirst` enabled) * // `data-selected` - Where to print selected selectors * return ` * <div class="my-sm-header"> * <div>${labelHead}</div> * <div> * <select data-states> * <option value="">${labelStates}</option> * </select> * </div> * </div> * <div class="my-sm-body"> * <div data-selectors></div> * <input data-input/> * <span data-add>Add</span> * <span data-sync-style>Sync</span> * </div> * <div class="my-sm-info"> * <div>${labelInfo}</div> * <div data-selected></div> * </div> * `; * } */ render?: (props: any) => string; /** * When you select a component in the canvas the selected Model (Component or CSS Rule) * is passed to the StyleManager which will be then able to be styled, these are the cases: * - Selected component doesn't have any classes: Component will be passed * - Selected component has at least one class: The CSS Rule will be passed * * With this option enabled, also in the second case, the Component will be passed. * This method allows to avoid styling classes directly and make, for example, some * unintended changes below the visible canvas area (when components share same classes). * @default false */ componentFirst?: boolean; /** * Avoid rendering the default Selector Manager UI. * @default false */ custom?: boolean; } const config: SelectorManagerConfig = { stylePrefix: 'clm-', appendTo: '', selectors: [], states: [{ name: 'hover' }, { name: 'active' }, { name: 'nth-of-type(2n)' }], iconAdd: '<svg viewBox="0 0 24 24"><path d="M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"></path></svg>', iconSync: '<svg viewBox="0 0 24 24"><path d="M12 18c-3.31 0-6-2.69-6-6 0-1 .25-1.97.7-2.8L5.24 7.74A7.93 7.93 0 0 0 4 12c0 4.42 3.58 8 8 8v3l4-4-4-4m0-11V1L8 5l4 4V6c3.31 0 6 2.69 6 6 0 1-.25 1.97-.7 2.8l1.46 1.46A7.93 7.93 0 0 0 20 12c0-4.42-3.58-8-8-8z"></path></svg>', iconTagOn: '<svg viewBox="0 0 24 24"><path d="M19 19H5V5h10V3H5c-1.11 0-2 .89-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-8h-2m-11.09-.92L6.5 11.5 11 16 21 6l-1.41-1.42L11 13.17l-3.09-3.09z"></path></svg>', iconTagOff: '<svg viewBox="0 0 24 24"><path d="M19 3H5c-1.11 0-2 .89-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5a2 2 0 0 0-2-2m0 2v14H5V5h14z"></path></svg>', iconTagRemove: '<svg viewBox="0 0 24 24"><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"></path></svg>', componentFirst: false, custom: false, }; export default config;