index.js 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = exports.AppProps = void 0;
  7. var _vue = require("vue");
  8. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  9. var _propsUtil = require("../_util/props-util");
  10. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  11. var _type = require("../_util/type");
  12. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  13. var _useMessage = _interopRequireDefault(require("../message/useMessage"));
  14. var _useModal = _interopRequireDefault(require("../modal/useModal"));
  15. var _useNotification = _interopRequireDefault(require("../notification/useNotification"));
  16. var _context = require("./context");
  17. var _style = _interopRequireDefault(require("./style"));
  18. const AppProps = () => {
  19. return {
  20. rootClassName: String,
  21. message: (0, _type.objectType)(),
  22. notification: (0, _type.objectType)()
  23. };
  24. };
  25. exports.AppProps = AppProps;
  26. const useApp = () => {
  27. return (0, _context.useInjectAppContext)();
  28. };
  29. const App = (0, _vue.defineComponent)({
  30. name: 'AApp',
  31. props: (0, _propsUtil.initDefaultProps)(AppProps(), {}),
  32. setup(props, _ref) {
  33. let {
  34. slots
  35. } = _ref;
  36. const {
  37. prefixCls
  38. } = (0, _useConfigInject.default)('app', props);
  39. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  40. const customClassName = (0, _vue.computed)(() => {
  41. return (0, _classNames.default)(hashId.value, prefixCls.value, props.rootClassName);
  42. });
  43. const appConfig = (0, _context.useInjectAppConfigContext)();
  44. const mergedAppConfig = (0, _vue.computed)(() => ({
  45. message: (0, _extends2.default)((0, _extends2.default)({}, appConfig.message), props.message),
  46. notification: (0, _extends2.default)((0, _extends2.default)({}, appConfig.notification), props.notification)
  47. }));
  48. (0, _context.useProvideAppConfigContext)(mergedAppConfig.value);
  49. const [messageApi, messageContextHolder] = (0, _useMessage.default)(mergedAppConfig.value.message);
  50. const [notificationApi, notificationContextHolder] = (0, _useNotification.default)(mergedAppConfig.value.notification);
  51. const [ModalApi, ModalContextHolder] = (0, _useModal.default)();
  52. const memoizedContextValue = (0, _vue.computed)(() => ({
  53. message: messageApi,
  54. notification: notificationApi,
  55. modal: ModalApi
  56. }));
  57. (0, _context.useProvideAppContext)(memoizedContextValue.value);
  58. return () => {
  59. var _a;
  60. return wrapSSR((0, _vue.createVNode)("div", {
  61. "class": customClassName.value
  62. }, [ModalContextHolder(), messageContextHolder(), notificationContextHolder(), (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)]));
  63. };
  64. }
  65. });
  66. App.useApp = useApp;
  67. App.install = function (app) {
  68. app.component(App.name, App);
  69. };
  70. var _default = exports.default = App;