itmar-block-packages 2.1.2 → 3.0.2

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 (218) hide show
  1. package/README.md +18 -4
  2. package/build/cjs/AnimationBlock.js +61 -92
  3. package/build/cjs/AnimationBlock.js.map +1 -1
  4. package/build/cjs/BlockEditWrapper.js +3 -10
  5. package/build/cjs/BlockEditWrapper.js.map +1 -1
  6. package/build/cjs/BlockPlace.js +277 -482
  7. package/build/cjs/BlockPlace.js.map +1 -1
  8. package/build/cjs/BrockInserter.js +195 -191
  9. package/build/cjs/BrockInserter.js.map +1 -1
  10. package/build/cjs/DateElm.js +254 -281
  11. package/build/cjs/DateElm.js.map +1 -1
  12. package/build/cjs/DraggableBox.js +99 -129
  13. package/build/cjs/DraggableBox.js.map +1 -1
  14. package/build/cjs/GridControls.js +292 -392
  15. package/build/cjs/GridControls.js.map +1 -1
  16. package/build/cjs/IconSelectControl.js +65 -156
  17. package/build/cjs/IconSelectControl.js.map +1 -1
  18. package/build/cjs/JapaneseHolidays.js +67 -76
  19. package/build/cjs/JapaneseHolidays.js.map +1 -1
  20. package/build/cjs/MasonryControl.js +95 -100
  21. package/build/cjs/MasonryControl.js.map +1 -1
  22. package/build/cjs/PseudoElm.js +37 -50
  23. package/build/cjs/PseudoElm.js.map +1 -1
  24. package/build/cjs/ShadowStyle.js +216 -430
  25. package/build/cjs/ShadowStyle.js.map +1 -1
  26. package/build/cjs/SwiperControl.js +240 -241
  27. package/build/cjs/SwiperControl.js.map +1 -1
  28. package/build/cjs/ToggleElement.js +17 -9
  29. package/build/cjs/ToggleElement.js.map +1 -1
  30. package/build/cjs/TypographyControls.js +73 -139
  31. package/build/cjs/TypographyControls.js.map +1 -1
  32. package/build/cjs/UpdateAllPostsBlockAttributes.js +102 -119
  33. package/build/cjs/UpdateAllPostsBlockAttributes.js.map +1 -1
  34. package/build/cjs/ZipAddress.js +27 -23
  35. package/build/cjs/ZipAddress.js.map +1 -1
  36. package/build/cjs/blockStore.js +42 -47
  37. package/build/cjs/blockStore.js.map +1 -1
  38. package/build/cjs/cssPropertes.js +165 -117
  39. package/build/cjs/cssPropertes.js.map +1 -1
  40. package/build/cjs/customHooks.js +277 -0
  41. package/build/cjs/customHooks.js.map +1 -0
  42. package/build/cjs/formatCreate.js +115 -145
  43. package/build/cjs/formatCreate.js.map +1 -1
  44. package/build/cjs/hslToRgb.js +112 -116
  45. package/build/cjs/hslToRgb.js.map +1 -1
  46. package/build/cjs/index.js +15 -11
  47. package/build/cjs/index.js.map +1 -1
  48. package/build/cjs/mediaUpload.js +95 -158
  49. package/build/cjs/mediaUpload.js.map +1 -1
  50. package/build/cjs/node_modules/swiper/shared/ssr-window.esm.js +144 -0
  51. package/build/cjs/node_modules/swiper/shared/ssr-window.esm.js.map +1 -0
  52. package/build/cjs/node_modules/swiper/shared/swiper-core.js +3925 -0
  53. package/build/cjs/node_modules/swiper/shared/swiper-core.js.map +1 -0
  54. package/build/cjs/node_modules/swiper/shared/utils.js +294 -0
  55. package/build/cjs/node_modules/swiper/shared/utils.js.map +1 -0
  56. package/build/cjs/pickupStore.js +56 -54
  57. package/build/cjs/pickupStore.js.map +1 -1
  58. package/build/cjs/shopfiApi.js +127 -138
  59. package/build/cjs/shopfiApi.js.map +1 -1
  60. package/build/cjs/types/AnimationBlock.d.ts +22 -0
  61. package/build/cjs/types/BlockEditWrapper.d.ts +7 -0
  62. package/build/cjs/types/BlockPlace.d.ts +49 -0
  63. package/build/cjs/types/BrockInserter.d.ts +6 -0
  64. package/build/cjs/types/DateElm.d.ts +69 -0
  65. package/build/cjs/types/DraggableBox.d.ts +19 -0
  66. package/build/cjs/types/GridControls.d.ts +27 -0
  67. package/build/cjs/types/IconSelectControl.d.ts +17 -0
  68. package/build/cjs/types/JapaneseHolidays.d.ts +6 -0
  69. package/build/cjs/types/MasonryControl.d.ts +35 -0
  70. package/build/cjs/types/PseudoElm.d.ts +11 -0
  71. package/build/cjs/types/ShadowStyle.d.ts +33 -0
  72. package/build/cjs/types/SwiperControl.d.ts +12 -0
  73. package/build/cjs/types/ToggleElement.d.ts +13 -0
  74. package/build/cjs/types/TypographyControls.d.ts +17 -0
  75. package/build/cjs/types/UpdateAllPostsBlockAttributes.d.ts +10 -0
  76. package/build/cjs/types/ZipAddress.d.ts +18 -0
  77. package/build/cjs/types/blockStore.d.ts +15 -0
  78. package/build/cjs/types/cssPropertes.d.ts +53 -0
  79. package/build/cjs/types/customHooks.d.ts +11 -0
  80. package/build/cjs/types/formatCreate.d.ts +18 -0
  81. package/build/cjs/types/hslToRgb.d.ts +23 -0
  82. package/build/cjs/types/index.d.ts +31 -0
  83. package/build/cjs/types/mediaUpload.d.ts +29 -0
  84. package/build/cjs/types/pickupStore.d.ts +39 -0
  85. package/build/cjs/types/shopfiApi.d.ts +18 -0
  86. package/build/cjs/types/validationCheck.d.ts +5 -0
  87. package/build/cjs/types/wordpressApi.d.ts +99 -0
  88. package/build/cjs/validationCheck.js +15 -9
  89. package/build/cjs/validationCheck.js.map +1 -1
  90. package/build/cjs/wordpressApi.js +364 -576
  91. package/build/cjs/wordpressApi.js.map +1 -1
  92. package/build/esm/AnimationBlock.d.ts +22 -0
  93. package/build/esm/AnimationBlock.js +61 -92
  94. package/build/esm/AnimationBlock.js.map +1 -1
  95. package/build/esm/BlockEditWrapper.d.ts +7 -0
  96. package/build/esm/BlockEditWrapper.js +4 -11
  97. package/build/esm/BlockEditWrapper.js.map +1 -1
  98. package/build/esm/BlockPlace.d.ts +49 -0
  99. package/build/esm/BlockPlace.js +279 -484
  100. package/build/esm/BlockPlace.js.map +1 -1
  101. package/build/esm/BrockInserter.d.ts +6 -0
  102. package/build/esm/BrockInserter.js +195 -191
  103. package/build/esm/BrockInserter.js.map +1 -1
  104. package/build/esm/DateElm.d.ts +69 -0
  105. package/build/esm/DateElm.js +254 -281
  106. package/build/esm/DateElm.js.map +1 -1
  107. package/build/esm/DraggableBox.d.ts +19 -0
  108. package/build/esm/DraggableBox.js +99 -129
  109. package/build/esm/DraggableBox.js.map +1 -1
  110. package/build/esm/GridControls.d.ts +27 -0
  111. package/build/esm/GridControls.js +294 -394
  112. package/build/esm/GridControls.js.map +1 -1
  113. package/build/esm/IconSelectControl.d.ts +17 -0
  114. package/build/esm/IconSelectControl.js +65 -156
  115. package/build/esm/IconSelectControl.js.map +1 -1
  116. package/build/esm/JapaneseHolidays.d.ts +6 -0
  117. package/build/esm/JapaneseHolidays.js +67 -76
  118. package/build/esm/JapaneseHolidays.js.map +1 -1
  119. package/build/esm/MasonryControl.d.ts +35 -0
  120. package/build/esm/MasonryControl.js +95 -100
  121. package/build/esm/MasonryControl.js.map +1 -1
  122. package/build/esm/PseudoElm.d.ts +11 -0
  123. package/build/esm/PseudoElm.js +37 -50
  124. package/build/esm/PseudoElm.js.map +1 -1
  125. package/build/esm/ShadowStyle.d.ts +33 -0
  126. package/build/esm/ShadowStyle.js +217 -431
  127. package/build/esm/ShadowStyle.js.map +1 -1
  128. package/build/esm/SwiperControl.d.ts +12 -0
  129. package/build/esm/SwiperControl.js +240 -241
  130. package/build/esm/SwiperControl.js.map +1 -1
  131. package/build/esm/ToggleElement.d.ts +13 -0
  132. package/build/esm/ToggleElement.js +17 -9
  133. package/build/esm/ToggleElement.js.map +1 -1
  134. package/build/esm/TypographyControls.d.ts +17 -0
  135. package/build/esm/TypographyControls.js +73 -139
  136. package/build/esm/TypographyControls.js.map +1 -1
  137. package/build/esm/UpdateAllPostsBlockAttributes.d.ts +10 -0
  138. package/build/esm/UpdateAllPostsBlockAttributes.js +103 -120
  139. package/build/esm/UpdateAllPostsBlockAttributes.js.map +1 -1
  140. package/build/esm/ZipAddress.d.ts +18 -0
  141. package/build/esm/ZipAddress.js +27 -23
  142. package/build/esm/ZipAddress.js.map +1 -1
  143. package/build/esm/blockStore.d.ts +15 -0
  144. package/build/esm/blockStore.js +42 -47
  145. package/build/esm/blockStore.js.map +1 -1
  146. package/build/esm/cssPropertes.d.ts +53 -0
  147. package/build/esm/cssPropertes.js +165 -117
  148. package/build/esm/cssPropertes.js.map +1 -1
  149. package/build/esm/customHooks.d.ts +11 -0
  150. package/build/esm/customHooks.js +267 -0
  151. package/build/esm/customHooks.js.map +1 -0
  152. package/build/esm/formatCreate.d.ts +18 -0
  153. package/build/esm/formatCreate.js +115 -145
  154. package/build/esm/formatCreate.js.map +1 -1
  155. package/build/esm/hslToRgb.d.ts +23 -0
  156. package/build/esm/hslToRgb.js +112 -116
  157. package/build/esm/hslToRgb.js.map +1 -1
  158. package/build/esm/index.d.ts +27 -0
  159. package/build/esm/index.js +8 -1
  160. package/build/esm/index.js.map +1 -1
  161. package/build/esm/mediaUpload.d.ts +29 -0
  162. package/build/esm/mediaUpload.js +95 -158
  163. package/build/esm/mediaUpload.js.map +1 -1
  164. package/build/esm/node_modules/swiper/shared/ssr-window.esm.js +141 -0
  165. package/build/esm/node_modules/swiper/shared/ssr-window.esm.js.map +1 -0
  166. package/build/esm/node_modules/swiper/shared/swiper-core.js +3922 -0
  167. package/build/esm/node_modules/swiper/shared/swiper-core.js.map +1 -0
  168. package/build/esm/node_modules/swiper/shared/utils.js +274 -0
  169. package/build/esm/node_modules/swiper/shared/utils.js.map +1 -0
  170. package/build/esm/pickupStore.d.ts +39 -0
  171. package/build/esm/pickupStore.js +56 -54
  172. package/build/esm/pickupStore.js.map +1 -1
  173. package/build/esm/shopfiApi.d.ts +18 -0
  174. package/build/esm/shopfiApi.js +127 -138
  175. package/build/esm/shopfiApi.js.map +1 -1
  176. package/build/esm/types/AnimationBlock.d.ts +22 -0
  177. package/build/esm/types/BlockEditWrapper.d.ts +7 -0
  178. package/build/esm/types/BlockPlace.d.ts +49 -0
  179. package/build/esm/types/BrockInserter.d.ts +6 -0
  180. package/build/esm/types/DateElm.d.ts +69 -0
  181. package/build/esm/types/DraggableBox.d.ts +19 -0
  182. package/build/esm/types/GridControls.d.ts +27 -0
  183. package/build/esm/types/IconSelectControl.d.ts +17 -0
  184. package/build/esm/types/JapaneseHolidays.d.ts +6 -0
  185. package/build/esm/types/MasonryControl.d.ts +35 -0
  186. package/build/esm/types/PseudoElm.d.ts +11 -0
  187. package/build/esm/types/ShadowStyle.d.ts +33 -0
  188. package/build/esm/types/SwiperControl.d.ts +12 -0
  189. package/build/esm/types/ToggleElement.d.ts +13 -0
  190. package/build/esm/types/TypographyControls.d.ts +17 -0
  191. package/build/esm/types/UpdateAllPostsBlockAttributes.d.ts +10 -0
  192. package/build/esm/types/ZipAddress.d.ts +18 -0
  193. package/build/esm/types/blockStore.d.ts +15 -0
  194. package/build/esm/types/cssPropertes.d.ts +53 -0
  195. package/build/esm/types/customHooks.d.ts +11 -0
  196. package/build/esm/types/formatCreate.d.ts +18 -0
  197. package/build/esm/types/hslToRgb.d.ts +23 -0
  198. package/build/esm/types/index.d.ts +31 -0
  199. package/build/esm/types/mediaUpload.d.ts +29 -0
  200. package/build/esm/types/pickupStore.d.ts +39 -0
  201. package/build/esm/types/shopfiApi.d.ts +18 -0
  202. package/build/esm/types/validationCheck.d.ts +5 -0
  203. package/build/esm/types/wordpressApi.d.ts +99 -0
  204. package/build/esm/validationCheck.d.ts +5 -0
  205. package/build/esm/validationCheck.js +15 -9
  206. package/build/esm/validationCheck.js.map +1 -1
  207. package/build/esm/wordpressApi.d.ts +99 -0
  208. package/build/esm/wordpressApi.js +365 -577
  209. package/build/esm/wordpressApi.js.map +1 -1
  210. package/package.json +29 -7
  211. package/build/cjs/_virtual/_rollupPluginBabelHelpers.js +0 -117
  212. package/build/cjs/_virtual/_rollupPluginBabelHelpers.js.map +0 -1
  213. package/build/cjs/customFooks.js +0 -300
  214. package/build/cjs/customFooks.js.map +0 -1
  215. package/build/esm/_virtual/_rollupPluginBabelHelpers.js +0 -107
  216. package/build/esm/_virtual/_rollupPluginBabelHelpers.js.map +0 -1
  217. package/build/esm/customFooks.js +0 -290
  218. package/build/esm/customFooks.js.map +0 -1
@@ -1,308 +1,281 @@
1
- import { objectSpread2 as _objectSpread2 } from './_virtual/_rollupPluginBabelHelpers.js';
1
+ import { createElement } from '@wordpress/element';
2
2
  import { __ } from '@wordpress/i18n';
3
3
  import { nanoid } from './node_modules/nanoid/non-secure/index.js';
4
4
  import { PanelBody, PanelRow, __experimentalNumberControl } from '@wordpress/components';
5
5
 
6
6
  //期間の設定から選択できる月の情報オブジェクトを配列にする関数
7
- var generateDateArray = (dateObj, isMonth) => {
8
- var {
9
- startYear,
10
- startMonth,
11
- endYear,
12
- endMonth
13
- } = dateObj;
14
- var result = [];
15
- for (var year = startYear; year <= endYear; year++) {
16
- if (isMonth) {
17
- var monthStart = year === startYear ? startMonth : 1;
18
- var monthEnd = year === endYear ? endMonth : 12;
19
- for (var month = monthStart; month <= monthEnd; month++) {
20
- var unitObj = {
21
- id: nanoid(5),
22
- value: "".concat(year, "/").concat(month.toString().padStart(2, "0")),
23
- label: "".concat(year, "/").concat(month.toString().padStart(2, "0")),
24
- classname: "filter_date"
25
- };
26
- result.push(unitObj);
27
- }
28
- } else {
29
- var _unitObj = {
30
- id: nanoid(5),
31
- value: "".concat(year),
32
- label: "".concat(year),
33
- classname: "filter_date"
34
- };
35
- result.push(_unitObj);
7
+ const generateDateArray = (dateObj, isMonth) => {
8
+ const { startYear, startMonth, endYear, endMonth } = dateObj;
9
+ const result = [];
10
+ for (let year = startYear; year <= endYear; year++) {
11
+ if (isMonth) {
12
+ const monthStart = year === startYear ? startMonth : 1;
13
+ const monthEnd = year === endYear ? endMonth : 12;
14
+ for (let month = monthStart; month <= monthEnd; month++) {
15
+ const unitObj = {
16
+ id: nanoid(5),
17
+ value: `${year}/${month.toString().padStart(2, "0")}`,
18
+ label: `${year}/${month.toString().padStart(2, "0")}`,
19
+ classname: "filter_date",
20
+ };
21
+ result.push(unitObj);
22
+ }
23
+ }
24
+ else {
25
+ const unitObj = {
26
+ id: nanoid(5),
27
+ value: `${year}`,
28
+ label: `${year}`,
29
+ classname: "filter_date",
30
+ };
31
+ result.push(unitObj);
32
+ }
36
33
  }
37
- }
38
- return result;
34
+ return result;
39
35
  };
40
-
41
- //与えられた月から日付と曜日を要素とする配列を生成する
42
- var generateMonthCalendar = function generateMonthCalendar(dateString) {
43
- var holidays = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
44
- var [year, month] = dateString.split("/").map(Number);
45
- var date = new Date(year, month - 1, 1);
46
- var lastDay = new Date(year, month, 0).getDate();
47
- var calendar = [];
48
- var _loop = function _loop(day) {
49
- date.setDate(day);
50
- //祝日の情報
51
- var holidayItem = holidays === null || holidays === void 0 ? void 0 : holidays.find(item => {
52
- var _item$date;
53
- var s = String((_item$date = item.date) !== null && _item$date !== void 0 ? _item$date : "");
54
-
55
- // item.date から YYYY, MM, DD を取り出す("YYYYMMDD" / "YYYY-MM-DD" などに対応)
56
- var yearStr = s.slice(0, 4);
57
- var monthStr = s.replace(/\D/g, "").slice(4, 6); // 数字だけにして5-6桁
58
- var dayStr = s.replace(/\D/g, "").slice(6, 8); // 数字だけにして7-8桁
59
-
60
- var itemYear = Number(yearStr);
61
- var itemMonth = Number(monthStr);
62
- var itemDay = Number(dayStr);
63
- return itemYear === year && itemMonth === month && itemDay === day;
64
- });
65
- //日付情報オブジェクト
66
- var dayObj = holidayItem ? {
67
- date: day,
68
- weekday: date.getDay(),
69
- holiday: holidayItem.name
70
- } : {
71
- date: day,
72
- weekday: date.getDay()
73
- };
74
- calendar.push(dayObj);
75
- };
76
- for (var day = 1; day <= lastDay; day++) {
77
- _loop(day);
78
- }
79
- return calendar;
36
+ const generateMonthCalendar = (dateString, holidays = null) => {
37
+ const [year, month] = dateString.split("/").map(Number);
38
+ const date = new Date(year, month - 1, 1);
39
+ const lastDay = new Date(year, month, 0).getDate();
40
+ const calendar = [];
41
+ for (let day = 1; day <= lastDay; day++) {
42
+ date.setDate(day);
43
+ //祝日の情報
44
+ const holidayItem = holidays?.find((item) => {
45
+ const s = String(item.date ?? "");
46
+ // item.date から YYYY, MM, DD を取り出す("YYYYMMDD" / "YYYY-MM-DD" などに対応)
47
+ const yearStr = s.slice(0, 4);
48
+ const monthStr = s.replace(/\D/g, "").slice(4, 6); // 数字だけにして5-6桁
49
+ const dayStr = s.replace(/\D/g, "").slice(6, 8); // 数字だけにして7-8桁
50
+ const itemYear = Number(yearStr);
51
+ const itemMonth = Number(monthStr);
52
+ const itemDay = Number(dayStr);
53
+ return itemYear === year && itemMonth === month && itemDay === day;
54
+ });
55
+ //日付情報オブジェクト
56
+ const dayObj = holidayItem
57
+ ? {
58
+ date: day,
59
+ weekday: date.getDay(),
60
+ holiday: holidayItem.name,
61
+ }
62
+ : {
63
+ date: day,
64
+ weekday: date.getDay(),
65
+ };
66
+ calendar.push(dayObj);
67
+ }
68
+ return calendar;
80
69
  };
81
-
82
- //期間設定のインスペクターコントロール
83
- var PeriodCtrl = _ref => {
84
- var {
85
- startYear,
86
- endYear,
87
- dateSpan,
88
- isMonth,
89
- onChange: _onChange
90
- } = _ref;
91
- return /*#__PURE__*/React.createElement(PanelBody, {
92
- title: __("Period Setting", "block-collections"),
93
- initialOpen: true,
94
- className: "form_setteing_ctrl"
95
- }, /*#__PURE__*/React.createElement("label", null, __("Start of period", "block-collections")), /*#__PURE__*/React.createElement(PanelRow, {
96
- className: "itmar_date_span"
97
- }, /*#__PURE__*/React.createElement(__experimentalNumberControl, {
98
- label: __("Year", "block-collections"),
99
- labelPosition: "side",
100
- max: endYear,
101
- min: startYear,
102
- onChange: newValue => {
103
- var newSpanObj = {
104
- dateSpan: _objectSpread2(_objectSpread2({}, dateSpan), {}, {
105
- startYear: Number(newValue)
106
- })
107
- };
108
- _onChange(newSpanObj);
109
- },
110
- value: dateSpan.startYear
111
- }), isMonth && /*#__PURE__*/React.createElement(__experimentalNumberControl, {
112
- label: __("Month", "block-collections"),
113
- labelPosition: "side",
114
- max: 12,
115
- min: 1,
116
- onChange: newValue => {
117
- var newSpanObj = {
118
- dateSpan: _objectSpread2(_objectSpread2({}, dateSpan), {}, {
119
- startMonth: Number(newValue)
120
- })
121
- };
122
- _onChange(newSpanObj);
123
- },
124
- value: dateSpan.startMonth
125
- })), /*#__PURE__*/React.createElement("label", null, __("End of period", "block-collections")), /*#__PURE__*/React.createElement(PanelRow, {
126
- className: "itmar_date_span"
127
- }, /*#__PURE__*/React.createElement(__experimentalNumberControl, {
128
- label: __("Year", "block-collections"),
129
- labelPosition: "side",
130
- max: endYear,
131
- min: startYear,
132
- onChange: newValue => {
133
- var newSpanObj = {
134
- dateSpan: _objectSpread2(_objectSpread2({}, dateSpan), {}, {
135
- endYear: Number(newValue)
136
- })
137
- };
138
- _onChange(newSpanObj);
139
- },
140
- value: dateSpan.endYear
141
- }), /*#__PURE__*/React.createElement(__experimentalNumberControl, {
142
- label: __("Month", "block-collections"),
143
- labelPosition: "side",
144
- max: 12,
145
- min: 1,
146
- onChange: newValue => {
147
- var newSpanObj = {
148
- dateSpan: _objectSpread2(_objectSpread2({}, dateSpan), {}, {
149
- endMonth: Number(newValue)
150
- })
151
- };
152
- _onChange(newSpanObj);
153
- },
154
- value: dateSpan.endMonth
155
- })));
70
+ const PeriodCtrl = ({ startYear, endYear, dateSpan, isMonth, onChange, }) => {
71
+ return (createElement(PanelBody, { title: __("Period Setting", "block-collections"), initialOpen: true, className: "form_setteing_ctrl" },
72
+ createElement("label", null, __("Start of period", "block-collections")),
73
+ createElement(PanelRow, { className: "itmar_date_span" },
74
+ createElement(__experimentalNumberControl, { label: __("Year", "block-collections"), labelPosition: "side", max: endYear, min: startYear, onChange: (newValue) => {
75
+ const newSpanObj = {
76
+ dateSpan: {
77
+ ...dateSpan,
78
+ startYear: Number(newValue),
79
+ },
80
+ };
81
+ onChange(newSpanObj);
82
+ }, value: dateSpan.startYear }),
83
+ isMonth && (createElement(__experimentalNumberControl, { label: __("Month", "block-collections"), labelPosition: "side", max: 12, min: 1, onChange: (newValue) => {
84
+ const newSpanObj = {
85
+ dateSpan: {
86
+ ...dateSpan,
87
+ startMonth: Number(newValue),
88
+ },
89
+ };
90
+ onChange(newSpanObj);
91
+ }, value: dateSpan.startMonth }))),
92
+ createElement("label", null, __("End of period", "block-collections")),
93
+ createElement(PanelRow, { className: "itmar_date_span" },
94
+ createElement(__experimentalNumberControl, { label: __("Year", "block-collections"), labelPosition: "side", max: endYear, min: startYear, onChange: (newValue) => {
95
+ const newSpanObj = {
96
+ dateSpan: {
97
+ ...dateSpan,
98
+ endYear: Number(newValue),
99
+ },
100
+ };
101
+ onChange(newSpanObj);
102
+ }, value: dateSpan.endYear }),
103
+ createElement(__experimentalNumberControl, { label: __("Month", "block-collections"), labelPosition: "side", max: 12, min: 1, onChange: (newValue) => {
104
+ const newSpanObj = {
105
+ dateSpan: {
106
+ ...dateSpan,
107
+ endMonth: Number(newValue),
108
+ },
109
+ };
110
+ onChange(newSpanObj);
111
+ }, value: dateSpan.endMonth }))));
156
112
  };
157
-
158
- //日付から期間のクエリー用の配列を生成
159
- var getPeriodQuery = dateString => {
160
- if (!dateString) {
161
- return null; //与えられた文字列が空ならnullをかえす
162
- }
163
- var parts = dateString.split("/");
164
- var year = parseInt(parts[0], 10);
165
- var month = parts.length > 1 ? parseInt(parts[1], 10) : null;
166
- var day = parts.length > 2 ? parseInt(parts[2], 10) : null;
167
- var startDate, endDate;
168
- if (day) {
169
- // 特定の日
170
- startDate = new Date(year, month - 1, day, 0, 0, 0, -1);
171
- endDate = new Date(year, month - 1, day, 23, 59, 59, 1000);
172
- } else if (month) {
173
- // 特定の月
174
- startDate = new Date(year, month - 1, 1, 0, 0, 0, -1);
175
- endDate = new Date(year, month, 1, 0, 0, 0, 0);
176
- } else {
177
- // 特定の年
178
- startDate = new Date(year, 0, 1, 0, 0, 0, -1);
179
- endDate = new Date(year + 1, 0, 1, 0, 0, 0, 0);
180
- }
181
- return {
182
- after: startDate.toISOString(),
183
- before: endDate.toISOString()
184
- };
113
+ const getPeriodQuery = (dateString) => {
114
+ if (!dateString) {
115
+ return null; //与えられた文字列が空ならnullをかえす
116
+ }
117
+ const parts = dateString.split("/");
118
+ // 1. 年は必須。取れない場合は null を返す
119
+ const year = parts[0] ? parseInt(parts[0], 10) : null;
120
+ if (year === null || isNaN(year))
121
+ return null;
122
+ // 2. 月と日を「数値」または「undefined」として安全に抽出
123
+ // NaN を避けるために、条件式で厳密にチェックします
124
+ const month = parts.length > 1 && !isNaN(parseInt(parts[1], 10))
125
+ ? parseInt(parts[1], 10)
126
+ : undefined;
127
+ const day = parts.length > 2 && !isNaN(parseInt(parts[2], 10))
128
+ ? parseInt(parts[2], 10)
129
+ : undefined;
130
+ let startDate;
131
+ let endDate;
132
+ // 3. 判定ロジック(undefined を使った方が TS の相性が良いです)
133
+ if (month !== undefined && day !== undefined) {
134
+ startDate = new Date(year, month - 1, day, 0, 0, 0, -1);
135
+ endDate = new Date(year, month - 1, day, 23, 59, 59, 1000);
136
+ }
137
+ else if (month !== undefined) {
138
+ startDate = new Date(year, month - 1, 1, 0, 0, 0, -1);
139
+ endDate = new Date(year, month, 1, 0, 0, 0, 0);
140
+ }
141
+ else {
142
+ startDate = new Date(year, 0, 1, 0, 0, 0, -1);
143
+ endDate = new Date(year + 1, 0, 1, 0, 0, 0, 0);
144
+ }
145
+ return {
146
+ after: startDate.toISOString(),
147
+ before: endDate.toISOString(),
148
+ };
185
149
  };
186
-
187
150
  //本日の日付から'YYYY/MM'形式の日付文字列を生成する
188
- var getTodayYearMonth = () => {
189
- var today = new Date();
190
- var year = today.getFullYear();
191
- var month = String(today.getMonth() + 1).padStart(2, "0");
192
- return "".concat(year, "/").concat(month);
151
+ const getTodayYearMonth = () => {
152
+ const today = new Date();
153
+ const year = today.getFullYear();
154
+ const month = String(today.getMonth() + 1).padStart(2, "0");
155
+ return `${year}/${month}`;
193
156
  };
194
157
  //本日の日付から年を返す
195
- var getTodayYear = () => {
196
- var today = new Date();
197
- return today.getFullYear();
158
+ const getTodayYear = () => {
159
+ const today = new Date();
160
+ return today.getFullYear();
198
161
  };
199
162
  //本日の日付から月を返す
200
- var getTodayMonth = () => {
201
- var today = new Date();
202
- return today.getMonth() + 1;
163
+ const getTodayMonth = () => {
164
+ const today = new Date();
165
+ return today.getMonth() + 1;
203
166
  };
204
-
205
- // "2026/01" -> { ym:"2026-01", from:"2026-01-01", to:"2026-01-31", year:2026, month:1 }
206
- var pad2 = n => String(n).padStart(2, "0");
207
- var getMonthRangeYmd = selectedMonth => {
208
- if (!selectedMonth) return {
209
- ym: "",
210
- from: "",
211
- to: "",
212
- year: 0,
213
- month: 0,
214
- lastDay: 0
215
- };
216
- var [yStr, mStr] = String(selectedMonth).split("/");
217
- var year = Number(yStr);
218
- var month = Number(mStr);
219
- if (!year || !month) return {
220
- ym: "",
221
- from: "",
222
- to: "",
223
- year: 0,
224
- month: 0,
225
- lastDay: 0
226
- };
227
- var lastDay = new Date(year, month, 0).getDate();
228
- var mm = pad2(month);
229
- return {
230
- ym: "".concat(year, "-").concat(mm),
231
- from: "".concat(year, "-").concat(mm, "-01"),
232
- to: "".concat(year, "-").concat(mm, "-").concat(pad2(lastDay)),
233
- year,
234
- month,
235
- lastDay
236
- };
167
+ const pad2 = (n) => String(n).padStart(2, "0");
168
+ const getMonthRangeYmd = (selectedMonth) => {
169
+ // 初期値(エラー時や未選択時)
170
+ const defaultRange = {
171
+ ym: "",
172
+ from: "",
173
+ to: "",
174
+ year: 0,
175
+ month: 0,
176
+ lastDay: 0,
177
+ };
178
+ if (!selectedMonth)
179
+ return defaultRange;
180
+ const [yStr, mStr] = String(selectedMonth).split("/");
181
+ const year = Number(yStr);
182
+ const month = Number(mStr);
183
+ // 2. NaN チェックを含めたガード
184
+ if (isNaN(year) || isNaN(month) || year === 0 || month === 0) {
185
+ return defaultRange;
186
+ }
187
+ // その月の「0日目」を指定することで、前月の最終日(=今月の末日)を取得
188
+ const lastDay = new Date(year, month, 0).getDate();
189
+ const mm = pad2(month);
190
+ return {
191
+ ym: `${year}-${mm}`,
192
+ from: `${year}-${mm}-01`,
193
+ to: `${year}-${mm}-${pad2(lastDay)}`,
194
+ year,
195
+ month,
196
+ lastDay,
197
+ };
237
198
  };
238
- var normalizeDateYYYYMMDD = value => {
239
- // 期待値: 'YYYY-MM-DD'
240
- if (!value) return "";
241
- return String(value).slice(0, 10);
199
+ const normalizeDateYYYYMMDD = (value) => {
200
+ // 期待値: 'YYYY-MM-DD'
201
+ if (!value)
202
+ return "";
203
+ return String(value).slice(0, 10);
242
204
  };
243
- var toYmdFromMonthAndDay = (selectedMonth, dayValue) => {
244
- if (!dayValue) return "";
245
- var dayStr = String(dayValue).trim();
246
-
247
- // already "YYYY-MM-DD"
248
- if (/^\d{4}-\d{2}-\d{2}$/.test(dayStr)) return dayStr;
249
-
250
- // 8 digits "YYYYMMDD"
251
- if (/^\d{8}$/.test(dayStr)) {
252
- var y = dayStr.slice(0, 4);
253
- var m = dayStr.slice(4, 6);
254
- var d = dayStr.slice(6, 8);
255
- return "".concat(y, "-").concat(m, "-").concat(d);
256
- }
257
- // day-of-month number
258
- var dayNum = Number(dayStr);
259
- if (!selectedMonth || !dayNum) return "";
260
- var [yStr, mStr] = String(selectedMonth).split("/");
261
- if (!yStr || !mStr) return "";
262
- return "".concat(yStr, "-").concat(pad2(Number(mStr)), "-").concat(pad2(dayNum));
205
+ /**
206
+ * 様々な形式の「日」の入力と「選択された月」を組み合わせて YYYY-MM-DD 形式を返す
207
+ */
208
+ const toYmdFromMonthAndDay = (selectedMonth, dayValue) => {
209
+ if (!dayValue)
210
+ return "";
211
+ const dayStr = String(dayValue).trim();
212
+ // already "YYYY-MM-DD"
213
+ if (/^\d{4}-\d{2}-\d{2}$/.test(dayStr))
214
+ return dayStr;
215
+ // 8 digits "YYYYMMDD"
216
+ if (/^\d{8}$/.test(dayStr)) {
217
+ const y = dayStr.slice(0, 4);
218
+ const m = dayStr.slice(4, 6);
219
+ const d = dayStr.slice(6, 8);
220
+ return `${y}-${m}-${d}`;
221
+ }
222
+ // day-of-month number
223
+ const dayNum = Number(dayStr);
224
+ if (!selectedMonth || !dayNum)
225
+ return "";
226
+ const [yStr, mStr] = String(selectedMonth).split("/");
227
+ if (!yStr || !mStr)
228
+ return "";
229
+ return `${yStr}-${pad2(Number(mStr))}-${pad2(dayNum)}`;
263
230
  };
264
-
265
231
  /* ------------------------------
266
232
  カレンダー用グリッドAreasの生成関数
267
233
  ------------------------------ */
268
- var week = ["sun", "mon", "tue", "wed", "thu", "fri", "sat"];
269
- var generateGridAreas = (firstDayOfMonth, totalDays, isMonday) => {
270
- var areas = [];
271
- var currentDay = 1;
272
- //月曜日を先頭に持ってくる場合の係数
273
- var mondayFirstDay = firstDayOfMonth - 1 < 0 ? 6 : firstDayOfMonth - 1;
274
- //先頭曜日の選択
275
- var modifyFirstDay = isMonday ? mondayFirstDay : firstDayOfMonth;
276
-
277
- //曜日ラベル
278
- var weekLabels = [];
279
- var week_index;
280
- for (var i = 0; i < 7; i++) {
281
- week_index = isMonday ? i + 1 : i; //月曜日を先頭に持ってくる場合の補正
282
- if (week_index > 6) week_index = 0;
283
- weekLabels.push(week[week_index]);
284
- }
285
- areas.push(weekLabels.join(" "));
286
- for (var _i = 0; _i < 6; _i++) {
287
- // 6週分のループ
288
- var _week = [];
289
- for (var j = 0; j < 7; j++) {
290
- // 1週間の7日分のループ
291
- if (_i === 0 && j < modifyFirstDay || currentDay > totalDays) {
292
- _week.push("empty".concat(_i));
293
- } else {
294
- _week.push("day".concat(currentDay));
295
- currentDay++;
296
- }
234
+ const WEEK_NAMES = ["sun", "mon", "tue", "wed", "thu", "fri", "sat"];
235
+ /**
236
+ * カレンダーの grid-template-areas 用の文字列を生成する
237
+ * @param firstDayOfMonth 月の最初の日の曜日番号 (0:日, 1:月...)
238
+ * @param totalDays 月の総日数 (28-31)
239
+ * @param isMonday 月曜始まりにするかどうか
240
+ */
241
+ const generateGridAreas = (firstDayOfMonth, totalDays, isMonday) => {
242
+ let areas = [];
243
+ let currentDay = 1;
244
+ //月曜日を先頭に持ってくる場合の係数
245
+ const mondayFirstDay = firstDayOfMonth - 1 < 0 ? 6 : firstDayOfMonth - 1;
246
+ //先頭曜日の選択
247
+ const modifyFirstDay = isMonday ? mondayFirstDay : firstDayOfMonth;
248
+ //曜日ラベル
249
+ let weekLabels = [];
250
+ let week_index;
251
+ for (let i = 0; i < 7; i++) {
252
+ week_index = isMonday ? i + 1 : i; //月曜日を先頭に持ってくる場合の補正
253
+ if (week_index > 6)
254
+ week_index = 0;
255
+ weekLabels.push(WEEK_NAMES[week_index]);
297
256
  }
298
- if (_i == 5) {
299
- //最後の週
300
- _week[5] = "day_clear";
301
- _week[6] = "day_clear";
257
+ areas.push(weekLabels.join(" "));
258
+ for (let i = 0; i < 6; i++) {
259
+ // 6週分のループ
260
+ let week = [];
261
+ for (let j = 0; j < 7; j++) {
262
+ // 1週間の7日分のループ
263
+ if ((i === 0 && j < modifyFirstDay) || currentDay > totalDays) {
264
+ week.push(`empty${i}`);
265
+ }
266
+ else {
267
+ week.push(`day${currentDay}`);
268
+ currentDay++;
269
+ }
270
+ }
271
+ if (i == 5) {
272
+ //最後の週
273
+ week[5] = "day_clear";
274
+ week[6] = "day_clear";
275
+ }
276
+ areas.push(week.join(" "));
302
277
  }
303
- areas.push(_week.join(" "));
304
- }
305
- return areas.map(week => "\"".concat(week, "\"")).join("\n");
278
+ return areas.map((week) => `"${week}"`).join("\n");
306
279
  };
307
280
 
308
281
  export { PeriodCtrl, generateDateArray, generateGridAreas, generateMonthCalendar, getMonthRangeYmd, getPeriodQuery, getTodayMonth, getTodayYear, getTodayYearMonth, normalizeDateYYYYMMDD, toYmdFromMonthAndDay };