@wix/cli-app 1.1.132 → 1.1.134

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 (67) hide show
  1. package/build/{AddPermissionCommand-7QIFVBXV.js → AddPermissionCommand-TL46A3YR.js} +2 -2
  2. package/build/{DevCommand-RDPL27X5.js → DevCommand-KKSEAF6U.js} +20 -204
  3. package/build/DevCommand-KKSEAF6U.js.map +1 -0
  4. package/build/{GenerateCommand-6ADO2EJU.js → GenerateCommand-CHACGG6N.js} +8 -8
  5. package/build/{LogsCommand-PIRWJADI.js → LogsCommand-ONUNVGZR.js} +3 -3
  6. package/build/PreviewCommand-Y7JEA26N.js +19 -0
  7. package/build/ReleaseCommand-QIDFQA2M.js +23 -0
  8. package/build/{ServeCommand-5HERPY2Q.js → ServeCommand-I57RKIFD.js} +3 -3
  9. package/build/{build-6IDZAW4E.js → build-UZCNG6SL.js} +6 -6
  10. package/build/{chunk-FWRUE2NB.js → chunk-3GHB2NXZ.js} +2 -2
  11. package/build/{chunk-ZHQREOZP.js → chunk-3QFT6UQF.js} +2 -1
  12. package/build/chunk-3QFT6UQF.js.map +1 -0
  13. package/build/{chunk-ESTYQVMX.js → chunk-DLJA76CA.js} +270 -141
  14. package/build/{chunk-ESTYQVMX.js.map → chunk-DLJA76CA.js.map} +1 -1
  15. package/build/{chunk-IIF6P6XG.js → chunk-FDSZMRFC.js} +2 -2
  16. package/build/{chunk-LQZSH33G.js → chunk-FUAEI7OE.js} +6 -6
  17. package/build/{chunk-WA2CFDB5.js → chunk-GY4LG7V4.js} +3 -3
  18. package/build/{chunk-O2MISIES.js → chunk-JPSY3QB7.js} +2 -2
  19. package/build/{chunk-XDUVJLLQ.js → chunk-NPYJ3GAT.js} +2 -2
  20. package/build/{chunk-VDQEUTFT.js → chunk-NQ4YNX6A.js} +5 -5
  21. package/build/{chunk-KVESKT7X.js → chunk-NU7CPDB5.js} +5 -5
  22. package/build/{chunk-QQ4OBBX7.js → chunk-PRRRKDRX.js} +6 -6
  23. package/build/{chunk-DK2KK5UN.js → chunk-PTXQ3EPG.js} +2 -2
  24. package/build/{chunk-NJXD2TTX.js → chunk-R5HMH6QX.js} +30 -10
  25. package/build/{chunk-NJXD2TTX.js.map → chunk-R5HMH6QX.js.map} +1 -1
  26. package/build/{chunk-GNL53AZS.js → chunk-TNH2NG27.js} +3 -3
  27. package/build/{chunk-KHUHWBJD.js → chunk-U2CR5VPH.js} +400 -95
  28. package/build/chunk-U2CR5VPH.js.map +1 -0
  29. package/build/{chunk-PREYTA74.js → chunk-UWCQA4MW.js} +3 -3
  30. package/build/{chunk-UJ4SA2PC.js → chunk-WOIU7VIM.js} +2 -2
  31. package/build/{chunk-JYZ5QJ5C.js → chunk-YLUVMDX7.js} +2 -2
  32. package/build/index.js +24 -24
  33. package/build/platform-sdk/editor.js +1 -1
  34. package/build/platform-sdk/editor.js.map +1 -1
  35. package/build/{preview-IXHPIOMO.js → preview-6SJAV4D6.js} +13 -13
  36. package/build/{release-RFFKID6V.js → release-JUZK53KH.js} +15 -15
  37. package/build/{render-command-NUU6LT5M.js → render-command-FFAZSU54.js} +6 -6
  38. package/package.json +3 -3
  39. package/build/DevCommand-RDPL27X5.js.map +0 -1
  40. package/build/PreviewCommand-AN6WMCYS.js +0 -19
  41. package/build/ReleaseCommand-DAK2EFM2.js +0 -23
  42. package/build/chunk-KHUHWBJD.js.map +0 -1
  43. package/build/chunk-ZHQREOZP.js.map +0 -1
  44. /package/build/{AddPermissionCommand-7QIFVBXV.js.map → AddPermissionCommand-TL46A3YR.js.map} +0 -0
  45. /package/build/{GenerateCommand-6ADO2EJU.js.map → GenerateCommand-CHACGG6N.js.map} +0 -0
  46. /package/build/{LogsCommand-PIRWJADI.js.map → LogsCommand-ONUNVGZR.js.map} +0 -0
  47. /package/build/{PreviewCommand-AN6WMCYS.js.map → PreviewCommand-Y7JEA26N.js.map} +0 -0
  48. /package/build/{ReleaseCommand-DAK2EFM2.js.map → ReleaseCommand-QIDFQA2M.js.map} +0 -0
  49. /package/build/{ServeCommand-5HERPY2Q.js.map → ServeCommand-I57RKIFD.js.map} +0 -0
  50. /package/build/{build-6IDZAW4E.js.map → build-UZCNG6SL.js.map} +0 -0
  51. /package/build/{chunk-FWRUE2NB.js.map → chunk-3GHB2NXZ.js.map} +0 -0
  52. /package/build/{chunk-IIF6P6XG.js.map → chunk-FDSZMRFC.js.map} +0 -0
  53. /package/build/{chunk-LQZSH33G.js.map → chunk-FUAEI7OE.js.map} +0 -0
  54. /package/build/{chunk-WA2CFDB5.js.map → chunk-GY4LG7V4.js.map} +0 -0
  55. /package/build/{chunk-O2MISIES.js.map → chunk-JPSY3QB7.js.map} +0 -0
  56. /package/build/{chunk-XDUVJLLQ.js.map → chunk-NPYJ3GAT.js.map} +0 -0
  57. /package/build/{chunk-VDQEUTFT.js.map → chunk-NQ4YNX6A.js.map} +0 -0
  58. /package/build/{chunk-KVESKT7X.js.map → chunk-NU7CPDB5.js.map} +0 -0
  59. /package/build/{chunk-QQ4OBBX7.js.map → chunk-PRRRKDRX.js.map} +0 -0
  60. /package/build/{chunk-DK2KK5UN.js.map → chunk-PTXQ3EPG.js.map} +0 -0
  61. /package/build/{chunk-GNL53AZS.js.map → chunk-TNH2NG27.js.map} +0 -0
  62. /package/build/{chunk-PREYTA74.js.map → chunk-UWCQA4MW.js.map} +0 -0
  63. /package/build/{chunk-UJ4SA2PC.js.map → chunk-WOIU7VIM.js.map} +0 -0
  64. /package/build/{chunk-JYZ5QJ5C.js.map → chunk-YLUVMDX7.js.map} +0 -0
  65. /package/build/{preview-IXHPIOMO.js.map → preview-6SJAV4D6.js.map} +0 -0
  66. /package/build/{release-RFFKID6V.js.map → release-JUZK53KH.js.map} +0 -0
  67. /package/build/{render-command-NUU6LT5M.js.map → render-command-FFAZSU54.js.map} +0 -0
@@ -4,13 +4,13 @@ import {
4
4
  componentGenerator,
5
5
  require_lodash,
6
6
  useBackendComponents
7
- } from "./chunk-JYZ5QJ5C.js";
7
+ } from "./chunk-YLUVMDX7.js";
8
8
  import {
9
9
  useTunnel
10
- } from "./chunk-DK2KK5UN.js";
10
+ } from "./chunk-PTXQ3EPG.js";
11
11
  import {
12
12
  useDebugLog
13
- } from "./chunk-IIF6P6XG.js";
13
+ } from "./chunk-FDSZMRFC.js";
14
14
  import {
15
15
  createAppManifest,
16
16
  getComponentDevSourceBuilder,
@@ -19,10 +19,10 @@ import {
19
19
  getViteConfig3,
20
20
  getViteServerUrl,
21
21
  updateAppManifestComponents
22
- } from "./chunk-PREYTA74.js";
22
+ } from "./chunk-UWCQA4MW.js";
23
23
  import {
24
24
  useExtensionDataClient
25
- } from "./chunk-NJXD2TTX.js";
25
+ } from "./chunk-R5HMH6QX.js";
26
26
  import {
27
27
  APP_CONFIG_PATH,
28
28
  Alert,
@@ -46,6 +46,7 @@ import {
46
46
  Text,
47
47
  TimeoutError,
48
48
  Trans,
49
+ createHttpClient,
49
50
  deepEqual,
50
51
  external_exports,
51
52
  getBlocksTypesPath,
@@ -82,11 +83,12 @@ import {
82
83
  useHttpClient,
83
84
  usePanoramaMethodLogger,
84
85
  useProjectModel,
86
+ useSiteAuth,
85
87
  useTranslation,
86
88
  use_input_default,
87
89
  wixCliAction,
88
90
  wixCliAppFlowStepsAnswers
89
- } from "./chunk-ESTYQVMX.js";
91
+ } from "./chunk-DLJA76CA.js";
90
92
  import {
91
93
  __commonJS,
92
94
  __dirname,
@@ -23566,12 +23568,20 @@ var SiteListClient = class {
23566
23568
  });
23567
23569
  }
23568
23570
  };
23569
- getSite = async (id) => {
23571
+ getSite = async (id, inclHeadless) => {
23572
+ const queryPayload = {
23573
+ query: {
23574
+ filter: {
23575
+ id: { $in: [id] },
23576
+ ...inclHeadless ? {
23577
+ namespace: { $in: ["WIX", "HEADLESS"] }
23578
+ } : {}
23579
+ }
23580
+ }
23581
+ };
23570
23582
  try {
23571
23583
  const { data } = await pRetry(
23572
- () => this.httpClient.request(
23573
- querySites({ query: { filter: { id: { $in: [id] } } } })
23574
- ),
23584
+ () => this.httpClient.request(querySites(queryPayload)),
23575
23585
  this.retryOptions
23576
23586
  );
23577
23587
  const { sites } = querySitesSchema.parse(data);
@@ -24120,14 +24130,283 @@ var SiteProvider = ({ children, siteId }) => {
24120
24130
 
24121
24131
  // src/components/DevCommand/DevEnvironment.tsx
24122
24132
  init_esm_shims();
24123
- var import_react25 = __toESM(require_react(), 1);
24133
+ var import_react26 = __toESM(require_react(), 1);
24124
24134
  var import_variant13 = __toESM(require_lib(), 1);
24125
24135
 
24126
24136
  // src/components/DevCommand/useArmUpdater.ts
24127
24137
  init_esm_shims();
24128
- var import_react15 = __toESM(require_react(), 1);
24138
+ var import_react17 = __toESM(require_react(), 1);
24129
24139
  var import_variant10 = __toESM(require_lib(), 1);
24130
24140
 
24141
+ // ../metasite-manager-client/src/index.ts
24142
+ init_esm_shims();
24143
+
24144
+ // ../metasite-manager-client/src/useMetasiteManagerClient.ts
24145
+ init_esm_shims();
24146
+ var import_react13 = __toESM(require_react(), 1);
24147
+
24148
+ // ../metasite-manager-client/src/metasite-manager-client.ts
24149
+ init_esm_shims();
24150
+
24151
+ // ../../node_modules/@wix/ambassador-metasite-api-v1-meta-site/build/es/http.impl.js
24152
+ init_esm_shims();
24153
+ var _createMetaSiteFromTemplateRequest = {};
24154
+ var _createMetaSiteFromTemplateResponse = { metaSite: "_metaSite" };
24155
+ var _metaSite = {
24156
+ dateCreated: "google.protobuf.Timestamp",
24157
+ dateUpdated: "google.protobuf.Timestamp",
24158
+ accountCreatedDate: "google.protobuf.Timestamp"
24159
+ };
24160
+ function resolveComWixpressMetasiteApiV1MetaSiteLifecycleUrl(opts) {
24161
+ var domainToMappings = {
24162
+ "www._base_domain_": [
24163
+ {
24164
+ srcPath: "/_api/msm-writer",
24165
+ destPath: ""
24166
+ },
24167
+ {
24168
+ srcPath: "/_api/msm",
24169
+ destPath: ""
24170
+ }
24171
+ ],
24172
+ "manage._base_domain_": [
24173
+ {
24174
+ srcPath: "/_api/msm-writer",
24175
+ destPath: ""
24176
+ },
24177
+ {
24178
+ srcPath: "/_api/msm",
24179
+ destPath: ""
24180
+ }
24181
+ ],
24182
+ "www.wixapis.com": [
24183
+ {
24184
+ srcPath: "/msm",
24185
+ destPath: ""
24186
+ }
24187
+ ],
24188
+ "editor._base_domain_": [
24189
+ {
24190
+ srcPath: "/_api/msm-writer",
24191
+ destPath: ""
24192
+ }
24193
+ ],
24194
+ "blocks._base_domain_": [
24195
+ {
24196
+ srcPath: "/_api/msm-writer",
24197
+ destPath: ""
24198
+ }
24199
+ ],
24200
+ "create.editorx": [
24201
+ {
24202
+ srcPath: "/_api/msm-writer",
24203
+ destPath: ""
24204
+ }
24205
+ ]
24206
+ };
24207
+ return resolveUrl(Object.assign(opts, { domainToMappings }));
24208
+ }
24209
+ function createMetaSiteFromTemplate(payload) {
24210
+ var _a = serializer(_createMetaSiteFromTemplateRequest, {}), toReq = _a.toJSON, fromReq = _a.fromJSON;
24211
+ var fromRes = serializer(_createMetaSiteFromTemplateResponse, { _metaSite }).fromJSON;
24212
+ function __createMetaSiteFromTemplate(_a2) {
24213
+ var host = _a2.host;
24214
+ var serializedData = toReq(payload);
24215
+ var metadata = {
24216
+ entityFqdn: "wix.metasite.api.v1.meta_site",
24217
+ method: "POST",
24218
+ methodFqn: "com.wixpress.metasite.api.v1.MetaSiteLifecycle.CreateMetaSiteFromTemplate",
24219
+ url: resolveComWixpressMetasiteApiV1MetaSiteLifecycleUrl({
24220
+ protoPath: "/v1/meta-site/create-from-template",
24221
+ data: serializedData,
24222
+ host
24223
+ }),
24224
+ data: serializedData,
24225
+ transformResponse: fromRes
24226
+ };
24227
+ return metadata;
24228
+ }
24229
+ __createMetaSiteFromTemplate.fromReq = fromReq;
24230
+ __createMetaSiteFromTemplate.__isAmbassador = true;
24231
+ return __createMetaSiteFromTemplate;
24232
+ }
24233
+
24234
+ // ../../node_modules/@wix/ambassador-document-management-document-store-v1-transaction/build/es/http.impl.js
24235
+ init_esm_shims();
24236
+ var _distributeRequest = {};
24237
+ var _distributeResponse = {};
24238
+ function resolveComWixpressEditorApiDocumentStoreServiceUrl(opts) {
24239
+ var domainToMappings = {
24240
+ "api._api_base_domain_": [
24241
+ {
24242
+ srcPath: "/editor-document-store",
24243
+ destPath: ""
24244
+ }
24245
+ ],
24246
+ "www._base_domain_": [
24247
+ {
24248
+ srcPath: "/_api/editor-document-store",
24249
+ destPath: ""
24250
+ }
24251
+ ],
24252
+ "editor._base_domain_": [
24253
+ {
24254
+ srcPath: "/_api/editor-document-store",
24255
+ destPath: ""
24256
+ }
24257
+ ],
24258
+ "blocks._base_domain_": [
24259
+ {
24260
+ srcPath: "/_api/editor-document-store",
24261
+ destPath: ""
24262
+ }
24263
+ ],
24264
+ "create.editorx": [
24265
+ {
24266
+ srcPath: "/_api/editor-document-store",
24267
+ destPath: ""
24268
+ }
24269
+ ]
24270
+ };
24271
+ return resolveUrl(Object.assign(opts, { domainToMappings }));
24272
+ }
24273
+ function distribute(payload) {
24274
+ var _a = serializer(_distributeRequest, {}), toReq = _a.toJSON, fromReq = _a.fromJSON;
24275
+ var fromRes = serializer(_distributeResponse, {}).fromJSON;
24276
+ function __distribute(_a2) {
24277
+ var host = _a2.host;
24278
+ var serializedData = toReq(payload);
24279
+ var metadata = {
24280
+ entityFqdn: "wix.document_management.document_store.v1.transaction",
24281
+ method: "POST",
24282
+ methodFqn: "com.wixpress.editor.api.DocumentStoreService.Distribute",
24283
+ migrationOptions: {
24284
+ optInTransformResponse: true
24285
+ },
24286
+ url: resolveComWixpressEditorApiDocumentStoreServiceUrl({
24287
+ protoPath: "/v1/distribute",
24288
+ data: serializedData,
24289
+ host
24290
+ }),
24291
+ data: serializedData,
24292
+ transformResponse: fromRes
24293
+ };
24294
+ return metadata;
24295
+ }
24296
+ __distribute.fromReq = fromReq;
24297
+ __distribute.__isAmbassador = true;
24298
+ return __distribute;
24299
+ }
24300
+
24301
+ // ../metasite-manager-client/src/schemas.ts
24302
+ init_esm_shims();
24303
+ var clientSpecMapSchema = external_exports.record(
24304
+ external_exports.object({
24305
+ appDefinitionId: external_exports.string().optional(),
24306
+ permissions: external_exports.object({ revoked: external_exports.boolean() }).optional(),
24307
+ instanceId: external_exports.string().optional()
24308
+ })
24309
+ );
24310
+ var createMetaSiteFromTemplateSchema = external_exports.object({
24311
+ metaSite: external_exports.object({
24312
+ metaSiteId: external_exports.string()
24313
+ })
24314
+ });
24315
+
24316
+ // ../metasite-manager-client/src/metasite-manager-client.ts
24317
+ var MetasiteManagerClient = class {
24318
+ constructor(httpClient) {
24319
+ this.httpClient = httpClient;
24320
+ }
24321
+ getClientSpecMap = async (metaSiteId) => {
24322
+ try {
24323
+ const { data } = await this.httpClient.request({
24324
+ url: `/_api/msm/v1/meta-site/editor-client-spec-map/${metaSiteId}`
24325
+ });
24326
+ return clientSpecMapSchema.parse(data);
24327
+ } catch (e) {
24328
+ throw new CliError({
24329
+ code: CliErrorCode.FailedToGetClientSpecMap(),
24330
+ cause: e
24331
+ });
24332
+ }
24333
+ };
24334
+ createMetaSiteFromTemplate = async (request) => {
24335
+ try {
24336
+ const { data } = await this.httpClient.request(
24337
+ createMetaSiteFromTemplate(request)
24338
+ );
24339
+ return createMetaSiteFromTemplateSchema.parse(data).metaSite;
24340
+ } catch (e) {
24341
+ throw new CliError({
24342
+ code: CliErrorCode.FailedToCreateMetaSiteFromTemplate(),
24343
+ cause: e
24344
+ });
24345
+ }
24346
+ };
24347
+ getSiteInstalledApps = async (metaSiteId) => {
24348
+ try {
24349
+ const clientSpecMap = await this.getClientSpecMap(metaSiteId);
24350
+ return Object.values(clientSpecMap).filter((spec) => spec.appDefinitionId && !spec.permissions?.revoked).map((spec) => spec.appDefinitionId);
24351
+ } catch (e) {
24352
+ throw new CliError({
24353
+ code: CliErrorCode.FailedToGetSiteInstalledApps(),
24354
+ cause: e
24355
+ });
24356
+ }
24357
+ };
24358
+ getInstalledAppInstanceId = async ({
24359
+ metaSiteId,
24360
+ appId
24361
+ }) => {
24362
+ try {
24363
+ const clientSpecMap = await this.getClientSpecMap(metaSiteId);
24364
+ const installedApp = Object.values(clientSpecMap).find(
24365
+ (spec) => spec.appDefinitionId === appId
24366
+ );
24367
+ return installedApp?.instanceId ?? "";
24368
+ } catch (e) {
24369
+ throw new CliError({
24370
+ code: CliErrorCode.FailedToGetSiteInstalledAppInstanceId(),
24371
+ cause: e
24372
+ });
24373
+ }
24374
+ };
24375
+ distributeClientUpdate = async (appId) => {
24376
+ try {
24377
+ await this.httpClient.request(
24378
+ distribute({
24379
+ payloads: [
24380
+ {
24381
+ id: appId,
24382
+ messageType: "MANIFEST_UPDATE",
24383
+ data: {
24384
+ appId
24385
+ }
24386
+ }
24387
+ ],
24388
+ branchId: "00000000-0000-0000-0000-000000000000"
24389
+ })
24390
+ );
24391
+ } catch (e) {
24392
+ throw new CliError({
24393
+ code: CliErrorCode.FailedToDistributeClientManifestUpdate(),
24394
+ cause: e
24395
+ });
24396
+ }
24397
+ };
24398
+ };
24399
+
24400
+ // ../metasite-manager-client/src/useMetasiteManagerClient.ts
24401
+ function useMetasiteManagerClient() {
24402
+ const httpClient = useHttpClient({ type: "general" });
24403
+ const client = (0, import_react13.useMemo)(
24404
+ () => new MetasiteManagerClient(httpClient),
24405
+ [httpClient]
24406
+ );
24407
+ return usePanoramaMethodLogger(client);
24408
+ }
24409
+
24131
24410
  // ../arm-client/src/index.ts
24132
24411
  init_esm_shims();
24133
24412
 
@@ -24697,13 +24976,13 @@ var ARMClient = class {
24697
24976
  };
24698
24977
  release = async (appId, componentOverrideId, options) => {
24699
24978
  try {
24700
- const { comments, createMinorVersion } = options;
24979
+ const { comment, createMinorVersion } = options;
24701
24980
  const { data } = await this.httpClient.request(
24702
24981
  release({
24703
24982
  appId,
24704
24983
  componentOverrideId,
24705
24984
  createMinorVersion,
24706
- notes: comments
24985
+ notes: comment
24707
24986
  })
24708
24987
  );
24709
24988
  return releaseArm2Schema.parse(data).releaseBaseUrl;
@@ -24718,16 +24997,16 @@ var ARMClient = class {
24718
24997
 
24719
24998
  // ../arm-client/src/useARMClient.ts
24720
24999
  init_esm_shims();
24721
- var import_react13 = __toESM(require_react(), 1);
25000
+ var import_react14 = __toESM(require_react(), 1);
24722
25001
  function useARMClient() {
24723
25002
  const httpClient = useHttpClient({ type: "backoffice" });
24724
- const client = (0, import_react13.useMemo)(() => new ARMClient(httpClient), [httpClient]);
25003
+ const client = (0, import_react14.useMemo)(() => new ARMClient(httpClient), [httpClient]);
24725
25004
  return usePanoramaMethodLogger(client);
24726
25005
  }
24727
25006
 
24728
25007
  // src/blocks/useBlocksServicesClient.ts
24729
25008
  init_esm_shims();
24730
- var import_react14 = __toESM(require_react(), 1);
25009
+ var import_react15 = __toESM(require_react(), 1);
24731
25010
 
24732
25011
  // src/blocks/blocks-services-client.ts
24733
25012
  init_esm_shims();
@@ -25013,13 +25292,24 @@ var BlocksServicesClient = class {
25013
25292
  // src/blocks/useBlocksServicesClient.ts
25014
25293
  function useBlocksServicesClient() {
25015
25294
  const httpClient = useHttpClient({ type: "api" });
25016
- const client = (0, import_react14.useMemo)(
25295
+ const client = (0, import_react15.useMemo)(
25017
25296
  () => new BlocksServicesClient(httpClient),
25018
25297
  [httpClient]
25019
25298
  );
25020
25299
  return usePanoramaMethodLogger(client);
25021
25300
  }
25022
25301
 
25302
+ // src/site/useSite.ts
25303
+ init_esm_shims();
25304
+ var import_react16 = __toESM(require_react(), 1);
25305
+ function useSite() {
25306
+ const context = (0, import_react16.useContext)(SiteContext);
25307
+ if (context == null) {
25308
+ throw new Error("useSite() cannot be used without an <SiteProvider>");
25309
+ }
25310
+ return context;
25311
+ }
25312
+
25023
25313
  // src/components/DevCommand/useArmUpdater.ts
25024
25314
  var createAppManifestWithBaseUrl = async ({
25025
25315
  model,
@@ -25048,7 +25338,24 @@ function useArmUpdater() {
25048
25338
  const blocksServicesClient = useBlocksServicesClient();
25049
25339
  const writeDebugLog = useDebugLog();
25050
25340
  const { createAppRelease: createAppRelease2, updateAppRelease: updateAppRelease2 } = useARMClient();
25051
- return (0, import_react15.useCallback)(
25341
+ const { site } = useSite();
25342
+ const siteAuth = useSiteAuth({
25343
+ siteId: site.id
25344
+ });
25345
+ const siteClient = (0, import_react17.useMemo)(
25346
+ () => siteAuth.isAuthenticated && createHttpClient({
25347
+ type: "editor",
25348
+ getAppToken: siteAuth.getAccessToken,
25349
+ createHeaders: siteAuth.getRequestHeaders
25350
+ }),
25351
+ // eslint-disable-next-line react-hooks/exhaustive-deps
25352
+ [siteAuth.isAuthenticated]
25353
+ );
25354
+ const metasiteManagerClientRef = (0, import_react17.useRef)(null);
25355
+ (0, import_react17.useEffect)(() => {
25356
+ metasiteManagerClientRef.current = siteClient ? new MetasiteManagerClient(siteClient) : null;
25357
+ }, [siteClient]);
25358
+ return (0, import_react17.useCallback)(
25052
25359
  async ({
25053
25360
  backendServerUrl,
25054
25361
  devServerUrl,
@@ -25086,7 +25393,7 @@ function useArmUpdater() {
25086
25393
  }
25087
25394
  projectModelWatcher.onChange(async (newModel, changeType) => {
25088
25395
  try {
25089
- if (changeType === "model-updated" || changeType === "blocks-revision-changed") {
25396
+ if (changeType === "model-updated" || changeType === "blocks-revision-changed" || changeType === "component-updated") {
25090
25397
  if (newModel.components.length === 0) {
25091
25398
  return;
25092
25399
  }
@@ -25109,6 +25416,11 @@ function useArmUpdater() {
25109
25416
  appDefId: newModel.config.appId
25110
25417
  });
25111
25418
  }
25419
+ if (metasiteManagerClientRef.current && changeType === "component-updated") {
25420
+ await metasiteManagerClientRef.current.distributeClientUpdate(
25421
+ newModel.config.appId
25422
+ );
25423
+ }
25112
25424
  onChange(changeType);
25113
25425
  } catch (e) {
25114
25426
  onError(e);
@@ -25128,7 +25440,7 @@ function useArmUpdater() {
25128
25440
 
25129
25441
  // src/components/DevCommand/useDevServer.ts
25130
25442
  init_esm_shims();
25131
- var import_react16 = __toESM(require_react(), 1);
25443
+ var import_react18 = __toESM(require_react(), 1);
25132
25444
  import { createServer } from "vite";
25133
25445
 
25134
25446
  // src/vite/plugins/proxy-dev-servers.ts
@@ -25193,13 +25505,13 @@ function useViteDevServer({
25193
25505
  createConfig
25194
25506
  }) {
25195
25507
  const { reportError } = useErrorReporter();
25196
- const devServerRef = (0, import_react16.useRef)();
25197
- (0, import_react16.useEffect)(() => {
25508
+ const devServerRef = (0, import_react18.useRef)();
25509
+ (0, import_react18.useEffect)(() => {
25198
25510
  return () => {
25199
25511
  devServerRef.current?.close().catch(reportError);
25200
25512
  };
25201
25513
  }, [reportError]);
25202
- return (0, import_react16.useCallback)(
25514
+ return (0, import_react18.useCallback)(
25203
25515
  async (options) => {
25204
25516
  try {
25205
25517
  const config = await createConfig(options);
@@ -25277,16 +25589,16 @@ function useBackendDevServer() {
25277
25589
 
25278
25590
  // src/context/armTag.tsx
25279
25591
  init_esm_shims();
25280
- var import_react17 = __toESM(require_react(), 1);
25281
- var ArmTagContext = (0, import_react17.createContext)(null);
25592
+ var import_react19 = __toESM(require_react(), 1);
25593
+ var ArmTagContext = (0, import_react19.createContext)(null);
25282
25594
  var ArmTagProvider = ({
25283
25595
  children,
25284
25596
  armTag
25285
25597
  }) => {
25286
- return /* @__PURE__ */ import_react17.default.createElement(ArmTagContext.Provider, { value: { armTag } }, children);
25598
+ return /* @__PURE__ */ import_react19.default.createElement(ArmTagContext.Provider, { value: { armTag } }, children);
25287
25599
  };
25288
25600
  var useArmTag = () => {
25289
- const context = (0, import_react17.useContext)(ArmTagContext);
25601
+ const context = (0, import_react19.useContext)(ArmTagContext);
25290
25602
  if (context == null) {
25291
25603
  throw new Error("useArmTag() cannot be used without an <ArmTagProvider>");
25292
25604
  }
@@ -25295,7 +25607,7 @@ var useArmTag = () => {
25295
25607
 
25296
25608
  // src/components/DevCommand/useSiteOverrideUpdater.ts
25297
25609
  init_esm_shims();
25298
- var import_react20 = __toESM(require_react(), 1);
25610
+ var import_react21 = __toESM(require_react(), 1);
25299
25611
 
25300
25612
  // ../site-override-client/src/index.ts
25301
25613
  init_esm_shims();
@@ -25425,10 +25737,10 @@ var SiteOverrideClient = class {
25425
25737
 
25426
25738
  // ../site-override-client/src/useSiteOverrideClient.ts
25427
25739
  init_esm_shims();
25428
- var import_react18 = __toESM(require_react(), 1);
25740
+ var import_react20 = __toESM(require_react(), 1);
25429
25741
  function useSiteOverrideClient() {
25430
25742
  const httpClient = useHttpClient({ type: "backoffice" });
25431
- const client = (0, import_react18.useMemo)(
25743
+ const client = (0, import_react20.useMemo)(
25432
25744
  () => new SiteOverrideClient(httpClient),
25433
25745
  [httpClient]
25434
25746
  );
@@ -25479,17 +25791,6 @@ function createSiteOverrides(model) {
25479
25791
  );
25480
25792
  }
25481
25793
 
25482
- // src/site/useSite.ts
25483
- init_esm_shims();
25484
- var import_react19 = __toESM(require_react(), 1);
25485
- function useSite() {
25486
- const context = (0, import_react19.useContext)(SiteContext);
25487
- if (context == null) {
25488
- throw new Error("useSite() cannot be used without an <SiteProvider>");
25489
- }
25490
- return context;
25491
- }
25492
-
25493
25794
  // src/components/DevCommand/useSiteOverrideUpdater.ts
25494
25795
  function useSiteOverrideUpdater() {
25495
25796
  const { model } = useProjectModel();
@@ -25498,9 +25799,9 @@ function useSiteOverrideUpdater() {
25498
25799
  const writeDebugLog = useDebugLog();
25499
25800
  const { createOverride: createOverride2 } = useSiteOverrideClient();
25500
25801
  const { appId } = model.config;
25501
- const siteRef = (0, import_react20.useRef)(site);
25502
- const isUpdaterInitialized = (0, import_react20.useRef)(false);
25503
- (0, import_react20.useEffect)(() => {
25802
+ const siteRef = (0, import_react21.useRef)(site);
25803
+ const isUpdaterInitialized = (0, import_react21.useRef)(false);
25804
+ (0, import_react21.useEffect)(() => {
25504
25805
  siteRef.current = site;
25505
25806
  const updateSiteOverrides = async () => {
25506
25807
  const overrides = createSiteOverrides(model) ?? {};
@@ -25523,7 +25824,7 @@ function useSiteOverrideUpdater() {
25523
25824
  updateSiteOverrides().catch(exit);
25524
25825
  }
25525
25826
  }, [site]);
25526
- return (0, import_react20.useCallback)(
25827
+ return (0, import_react21.useCallback)(
25527
25828
  async ({
25528
25829
  projectModelWatcher
25529
25830
  }) => {
@@ -25563,13 +25864,13 @@ function useSiteOverrideUpdater() {
25563
25864
 
25564
25865
  // src/context/siteOverride.tsx
25565
25866
  init_esm_shims();
25566
- var import_react21 = __toESM(require_react(), 1);
25567
- var SiteOverrideContext = (0, import_react21.createContext)(null);
25867
+ var import_react22 = __toESM(require_react(), 1);
25868
+ var SiteOverrideContext = (0, import_react22.createContext)(null);
25568
25869
  var SiteOverrideProvider = ({ children, siteOverrideId }) => {
25569
- return /* @__PURE__ */ import_react21.default.createElement(SiteOverrideContext.Provider, { value: { siteOverrideId } }, children);
25870
+ return /* @__PURE__ */ import_react22.default.createElement(SiteOverrideContext.Provider, { value: { siteOverrideId } }, children);
25570
25871
  };
25571
25872
  var useSiteOverrideId = () => {
25572
- const context = (0, import_react21.useContext)(SiteOverrideContext);
25873
+ const context = (0, import_react22.useContext)(SiteOverrideContext);
25573
25874
  if (context == null) {
25574
25875
  throw new Error(
25575
25876
  "useSiteOverrideId() cannot be used without an <SiteOverrideProvider>"
@@ -25580,7 +25881,7 @@ var useSiteOverrideId = () => {
25580
25881
 
25581
25882
  // src/components/DevCommand/BlocksCLIServerProvider.tsx
25582
25883
  init_esm_shims();
25583
- var import_react23 = __toESM(require_react(), 1);
25884
+ var import_react24 = __toESM(require_react(), 1);
25584
25885
 
25585
25886
  // ../cli-blocks-editor-comm-api/build/index.js
25586
25887
  init_esm_shims();
@@ -29342,18 +29643,18 @@ var import_serialize_error2 = __toESM2(require_serialize_error(), 1);
29342
29643
 
29343
29644
  // src/components/DevCommand/blocks-cli-dev-server/useSyncBlocksComponents.ts
29344
29645
  init_esm_shims();
29345
- var import_react22 = __toESM(require_react(), 1);
29646
+ var import_react23 = __toESM(require_react(), 1);
29346
29647
  function useBlocksComponentsRef() {
29347
29648
  const { getExtensions } = useExtensions();
29348
- const blocksComponents = (0, import_react22.useMemo)(
29649
+ const blocksComponents = (0, import_react23.useMemo)(
29349
29650
  () => ({
29350
29651
  widgets: getExtensions("BlocksWidget"),
29351
29652
  panels: getExtensions("BlocksWidgetPanel")
29352
29653
  }),
29353
29654
  [getExtensions]
29354
29655
  );
29355
- const blocksComponentsRef = (0, import_react22.useRef)(blocksComponents);
29356
- (0, import_react22.useEffect)(() => {
29656
+ const blocksComponentsRef = (0, import_react23.useRef)(blocksComponents);
29657
+ (0, import_react23.useEffect)(() => {
29357
29658
  blocksComponentsRef.current = blocksComponents;
29358
29659
  }, [blocksComponents]);
29359
29660
  return blocksComponentsRef;
@@ -29486,15 +29787,15 @@ async function syncBlocksComponents(projectFolder, targetWidgets, existingWidget
29486
29787
  var sync_blocks_components_default = syncBlocksComponents;
29487
29788
 
29488
29789
  // src/components/DevCommand/BlocksCLIServerProvider.tsx
29489
- var BlocksCLIServerContext = (0, import_react23.createContext)(null);
29790
+ var BlocksCLIServerContext = (0, import_react24.createContext)(null);
29490
29791
  var BlocksCLIDevServerProvider = ({ httpServer, children }) => {
29491
29792
  const { t } = useTranslation();
29492
29793
  const { logger } = useDevEnvironment();
29493
29794
  const { model } = useProjectModel();
29494
29795
  const blocksComponentsRef = useBlocksComponentsRef();
29495
29796
  const { reportError } = useErrorReporter();
29496
- const wixConfigRef = (0, import_react23.useRef)(model.config);
29497
- const [server] = (0, import_react23.useState)(() => {
29797
+ const wixConfigRef = (0, import_react24.useRef)(model.config);
29798
+ const [server] = (0, import_react24.useState)(() => {
29498
29799
  if (!model.config.blocks || !httpServer) {
29499
29800
  return;
29500
29801
  }
@@ -29521,17 +29822,17 @@ var BlocksCLIDevServerProvider = ({ httpServer, children }) => {
29521
29822
  });
29522
29823
  } catch (error) {
29523
29824
  reportError(error);
29524
- logger.error(/* @__PURE__ */ import_react23.default.createElement(ErrorViewer, { error }));
29825
+ logger.error(/* @__PURE__ */ import_react24.default.createElement(ErrorViewer, { error }));
29525
29826
  throw error;
29526
29827
  }
29527
29828
  }
29528
29829
  });
29529
29830
  return server2;
29530
29831
  });
29531
- (0, import_react23.useEffect)(() => {
29832
+ (0, import_react24.useEffect)(() => {
29532
29833
  wixConfigRef.current = model.config;
29533
29834
  }, [model.config]);
29534
- (0, import_react23.useEffect)(() => {
29835
+ (0, import_react24.useEffect)(() => {
29535
29836
  if (!server) {
29536
29837
  return;
29537
29838
  }
@@ -29543,7 +29844,7 @@ var BlocksCLIDevServerProvider = ({ httpServer, children }) => {
29543
29844
  server.close().catch(reportError);
29544
29845
  };
29545
29846
  }, [server, reportError, logger, t]);
29546
- return /* @__PURE__ */ import_react23.default.createElement(
29847
+ return /* @__PURE__ */ import_react24.default.createElement(
29547
29848
  BlocksCLIServerContext.Provider,
29548
29849
  {
29549
29850
  value: {
@@ -29555,7 +29856,7 @@ var BlocksCLIDevServerProvider = ({ httpServer, children }) => {
29555
29856
  );
29556
29857
  };
29557
29858
  function useBlocksCLIDevServerProvider() {
29558
- const context = (0, import_react23.useContext)(BlocksCLIServerContext);
29859
+ const context = (0, import_react24.useContext)(BlocksCLIServerContext);
29559
29860
  if (context == null) {
29560
29861
  throw new Error(
29561
29862
  "useBlocksCLIDevServerProvider() cannot be used without an <BlocksCLIServerProvider>"
@@ -29566,7 +29867,7 @@ function useBlocksCLIDevServerProvider() {
29566
29867
 
29567
29868
  // src/blocks/BlocksTypesUpdater.tsx
29568
29869
  init_esm_shims();
29569
- var import_react24 = __toESM(require_react(), 1);
29870
+ var import_react25 = __toESM(require_react(), 1);
29570
29871
  var import_variant12 = __toESM(require_lib(), 1);
29571
29872
  import { parse as parse3, relative } from "node:path";
29572
29873
  var getBlocksTypesContent = (structure) => `type ComponentsStructureMap = {
@@ -29614,7 +29915,7 @@ var BlocksTypesUpdater = ({ logger, children }) => {
29614
29915
  const { model } = useProjectModel();
29615
29916
  const { reportError } = useErrorReporter();
29616
29917
  const blocksServicesClient = useBlocksServicesClient();
29617
- (0, import_react24.useEffect)(() => {
29918
+ (0, import_react25.useEffect)(() => {
29618
29919
  const {
29619
29920
  components,
29620
29921
  config: { appId, blocks },
@@ -29641,14 +29942,14 @@ var BlocksTypesUpdater = ({ logger, children }) => {
29641
29942
  };
29642
29943
  generateContent().catch((error) => {
29643
29944
  reportError(error);
29644
- logger.info(/* @__PURE__ */ import_react24.default.createElement(ErrorViewer, { error }));
29945
+ logger.info(/* @__PURE__ */ import_react25.default.createElement(ErrorViewer, { error }));
29645
29946
  });
29646
29947
  }, [model.config.blocks?.uiRevision]);
29647
- return /* @__PURE__ */ import_react24.default.createElement(import_react24.default.Fragment, null, children);
29948
+ return /* @__PURE__ */ import_react25.default.createElement(import_react25.default.Fragment, null, children);
29648
29949
  };
29649
29950
 
29650
29951
  // src/components/DevCommand/DevEnvironment.tsx
29651
- var DevEnvironmentContext = (0, import_react25.createContext)(null);
29952
+ var DevEnvironmentContext = (0, import_react26.createContext)(null);
29652
29953
  var DevEnvironmentProvider = ({ https, logger, origin, port, children }) => {
29653
29954
  const { t } = useTranslation();
29654
29955
  const { reportError } = useErrorReporter();
@@ -29685,6 +29986,9 @@ var DevEnvironmentProvider = ({ https, logger, origin, port, children }) => {
29685
29986
  projectModelWatcher,
29686
29987
  onChange(changeType) {
29687
29988
  (0, import_variant13.match)(changeType, {
29989
+ "component-updated": () => {
29990
+ logger.info(t("dev_command.component_updated"));
29991
+ },
29688
29992
  "change-received": () => {
29689
29993
  logger.info(t("dev_command.config_change"));
29690
29994
  },
@@ -29702,7 +30006,7 @@ var DevEnvironmentProvider = ({ https, logger, origin, port, children }) => {
29702
30006
  },
29703
30007
  onError(error) {
29704
30008
  reportError(error);
29705
- logger.error(/* @__PURE__ */ import_react25.default.createElement(ErrorViewer, { error }));
30009
+ logger.error(/* @__PURE__ */ import_react26.default.createElement(ErrorViewer, { error }));
29706
30010
  logger.info(t("dev_command.config_didnt_update"));
29707
30011
  }
29708
30012
  });
@@ -29710,7 +30014,7 @@ var DevEnvironmentProvider = ({ https, logger, origin, port, children }) => {
29710
30014
  projectModelWatcher
29711
30015
  });
29712
30016
  logger.info(
29713
- /* @__PURE__ */ import_react25.default.createElement(Alert, { type: "success" }, t("dev_command.dev_environment.started"))
30017
+ /* @__PURE__ */ import_react26.default.createElement(Alert, { type: "success" }, t("dev_command.dev_environment.started"))
29714
30018
  );
29715
30019
  return {
29716
30020
  clientDevServer,
@@ -29722,7 +30026,7 @@ var DevEnvironmentProvider = ({ https, logger, origin, port, children }) => {
29722
30026
  }, []);
29723
30027
  return (0, import_variant13.match)(status, {
29724
30028
  Error: () => null,
29725
- Loading: () => /* @__PURE__ */ import_react25.default.createElement(Spinner, { text: t("dev_command.dev_environment.loading") }),
30029
+ Loading: () => /* @__PURE__ */ import_react26.default.createElement(Spinner, { text: t("dev_command.dev_environment.loading") }),
29726
30030
  Success: ({
29727
30031
  result: {
29728
30032
  clientDevServer,
@@ -29731,7 +30035,7 @@ var DevEnvironmentProvider = ({ https, logger, origin, port, children }) => {
29731
30035
  armTag,
29732
30036
  siteOverrideId
29733
30037
  }
29734
- }) => /* @__PURE__ */ import_react25.default.createElement(
30038
+ }) => /* @__PURE__ */ import_react26.default.createElement(
29735
30039
  DevEnvironmentContext.Provider,
29736
30040
  {
29737
30041
  value: {
@@ -29740,12 +30044,12 @@ var DevEnvironmentProvider = ({ https, logger, origin, port, children }) => {
29740
30044
  logger
29741
30045
  }
29742
30046
  },
29743
- /* @__PURE__ */ import_react25.default.createElement(BlocksTypesUpdater, { logger }, /* @__PURE__ */ import_react25.default.createElement(BlocksCLIDevServerProvider, { httpServer: clientDevServer.httpServer }, /* @__PURE__ */ import_react25.default.createElement(SiteOverrideProvider, { siteOverrideId }, /* @__PURE__ */ import_react25.default.createElement(ArmTagProvider, { armTag }, children))))
30047
+ /* @__PURE__ */ import_react26.default.createElement(BlocksTypesUpdater, { logger }, /* @__PURE__ */ import_react26.default.createElement(BlocksCLIDevServerProvider, { httpServer: clientDevServer.httpServer }, /* @__PURE__ */ import_react26.default.createElement(SiteOverrideProvider, { siteOverrideId }, /* @__PURE__ */ import_react26.default.createElement(ArmTagProvider, { armTag }, children))))
29744
30048
  )
29745
30049
  });
29746
30050
  };
29747
30051
  function useDevEnvironment() {
29748
- const context = (0, import_react25.useContext)(DevEnvironmentContext);
30052
+ const context = (0, import_react26.useContext)(DevEnvironmentContext);
29749
30053
  if (context == null) {
29750
30054
  throw new Error(
29751
30055
  "useDevEnvironment() cannot be used without an <DevEnvironmentProvider>"
@@ -29759,9 +30063,9 @@ init_esm_shims();
29759
30063
 
29760
30064
  // src/context/extensionData.tsx
29761
30065
  init_esm_shims();
29762
- var import_react26 = __toESM(require_react(), 1);
30066
+ var import_react27 = __toESM(require_react(), 1);
29763
30067
  var import_variant14 = __toESM(require_lib(), 1);
29764
- var ExtensionDataContext = (0, import_react26.createContext)(null);
30068
+ var ExtensionDataContext = (0, import_react27.createContext)(null);
29765
30069
  var ExtensionDataProvider = ({
29766
30070
  children
29767
30071
  }) => {
@@ -29784,18 +30088,18 @@ var ExtensionDataProvider = ({
29784
30088
  }, [hasExtensions]);
29785
30089
  return (0, import_variant14.match)(status, {
29786
30090
  Error: () => null,
29787
- Loading: () => /* @__PURE__ */ import_react26.default.createElement(Spinner, { text: t("general.loading") }),
29788
- Success: ({ result: extensionDataContainers }) => /* @__PURE__ */ import_react26.default.createElement(ExtensionDataContext.Provider, { value: { extensionDataContainers } }, children)
30091
+ Loading: () => /* @__PURE__ */ import_react27.default.createElement(Spinner, { text: t("general.loading") }),
30092
+ Success: ({ result: extensionDataContainers }) => /* @__PURE__ */ import_react27.default.createElement(ExtensionDataContext.Provider, { value: { extensionDataContainers } }, children)
29789
30093
  });
29790
30094
  };
29791
30095
  function useExtensionData() {
29792
- const context = (0, import_react26.useContext)(ExtensionDataContext);
30096
+ const context = (0, import_react27.useContext)(ExtensionDataContext);
29793
30097
  if (context == null) {
29794
30098
  throw new Error(
29795
30099
  "useExtensionData() cannot be used without an <ExtensionDataProvider>"
29796
30100
  );
29797
30101
  }
29798
- const getDashboardExtensionsRoute = (0, import_react26.useCallback)(
30102
+ const getDashboardExtensionsRoute = (0, import_react27.useCallback)(
29799
30103
  (dashboardExtension) => {
29800
30104
  if ((0, import_variant14.isType)(dashboardExtension, "DashboardPlugin") || (0, import_variant14.isType)(dashboardExtension, "DashboardMenuPlugin")) {
29801
30105
  return context.extensionDataContainers[dashboardExtension.extends]?.component.data.backOfficeExtensionContainer.defaultRoute ?? "/";
@@ -29809,7 +30113,7 @@ function useExtensionData() {
29809
30113
 
29810
30114
  // src/components/extensions/utils.tsx
29811
30115
  init_esm_shims();
29812
- var import_react27 = __toESM(require_react(), 1);
30116
+ var import_react28 = __toESM(require_react(), 1);
29813
30117
  var import_variant15 = __toESM(require_lib(), 1);
29814
30118
  import { URL as URL2 } from "node:url";
29815
30119
  var redirectWithCSMv2FTs = (url2, platformType) => {
@@ -29846,7 +30150,7 @@ function useResolvePlatformUrl() {
29846
30150
  const { site } = useSite();
29847
30151
  const { armTag } = useArmTag();
29848
30152
  const { siteOverrideId } = useSiteOverrideId();
29849
- return (0, import_react27.useCallback)(
30153
+ return (0, import_react28.useCallback)(
29850
30154
  (platformType, openAddPanel) => {
29851
30155
  return resolvePlatformUrl(platformType, {
29852
30156
  openAddPanel,
@@ -29862,7 +30166,7 @@ function useResolvePlatformUrl() {
29862
30166
  function useResolvePlatformDevUrl() {
29863
30167
  const resolvePlatformUrl2 = useResolvePlatformUrl();
29864
30168
  const { https, clientDevServerUrl } = useDevEnvironment();
29865
- return (0, import_react27.useCallback)(
30169
+ return (0, import_react28.useCallback)(
29866
30170
  (platformType, openAddPanel) => {
29867
30171
  let url2 = resolvePlatformUrl2(platformType, openAddPanel);
29868
30172
  if (https) {
@@ -29905,7 +30209,7 @@ function useResolveDashboardExtensionUrl() {
29905
30209
  const { armTag } = useArmTag();
29906
30210
  const { siteOverrideId } = useSiteOverrideId();
29907
30211
  const { getDashboardExtensionsRoute } = useExtensionData();
29908
- return (0, import_react27.useCallback)(
30212
+ return (0, import_react28.useCallback)(
29909
30213
  (extension) => {
29910
30214
  return resolveDashboardExtensionUrl(extension, {
29911
30215
  site,
@@ -29927,7 +30231,7 @@ function useResolveDashboardExtensionUrl() {
29927
30231
  function useResolveDashboardExtensionDevUrl() {
29928
30232
  const resolveDashboardExtensionUrl2 = useResolveDashboardExtensionUrl();
29929
30233
  const { https, clientDevServerUrl } = useDevEnvironment();
29930
- return (0, import_react27.useCallback)(
30234
+ return (0, import_react28.useCallback)(
29931
30235
  (extension) => {
29932
30236
  let url2 = resolveDashboardExtensionUrl2(extension);
29933
30237
  if (https) {
@@ -29948,7 +30252,7 @@ function useResolveBlocksEditorURL() {
29948
30252
  const { model } = useProjectModel();
29949
30253
  const { enabled: cliBlocksServerEnabled, port: cliBlocksServerPort } = useBlocksCLIDevServerProvider();
29950
30254
  const { https, clientDevServerUrl } = useDevEnvironment();
29951
- return (0, import_react27.useCallback)(() => {
30255
+ return (0, import_react28.useCallback)(() => {
29952
30256
  if (!cliBlocksServerEnabled || !cliBlocksServerPort) {
29953
30257
  throw new Error("Blocks CLI Server is not running");
29954
30258
  }
@@ -29984,20 +30288,20 @@ function resolveDashboardExtensionUrl(extension, options) {
29984
30288
  }
29985
30289
  var useOpenPage = () => {
29986
30290
  const { logger } = useDevEnvironment();
29987
- return (0, import_react27.useCallback)(
30291
+ return (0, import_react28.useCallback)(
29988
30292
  async ({ url: url2, title }) => {
29989
30293
  try {
29990
30294
  await openBrowser(url2);
29991
30295
  } catch {
29992
30296
  logger.error(
29993
- /* @__PURE__ */ import_react27.default.createElement(Alert, { type: "error" }, /* @__PURE__ */ import_react27.default.createElement(
30297
+ /* @__PURE__ */ import_react28.default.createElement(Alert, { type: "error" }, /* @__PURE__ */ import_react28.default.createElement(
29994
30298
  Trans,
29995
30299
  {
29996
30300
  i18nKey: "general.open_page_error",
29997
- components: [/* @__PURE__ */ import_react27.default.createElement(Text, { bold: true })],
30301
+ components: [/* @__PURE__ */ import_react28.default.createElement(Text, { bold: true })],
29998
30302
  values: { title }
29999
30303
  }
30000
- ), /* @__PURE__ */ import_react27.default.createElement(Newline, null), /* @__PURE__ */ import_react27.default.createElement(Link, { url: url2 }))
30304
+ ), /* @__PURE__ */ import_react28.default.createElement(Newline, null), /* @__PURE__ */ import_react28.default.createElement(Link, { url: url2 }))
30001
30305
  );
30002
30306
  }
30003
30307
  },
@@ -30007,17 +30311,17 @@ var useOpenPage = () => {
30007
30311
 
30008
30312
  // src/components/Platform/usePlatform.tsx
30009
30313
  init_esm_shims();
30010
- var import_react28 = __toESM(require_react(), 1);
30314
+ var import_react29 = __toESM(require_react(), 1);
30011
30315
  var import_variant16 = __toESM(require_lib(), 1);
30012
30316
  function usePlatform() {
30013
30317
  const { model } = useProjectModel();
30014
- const isPlatformExists = (0, import_react28.useCallback)(
30318
+ const isPlatformExists = (0, import_react29.useCallback)(
30015
30319
  (platformType) => model.components.some(
30016
30320
  (component) => component.platforms.some((0, import_variant16.isType)(platformType.type))
30017
30321
  ),
30018
30322
  [model.components]
30019
30323
  );
30020
- const hasSinglePlatform = (0, import_react28.useCallback)(
30324
+ const hasSinglePlatform = (0, import_react29.useCallback)(
30021
30325
  (platformType) => model.components.every(
30022
30326
  (component) => component.platforms.some((0, import_variant16.isType)(platformType.type)) || component.platforms.length === 0
30023
30327
  ),
@@ -30032,13 +30336,14 @@ function usePlatform() {
30032
30336
  export {
30033
30337
  SiteSelector,
30034
30338
  SiteProvider,
30339
+ useMetasiteManagerClient,
30035
30340
  useARMClient,
30036
30341
  useBlocksServicesClient,
30342
+ useSite,
30037
30343
  ArmTagProvider,
30038
30344
  useArmTag,
30039
30345
  useSiteOverrideClient,
30040
30346
  createSiteOverrides,
30041
- useSite,
30042
30347
  SiteOverrideProvider,
30043
30348
  useBlocksCLIDevServerProvider,
30044
30349
  DevEnvironmentProvider,
@@ -30117,4 +30422,4 @@ xmlhttprequest-ssl/lib/XMLHttpRequest.js:
30117
30422
  * @license MIT
30118
30423
  *)
30119
30424
  */
30120
- //# sourceMappingURL=chunk-KHUHWBJD.js.map
30425
+ //# sourceMappingURL=chunk-U2CR5VPH.js.map