@nickeylin/antd-mobile-pro 2.0.2 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/dist/cjs/components/checkbox/checkbox.d.ts +1 -1
  2. package/dist/cjs/components/checkbox/index.d.ts +1 -1
  3. package/dist/cjs/components/index.d.ts +1 -0
  4. package/dist/cjs/components/index.js +3 -0
  5. package/dist/cjs/components/popup-page/popup-page.d.ts +1 -0
  6. package/dist/cjs/components/popup-page/popup-page.js +30 -6
  7. package/dist/cjs/components/popup-page/style.less +4 -0
  8. package/dist/cjs/components/pro-calendar/index.d.ts +10 -0
  9. package/dist/cjs/components/pro-calendar/index.js +42 -0
  10. package/dist/cjs/components/pro-calendar/pro-calendar.d.ts +37 -0
  11. package/dist/cjs/components/pro-calendar/pro-calendar.js +173 -0
  12. package/dist/cjs/components/pro-calendar/style.less +105 -0
  13. package/dist/cjs/components/pro-calendar/utils.d.ts +32 -0
  14. package/dist/cjs/components/pro-calendar/utils.js +175 -0
  15. package/dist/cjs/components/pro-calendar-picker/index.d.ts +3 -2
  16. package/dist/cjs/components/pro-calendar-picker/index.js +3 -2
  17. package/dist/cjs/components/pro-calendar-picker/pro-calendar-picker.d.ts +13 -0
  18. package/dist/cjs/components/pro-calendar-picker/pro-calendar-picker.js +141 -0
  19. package/dist/cjs/components/pro-calendar-picker/style.less +38 -0
  20. package/dist/cjs/components/pro-form/pro-form-item-calendar-picker.d.ts +1 -1
  21. package/dist/cjs/components/pro-form/pro-form-item-calendar-picker.js +12 -6
  22. package/dist/cjs/components/styles/global.less +6 -0
  23. package/dist/cjs/components/tree-picker/index.d.ts +1 -1
  24. package/dist/cjs/components/tree-picker/tree-picker.d.ts +1 -1
  25. package/dist/cjs/locales/base.d.ts +4 -0
  26. package/dist/cjs/locales/en-US.d.ts +4 -0
  27. package/dist/es/components/checkbox/checkbox.d.ts +1 -1
  28. package/dist/es/components/checkbox/index.d.ts +1 -1
  29. package/dist/es/components/index.d.ts +1 -0
  30. package/dist/es/components/index.js +1 -0
  31. package/dist/es/components/popup-page/popup-page.d.ts +1 -0
  32. package/dist/es/components/popup-page/popup-page.js +32 -11
  33. package/dist/es/components/popup-page/style.less +4 -0
  34. package/dist/es/components/pro-calendar/index.d.ts +10 -0
  35. package/dist/es/components/pro-calendar/index.js +8 -0
  36. package/dist/es/components/pro-calendar/pro-calendar.d.ts +37 -0
  37. package/dist/es/components/pro-calendar/pro-calendar.js +138 -0
  38. package/dist/es/components/pro-calendar/style.less +105 -0
  39. package/dist/es/components/pro-calendar/utils.d.ts +32 -0
  40. package/dist/es/components/pro-calendar/utils.js +138 -0
  41. package/dist/es/components/pro-calendar-picker/index.d.ts +3 -2
  42. package/dist/es/components/pro-calendar-picker/index.js +2 -1
  43. package/dist/es/components/pro-calendar-picker/pro-calendar-picker.d.ts +13 -0
  44. package/dist/es/components/pro-calendar-picker/pro-calendar-picker.js +124 -0
  45. package/dist/es/components/pro-calendar-picker/style.less +38 -0
  46. package/dist/es/components/pro-form/pro-form-item-calendar-picker.d.ts +1 -1
  47. package/dist/es/components/pro-form/pro-form-item-calendar-picker.js +8 -8
  48. package/dist/es/components/styles/global.less +6 -0
  49. package/dist/es/components/tree-picker/index.d.ts +1 -1
  50. package/dist/es/components/tree-picker/tree-picker.d.ts +1 -1
  51. package/dist/es/locales/base.d.ts +4 -0
  52. package/dist/es/locales/en-US.d.ts +4 -0
  53. package/dist/umd/antd-mobile-pro.min.css +1 -1
  54. package/dist/umd/antd-mobile-pro.min.js +1 -1
  55. package/package.json +3 -2
@@ -17,7 +17,7 @@ declare const Checkbox: import("react").ForwardRefExoticComponent<{
17
17
  onClick?: ((event: import("react").MouseEvent<HTMLLabelElement, MouseEvent>) => void) | undefined;
18
18
  } & {
19
19
  className?: string | undefined;
20
- style?: (import("react").CSSProperties & Partial<Record<"--font-size" | "--gap" | "--icon-size", string>>) | undefined;
20
+ style?: (import("react").CSSProperties & Partial<Record<"--gap" | "--icon-size" | "--font-size", string>>) | undefined;
21
21
  tabIndex?: number | undefined;
22
22
  } & import("react").AriaAttributes & {
23
23
  shape?: "circle" | "square" | undefined;
@@ -14,7 +14,7 @@ declare const Checkbox: import("react").ForwardRefExoticComponent<{
14
14
  onClick?: ((event: import("react").MouseEvent<HTMLLabelElement, MouseEvent>) => void) | undefined;
15
15
  } & {
16
16
  className?: string | undefined;
17
- style?: (import("react").CSSProperties & Partial<Record<"--font-size" | "--gap" | "--icon-size", string>>) | undefined;
17
+ style?: (import("react").CSSProperties & Partial<Record<"--gap" | "--icon-size" | "--font-size", string>>) | undefined;
18
18
  tabIndex?: number | undefined;
19
19
  } & import("react").AriaAttributes & {
20
20
  shape?: "circle" | "square" | undefined;
@@ -19,6 +19,7 @@ export { default as Money, type MoneyProps } from './money';
19
19
  export { default as Page, type PageBodyProps, type PageFooterProps, type PageProps, type PageToolbarProps, } from './page';
20
20
  export { default as PopupPage, type PopupPageProps } from './popup-page';
21
21
  export { createPopupPickerPrompt, usePopupPickerMixin, type PopupPickerActions, type PopupPickerMixinProps, } from './popup-picker-base';
22
+ export { default as ProCalendar, type ProCalendarDate, type ProCalendarProps, } from './pro-calendar';
22
23
  export { default as ProCalendarPicker, type ProCalendarPickerActions, type ProCalendarPickerProps, } from './pro-calendar-picker';
23
24
  export * from './pro-form';
24
25
  export { default as ProList, type ProListAction, type ProListPaginationProps, type ProListProps, } from './pro-list';
@@ -50,6 +50,7 @@ __export(components_exports, {
50
50
  Money: () => import_money.default,
51
51
  Page: () => import_page.default,
52
52
  PopupPage: () => import_popup_page.default,
53
+ ProCalendar: () => import_pro_calendar.default,
53
54
  ProCalendarPicker: () => import_pro_calendar_picker.default,
54
55
  ProList: () => import_pro_list.default,
55
56
  ProListPicker: () => import_pro_list_picker.default,
@@ -87,6 +88,7 @@ var import_money = __toESM(require("./money"));
87
88
  var import_page = __toESM(require("./page"));
88
89
  var import_popup_page = __toESM(require("./popup-page"));
89
90
  var import_popup_picker_base = require("./popup-picker-base");
91
+ var import_pro_calendar = __toESM(require("./pro-calendar"));
90
92
  var import_pro_calendar_picker = __toESM(require("./pro-calendar-picker"));
91
93
  __reExport(components_exports, require("./pro-form"), module.exports);
92
94
  var import_pro_list = __toESM(require("./pro-list"));
@@ -121,6 +123,7 @@ var import_tree_picker = __toESM(require("./tree-picker"));
121
123
  Money,
122
124
  Page,
123
125
  PopupPage,
126
+ ProCalendar,
124
127
  ProCalendarPicker,
125
128
  ProList,
126
129
  ProListPicker,
@@ -5,6 +5,7 @@ import { PageProps } from '../page';
5
5
  export type PopupPageProps = Omit<PopupProps, 'showCloseButton' | 'children'> & Omit<PageProps, 'style'> & {
6
6
  pageStyle?: PageProps['style'];
7
7
  pageClassName?: PageProps['className'];
8
+ closeButtonPosition?: 'left' | 'right';
8
9
  } & NativeProps<'--page-height'>;
9
10
  declare const PopupPage: FC<PopupPageProps>;
10
11
  export default PopupPage;
@@ -36,6 +36,7 @@ var import_rc_utils = require("@nickeylin/rc-utils");
36
36
  var import_antd_mobile = require("antd-mobile");
37
37
  var import_antd_mobile_icons = require("antd-mobile-icons");
38
38
  var import_classnames = __toESM(require("classnames"));
39
+ var import_react = require("react");
39
40
  var import_bem = require("../../utils/bem");
40
41
  var import_page = __toESM(require("../page"));
41
42
  var bem = (0, import_bem.cn)("popup-page");
@@ -52,6 +53,7 @@ var PopupPage = ({
52
53
  error,
53
54
  onBack,
54
55
  title,
56
+ closeButtonPosition = "left",
55
57
  // popup prps
56
58
  ...props
57
59
  }) => {
@@ -62,6 +64,32 @@ var PopupPage = ({
62
64
  onClose == null ? void 0 : onClose();
63
65
  }
64
66
  });
67
+ const pageProps = (0, import_react.useMemo)(() => {
68
+ if (closeButtonPosition === "right") {
69
+ return {
70
+ navbar: {
71
+ right: /* @__PURE__ */ React.createElement(
72
+ import_antd_mobile_icons.CloseOutline,
73
+ {
74
+ className: bem("close-button"),
75
+ onClick: () => {
76
+ setVisible(false);
77
+ onBack == null ? void 0 : onBack();
78
+ }
79
+ }
80
+ ),
81
+ ...navbar
82
+ }
83
+ };
84
+ }
85
+ return {
86
+ navbar: { backIcon: /* @__PURE__ */ React.createElement(import_antd_mobile_icons.CloseOutline, null), ...navbar },
87
+ onBack() {
88
+ setVisible(false);
89
+ onBack == null ? void 0 : onBack();
90
+ }
91
+ };
92
+ }, [closeButtonPosition, navbar, onBack, setVisible]);
65
93
  return /* @__PURE__ */ React.createElement(
66
94
  import_antd_mobile.Popup,
67
95
  {
@@ -75,13 +103,9 @@ var PopupPage = ({
75
103
  {
76
104
  style: pageStyle,
77
105
  className: pageClassName,
78
- navbar: { backIcon: /* @__PURE__ */ React.createElement(import_antd_mobile_icons.CloseOutline, null), ...navbar },
106
+ ...pageProps,
79
107
  ...{ loading, error, title },
80
- showNavBar: true,
81
- onBack: () => {
82
- setVisible(false);
83
- onBack == null ? void 0 : onBack();
84
- }
108
+ showNavBar: true
85
109
  },
86
110
  children
87
111
  )
@@ -18,4 +18,8 @@
18
18
  &__default-action-footer {
19
19
  padding: 8px 14px;
20
20
  }
21
+
22
+ &__close-button {
23
+ font-size: 24px;
24
+ }
21
25
  }
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ import './style.less';
3
+ import { computeDays, formatProCalendarDateValues } from './utils';
4
+ declare const ProCalendar: import("react").ForwardRefExoticComponent<import("./pro-calendar").ProCalendarProps & import("react").RefAttributes<import("antd-mobile").CalendarRef>> & {
5
+ defaultFormat: typeof formatProCalendarDateValues;
6
+ computeDays: typeof computeDays;
7
+ };
8
+ export default ProCalendar;
9
+ export type { ProCalendarProps } from './pro-calendar';
10
+ export type { PickerDate as ProCalendarDate } from './utils';
@@ -0,0 +1,42 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+
29
+ // src/components/pro-calendar/index.tsx
30
+ var pro_calendar_exports = {};
31
+ __export(pro_calendar_exports, {
32
+ default: () => pro_calendar_default
33
+ });
34
+ module.exports = __toCommonJS(pro_calendar_exports);
35
+ var import_pro_calendar = __toESM(require("./pro-calendar"));
36
+ var import_style = require("./style.less");
37
+ var import_utils = require("./utils");
38
+ var ProCalendar = Object.assign(import_pro_calendar.default, {
39
+ defaultFormat: import_utils.formatProCalendarDateValues,
40
+ computeDays: import_utils.computeDays
41
+ });
42
+ var pro_calendar_default = ProCalendar;
@@ -0,0 +1,37 @@
1
+ /// <reference types="react" />
2
+ import { CalendarProps, CalendarRef } from 'antd-mobile';
3
+ import { PickerDate } from './utils';
4
+ interface ProCalendarPropsInner {
5
+ /**
6
+ * 是否开启半日选择
7
+ * @default false
8
+ */
9
+ enableHalfDay?: boolean;
10
+ /**
11
+ * 是否开启晚上选择
12
+ * @default false
13
+ */
14
+ enableHalfDayNight?: boolean;
15
+ }
16
+ interface ProCalendarNormalProps {
17
+ selectionMode?: undefined;
18
+ value?: undefined;
19
+ defaultValue?: undefined;
20
+ onChange?: undefined;
21
+ }
22
+ interface ProCalendarSingleProps {
23
+ selectionMode: 'single';
24
+ value?: PickerDate | null;
25
+ defaultValue?: PickerDate | null;
26
+ onChange?: (value: PickerDate | null) => void;
27
+ }
28
+ interface ProCalendarRangeProps {
29
+ selectionMode?: 'range';
30
+ value?: PickerDate[] | null;
31
+ defaultValue?: PickerDate[] | null;
32
+ onChange?: (value: PickerDate[] | null) => void;
33
+ }
34
+ export type ProCalendarProps = ProCalendarPropsInner & (ProCalendarNormalProps | ProCalendarSingleProps | ProCalendarRangeProps) & Omit<CalendarProps, 'value' | 'onChange' | 'defaultValue' | 'selectionMode'>;
35
+ export declare function convertValueToRange(value: PickerDate | PickerDate[] | null): PickerDate[] | null;
36
+ declare const ProCalendar: import("react").ForwardRefExoticComponent<ProCalendarProps & import("react").RefAttributes<CalendarRef>>;
37
+ export default ProCalendar;
@@ -0,0 +1,173 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+
29
+ // src/components/pro-calendar/pro-calendar.tsx
30
+ var pro_calendar_exports = {};
31
+ __export(pro_calendar_exports, {
32
+ convertValueToRange: () => convertValueToRange,
33
+ default: () => pro_calendar_default
34
+ });
35
+ module.exports = __toCommonJS(pro_calendar_exports);
36
+ var import_ahooks = require("ahooks");
37
+ var import_antd_mobile = require("antd-mobile");
38
+ var import_classnames = __toESM(require("classnames"));
39
+ var import_dayjs = __toESM(require("dayjs"));
40
+ var import_lodash = require("lodash");
41
+ var import_react = require("react");
42
+ var import_bem = require("../../utils/bem");
43
+ var import_utils = require("./utils");
44
+ var bem = (0, import_bem.cn)("calendar");
45
+ function convertValueToRange(value) {
46
+ if (!value)
47
+ return null;
48
+ if (Array.isArray(value)) {
49
+ if (value.length <= 1)
50
+ return value;
51
+ return value;
52
+ }
53
+ return [value];
54
+ }
55
+ var ProCalendarRaw = ({
56
+ enableHalfDay = false,
57
+ enableHalfDayNight = false,
58
+ weekStartsOn = "Monday",
59
+ value: valueProp,
60
+ onChange: onChangeProp,
61
+ defaultValue: defaultValueProp,
62
+ selectionMode,
63
+ className,
64
+ ...props
65
+ }, ref) => {
66
+ const [value, setValue_] = (0, import_ahooks.useControllableValue)(
67
+ (0, import_lodash.pickBy)(
68
+ {
69
+ value: valueProp,
70
+ defaultValue: defaultValueProp,
71
+ onChange: onChangeProp
72
+ },
73
+ (v) => v !== void 0
74
+ )
75
+ );
76
+ const rangeValue = (0, import_react.useMemo)(() => convertValueToRange(value) ?? [], [value]);
77
+ const setValue = (0, import_react.useCallback)(
78
+ (v) => {
79
+ if (selectionMode === "range" && enableHalfDay) {
80
+ setValue_((prev) => {
81
+ if (!v)
82
+ return v;
83
+ if (!prev || !Array.isArray(prev) || !prev[0] || prev.length >= 2) {
84
+ return [v];
85
+ }
86
+ return (0, import_utils.mergeDates)([...prev, v]);
87
+ });
88
+ return;
89
+ }
90
+ setValue_(v);
91
+ },
92
+ [enableHalfDay, selectionMode, setValue_]
93
+ );
94
+ return /* @__PURE__ */ React.createElement(
95
+ import_antd_mobile.Calendar,
96
+ {
97
+ ref,
98
+ className: (0, import_classnames.default)(bem(), className),
99
+ weekStartsOn,
100
+ selectionMode: enableHalfDay ? void 0 : selectionMode,
101
+ value,
102
+ onChange: (v) => {
103
+ if (enableHalfDay)
104
+ return;
105
+ setValue(v);
106
+ },
107
+ cellRender: (oriNode, { date }) => {
108
+ const dd = (0, import_dayjs.default)(date);
109
+ const isWeekend = dd.day() === 0 || dd.day() === 6;
110
+ if (!enableHalfDay) {
111
+ const node2 = (0, import_react.cloneElement)(oriNode, {
112
+ className: (0, import_classnames.default)(
113
+ oriNode.props.className,
114
+ bem("cell", {
115
+ weekend: isWeekend
116
+ })
117
+ )
118
+ });
119
+ return node2;
120
+ }
121
+ const nextValue = new Date(date);
122
+ const classes = (0, import_utils.classesForDate)(date, rangeValue);
123
+ const node = (0, import_react.cloneElement)(oriNode, {
124
+ className: (0, import_classnames.default)(oriNode.props.className, bem("cell", classes)),
125
+ onClick: () => {
126
+ }
127
+ });
128
+ const acts = [import_utils.HALF_DAY_PERIOD.AM, import_utils.HALF_DAY_PERIOD.PM];
129
+ if (enableHalfDayNight) {
130
+ acts.push(import_utils.HALF_DAY_PERIOD.NIGHT);
131
+ }
132
+ acts.unshift(import_utils.HALF_DAY_PERIOD.ALL);
133
+ const actions = acts.map((act) => ({
134
+ key: act,
135
+ text: import_utils.HALF_DAY_PERIOD_NAMES[act]
136
+ }));
137
+ return /* @__PURE__ */ React.createElement(
138
+ import_antd_mobile.Popover.Menu,
139
+ {
140
+ actions,
141
+ placement: "top",
142
+ className: bem("period-menu"),
143
+ onAction: (node2) => {
144
+ switch (node2.key) {
145
+ case import_utils.HALF_DAY_PERIOD.AM:
146
+ nextValue.period = import_utils.HALF_DAY_PERIOD.AM;
147
+ break;
148
+ case import_utils.HALF_DAY_PERIOD.PM:
149
+ nextValue.period = import_utils.HALF_DAY_PERIOD.PM;
150
+ break;
151
+ case import_utils.HALF_DAY_PERIOD.NIGHT:
152
+ nextValue.period = import_utils.HALF_DAY_PERIOD.NIGHT;
153
+ break;
154
+ default:
155
+ break;
156
+ }
157
+ setValue(nextValue);
158
+ },
159
+ trigger: "click"
160
+ },
161
+ node
162
+ );
163
+ },
164
+ ...props
165
+ }
166
+ );
167
+ };
168
+ var ProCalendar = (0, import_react.forwardRef)(ProCalendarRaw);
169
+ var pro_calendar_default = ProCalendar;
170
+ // Annotate the CommonJS export names for ESM import in node:
171
+ 0 && (module.exports = {
172
+ convertValueToRange
173
+ });
@@ -0,0 +1,105 @@
1
+ @import '../styles/variable.less';
2
+
3
+ @class-prefix-pro-calendar:~ '@{adm-pro-prefix}-calendar';
4
+
5
+ .@{class-prefix-pro-calendar} {
6
+ .adm-calendar-cell {
7
+ &-selected:not(&-selected-begin):not(&-selected-end) {
8
+ background-color: rgba(22, 119, 255, 0.1);
9
+ color: var(--adm-color-text);
10
+ }
11
+ }
12
+ .adm-calendar-cell.adm-calendar-cell-disabled {
13
+ color: var(--adm-color-border);
14
+ }
15
+ .adm-calendar-cell.adm-calendar-cell-today {
16
+ color: var(--adm-color-text);
17
+ border: 1px solid var(--adm-color-primary);
18
+ border-radius: 4px;
19
+ box-sizing: border-box;
20
+ }
21
+
22
+ &__cell {
23
+ position: relative;
24
+ overflow: hidden;
25
+ & > div {
26
+ position: relative;
27
+ }
28
+ // &&--weekend {
29
+ // color: var(--adm-color-weak);
30
+ // }
31
+ &&--allday,
32
+ &&--allday.adm-calendar-cell-today {
33
+ background-color: var(--adm-color-primary);
34
+ color: var(--adm-color-white);
35
+ }
36
+ &--begin {
37
+ border-top-left-radius: 4px;
38
+ border-bottom-left-radius: 4px;
39
+ }
40
+ &--end {
41
+ border-top-right-radius: 4px;
42
+ border-bottom-right-radius: 4px;
43
+ }
44
+ &--am::before,
45
+ &--pm::before,
46
+ &--night::before {
47
+ content: '';
48
+ position: absolute;
49
+ left: 0;
50
+ right: 0;
51
+ background-color: var(--adm-color-primary);
52
+ }
53
+
54
+ &--am {
55
+ &::before {
56
+ top: 0;
57
+ height: 50%;
58
+ // border-top-left-radius: 4px;
59
+ // border-top-right-radius: 4px;
60
+ }
61
+ }
62
+ &--pm {
63
+ &::before {
64
+ bottom: 0;
65
+ height: 50%;
66
+ // border-bottom-left-radius: 4px;
67
+ // border-bottom-right-radius: 4px;
68
+ }
69
+ }
70
+ &--night {
71
+ &::before {
72
+ bottom: 0;
73
+ height: 6px;
74
+ // border-bottom-left-radius: 4px;
75
+ // border-bottom-right-radius: 4px;
76
+ }
77
+ }
78
+ &--cover {
79
+ background-color: rgba(22, 119, 255, 0.1);
80
+ }
81
+ }
82
+
83
+ &__period-menu {
84
+ .adm-popover-menu-list {
85
+ min-width: 80px;
86
+ }
87
+ .adm-popover-menu-item {
88
+ padding: 0;
89
+ }
90
+ .adm-popover-menu-item-text {
91
+ padding: 10px 20px 10px 20px;
92
+ text-align: center;
93
+ }
94
+ }
95
+ }
96
+
97
+ html[data-prefers-color-scheme='dark'] {
98
+ .@{class-prefix-pro-calendar} {
99
+ &__period-menu {
100
+ --background: rgba(0, 0, 0, 0.75);
101
+ --adm-color-text: #ffffff;
102
+ backdrop-filter: blur(10px);
103
+ }
104
+ }
105
+ }
@@ -0,0 +1,32 @@
1
+ export declare enum HALF_DAY_PERIOD {
2
+ ALL = 0,
3
+ AM = 1,
4
+ PM = 2,
5
+ NIGHT = 3
6
+ }
7
+ export declare const HALF_DAY_PERIOD_NAMES: {
8
+ readonly 0: "全天";
9
+ readonly 1: "上午";
10
+ readonly 2: "下午";
11
+ readonly 3: "晚上";
12
+ };
13
+ export type PickerDate = Date & {
14
+ period?: HALF_DAY_PERIOD;
15
+ };
16
+ /**
17
+ * 将选择的起止日期合并为有效的日期范围
18
+ */
19
+ export declare function mergeDates(dates: PickerDate[]): PickerDate[];
20
+ export declare function classesForDate(date: Date, rangeValue: PickerDate[]): {
21
+ am: boolean;
22
+ pm: boolean;
23
+ night: boolean;
24
+ allday: boolean;
25
+ begin: boolean;
26
+ end: boolean;
27
+ cover: boolean;
28
+ weekend: boolean;
29
+ };
30
+ export declare function formatProCalendarDate(date?: PickerDate): string;
31
+ export declare function formatProCalendarDateValues(dates?: PickerDate | PickerDate[] | null): string;
32
+ export declare function computeDays(value: PickerDate | PickerDate[] | null | undefined): number;