itmar-block-packages 1.10.1 → 2.0.1
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.
- package/README.md +1445 -1369
- package/build/cjs/AnimationBlock.js +107 -0
- package/build/cjs/AnimationBlock.js.map +1 -0
- package/build/cjs/BlockEditWrapper.js +20 -0
- package/build/cjs/BlockEditWrapper.js.map +1 -0
- package/build/cjs/BlockPlace.js +509 -0
- package/build/cjs/BlockPlace.js.map +1 -0
- package/build/cjs/BrockInserter.js +204 -0
- package/build/cjs/BrockInserter.js.map +1 -0
- package/build/cjs/DateElm.js +321 -0
- package/build/cjs/DateElm.js.map +1 -0
- package/build/cjs/DraggableBox.js +143 -0
- package/build/cjs/DraggableBox.js.map +1 -0
- package/build/cjs/GridControls.js +421 -0
- package/build/cjs/GridControls.js.map +1 -0
- package/build/cjs/IconSelectControl.js +167 -0
- package/build/cjs/IconSelectControl.js.map +1 -0
- package/build/cjs/JapaneseHolidays.js +99 -0
- package/build/cjs/JapaneseHolidays.js.map +1 -0
- package/build/cjs/MasonryControl.js +124 -0
- package/build/cjs/MasonryControl.js.map +1 -0
- package/build/cjs/PseudoElm.js +66 -0
- package/build/cjs/PseudoElm.js.map +1 -0
- package/build/cjs/ShadowStyle.js +453 -0
- package/build/cjs/ShadowStyle.js.map +1 -0
- package/build/cjs/SwiperControl.js +267 -0
- package/build/cjs/SwiperControl.js.map +1 -0
- package/build/cjs/ToggleElement.js +17 -0
- package/build/cjs/ToggleElement.js.map +1 -0
- package/build/cjs/TypographyControls.js +151 -0
- package/build/cjs/TypographyControls.js.map +1 -0
- package/build/cjs/UpdateAllPostsBlockAttributes.js +137 -0
- package/build/cjs/UpdateAllPostsBlockAttributes.js.map +1 -0
- package/build/cjs/ZipAddress.js +34 -0
- package/build/cjs/ZipAddress.js.map +1 -0
- package/build/cjs/_virtual/_rollupPluginBabelHelpers.js +117 -0
- package/build/cjs/_virtual/_rollupPluginBabelHelpers.js.map +1 -0
- package/build/cjs/blockStore.js +65 -0
- package/build/cjs/blockStore.js.map +1 -0
- package/build/cjs/cssPropertes.js +157 -0
- package/build/cjs/cssPropertes.js.map +1 -0
- package/build/cjs/customFooks.js +300 -0
- package/build/cjs/customFooks.js.map +1 -0
- package/build/cjs/formatCreate.js +160 -0
- package/build/cjs/formatCreate.js.map +1 -0
- package/build/cjs/hslToRgb.js +133 -0
- package/build/cjs/hslToRgb.js.map +1 -0
- package/build/cjs/index.js +115 -0
- package/build/cjs/index.js.map +1 -0
- package/build/cjs/mediaUpload.js +182 -0
- package/build/cjs/mediaUpload.js.map +1 -0
- package/build/cjs/node_modules/nanoid/index.js +30 -0
- package/build/cjs/node_modules/nanoid/index.js.map +1 -0
- package/build/cjs/node_modules/nanoid/url-alphabet/index.js +7 -0
- package/build/cjs/node_modules/nanoid/url-alphabet/index.js.map +1 -0
- package/build/cjs/shopfiApi.js +188 -0
- package/build/cjs/shopfiApi.js.map +1 -0
- package/build/cjs/validationCheck.js +15 -0
- package/build/cjs/validationCheck.js.map +1 -0
- package/build/cjs/wordpressApi.js +631 -0
- package/build/cjs/wordpressApi.js.map +1 -0
- package/build/esm/AnimationBlock.js +102 -0
- package/build/esm/AnimationBlock.js.map +1 -0
- package/build/esm/BlockEditWrapper.js +16 -0
- package/build/esm/BlockEditWrapper.js.map +1 -0
- package/build/esm/BlockPlace.js +503 -0
- package/build/esm/BlockPlace.js.map +1 -0
- package/build/esm/BrockInserter.js +202 -0
- package/build/esm/BrockInserter.js.map +1 -0
- package/build/esm/DateElm.js +309 -0
- package/build/esm/DateElm.js.map +1 -0
- package/build/esm/DraggableBox.js +138 -0
- package/build/esm/DraggableBox.js.map +1 -0
- package/build/esm/GridControls.js +417 -0
- package/build/esm/GridControls.js.map +1 -0
- package/build/esm/IconSelectControl.js +163 -0
- package/build/esm/IconSelectControl.js.map +1 -0
- package/build/esm/JapaneseHolidays.js +97 -0
- package/build/esm/JapaneseHolidays.js.map +1 -0
- package/{src → build/esm}/MasonryControl.js +120 -125
- package/build/esm/MasonryControl.js.map +1 -0
- package/build/esm/PseudoElm.js +61 -0
- package/build/esm/PseudoElm.js.map +1 -0
- package/build/esm/ShadowStyle.js +448 -0
- package/build/esm/ShadowStyle.js.map +1 -0
- package/{src → build/esm}/SwiperControl.js +265 -265
- package/build/esm/SwiperControl.js.map +1 -0
- package/build/esm/ToggleElement.js +13 -0
- package/build/esm/ToggleElement.js.map +1 -0
- package/build/esm/TypographyControls.js +147 -0
- package/build/esm/TypographyControls.js.map +1 -0
- package/build/esm/UpdateAllPostsBlockAttributes.js +133 -0
- package/build/esm/UpdateAllPostsBlockAttributes.js.map +1 -0
- package/build/esm/ZipAddress.js +32 -0
- package/build/esm/ZipAddress.js.map +1 -0
- package/build/esm/_virtual/_rollupPluginBabelHelpers.js +107 -0
- package/build/esm/_virtual/_rollupPluginBabelHelpers.js.map +1 -0
- package/build/esm/blockStore.js +60 -0
- package/build/esm/blockStore.js.map +1 -0
- package/build/esm/cssPropertes.js +144 -0
- package/build/esm/cssPropertes.js.map +1 -0
- package/{src → build/esm}/customFooks.js +290 -337
- package/build/esm/customFooks.js.map +1 -0
- package/build/esm/formatCreate.js +157 -0
- package/build/esm/formatCreate.js.map +1 -0
- package/build/esm/hslToRgb.js +129 -0
- package/build/esm/hslToRgb.js.map +1 -0
- package/build/esm/index.js +27 -0
- package/build/esm/index.js.map +1 -0
- package/build/esm/mediaUpload.js +176 -0
- package/build/esm/mediaUpload.js.map +1 -0
- package/build/esm/node_modules/nanoid/index.js +27 -0
- package/build/esm/node_modules/nanoid/index.js.map +1 -0
- package/build/esm/node_modules/nanoid/url-alphabet/index.js +5 -0
- package/build/esm/node_modules/nanoid/url-alphabet/index.js.map +1 -0
- package/build/esm/shopfiApi.js +184 -0
- package/build/esm/shopfiApi.js.map +1 -0
- package/build/esm/validationCheck.js +13 -0
- package/build/esm/validationCheck.js.map +1 -0
- package/build/esm/wordpressApi.js +618 -0
- package/build/esm/wordpressApi.js.map +1 -0
- package/package.json +22 -6
- package/build/index.asset.php +0 -1
- package/build/index.js +0 -25
- package/css/editor.css +0 -23
- package/css/editor.css.map +0 -1
- package/img/animation.png +0 -0
- package/img/blockplace.png +0 -0
- package/img/grid.png +0 -0
- package/img/iconControl.png +0 -0
- package/img/pseudo.png +0 -0
- package/img/shadow.png +0 -0
- package/img/typography.png +0 -0
- package/src/AnimationBlock.js +0 -112
- package/src/BlockEditWrapper.js +0 -11
- package/src/BlockPlace.js +0 -904
- package/src/BrockInserter.js +0 -247
- package/src/DateElm.js +0 -354
- package/src/DraggableBox.js +0 -143
- package/src/GridControls.js +0 -462
- package/src/IconSelectControl.js +0 -186
- package/src/PseudoElm.js +0 -54
- package/src/ShadowStyle.js +0 -520
- package/src/ToggleElement.js +0 -18
- package/src/TypographyControls.js +0 -145
- package/src/UpdateAllPostsBlockAttributes.js +0 -127
- package/src/ZipAddress.js +0 -35
- package/src/blockStore.js +0 -75
- package/src/cssPropertes.js +0 -212
- package/src/formatCreate.js +0 -179
- package/src/hslToRgb.js +0 -162
- package/src/index.js +0 -131
- package/src/mediaUpload.js +0 -178
- package/src/shopfiApi.js +0 -187
- package/src/validationCheck.js +0 -10
- package/src/wordpressApi.js +0 -707
- package/webpack.config.js +0 -10
|
@@ -1,337 +1,290 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
useEffect(() => {
|
|
12
|
-
|
|
13
|
-
for (
|
|
14
|
-
setWidth(entry.contentRect.width);
|
|
15
|
-
}
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
// iframeのcontentWindow
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
iframeInstance.contentWindow
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
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
|