Svelecte

Global Config

Svelecte provides global config with many of settings. Basically it is an export from <script module></script> so when you call it before you create any <Svelecte /> instance, you can change some defaults for your whole app.

Part of global config is also global i18n object, although it can be set also on component level.

Example

Toggle buttons and visit another pages. YOu will see the settings are applied globally.

Settings

export type Settings = {
  valueField: string | null;
  labelField: string | null;
  groupLabelField: string;
  groupItemsField: string;
  disabledField: string;
  placeholder: string;
  valueAsObject: boolean;
  searchable: boolean;
  clearable: boolean;
  highlightFirstItem: boolean;
  selectOnTab: boolean | 'select-navigate';
  resetOnBlur: boolean;
  resetOnSelect: boolean;
  fetchResetOnBlur: boolean;
  fetchDebounceTime: number;
  multiple: boolean;
  closeAfterSelect: boolean | string;
  max: number;
  collapseSelection: 'blur' | 'always' | null;
  keepSelectionInList: 'auto' | boolean;
  creatable: boolean;
  creatablePrefix: string;
  keepCreated: boolean;
  allowEditing: boolean;
  delimiter: string;
  fetchCallback: Function;
  minQuery: number;
  lazyDropdown: boolean;
  virtualList: boolean;
  vlItemSize: number | null;
  i18n: I18nObject;
  requestFactory: import("./utils/fetch").RequestFactoryFn;
}
export type Settings = {
  valueField: string | null;
  labelField: string | null;
  groupLabelField: string;
  groupItemsField: string;
  disabledField: string;
  placeholder: string;
  valueAsObject: boolean;
  searchable: boolean;
  clearable: boolean;
  highlightFirstItem: boolean;
  selectOnTab: boolean | 'select-navigate';
  resetOnBlur: boolean;
  resetOnSelect: boolean;
  fetchResetOnBlur: boolean;
  fetchDebounceTime: number;
  multiple: boolean;
  closeAfterSelect: boolean | string;
  max: number;
  collapseSelection: 'blur' | 'always' | null;
  keepSelectionInList: 'auto' | boolean;
  creatable: boolean;
  creatablePrefix: string;
  keepCreated: boolean;
  allowEditing: boolean;
  delimiter: string;
  fetchCallback: Function;
  minQuery: number;
  lazyDropdown: boolean;
  virtualList: boolean;
  vlItemSize: number | null;
  i18n: I18nObject;
  requestFactory: import("./utils/fetch").RequestFactoryFn;
}
const settings = {
  valueField: null,
  labelField: null,
  groupLabelField: 'label',
  groupItemsField: 'options',
  disabledField: '$disabled',
  placeholder: 'Select',
  valueAsObject: false,
  searchable: true,
  clearable: false,
  highlightFirstItem: true,
  selectOnTab: false,
  resetOnBlur: true,
  resetOnSelect: true,
  fetchResetOnBlur: true,
  fetchDebounceTime: 300,
  multiple: false,
  closeAfterSelect: 'auto',
  max: 0,
  collapseSelection: null,
  keepSelectionInList: 'auto',
  creatable: false,
  creatablePrefix: '*',
  keepCreated: true,
  allowEditing: false,
  delimiter: ',',
  fetchCallback: null,
  minQuery: 1,
  lazyDropdown: true,
  virtualList: false,
  vlItemSize: null
}
const settings = {
  valueField: null,
  labelField: null,
  groupLabelField: 'label',
  groupItemsField: 'options',
  disabledField: '$disabled',
  placeholder: 'Select',
  valueAsObject: false,
  searchable: true,
  clearable: false,
  highlightFirstItem: true,
  selectOnTab: false,
  resetOnBlur: true,
  resetOnSelect: true,
  fetchResetOnBlur: true,
  fetchDebounceTime: 300,
  multiple: false,
  closeAfterSelect: 'auto',
  max: 0,
  collapseSelection: null,
  keepSelectionInList: 'auto',
  creatable: false,
  creatablePrefix: '*',
  keepCreated: true,
  allowEditing: false,
  delimiter: ',',
  fetchCallback: null,
  minQuery: 1,
  lazyDropdown: true,
  virtualList: false,
  vlItemSize: null
}

I18n

I18n section contains some ARIA related properties.

export type I18nObject = {
  empty: string;
  nomatch: string;
  max: (max: number) => string;
  fetchBefore: string;
  fetchQuery: (minQuery: number, inputLength: number) => string;
  fetchInit: string;
  fetchEmpty: string;
  collapsedSelection: (count: number) => string;
  createRowLabel: (value: string) => string;
  aria_selected: (opts: string[]) => string;
  aria_listActive: (opt: object, labelField: string, resultCount: number) => string;
  aria_inputFocused: () => string;
  aria_removeItemLabel: (opt: object, labelField: string) => string;
  aria_label: string;
  aria_describedby: string;
}
export type I18nObject = {
  empty: string;
  nomatch: string;
  max: (max: number) => string;
  fetchBefore: string;
  fetchQuery: (minQuery: number, inputLength: number) => string;
  fetchInit: string;
  fetchEmpty: string;
  collapsedSelection: (count: number) => string;
  createRowLabel: (value: string) => string;
  aria_selected: (opts: string[]) => string;
  aria_listActive: (opt: object, labelField: string, resultCount: number) => string;
  aria_inputFocused: () => string;
  aria_removeItemLabel: (opt: object, labelField: string) => string;
  aria_label: string;
  aria_describedby: string;
}
i18n: {
  aria_label: '',
  aria_describedby: '',
  aria_selected: (opts) => opts.length ? `Option${opts.length > 1 ? 's' : ''} ${opts.join(', ')} selected.` : '',
  aria_listActive: (opt, labelField, count) => `You are currently focused on option ${opt[labelField]}. ${count} result${count>1?'s': ''} available.`,
  aria_inputFocused: () => 'Select is focused, type to refine list, press down to scroll through the list',
  aria_removeItemLabel: (opt, labelField) => `Remove item`,
  empty: 'No options',
  nomatch: 'No matching options',
  max: num => `Maximum items ${num} selected`,
  fetchBefore: 'Type to start searching',
  fetchQuery: (minQuery, inputLength) => `Type at least ${minQuery} character${
      minQuery > 1 ? 's' : ''
    } to start searching`
  ,
  fetchInit: 'Fetching data, please wait...',
  fetchEmpty: 'No data related to your search',
  collapsedSelection: count => `${count} selected`,
  createRowLabel: value => `Add '${value}'`,
  emptyCreatable: 'Add new by typing'
}
i18n: {
  aria_label: '',
  aria_describedby: '',
  aria_selected: (opts) => opts.length ? `Option${opts.length > 1 ? 's' : ''} ${opts.join(', ')} selected.` : '',
  aria_listActive: (opt, labelField, count) => `You are currently focused on option ${opt[labelField]}. ${count} result${count>1?'s': ''} available.`,
  aria_inputFocused: () => 'Select is focused, type to refine list, press down to scroll through the list',
  aria_removeItemLabel: (opt, labelField) => `Remove item`,
  empty: 'No options',
  nomatch: 'No matching options',
  max: num => `Maximum items ${num} selected`,
  fetchBefore: 'Type to start searching',
  fetchQuery: (minQuery, inputLength) => `Type at least ${minQuery} character${
      minQuery > 1 ? 's' : ''
    } to start searching`
  ,
  fetchInit: 'Fetching data, please wait...',
  fetchEmpty: 'No data related to your search',
  collapsedSelection: count => `${count} selected`,
  createRowLabel: value => `Add '${value}'`,
  emptyCreatable: 'Add new by typing'
}

Made with Svelte ❤ by Martin Skocik.

You can support me through GitHub.