strapi-plugin-firebase-authentication 1.0.6 → 1.0.7

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.
@@ -3,14 +3,14 @@ import { getFetchClient, Pagination, useQueryParams as useQueryParams$1, useNoti
3
3
  import { useNavigate, useLocation, Routes, Route } from "react-router-dom";
4
4
  import { useState, useEffect, useMemo, useCallback, useRef, useLayoutEffect, memo } from "react";
5
5
  import { Flex, Tooltip, Thead, Tr, Th, Tbody, Td, Checkbox, Box, Button, Typography, Dialog, Table, SearchForm, Searchbar, TextInput, Main, Link } from "@strapi/design-system";
6
- import { P as PLUGIN_ID } from "./index-VqMriC8x.mjs";
6
+ import { P as PLUGIN_ID } from "./index-8ErokDMe.mjs";
7
7
  import { useIntl } from "react-intl";
8
8
  import { Key, Trash, WarningCircle, ArrowLeft, Plus } from "@strapi/icons";
9
9
  import { RxCheck, RxCross2 } from "react-icons/rx";
10
10
  import styled from "styled-components";
11
11
  import { AiOutlineUserAdd, AiFillPhone, AiFillMail, AiFillYahoo, AiFillGithub, AiFillTwitterCircle, AiFillFacebook, AiFillApple, AiFillGoogleCircle } from "react-icons/ai";
12
12
  import { MdPassword } from "react-icons/md";
13
- import { g as getFirebaseConfig } from "./api-KRlq4Oq_.mjs";
13
+ import { g as getFirebaseConfig } from "./api-CSB13cU_.mjs";
14
14
  const fetchUsers = async (query = {}) => {
15
15
  if (!query.page) {
16
16
  query.page = 1;
@@ -2015,7 +2015,7 @@ var objectInspect = function inspect_(obj, options, depth, seen) {
2015
2015
  var ys = arrObjKeys(obj, inspect2);
2016
2016
  var isPlainObject = gPO ? gPO(obj) === Object.prototype : obj instanceof Object || obj.constructor === Object;
2017
2017
  var protoTag = obj instanceof Object ? "" : "null prototype";
2018
- var stringTag = !isPlainObject && toStringTag && Object(obj) === obj && toStringTag in obj ? $slice.call(toStr$1(obj), 8, -1) : protoTag ? "Object" : "";
2018
+ var stringTag = !isPlainObject && toStringTag && Object(obj) === obj && toStringTag in obj ? $slice.call(toStr(obj), 8, -1) : protoTag ? "Object" : "";
2019
2019
  var constructorTag = isPlainObject || typeof obj.constructor !== "function" ? "" : obj.constructor.name ? obj.constructor.name + " " : "";
2020
2020
  var tag = constructorTag + (stringTag || protoTag ? "[" + $join.call($concat$1.call([], stringTag || [], protoTag || []), ": ") + "] " : "");
2021
2021
  if (ys.length === 0) {
@@ -2040,25 +2040,25 @@ function canTrustToString(obj) {
2040
2040
  return !toStringTag || !(typeof obj === "object" && (toStringTag in obj || typeof obj[toStringTag] !== "undefined"));
2041
2041
  }
2042
2042
  function isArray$3(obj) {
2043
- return toStr$1(obj) === "[object Array]" && canTrustToString(obj);
2043
+ return toStr(obj) === "[object Array]" && canTrustToString(obj);
2044
2044
  }
2045
2045
  function isDate(obj) {
2046
- return toStr$1(obj) === "[object Date]" && canTrustToString(obj);
2046
+ return toStr(obj) === "[object Date]" && canTrustToString(obj);
2047
2047
  }
2048
2048
  function isRegExp$1(obj) {
2049
- return toStr$1(obj) === "[object RegExp]" && canTrustToString(obj);
2049
+ return toStr(obj) === "[object RegExp]" && canTrustToString(obj);
2050
2050
  }
2051
2051
  function isError(obj) {
2052
- return toStr$1(obj) === "[object Error]" && canTrustToString(obj);
2052
+ return toStr(obj) === "[object Error]" && canTrustToString(obj);
2053
2053
  }
2054
2054
  function isString(obj) {
2055
- return toStr$1(obj) === "[object String]" && canTrustToString(obj);
2055
+ return toStr(obj) === "[object String]" && canTrustToString(obj);
2056
2056
  }
2057
2057
  function isNumber(obj) {
2058
- return toStr$1(obj) === "[object Number]" && canTrustToString(obj);
2058
+ return toStr(obj) === "[object Number]" && canTrustToString(obj);
2059
2059
  }
2060
2060
  function isBoolean(obj) {
2061
- return toStr$1(obj) === "[object Boolean]" && canTrustToString(obj);
2061
+ return toStr(obj) === "[object Boolean]" && canTrustToString(obj);
2062
2062
  }
2063
2063
  function isSymbol(obj) {
2064
2064
  if (hasShammedSymbols) {
@@ -2094,7 +2094,7 @@ var hasOwn$1 = Object.prototype.hasOwnProperty || function(key) {
2094
2094
  function has$3(obj, key) {
2095
2095
  return hasOwn$1.call(obj, key);
2096
2096
  }
2097
- function toStr$1(obj) {
2097
+ function toStr(obj) {
2098
2098
  return objectToString.call(obj);
2099
2099
  }
2100
2100
  function nameOf(f) {
@@ -2403,7 +2403,7 @@ var syntax = SyntaxError;
2403
2403
  var uri = URIError;
2404
2404
  var abs$1 = Math.abs;
2405
2405
  var floor$1 = Math.floor;
2406
- var max$2 = Math.max;
2406
+ var max$1 = Math.max;
2407
2407
  var min$1 = Math.min;
2408
2408
  var pow$1 = Math.pow;
2409
2409
  var round$1 = Math.round;
@@ -2532,78 +2532,99 @@ function requireObject_getPrototypeOf() {
2532
2532
  Object_getPrototypeOf = $Object2.getPrototypeOf || null;
2533
2533
  return Object_getPrototypeOf;
2534
2534
  }
2535
- var ERROR_MESSAGE = "Function.prototype.bind called on incompatible ";
2536
- var toStr = Object.prototype.toString;
2537
- var max$1 = Math.max;
2538
- var funcType = "[object Function]";
2539
- var concatty = function concatty2(a, b) {
2540
- var arr = [];
2541
- for (var i = 0; i < a.length; i += 1) {
2542
- arr[i] = a[i];
2543
- }
2544
- for (var j = 0; j < b.length; j += 1) {
2545
- arr[j + a.length] = b[j];
2546
- }
2547
- return arr;
2548
- };
2549
- var slicy = function slicy2(arrLike, offset) {
2550
- var arr = [];
2551
- for (var i = offset, j = 0; i < arrLike.length; i += 1, j += 1) {
2552
- arr[j] = arrLike[i];
2553
- }
2554
- return arr;
2555
- };
2556
- var joiny = function(arr, joiner) {
2557
- var str = "";
2558
- for (var i = 0; i < arr.length; i += 1) {
2559
- str += arr[i];
2560
- if (i + 1 < arr.length) {
2561
- str += joiner;
2535
+ var implementation;
2536
+ var hasRequiredImplementation;
2537
+ function requireImplementation() {
2538
+ if (hasRequiredImplementation) return implementation;
2539
+ hasRequiredImplementation = 1;
2540
+ var ERROR_MESSAGE = "Function.prototype.bind called on incompatible ";
2541
+ var toStr2 = Object.prototype.toString;
2542
+ var max2 = Math.max;
2543
+ var funcType = "[object Function]";
2544
+ var concatty = function concatty2(a, b) {
2545
+ var arr = [];
2546
+ for (var i = 0; i < a.length; i += 1) {
2547
+ arr[i] = a[i];
2548
+ }
2549
+ for (var j = 0; j < b.length; j += 1) {
2550
+ arr[j + a.length] = b[j];
2551
+ }
2552
+ return arr;
2553
+ };
2554
+ var slicy = function slicy2(arrLike, offset) {
2555
+ var arr = [];
2556
+ for (var i = offset, j = 0; i < arrLike.length; i += 1, j += 1) {
2557
+ arr[j] = arrLike[i];
2562
2558
  }
2563
- }
2564
- return str;
2565
- };
2566
- var implementation$1 = function bind(that) {
2567
- var target = this;
2568
- if (typeof target !== "function" || toStr.apply(target) !== funcType) {
2569
- throw new TypeError(ERROR_MESSAGE + target);
2570
- }
2571
- var args = slicy(arguments, 1);
2572
- var bound;
2573
- var binder = function() {
2574
- if (this instanceof bound) {
2575
- var result = target.apply(
2576
- this,
2577
- concatty(args, arguments)
2578
- );
2579
- if (Object(result) === result) {
2580
- return result;
2559
+ return arr;
2560
+ };
2561
+ var joiny = function(arr, joiner) {
2562
+ var str = "";
2563
+ for (var i = 0; i < arr.length; i += 1) {
2564
+ str += arr[i];
2565
+ if (i + 1 < arr.length) {
2566
+ str += joiner;
2581
2567
  }
2582
- return this;
2583
2568
  }
2584
- return target.apply(
2585
- that,
2586
- concatty(args, arguments)
2587
- );
2569
+ return str;
2588
2570
  };
2589
- var boundLength = max$1(0, target.length - args.length);
2590
- var boundArgs = [];
2591
- for (var i = 0; i < boundLength; i++) {
2592
- boundArgs[i] = "$" + i;
2593
- }
2594
- bound = Function("binder", "return function (" + joiny(boundArgs, ",") + "){ return binder.apply(this,arguments); }")(binder);
2595
- if (target.prototype) {
2596
- var Empty = function Empty2() {
2571
+ implementation = function bind2(that) {
2572
+ var target = this;
2573
+ if (typeof target !== "function" || toStr2.apply(target) !== funcType) {
2574
+ throw new TypeError(ERROR_MESSAGE + target);
2575
+ }
2576
+ var args = slicy(arguments, 1);
2577
+ var bound;
2578
+ var binder = function() {
2579
+ if (this instanceof bound) {
2580
+ var result = target.apply(
2581
+ this,
2582
+ concatty(args, arguments)
2583
+ );
2584
+ if (Object(result) === result) {
2585
+ return result;
2586
+ }
2587
+ return this;
2588
+ }
2589
+ return target.apply(
2590
+ that,
2591
+ concatty(args, arguments)
2592
+ );
2597
2593
  };
2598
- Empty.prototype = target.prototype;
2599
- bound.prototype = new Empty();
2600
- Empty.prototype = null;
2601
- }
2602
- return bound;
2603
- };
2604
- var implementation = implementation$1;
2605
- var functionBind = Function.prototype.bind || implementation;
2606
- var functionCall = Function.prototype.call;
2594
+ var boundLength = max2(0, target.length - args.length);
2595
+ var boundArgs = [];
2596
+ for (var i = 0; i < boundLength; i++) {
2597
+ boundArgs[i] = "$" + i;
2598
+ }
2599
+ bound = Function("binder", "return function (" + joiny(boundArgs, ",") + "){ return binder.apply(this,arguments); }")(binder);
2600
+ if (target.prototype) {
2601
+ var Empty = function Empty2() {
2602
+ };
2603
+ Empty.prototype = target.prototype;
2604
+ bound.prototype = new Empty();
2605
+ Empty.prototype = null;
2606
+ }
2607
+ return bound;
2608
+ };
2609
+ return implementation;
2610
+ }
2611
+ var functionBind;
2612
+ var hasRequiredFunctionBind;
2613
+ function requireFunctionBind() {
2614
+ if (hasRequiredFunctionBind) return functionBind;
2615
+ hasRequiredFunctionBind = 1;
2616
+ var implementation2 = requireImplementation();
2617
+ functionBind = Function.prototype.bind || implementation2;
2618
+ return functionBind;
2619
+ }
2620
+ var functionCall;
2621
+ var hasRequiredFunctionCall;
2622
+ function requireFunctionCall() {
2623
+ if (hasRequiredFunctionCall) return functionCall;
2624
+ hasRequiredFunctionCall = 1;
2625
+ functionCall = Function.prototype.call;
2626
+ return functionCall;
2627
+ }
2607
2628
  var functionApply;
2608
2629
  var hasRequiredFunctionApply;
2609
2630
  function requireFunctionApply() {
@@ -2613,14 +2634,14 @@ function requireFunctionApply() {
2613
2634
  return functionApply;
2614
2635
  }
2615
2636
  var reflectApply = typeof Reflect !== "undefined" && Reflect && Reflect.apply;
2616
- var bind$2 = functionBind;
2637
+ var bind$2 = requireFunctionBind();
2617
2638
  var $apply$1 = requireFunctionApply();
2618
- var $call$2 = functionCall;
2639
+ var $call$2 = requireFunctionCall();
2619
2640
  var $reflectApply = reflectApply;
2620
2641
  var actualApply = $reflectApply || bind$2.call($call$2, $apply$1);
2621
- var bind$1 = functionBind;
2642
+ var bind$1 = requireFunctionBind();
2622
2643
  var $TypeError$4 = type;
2623
- var $call$1 = functionCall;
2644
+ var $call$1 = requireFunctionCall();
2624
2645
  var $actualApply = actualApply;
2625
2646
  var callBindApplyHelpers = function callBindBasic(args) {
2626
2647
  if (args.length < 1 || typeof args[0] !== "function") {
@@ -2686,8 +2707,8 @@ function requireHasown() {
2686
2707
  hasRequiredHasown = 1;
2687
2708
  var call = Function.prototype.call;
2688
2709
  var $hasOwn = Object.prototype.hasOwnProperty;
2689
- var bind3 = functionBind;
2690
- hasown = bind3.call(call, $hasOwn);
2710
+ var bind2 = requireFunctionBind();
2711
+ hasown = bind2.call(call, $hasOwn);
2691
2712
  return hasown;
2692
2713
  }
2693
2714
  var undefined$1;
@@ -2701,7 +2722,7 @@ var $TypeError$3 = type;
2701
2722
  var $URIError = uri;
2702
2723
  var abs = abs$1;
2703
2724
  var floor = floor$1;
2704
- var max = max$2;
2725
+ var max = max$1;
2705
2726
  var min = min$1;
2706
2727
  var pow = pow$1;
2707
2728
  var round = round$1;
@@ -2735,7 +2756,7 @@ var getProto = requireGetProto();
2735
2756
  var $ObjectGPO = requireObject_getPrototypeOf();
2736
2757
  var $ReflectGPO = requireReflect_getPrototypeOf();
2737
2758
  var $apply = requireFunctionApply();
2738
- var $call = functionCall;
2759
+ var $call = requireFunctionCall();
2739
2760
  var needsEval = {};
2740
2761
  var TypedArray = typeof Uint8Array === "undefined" || !getProto ? undefined$1 : getProto(Uint8Array);
2741
2762
  var INTRINSICS = {
@@ -2906,13 +2927,13 @@ var LEGACY_ALIASES = {
2906
2927
  "%WeakMapPrototype%": ["WeakMap", "prototype"],
2907
2928
  "%WeakSetPrototype%": ["WeakSet", "prototype"]
2908
2929
  };
2909
- var bind2 = functionBind;
2930
+ var bind = requireFunctionBind();
2910
2931
  var hasOwn = requireHasown();
2911
- var $concat = bind2.call($call, Array.prototype.concat);
2912
- var $spliceApply = bind2.call($apply, Array.prototype.splice);
2913
- var $replace = bind2.call($call, String.prototype.replace);
2914
- var $strSlice = bind2.call($call, String.prototype.slice);
2915
- var $exec = bind2.call($call, RegExp.prototype.exec);
2932
+ var $concat = bind.call($call, Array.prototype.concat);
2933
+ var $spliceApply = bind.call($apply, Array.prototype.splice);
2934
+ var $replace = bind.call($call, String.prototype.replace);
2935
+ var $strSlice = bind.call($call, String.prototype.slice);
2936
+ var $exec = bind.call($call, RegExp.prototype.exec);
2916
2937
  var rePropName = /[^%.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|%$))/g;
2917
2938
  var reEscapeChar = /\\(\\)?/g;
2918
2939
  var stringToPath = function stringToPath2(string) {
@@ -5,14 +5,14 @@ const admin = require("@strapi/strapi/admin");
5
5
  const reactRouterDom = require("react-router-dom");
6
6
  const react = require("react");
7
7
  const designSystem = require("@strapi/design-system");
8
- const index = require("./index-CY52kL3w.js");
8
+ const index = require("./index-CkvQtAgV.js");
9
9
  const reactIntl = require("react-intl");
10
10
  const icons = require("@strapi/icons");
11
11
  const rx = require("react-icons/rx");
12
12
  const styled = require("styled-components");
13
13
  const ai = require("react-icons/ai");
14
14
  const md = require("react-icons/md");
15
- const api = require("./api-BMQDkXhr.js");
15
+ const api = require("./api-DjpweKFG.js");
16
16
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
17
17
  const styled__default = /* @__PURE__ */ _interopDefault(styled);
18
18
  const fetchUsers = async (query = {}) => {
@@ -1,5 +1,5 @@
1
1
  import { getFetchClient } from "@strapi/strapi/admin";
2
- import { P as PLUGIN_ID } from "./index-VqMriC8x.mjs";
2
+ import { P as PLUGIN_ID } from "./index-8ErokDMe.mjs";
3
3
  const saveFirebaseConfig = async (json) => {
4
4
  const url = `/${PLUGIN_ID}/settings/firebase-config`;
5
5
  const { post } = getFetchClient();
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  const admin = require("@strapi/strapi/admin");
3
- const index = require("./index-CY52kL3w.js");
3
+ const index = require("./index-CkvQtAgV.js");
4
4
  const saveFirebaseConfig = async (json) => {
5
5
  const url = `/${index.PLUGIN_ID}/settings/firebase-config`;
6
6
  const { post } = admin.getFetchClient();
@@ -49,7 +49,7 @@ const index = {
49
49
  id: `${PLUGIN_ID}.page.title`,
50
50
  defaultMessage: PLUGIN_ID
51
51
  },
52
- Component: () => import("./App-ibb0A26-.mjs").then((mod) => ({
52
+ Component: () => import("./App-DaxdXe5h.mjs").then((mod) => ({
53
53
  default: mod.App
54
54
  })),
55
55
  permissions: PERMISSIONS["menu-link"]
@@ -71,7 +71,7 @@ const index = {
71
71
  id: "settings",
72
72
  to: `/settings/${PLUGIN_ID}`,
73
73
  async Component() {
74
- const component = await import("./index-CAq8_dR7.mjs");
74
+ const component = await import("./index-DIqCTZth.mjs");
75
75
  return component.default;
76
76
  },
77
77
  permissions: PERMISSIONS["menu-link"]
@@ -4,7 +4,7 @@ const jsxRuntime = require("react/jsx-runtime");
4
4
  const react = require("react");
5
5
  const designSystem = require("@strapi/design-system");
6
6
  const admin = require("@strapi/strapi/admin");
7
- const api = require("./api-BMQDkXhr.js");
7
+ const api = require("./api-DjpweKFG.js");
8
8
  const icons = require("@strapi/icons");
9
9
  const reactRouterDom = require("react-router-dom");
10
10
  const selectAppImage = "";
@@ -21,11 +21,18 @@ function SettingsPage() {
21
21
  api.getFirebaseConfig().then((data) => {
22
22
  console.log("Retrieved Firebase Config:", data);
23
23
  setLoading(false);
24
+ if (!data || Array.isArray(data) && data.length === 0) {
25
+ setFirebaseJsonValue(null);
26
+ setFirebaseJsonValueInput("");
27
+ return;
28
+ }
24
29
  setFirebaseJsonValue(data);
25
- setFirebaseJsonValueInput(data);
30
+ setFirebaseJsonValueInput(typeof data === "string" ? data : JSON.stringify(data));
26
31
  }).catch((error) => {
27
32
  setLoading(false);
28
33
  console.error("Error retrieving Firebase config:", error);
34
+ setFirebaseJsonValue(null);
35
+ setFirebaseJsonValueInput("");
29
36
  });
30
37
  };
31
38
  react.useEffect(() => {
@@ -35,7 +42,7 @@ function SettingsPage() {
35
42
  try {
36
43
  setLoading(true);
37
44
  await api.delFirebaseConfig();
38
- setFirebaseJsonValue("");
45
+ setFirebaseJsonValue(null);
39
46
  setFirebaseJsonValueInput("");
40
47
  setLoading(false);
41
48
  toggleNotification({
@@ -46,16 +53,21 @@ function SettingsPage() {
46
53
  setLoading(false);
47
54
  toggleNotification({
48
55
  type: "warning",
49
- message: "An error occured, please try again"
56
+ message: "An error occurred, please try again"
50
57
  });
51
58
  }
52
59
  };
53
60
  const handleFirebaseJsonSubmit = async () => {
54
61
  console.log("Submitting Firebase JSON:", firebaseJsonValueInput);
55
62
  try {
56
- const data = await api.saveFirebaseConfig(firebaseJsonValueInput);
63
+ setLoading(true);
64
+ const jsonToSubmit = typeof firebaseJsonValueInput === "string" ? firebaseJsonValueInput : JSON.stringify(firebaseJsonValueInput);
65
+ const data = await api.saveFirebaseConfig(jsonToSubmit);
57
66
  console.log("Firebase JSON submission response:", data);
58
- setFirebaseJsonValue(data["firebase_config_json"]);
67
+ if (!data || !data.firebase_config_json) {
68
+ throw new Error("Invalid response from server");
69
+ }
70
+ setFirebaseJsonValue(data);
59
71
  setLoading(false);
60
72
  toggleNotification({
61
73
  type: "success",
@@ -82,56 +94,65 @@ function SettingsPage() {
82
94
  }
83
95
  };
84
96
  return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { style: { padding: 32 }, direction: "column", alignItems: "flex-start", gap: 4, children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Box, { style: { width: "100%" }, children: [
85
- !firebaseJsonValue || !firebaseJsonValue.firebaseConfigJson ? /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
86
- console.log("Rendering JSON input form, firebaseJsonValue:", firebaseJsonValue),
87
- /* @__PURE__ */ jsxRuntime.jsx(
88
- designSystem.JSONInput,
89
- {
90
- label: "Firebase-json-configuration",
91
- value: firebaseJsonValueInput,
92
- height: 500,
93
- style: { height: 400 },
94
- onChange: setFirebaseJsonValueInput,
95
- error: firebaseJsonValueInput && !isJsonString(firebaseJsonValueInput) ? "Please enter a valid JSON string" : ""
96
- }
97
- ),
98
- /* @__PURE__ */ jsxRuntime.jsx(
99
- designSystem.Flex,
100
- {
101
- style: {
102
- marginTop: 32,
103
- width: "100%",
104
- padding: 16
105
- },
106
- justifyContent: "flex-end",
107
- children: /* @__PURE__ */ jsxRuntime.jsx(
97
+ (() => {
98
+ console.log("Current firebaseJsonValue:", firebaseJsonValue);
99
+ return !firebaseJsonValue || !firebaseJsonValue.firebaseConfigJson ? /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
100
+ /* @__PURE__ */ jsxRuntime.jsx(
101
+ designSystem.JSONInput,
102
+ {
103
+ label: "Firebase-json-configuration",
104
+ value: firebaseJsonValueInput,
105
+ height: 500,
106
+ style: { height: 400 },
107
+ onChange: setFirebaseJsonValueInput,
108
+ error: firebaseJsonValueInput && !isJsonString(firebaseJsonValueInput) ? "Please enter a valid JSON string" : ""
109
+ }
110
+ ),
111
+ /* @__PURE__ */ jsxRuntime.jsx(
112
+ designSystem.Flex,
113
+ {
114
+ style: {
115
+ marginTop: 32,
116
+ width: "100%",
117
+ padding: 16
118
+ },
119
+ justifyContent: "flex-end",
120
+ children: /* @__PURE__ */ jsxRuntime.jsx(
121
+ designSystem.Button,
122
+ {
123
+ size: "L",
124
+ onClick: handleFirebaseJsonSubmit,
125
+ disabled: !isJsonString(firebaseJsonValueInput),
126
+ children: "Submit"
127
+ }
128
+ )
129
+ }
130
+ )
131
+ ] }) : /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
132
+ /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { gap: 4, children: [
133
+ "🚀 You have successfully submitted your json configuration for project:",
134
+ " ",
135
+ /* @__PURE__ */ jsxRuntime.jsx("span", { style: { fontWeight: 700 }, children: firebaseJsonValue?.firebaseConfigJson && (() => {
136
+ try {
137
+ const config = JSON.parse(firebaseJsonValue.firebaseConfigJson);
138
+ return config.project_id || config.projectId || "Unknown Project";
139
+ } catch (e) {
140
+ return "Invalid Config";
141
+ }
142
+ })() }),
143
+ /* @__PURE__ */ jsxRuntime.jsx(
108
144
  designSystem.Button,
109
145
  {
110
- size: "L",
111
- onClick: handleFirebaseJsonSubmit,
112
- disabled: !isJsonString(firebaseJsonValueInput),
113
- children: "Submit"
146
+ variant: "danger-light",
147
+ onClick: handleDeleteFirebaseJsonConfig,
148
+ startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Trash, {}),
149
+ children: "Delete"
114
150
  }
115
151
  )
116
- }
117
- )
118
- ] }) : /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
119
- console.log("Showing success message, firebaseJsonValue:", firebaseJsonValue),
120
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { gap: 4, children: [
121
- "🚀 You have successfully submitted your json configuration for project:",
122
- " ",
123
- /* @__PURE__ */ jsxRuntime.jsx("span", { style: { fontWeight: 700 }, children: firebaseJsonValue?.firebaseConfigJson && (() => {
124
- try {
125
- const config = JSON.parse(firebaseJsonValue.firebaseConfigJson);
126
- return config.project_id || config.projectId || "Unknown Project";
127
- } catch (e) {
128
- return "Invalid Config";
129
- }
130
- })() }),
131
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { variant: "danger-light", onClick: handleDeleteFirebaseJsonConfig, startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Trash, {}), children: "Delete" })
132
- ] }),
133
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { onClick: () => navigate("/plugins/firebase-authentication"), marginTop: 4, children: "Back to firebase plugin" })
134
- ] }),
152
+ ] }),
153
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { onClick: () => navigate("/plugins/firebase-authentication"), marginTop: 4, children: "Back to firebase plugin" })
154
+ ] });
155
+ })(),
135
156
  !firebaseJsonValue ? /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "flex-start", marginTop: 10, children: [
136
157
  "How to setup the firebase configuration:",
137
158
  /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { marginTop: 2, marginLeft: 6, children: /* @__PURE__ */ jsxRuntime.jsxs("ol", { style: { listStyle: "auto" }, children: [
@@ -50,7 +50,7 @@ const index = {
50
50
  id: `${PLUGIN_ID}.page.title`,
51
51
  defaultMessage: PLUGIN_ID
52
52
  },
53
- Component: () => Promise.resolve().then(() => require("./App-LRljvkiG.js")).then((mod) => ({
53
+ Component: () => Promise.resolve().then(() => require("./App-k12rmpn2.js")).then((mod) => ({
54
54
  default: mod.App
55
55
  })),
56
56
  permissions: PERMISSIONS["menu-link"]
@@ -72,7 +72,7 @@ const index = {
72
72
  id: "settings",
73
73
  to: `/settings/${PLUGIN_ID}`,
74
74
  async Component() {
75
- const component = await Promise.resolve().then(() => require("./index-hVmu7PS8.js"));
75
+ const component = await Promise.resolve().then(() => require("./index-CWZQa-dK.js"));
76
76
  return component.default;
77
77
  },
78
78
  permissions: PERMISSIONS["menu-link"]
@@ -2,7 +2,7 @@ import { jsx, Fragment, jsxs } from "react/jsx-runtime";
2
2
  import { useState, useEffect } from "react";
3
3
  import { Flex, Box, JSONInput, Button, Typography } from "@strapi/design-system";
4
4
  import { useNotification, Page } from "@strapi/strapi/admin";
5
- import { g as getFirebaseConfig, s as saveFirebaseConfig, d as delFirebaseConfig } from "./api-KRlq4Oq_.mjs";
5
+ import { g as getFirebaseConfig, s as saveFirebaseConfig, d as delFirebaseConfig } from "./api-CSB13cU_.mjs";
6
6
  import { Trash } from "@strapi/icons";
7
7
  import { useNavigate } from "react-router-dom";
8
8
  const selectAppImage = "";
@@ -19,11 +19,18 @@ function SettingsPage() {
19
19
  getFirebaseConfig().then((data) => {
20
20
  console.log("Retrieved Firebase Config:", data);
21
21
  setLoading(false);
22
+ if (!data || Array.isArray(data) && data.length === 0) {
23
+ setFirebaseJsonValue(null);
24
+ setFirebaseJsonValueInput("");
25
+ return;
26
+ }
22
27
  setFirebaseJsonValue(data);
23
- setFirebaseJsonValueInput(data);
28
+ setFirebaseJsonValueInput(typeof data === "string" ? data : JSON.stringify(data));
24
29
  }).catch((error) => {
25
30
  setLoading(false);
26
31
  console.error("Error retrieving Firebase config:", error);
32
+ setFirebaseJsonValue(null);
33
+ setFirebaseJsonValueInput("");
27
34
  });
28
35
  };
29
36
  useEffect(() => {
@@ -33,7 +40,7 @@ function SettingsPage() {
33
40
  try {
34
41
  setLoading(true);
35
42
  await delFirebaseConfig();
36
- setFirebaseJsonValue("");
43
+ setFirebaseJsonValue(null);
37
44
  setFirebaseJsonValueInput("");
38
45
  setLoading(false);
39
46
  toggleNotification({
@@ -44,16 +51,21 @@ function SettingsPage() {
44
51
  setLoading(false);
45
52
  toggleNotification({
46
53
  type: "warning",
47
- message: "An error occured, please try again"
54
+ message: "An error occurred, please try again"
48
55
  });
49
56
  }
50
57
  };
51
58
  const handleFirebaseJsonSubmit = async () => {
52
59
  console.log("Submitting Firebase JSON:", firebaseJsonValueInput);
53
60
  try {
54
- const data = await saveFirebaseConfig(firebaseJsonValueInput);
61
+ setLoading(true);
62
+ const jsonToSubmit = typeof firebaseJsonValueInput === "string" ? firebaseJsonValueInput : JSON.stringify(firebaseJsonValueInput);
63
+ const data = await saveFirebaseConfig(jsonToSubmit);
55
64
  console.log("Firebase JSON submission response:", data);
56
- setFirebaseJsonValue(data["firebase_config_json"]);
65
+ if (!data || !data.firebase_config_json) {
66
+ throw new Error("Invalid response from server");
67
+ }
68
+ setFirebaseJsonValue(data);
57
69
  setLoading(false);
58
70
  toggleNotification({
59
71
  type: "success",
@@ -80,56 +92,65 @@ function SettingsPage() {
80
92
  }
81
93
  };
82
94
  return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsx(Flex, { style: { padding: 32 }, direction: "column", alignItems: "flex-start", gap: 4, children: /* @__PURE__ */ jsxs(Box, { style: { width: "100%" }, children: [
83
- !firebaseJsonValue || !firebaseJsonValue.firebaseConfigJson ? /* @__PURE__ */ jsxs(Fragment, { children: [
84
- console.log("Rendering JSON input form, firebaseJsonValue:", firebaseJsonValue),
85
- /* @__PURE__ */ jsx(
86
- JSONInput,
87
- {
88
- label: "Firebase-json-configuration",
89
- value: firebaseJsonValueInput,
90
- height: 500,
91
- style: { height: 400 },
92
- onChange: setFirebaseJsonValueInput,
93
- error: firebaseJsonValueInput && !isJsonString(firebaseJsonValueInput) ? "Please enter a valid JSON string" : ""
94
- }
95
- ),
96
- /* @__PURE__ */ jsx(
97
- Flex,
98
- {
99
- style: {
100
- marginTop: 32,
101
- width: "100%",
102
- padding: 16
103
- },
104
- justifyContent: "flex-end",
105
- children: /* @__PURE__ */ jsx(
95
+ (() => {
96
+ console.log("Current firebaseJsonValue:", firebaseJsonValue);
97
+ return !firebaseJsonValue || !firebaseJsonValue.firebaseConfigJson ? /* @__PURE__ */ jsxs(Fragment, { children: [
98
+ /* @__PURE__ */ jsx(
99
+ JSONInput,
100
+ {
101
+ label: "Firebase-json-configuration",
102
+ value: firebaseJsonValueInput,
103
+ height: 500,
104
+ style: { height: 400 },
105
+ onChange: setFirebaseJsonValueInput,
106
+ error: firebaseJsonValueInput && !isJsonString(firebaseJsonValueInput) ? "Please enter a valid JSON string" : ""
107
+ }
108
+ ),
109
+ /* @__PURE__ */ jsx(
110
+ Flex,
111
+ {
112
+ style: {
113
+ marginTop: 32,
114
+ width: "100%",
115
+ padding: 16
116
+ },
117
+ justifyContent: "flex-end",
118
+ children: /* @__PURE__ */ jsx(
119
+ Button,
120
+ {
121
+ size: "L",
122
+ onClick: handleFirebaseJsonSubmit,
123
+ disabled: !isJsonString(firebaseJsonValueInput),
124
+ children: "Submit"
125
+ }
126
+ )
127
+ }
128
+ )
129
+ ] }) : /* @__PURE__ */ jsxs(Fragment, { children: [
130
+ /* @__PURE__ */ jsxs(Flex, { gap: 4, children: [
131
+ "🚀 You have successfully submitted your json configuration for project:",
132
+ " ",
133
+ /* @__PURE__ */ jsx("span", { style: { fontWeight: 700 }, children: firebaseJsonValue?.firebaseConfigJson && (() => {
134
+ try {
135
+ const config = JSON.parse(firebaseJsonValue.firebaseConfigJson);
136
+ return config.project_id || config.projectId || "Unknown Project";
137
+ } catch (e) {
138
+ return "Invalid Config";
139
+ }
140
+ })() }),
141
+ /* @__PURE__ */ jsx(
106
142
  Button,
107
143
  {
108
- size: "L",
109
- onClick: handleFirebaseJsonSubmit,
110
- disabled: !isJsonString(firebaseJsonValueInput),
111
- children: "Submit"
144
+ variant: "danger-light",
145
+ onClick: handleDeleteFirebaseJsonConfig,
146
+ startIcon: /* @__PURE__ */ jsx(Trash, {}),
147
+ children: "Delete"
112
148
  }
113
149
  )
114
- }
115
- )
116
- ] }) : /* @__PURE__ */ jsxs(Fragment, { children: [
117
- console.log("Showing success message, firebaseJsonValue:", firebaseJsonValue),
118
- /* @__PURE__ */ jsxs(Flex, { gap: 4, children: [
119
- "🚀 You have successfully submitted your json configuration for project:",
120
- " ",
121
- /* @__PURE__ */ jsx("span", { style: { fontWeight: 700 }, children: firebaseJsonValue?.firebaseConfigJson && (() => {
122
- try {
123
- const config = JSON.parse(firebaseJsonValue.firebaseConfigJson);
124
- return config.project_id || config.projectId || "Unknown Project";
125
- } catch (e) {
126
- return "Invalid Config";
127
- }
128
- })() }),
129
- /* @__PURE__ */ jsx(Button, { variant: "danger-light", onClick: handleDeleteFirebaseJsonConfig, startIcon: /* @__PURE__ */ jsx(Trash, {}), children: "Delete" })
130
- ] }),
131
- /* @__PURE__ */ jsx(Button, { onClick: () => navigate("/plugins/firebase-authentication"), marginTop: 4, children: "Back to firebase plugin" })
132
- ] }),
150
+ ] }),
151
+ /* @__PURE__ */ jsx(Button, { onClick: () => navigate("/plugins/firebase-authentication"), marginTop: 4, children: "Back to firebase plugin" })
152
+ ] });
153
+ })(),
133
154
  !firebaseJsonValue ? /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "flex-start", marginTop: 10, children: [
134
155
  "How to setup the firebase configuration:",
135
156
  /* @__PURE__ */ jsx(Box, { marginTop: 2, marginLeft: 6, children: /* @__PURE__ */ jsxs("ol", { style: { listStyle: "auto" }, children: [
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
- const index = require("../_chunks/index-CY52kL3w.js");
2
+ const index = require("../_chunks/index-CkvQtAgV.js");
3
3
  module.exports = index.index;
@@ -1,4 +1,4 @@
1
- import { i } from "../_chunks/index-VqMriC8x.mjs";
1
+ import { i } from "../_chunks/index-8ErokDMe.mjs";
2
2
  export {
3
3
  i as default
4
4
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "strapi-plugin-firebase-authentication",
3
- "version": "1.0.6",
3
+ "version": "1.0.7",
4
4
  "description": "Allows easy integration between clients utilizing Firebase for authentication and Strapi",
5
5
  "license": "MIT",
6
6
  "repository": {