UIPredicateCoreVue.js

  1. /* eslint no-unused-vars: "off"*/
  2. /**
  3. * VueJS adapter for ui-predicate-core
  4. * @namespace vue
  5. * @since 1.0.0
  6. */
  7. import Vue from 'vue';
  8. import assign from 'lodash/assign';
  9. import { PredicateCore, UITypes } from 'ui-predicate-core';
  10. import DEFAULT_COMPONENTS from './default-components';
  11. const defaults = {
  12. options: {
  13. /**
  14. * UIPredicate Vue Adapter own default argument component
  15. * @return {Vue.component} the default Vue Component to use as argument specifier
  16. * @see core.defaults.getDefaultArgumentComponent
  17. * @memberof vue.defaults
  18. */
  19. getDefaultArgumentComponent() {
  20. return DEFAULT_COMPONENTS[UITypes.ARGUMENT_DEFAULT];
  21. },
  22. },
  23. };
  24. /**
  25. * UIPredicateCore adapter for VueJS
  26. * @param {?dataclasses.CompoundPredicate} [data=PredicateCore.defaults.options.getDefaultData] data
  27. * @param {Object} [columns=PredicateCore.defaults.columns] columns
  28. * @param {Object} [options=PredicateCore.defaults.options] options
  29. * @return {Promise<core.PredicateCoreAPI>} resolved promise yield a PredicateCoreAPI
  30. * @memberof vue
  31. */
  32. function UIPredicateCoreVue({ data, columns, ui, options } = {}) {
  33. return PredicateCore({
  34. data,
  35. columns,
  36. ui: assign({}, DEFAULT_COMPONENTS, ui),
  37. options: assign({}, defaults.options, options),
  38. });
  39. }
  40. UIPredicateCoreVue.defaults = defaults;
  41. export { UIPredicateCoreVue };