itmar-block-packages 1.10.0 → 2.0.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 (157) hide show
  1. package/README.md +81 -2
  2. package/build/cjs/AnimationBlock.js +107 -0
  3. package/build/cjs/AnimationBlock.js.map +1 -0
  4. package/build/cjs/BlockEditWrapper.js +20 -0
  5. package/build/cjs/BlockEditWrapper.js.map +1 -0
  6. package/build/cjs/BlockPlace.js +509 -0
  7. package/build/cjs/BlockPlace.js.map +1 -0
  8. package/build/cjs/BrockInserter.js +204 -0
  9. package/build/cjs/BrockInserter.js.map +1 -0
  10. package/build/cjs/DateElm.js +321 -0
  11. package/build/cjs/DateElm.js.map +1 -0
  12. package/build/cjs/DraggableBox.js +143 -0
  13. package/build/cjs/DraggableBox.js.map +1 -0
  14. package/build/cjs/GridControls.js +421 -0
  15. package/build/cjs/GridControls.js.map +1 -0
  16. package/build/cjs/IconSelectControl.js +167 -0
  17. package/build/cjs/IconSelectControl.js.map +1 -0
  18. package/build/cjs/JapaneseHolidays.js +99 -0
  19. package/build/cjs/JapaneseHolidays.js.map +1 -0
  20. package/build/cjs/MasonryControl.js +124 -0
  21. package/build/cjs/MasonryControl.js.map +1 -0
  22. package/build/cjs/PseudoElm.js +66 -0
  23. package/build/cjs/PseudoElm.js.map +1 -0
  24. package/build/cjs/ShadowStyle.js +453 -0
  25. package/build/cjs/ShadowStyle.js.map +1 -0
  26. package/build/cjs/SwiperControl.js +267 -0
  27. package/build/cjs/SwiperControl.js.map +1 -0
  28. package/build/cjs/ToggleElement.js +17 -0
  29. package/build/cjs/ToggleElement.js.map +1 -0
  30. package/build/cjs/TypographyControls.js +151 -0
  31. package/build/cjs/TypographyControls.js.map +1 -0
  32. package/build/cjs/UpdateAllPostsBlockAttributes.js +137 -0
  33. package/build/cjs/UpdateAllPostsBlockAttributes.js.map +1 -0
  34. package/build/cjs/ZipAddress.js +34 -0
  35. package/build/cjs/ZipAddress.js.map +1 -0
  36. package/build/cjs/_virtual/_rollupPluginBabelHelpers.js +117 -0
  37. package/build/cjs/_virtual/_rollupPluginBabelHelpers.js.map +1 -0
  38. package/build/cjs/blockStore.js +65 -0
  39. package/build/cjs/blockStore.js.map +1 -0
  40. package/build/cjs/cssPropertes.js +157 -0
  41. package/build/cjs/cssPropertes.js.map +1 -0
  42. package/build/cjs/customFooks.js +300 -0
  43. package/build/cjs/customFooks.js.map +1 -0
  44. package/build/cjs/formatCreate.js +160 -0
  45. package/build/cjs/formatCreate.js.map +1 -0
  46. package/build/cjs/hslToRgb.js +133 -0
  47. package/build/cjs/hslToRgb.js.map +1 -0
  48. package/build/cjs/index.js +115 -0
  49. package/build/cjs/index.js.map +1 -0
  50. package/build/cjs/mediaUpload.js +182 -0
  51. package/build/cjs/mediaUpload.js.map +1 -0
  52. package/build/cjs/node_modules/nanoid/index.js +30 -0
  53. package/build/cjs/node_modules/nanoid/index.js.map +1 -0
  54. package/build/cjs/node_modules/nanoid/url-alphabet/index.js +7 -0
  55. package/build/cjs/node_modules/nanoid/url-alphabet/index.js.map +1 -0
  56. package/build/cjs/shopfiApi.js +188 -0
  57. package/build/cjs/shopfiApi.js.map +1 -0
  58. package/build/cjs/validationCheck.js +15 -0
  59. package/build/cjs/validationCheck.js.map +1 -0
  60. package/build/cjs/wordpressApi.js +631 -0
  61. package/build/cjs/wordpressApi.js.map +1 -0
  62. package/build/esm/AnimationBlock.js +102 -0
  63. package/build/esm/AnimationBlock.js.map +1 -0
  64. package/build/esm/BlockEditWrapper.js +16 -0
  65. package/build/esm/BlockEditWrapper.js.map +1 -0
  66. package/build/esm/BlockPlace.js +503 -0
  67. package/build/esm/BlockPlace.js.map +1 -0
  68. package/build/esm/BrockInserter.js +202 -0
  69. package/build/esm/BrockInserter.js.map +1 -0
  70. package/build/esm/DateElm.js +309 -0
  71. package/build/esm/DateElm.js.map +1 -0
  72. package/build/esm/DraggableBox.js +138 -0
  73. package/build/esm/DraggableBox.js.map +1 -0
  74. package/build/esm/GridControls.js +417 -0
  75. package/build/esm/GridControls.js.map +1 -0
  76. package/build/esm/IconSelectControl.js +163 -0
  77. package/build/esm/IconSelectControl.js.map +1 -0
  78. package/build/esm/JapaneseHolidays.js +97 -0
  79. package/build/esm/JapaneseHolidays.js.map +1 -0
  80. package/{src → build/esm}/MasonryControl.js +108 -113
  81. package/build/esm/MasonryControl.js.map +1 -0
  82. package/build/esm/PseudoElm.js +61 -0
  83. package/build/esm/PseudoElm.js.map +1 -0
  84. package/build/esm/ShadowStyle.js +448 -0
  85. package/build/esm/ShadowStyle.js.map +1 -0
  86. package/{src → build/esm}/SwiperControl.js +265 -265
  87. package/build/esm/SwiperControl.js.map +1 -0
  88. package/build/esm/ToggleElement.js +13 -0
  89. package/build/esm/ToggleElement.js.map +1 -0
  90. package/build/esm/TypographyControls.js +147 -0
  91. package/build/esm/TypographyControls.js.map +1 -0
  92. package/build/esm/UpdateAllPostsBlockAttributes.js +133 -0
  93. package/build/esm/UpdateAllPostsBlockAttributes.js.map +1 -0
  94. package/build/esm/ZipAddress.js +32 -0
  95. package/build/esm/ZipAddress.js.map +1 -0
  96. package/build/esm/_virtual/_rollupPluginBabelHelpers.js +107 -0
  97. package/build/esm/_virtual/_rollupPluginBabelHelpers.js.map +1 -0
  98. package/build/esm/blockStore.js +60 -0
  99. package/build/esm/blockStore.js.map +1 -0
  100. package/build/esm/cssPropertes.js +144 -0
  101. package/build/esm/cssPropertes.js.map +1 -0
  102. package/{src → build/esm}/customFooks.js +290 -337
  103. package/build/esm/customFooks.js.map +1 -0
  104. package/build/esm/formatCreate.js +157 -0
  105. package/build/esm/formatCreate.js.map +1 -0
  106. package/build/esm/hslToRgb.js +129 -0
  107. package/build/esm/hslToRgb.js.map +1 -0
  108. package/build/esm/index.js +27 -0
  109. package/build/esm/index.js.map +1 -0
  110. package/build/esm/mediaUpload.js +176 -0
  111. package/build/esm/mediaUpload.js.map +1 -0
  112. package/build/esm/node_modules/nanoid/index.js +27 -0
  113. package/build/esm/node_modules/nanoid/index.js.map +1 -0
  114. package/build/esm/node_modules/nanoid/url-alphabet/index.js +5 -0
  115. package/build/esm/node_modules/nanoid/url-alphabet/index.js.map +1 -0
  116. package/build/esm/shopfiApi.js +184 -0
  117. package/build/esm/shopfiApi.js.map +1 -0
  118. package/build/esm/validationCheck.js +13 -0
  119. package/build/esm/validationCheck.js.map +1 -0
  120. package/build/esm/wordpressApi.js +618 -0
  121. package/build/esm/wordpressApi.js.map +1 -0
  122. package/package.json +22 -6
  123. package/build/index.asset.php +0 -1
  124. package/build/index.js +0 -25
  125. package/css/editor.css +0 -23
  126. package/css/editor.css.map +0 -1
  127. package/img/animation.png +0 -0
  128. package/img/blockplace.png +0 -0
  129. package/img/grid.png +0 -0
  130. package/img/iconControl.png +0 -0
  131. package/img/pseudo.png +0 -0
  132. package/img/shadow.png +0 -0
  133. package/img/typography.png +0 -0
  134. package/src/AnimationBlock.js +0 -112
  135. package/src/BlockEditWrapper.js +0 -11
  136. package/src/BlockPlace.js +0 -904
  137. package/src/BrockInserter.js +0 -247
  138. package/src/DateElm.js +0 -354
  139. package/src/DraggableBox.js +0 -143
  140. package/src/GridControls.js +0 -462
  141. package/src/IconSelectControl.js +0 -186
  142. package/src/PseudoElm.js +0 -54
  143. package/src/ShadowStyle.js +0 -520
  144. package/src/ToggleElement.js +0 -18
  145. package/src/TypographyControls.js +0 -145
  146. package/src/UpdateAllPostsBlockAttributes.js +0 -127
  147. package/src/ZipAddress.js +0 -35
  148. package/src/blockStore.js +0 -75
  149. package/src/cssPropertes.js +0 -212
  150. package/src/formatCreate.js +0 -179
  151. package/src/hslToRgb.js +0 -162
  152. package/src/index.js +0 -131
  153. package/src/mediaUpload.js +0 -178
  154. package/src/shopfiApi.js +0 -187
  155. package/src/validationCheck.js +0 -10
  156. package/src/wordpressApi.js +0 -686
  157. package/webpack.config.js +0 -10
@@ -1,337 +1,290 @@
1
- import { useRef, useEffect, useState } from "@wordpress/element";
2
- import { useSelect, useDispatch } from "@wordpress/data";
3
- import isEqual from "lodash/isEqual";
4
- import { __ } from "@wordpress/i18n";
5
-
6
- //useRefで参照したDOM要素の大きさを取得するカスタムフック
7
- export function useElementWidth() {
8
- const ref = useRef(null);
9
- const [width, setWidth] = useState(0);
10
-
11
- useEffect(() => {
12
- const resizeObserver = new ResizeObserver((entries) => {
13
- for (let entry of entries) {
14
- setWidth(entry.contentRect.width);
15
- }
16
- });
17
-
18
- if (ref.current) {
19
- resizeObserver.observe(ref.current);
20
- }
21
-
22
- return () => {
23
- resizeObserver.disconnect();
24
- };
25
- }, []);
26
-
27
- return [ref, width];
28
- }
29
-
30
- //ViewPortの大きさでモバイルを判断(767px以下がモバイル)するカスタムフック
31
- export function useIsMobile() {
32
- const [isMobile, setIsMobile] = useState(false);
33
-
34
- useEffect(() => {
35
- if (typeof window !== "undefined") {
36
- const handleResize = () => {
37
- setIsMobile(window.innerWidth <= 767);
38
- };
39
-
40
- window.addEventListener("resize", handleResize);
41
-
42
- return () => {
43
- window.removeEventListener("resize", handleResize);
44
- };
45
- }
46
- }, []);
47
-
48
- return isMobile;
49
- }
50
-
51
- //モバイル表示か否かを判定するフック
52
- export function useIsIframeMobile() {
53
- const [isMobile, setIsMobile] = useState(false);
54
-
55
- useEffect(() => {
56
- // iframeのcontentWindowを監視する関数
57
- const checkIframeSize = () => {
58
- const iframeInstance = document.getElementsByName("editor-canvas")[0];
59
- if (iframeInstance && iframeInstance.contentWindow) {
60
- setIsMobile(iframeInstance.contentWindow.innerWidth <= 767);
61
- }
62
- };
63
-
64
- // iframeのcontentWindowのリサイズイベントにリスナーを追加
65
- const iframeInstance = document.getElementsByName("editor-canvas")[0];
66
- if (iframeInstance && iframeInstance.contentWindow) {
67
- iframeInstance.contentWindow.addEventListener("resize", checkIframeSize);
68
- }
69
-
70
- // 初期チェックを実行
71
- checkIframeSize();
72
-
73
- // クリーンアップ関数
74
- return () => {
75
- if (iframeInstance && iframeInstance.contentWindow) {
76
- iframeInstance.contentWindow.removeEventListener(
77
- "resize",
78
- checkIframeSize
79
- );
80
- }
81
- };
82
- }, []);
83
-
84
- return isMobile;
85
- }
86
-
87
- //ブロックの背景色を取得するカスタムフック
88
- export function useElementBackgroundColor(blockRef, style) {
89
- const [baseColor, setBaseColor] = useState("");
90
-
91
- useEffect(() => {
92
- if (blockRef.current && style) {
93
- if (
94
- style.backgroundColor &&
95
- !style.backgroundColor.startsWith("var(--wp")
96
- ) {
97
- //backgroundColorが設定されており、それがカスタムプロパティでない
98
- setBaseColor(style.backgroundColor);
99
- } else {
100
- //レンダリング結果から背景色を取得
101
- if (blockRef.current) {
102
- const computedStyles = getComputedStyle(blockRef.current);
103
- setBaseColor(computedStyles.backgroundColor);
104
- }
105
- }
106
- }
107
- }, [style, blockRef]);
108
-
109
- return baseColor;
110
- }
111
-
112
- //ブロックのスタイルを取得し、コールバック関数を返すカスタムフック
113
- export function useElementStyleObject(blockRef, style) {
114
- const [styleObject, setStyleObject] = useState("");
115
-
116
- useEffect(() => {
117
- if (blockRef.current && style) {
118
- //レンダリング結果に基づくスタイルの取得
119
- const computedStyles = getComputedStyle(blockRef.current);
120
- // styleオブジェクトのキーに基づいてnewStyleObjectを生成
121
- const newStyleObject = Object.keys(style).reduce((acc, key) => {
122
- if (computedStyles[key]) {
123
- // computedStylesにキーが存在するか確認
124
- acc[key] = computedStyles[key];
125
- }
126
- return acc;
127
- }, {});
128
-
129
- setStyleObject(JSON.stringify(newStyleObject));
130
- }
131
- }, [blockRef, style]);
132
- // styleObjectをオブジェクトとして返す
133
- return styleObject;
134
- }
135
-
136
- //たくさんの要素をもつオブジェクトや配列の内容の変化で発火するuseEffect
137
- export function useDeepCompareEffect(callback, dependencies) {
138
- const dependenciesRef = useRef();
139
-
140
- if (!isEqual(dependencies, dependenciesRef.current)) {
141
- dependenciesRef.current = dependencies;
142
- }
143
-
144
- useEffect(() => {
145
- return callback();
146
- }, [dependenciesRef.current]);
147
- }
148
-
149
- export function useFontawesomeIframe() {
150
- //iframeにfontawesomeを読み込む
151
- useEffect(() => {
152
- const iframeInstance = document.getElementsByName("editor-canvas")[0];
153
-
154
- if (iframeInstance) {
155
- const iframeDocument =
156
- iframeInstance.contentDocument || iframeInstance.contentWindow.document;
157
- const scriptElement = iframeDocument.createElement("script");
158
- scriptElement.setAttribute("src", "../../../assets/fontawesome.js");
159
- //scriptElement.setAttribute("crossorigin", "anonymous");
160
-
161
- iframeDocument.body.appendChild(scriptElement);
162
-
163
- // Return a cleanup function to remove the script tag
164
- return () => {
165
- iframeDocument.body?.removeChild(scriptElement);
166
- };
167
- }
168
- }, []);
169
- }
170
-
171
- //ネストしたブロックを平坦化
172
- const getFlattenBlocks = (blocks) => {
173
- return blocks.reduce((acc, block) => {
174
- acc.push(block);
175
- if (block.innerBlocks && block.innerBlocks.length > 0) {
176
- acc.push(...getFlattenBlocks(block.innerBlocks));
177
- }
178
- return acc;
179
- }, []);
180
- };
181
-
182
- //指定されたブロック名とクラス名を含むブロックの属性が更新されたときその更新内容をかえすフック
183
- export function useBlockAttributeChanges(
184
- clientId,
185
- blockName,
186
- className,
187
- modFlg = false,
188
- excludeAttributes = {}
189
- ) {
190
- const [latestAttributes, setLatestAttributes] = useState(null);
191
- //const [idleFlg, setIdleFlg] = useState(null);
192
- const prevBlocksRef = useRef({});
193
-
194
- //属性変更関数を取得
195
- const { updateBlockAttributes } = useDispatch("core/block-editor");
196
- //インナーブロックを平坦化する関数
197
- const flattenedBlocks = useSelect(
198
- (select) => {
199
- const { getBlock } = select("core/block-editor");
200
- const rootBlock = getBlock(clientId);
201
- return rootBlock ? getFlattenBlocks([rootBlock]) : [];
202
- },
203
- [clientId]
204
- );
205
-
206
- const targetBlocks = flattenedBlocks.filter(
207
- (block) =>
208
- block.name === blockName &&
209
- block.attributes.className?.includes(className)
210
- );
211
-
212
- useEffect(() => {
213
- //平坦化されたブロックを調査
214
- for (const block of targetBlocks) {
215
- const prevAttributes =
216
- prevBlocksRef.current[block.clientId]?.attributes || {};
217
- //既に先に記録された属性があることをチェック
218
- if (Object.keys(prevAttributes).length > 0) {
219
- // 除外する属性を取り除いた属性オブジェクトを作成
220
- const filteredCurrentAttributes = Object.keys(block.attributes).reduce(
221
- (acc, key) => {
222
- if (!excludeAttributes.hasOwnProperty(key)) {
223
- acc[key] = block.attributes[key];
224
- }
225
- return acc;
226
- },
227
- {}
228
- );
229
-
230
- const filteredPrevAttributes = Object.keys(prevAttributes).reduce(
231
- (acc, key) => {
232
- if (!excludeAttributes.hasOwnProperty(key)) {
233
- acc[key] = prevAttributes[key];
234
- }
235
- return acc;
236
- },
237
- {}
238
- );
239
-
240
- //属性の変化を比較
241
- if (
242
- JSON.stringify(filteredCurrentAttributes) !==
243
- JSON.stringify(filteredPrevAttributes)
244
- ) {
245
- //確認ダイアログが出ている状態か否かで状態変数を変化させる
246
- // if (block.attributes.isIdle) {
247
- // setIdleFlg(true);
248
- // } else {
249
- // setIdleFlg(false);
250
- // }
251
- //呼び出し元に返すための更新後の属性オブジェクトを格納
252
-
253
- setLatestAttributes(JSON.stringify(filteredCurrentAttributes));
254
- }
255
- }
256
- // 現在のブロック状態を保存(除外属性も含めて保存)
257
- prevBlocksRef.current[block.clientId] = { ...block };
258
- }
259
- }, [targetBlocks, blockName, className]);
260
-
261
- //innerFlattenedBlocks内の同一種のブロックに対して属性をセットする;
262
- useEffect(() => {
263
- //確認ダイアログが処理されたことを確認してからこちらの処理を進める
264
- if (latestAttributes && modFlg) {
265
- // const latestAttrObj = JSON.parse(latestAttributes);
266
- // const setObj = {
267
- // ...latestAttrObj,
268
- // className: `auto_attr_change ${latestAttrObj.className}`,
269
- // };
270
- targetBlocks.forEach((block) => {
271
- updateBlockAttributes(block.clientId, JSON.parse(latestAttributes));
272
- });
273
- }
274
- }, [latestAttributes]);
275
-
276
- return JSON.parse(latestAttributes);
277
- }
278
-
279
- //インナーブロックが挿入されたとき、指定されたブロック名が存在れば、挿入されたブロックを削除するフック
280
- export function useDuplicateBlockRemove(clientId, blockNames) {
281
- const { removeBlock } = useDispatch("core/block-editor");
282
- const { createNotice } = useDispatch("core/notices");
283
-
284
- // clientIdに対応するインナーブロックを取得
285
- const innerBlocks = useSelect(
286
- (select) => select("core/block-editor").getBlocks(clientId),
287
- [clientId]
288
- );
289
-
290
- // 前回の innerBlocks を保存するための ref
291
- const prevInnerBlocksRef = useRef(innerBlocks);
292
-
293
- useEffect(() => {
294
- const prevInnerBlocks = prevInnerBlocksRef.current;
295
- //先に保存したインナーブロックの中に対象となるブロックが存在しなければ何もしない
296
- const result = prevInnerBlocks.some((block) =>
297
- blockNames.includes(block.name)
298
- );
299
-
300
- if (result) {
301
- // ブロックが挿入されているか確認(前回と比較)
302
- if (innerBlocks.length > prevInnerBlocks.length) {
303
- // 新しく挿入されたブロックを特定
304
- const newlyInsertedBlock = innerBlocks.find(
305
- (block) =>
306
- !prevInnerBlocks.some(
307
- (prevBlock) => prevBlock.clientId === block.clientId
308
- )
309
- );
310
-
311
- // 新しいブロックが blockNames に含まれている場合、削除
312
- if (
313
- newlyInsertedBlock &&
314
- blockNames.includes(newlyInsertedBlock.name)
315
- ) {
316
- removeBlock(newlyInsertedBlock.clientId);
317
-
318
- // 通知を作成
319
- createNotice(
320
- "error", // 通知のタイプ(エラー)
321
- __(
322
- "A new block cannot be inserted because a block has already been placed.",
323
- "block-collections"
324
- ), // メッセージ
325
- {
326
- type: "snackbar", // 通知のスタイル
327
- isDismissible: true, // 通知を閉じることができるか
328
- }
329
- );
330
- }
331
- }
332
- }
333
-
334
- // 現在の innerBlocks を次回用に保存
335
- prevInnerBlocksRef.current = innerBlocks;
336
- }, [innerBlocks, blockNames, removeBlock, createNotice]);
337
- }
1
+ import { objectSpread2 as _objectSpread2 } from './_virtual/_rollupPluginBabelHelpers.js';
2
+ import { useState, useRef, useEffect } from '@wordpress/element';
3
+ import { useDispatch, useSelect } from '@wordpress/data';
4
+ import isEqual from 'lodash/isEqual';
5
+ import { __ } from '@wordpress/i18n';
6
+
7
+ //useRefで参照したDOM要素の大きさを取得するカスタムフック
8
+ function useElementWidth() {
9
+ var ref = useRef(null);
10
+ var [width, setWidth] = useState(0);
11
+ useEffect(() => {
12
+ var resizeObserver = new ResizeObserver(entries => {
13
+ for (var entry of entries) {
14
+ setWidth(entry.contentRect.width);
15
+ }
16
+ });
17
+ if (ref.current) {
18
+ resizeObserver.observe(ref.current);
19
+ }
20
+ return () => {
21
+ resizeObserver.disconnect();
22
+ };
23
+ }, []);
24
+ return [ref, width];
25
+ }
26
+
27
+ //ViewPortの大きさでモバイルを判断(767px以下がモバイル)するカスタムフック
28
+ function useIsMobile() {
29
+ var [isMobile, setIsMobile] = useState(false);
30
+ useEffect(() => {
31
+ if (typeof window !== "undefined") {
32
+ var handleResize = () => {
33
+ setIsMobile(window.innerWidth <= 767);
34
+ };
35
+ window.addEventListener("resize", handleResize);
36
+ return () => {
37
+ window.removeEventListener("resize", handleResize);
38
+ };
39
+ }
40
+ }, []);
41
+ return isMobile;
42
+ }
43
+
44
+ //モバイル表示か否かを判定するフック
45
+ function useIsIframeMobile() {
46
+ var [isMobile, setIsMobile] = useState(false);
47
+ useEffect(() => {
48
+ // iframeのcontentWindowを監視する関数
49
+ var checkIframeSize = () => {
50
+ var iframeInstance = document.getElementsByName("editor-canvas")[0];
51
+ if (iframeInstance && iframeInstance.contentWindow) {
52
+ setIsMobile(iframeInstance.contentWindow.innerWidth <= 767);
53
+ }
54
+ };
55
+
56
+ // iframeのcontentWindowのリサイズイベントにリスナーを追加
57
+ var iframeInstance = document.getElementsByName("editor-canvas")[0];
58
+ if (iframeInstance && iframeInstance.contentWindow) {
59
+ iframeInstance.contentWindow.addEventListener("resize", checkIframeSize);
60
+ }
61
+
62
+ // 初期チェックを実行
63
+ checkIframeSize();
64
+
65
+ // クリーンアップ関数
66
+ return () => {
67
+ if (iframeInstance && iframeInstance.contentWindow) {
68
+ iframeInstance.contentWindow.removeEventListener("resize", checkIframeSize);
69
+ }
70
+ };
71
+ }, []);
72
+ return isMobile;
73
+ }
74
+
75
+ //ブロックの背景色を取得するカスタムフック
76
+ function useElementBackgroundColor(blockRef, style) {
77
+ var [baseColor, setBaseColor] = useState("");
78
+ useEffect(() => {
79
+ if (blockRef.current && style) {
80
+ if (style.backgroundColor && !style.backgroundColor.startsWith("var(--wp")) {
81
+ //backgroundColorが設定されており、それがカスタムプロパティでない
82
+ setBaseColor(style.backgroundColor);
83
+ } else {
84
+ //レンダリング結果から背景色を取得
85
+ if (blockRef.current) {
86
+ var computedStyles = getComputedStyle(blockRef.current);
87
+ setBaseColor(computedStyles.backgroundColor);
88
+ }
89
+ }
90
+ }
91
+ }, [style, blockRef]);
92
+ return baseColor;
93
+ }
94
+
95
+ //ブロックのスタイルを取得し、コールバック関数を返すカスタムフック
96
+ function useElementStyleObject(blockRef, style) {
97
+ var [styleObject, setStyleObject] = useState("");
98
+ useEffect(() => {
99
+ if (blockRef.current && style) {
100
+ //レンダリング結果に基づくスタイルの取得
101
+ var computedStyles = getComputedStyle(blockRef.current);
102
+ // styleオブジェクトのキーに基づいてnewStyleObjectを生成
103
+ var newStyleObject = Object.keys(style).reduce((acc, key) => {
104
+ if (computedStyles[key]) {
105
+ // computedStylesにキーが存在するか確認
106
+ acc[key] = computedStyles[key];
107
+ }
108
+ return acc;
109
+ }, {});
110
+ setStyleObject(JSON.stringify(newStyleObject));
111
+ }
112
+ }, [blockRef, style]);
113
+ // styleObjectをオブジェクトとして返す
114
+ return styleObject;
115
+ }
116
+
117
+ //たくさんの要素をもつオブジェクトや配列の内容の変化で発火するuseEffect
118
+ function useDeepCompareEffect(callback, dependencies) {
119
+ var dependenciesRef = useRef();
120
+ if (!isEqual(dependencies, dependenciesRef.current)) {
121
+ dependenciesRef.current = dependencies;
122
+ }
123
+ useEffect(() => {
124
+ return callback();
125
+ }, [dependenciesRef.current]);
126
+ }
127
+ function useFontawesomeIframe() {
128
+ //iframeにfontawesomeを読み込む
129
+ useEffect(() => {
130
+ var iframeInstance = document.getElementsByName("editor-canvas")[0];
131
+ if (iframeInstance) {
132
+ var iframeDocument = iframeInstance.contentDocument || iframeInstance.contentWindow.document;
133
+ var scriptElement = iframeDocument.createElement("script");
134
+ scriptElement.setAttribute("src", "../../../assets/fontawesome.js");
135
+ //scriptElement.setAttribute("crossorigin", "anonymous");
136
+
137
+ iframeDocument.body.appendChild(scriptElement);
138
+
139
+ // Return a cleanup function to remove the script tag
140
+ return () => {
141
+ var _iframeDocument$body;
142
+ (_iframeDocument$body = iframeDocument.body) === null || _iframeDocument$body === void 0 || _iframeDocument$body.removeChild(scriptElement);
143
+ };
144
+ }
145
+ }, []);
146
+ }
147
+
148
+ //ネストしたブロックを平坦化
149
+ var getFlattenBlocks = blocks => {
150
+ return blocks.reduce((acc, block) => {
151
+ acc.push(block);
152
+ if (block.innerBlocks && block.innerBlocks.length > 0) {
153
+ acc.push(...getFlattenBlocks(block.innerBlocks));
154
+ }
155
+ return acc;
156
+ }, []);
157
+ };
158
+
159
+ //指定されたブロック名とクラス名を含むブロックの属性が更新されたときその更新内容をかえすフック
160
+ function useBlockAttributeChanges(clientId, blockName, className) {
161
+ var modFlg = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
162
+ var excludeAttributes = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
163
+ var [latestAttributes, setLatestAttributes] = useState(null);
164
+ //const [idleFlg, setIdleFlg] = useState(null);
165
+ var prevBlocksRef = useRef({});
166
+
167
+ //属性変更関数を取得
168
+ var {
169
+ updateBlockAttributes
170
+ } = useDispatch("core/block-editor");
171
+ //インナーブロックを平坦化する関数
172
+ var flattenedBlocks = useSelect(select => {
173
+ var {
174
+ getBlock
175
+ } = select("core/block-editor");
176
+ var rootBlock = getBlock(clientId);
177
+ return rootBlock ? getFlattenBlocks([rootBlock]) : [];
178
+ }, [clientId]);
179
+ var targetBlocks = flattenedBlocks.filter(block => {
180
+ var _block$attributes$cla;
181
+ return block.name === blockName && ((_block$attributes$cla = block.attributes.className) === null || _block$attributes$cla === void 0 ? void 0 : _block$attributes$cla.includes(className));
182
+ });
183
+ useEffect(() => {
184
+ var _loop = function _loop(block) {
185
+ var _prevBlocksRef$curren;
186
+ var prevAttributes = ((_prevBlocksRef$curren = prevBlocksRef.current[block.clientId]) === null || _prevBlocksRef$curren === void 0 ? void 0 : _prevBlocksRef$curren.attributes) || {};
187
+ //既に先に記録された属性があることをチェック
188
+ if (Object.keys(prevAttributes).length > 0) {
189
+ // 除外する属性を取り除いた属性オブジェクトを作成
190
+ var filteredCurrentAttributes = Object.keys(block.attributes).reduce((acc, key) => {
191
+ if (!excludeAttributes.hasOwnProperty(key)) {
192
+ acc[key] = block.attributes[key];
193
+ }
194
+ return acc;
195
+ }, {});
196
+ var filteredPrevAttributes = Object.keys(prevAttributes).reduce((acc, key) => {
197
+ if (!excludeAttributes.hasOwnProperty(key)) {
198
+ acc[key] = prevAttributes[key];
199
+ }
200
+ return acc;
201
+ }, {});
202
+
203
+ //属性の変化を比較
204
+ if (JSON.stringify(filteredCurrentAttributes) !== JSON.stringify(filteredPrevAttributes)) {
205
+ //確認ダイアログが出ている状態か否かで状態変数を変化させる
206
+ // if (block.attributes.isIdle) {
207
+ // setIdleFlg(true);
208
+ // } else {
209
+ // setIdleFlg(false);
210
+ // }
211
+ //呼び出し元に返すための更新後の属性オブジェクトを格納
212
+
213
+ setLatestAttributes(JSON.stringify(filteredCurrentAttributes));
214
+ }
215
+ }
216
+ // 現在のブロック状態を保存(除外属性も含めて保存)
217
+ prevBlocksRef.current[block.clientId] = _objectSpread2({}, block);
218
+ };
219
+ //平坦化されたブロックを調査
220
+ for (var block of targetBlocks) {
221
+ _loop(block);
222
+ }
223
+ }, [targetBlocks, blockName, className]);
224
+
225
+ //innerFlattenedBlocks内の同一種のブロックに対して属性をセットする;
226
+ useEffect(() => {
227
+ //確認ダイアログが処理されたことを確認してからこちらの処理を進める
228
+ if (latestAttributes && modFlg) {
229
+ // const latestAttrObj = JSON.parse(latestAttributes);
230
+ // const setObj = {
231
+ // ...latestAttrObj,
232
+ // className: `auto_attr_change ${latestAttrObj.className}`,
233
+ // };
234
+ targetBlocks.forEach(block => {
235
+ updateBlockAttributes(block.clientId, JSON.parse(latestAttributes));
236
+ });
237
+ }
238
+ }, [latestAttributes]);
239
+ return JSON.parse(latestAttributes);
240
+ }
241
+
242
+ //インナーブロックが挿入されたとき、指定されたブロック名が存在れば、挿入されたブロックを削除するフック
243
+ function useDuplicateBlockRemove(clientId, blockNames) {
244
+ var {
245
+ removeBlock
246
+ } = useDispatch("core/block-editor");
247
+ var {
248
+ createNotice
249
+ } = useDispatch("core/notices");
250
+
251
+ // clientIdに対応するインナーブロックを取得
252
+ var innerBlocks = useSelect(select => select("core/block-editor").getBlocks(clientId), [clientId]);
253
+
254
+ // 前回の innerBlocks を保存するための ref
255
+ var prevInnerBlocksRef = useRef(innerBlocks);
256
+ useEffect(() => {
257
+ var prevInnerBlocks = prevInnerBlocksRef.current;
258
+ //先に保存したインナーブロックの中に対象となるブロックが存在しなければ何もしない
259
+ var result = prevInnerBlocks.some(block => blockNames.includes(block.name));
260
+ if (result) {
261
+ // ブロックが挿入されているか確認(前回と比較)
262
+ if (innerBlocks.length > prevInnerBlocks.length) {
263
+ // 新しく挿入されたブロックを特定
264
+ var newlyInsertedBlock = innerBlocks.find(block => !prevInnerBlocks.some(prevBlock => prevBlock.clientId === block.clientId));
265
+
266
+ // 新しいブロックが blockNames に含まれている場合、削除
267
+ if (newlyInsertedBlock && blockNames.includes(newlyInsertedBlock.name)) {
268
+ removeBlock(newlyInsertedBlock.clientId);
269
+
270
+ // 通知を作成
271
+ createNotice("error",
272
+ // 通知のタイプ(エラー)
273
+ __("A new block cannot be inserted because a block has already been placed.", "block-collections"),
274
+ // メッセージ
275
+ {
276
+ type: "snackbar",
277
+ // 通知のスタイル
278
+ isDismissible: true // 通知を閉じることができるか
279
+ });
280
+ }
281
+ }
282
+ }
283
+
284
+ // 現在の innerBlocks を次回用に保存
285
+ prevInnerBlocksRef.current = innerBlocks;
286
+ }, [innerBlocks, blockNames, removeBlock, createNotice]);
287
+ }
288
+
289
+ export { useBlockAttributeChanges, useDeepCompareEffect, useDuplicateBlockRemove, useElementBackgroundColor, useElementStyleObject, useElementWidth, useFontawesomeIframe, useIsIframeMobile, useIsMobile };
290
+ //# sourceMappingURL=customFooks.js.map