@sanity/language-filter 4.1.0 → 5.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 CHANGED
@@ -86,8 +86,8 @@ Config properties:
86
86
  - `field` (the field/fieldset member being rendered)
87
87
  - `selectedLanguageIds` (an array of currently selected language ids)
88
88
  - `parentValue` (the current enclosing object value; `undefined` when not available)
89
- This function is called for all fields and fieldsets in objects for documents that have language filter enabled.
90
- _Default:_ `!enclosingType.name.startsWith('locale') || selectedLanguageIds.includes(field.name)`
89
+ This function is called for all fields and fieldsets in objects for documents that have language filter enabled.
90
+ _Default:_ `!enclosingType.name.startsWith('locale') || selectedLanguageIds.includes(field.name)`
91
91
  - `apiVersion` (optional) used for the Sanity Client when asynchronously loading languages.
92
92
 
93
93
  ## Loading languages
@@ -0,0 +1,44 @@
1
+ import { FieldMember, FieldsetState, ObjectSchemaType, SanityClient, SchemaType, definePlugin } from "sanity";
2
+ interface LanguageFilterOptions {
3
+ languageFilter?: boolean;
4
+ }
5
+ interface LanguageFilterSchema extends ObjectSchemaType {
6
+ options?: LanguageFilterOptions;
7
+ }
8
+ type Language = {
9
+ id: Intl.UnicodeBCP47LocaleIdentifier;
10
+ title: string;
11
+ };
12
+ type LanguageCallback = (client: SanityClient, selectedValue: Record<string, unknown>) => Promise<Language[]>;
13
+ type FilterFieldFunction = (enclosingType: ObjectSchemaType, field: FieldMember | FieldsetState, selectedLanguageIds: string[], parentValue: Record<string, unknown> | undefined) => boolean;
14
+ interface LanguageFilterConfig {
15
+ supportedLanguages: Language[] | LanguageCallback;
16
+ defaultLanguages?: string[];
17
+ documentTypes?: string[];
18
+ filterField?: FilterFieldFunction;
19
+ /**
20
+ * https://www.sanity.io/docs/api-versioning
21
+ * @defaultValue '2022-11-27'
22
+ */
23
+ apiVersion?: string;
24
+ }
25
+ interface LanguageFilterConfigProcessed extends LanguageFilterConfig {
26
+ supportedLanguages: Language[];
27
+ }
28
+ declare const defaultFilterField: FilterFieldFunction;
29
+ declare function isLanguageFilterEnabled(schemaType: SchemaType | undefined, options: LanguageFilterConfig): boolean;
30
+ interface LanguageFilterStudioContextProcessed {
31
+ options: Required<LanguageFilterConfigProcessed>;
32
+ }
33
+ interface LanguageFilterStudioContextValue extends LanguageFilterStudioContextProcessed {
34
+ selectedLanguageIds: string[];
35
+ setSelectedLanguageIds: (ids: string[]) => void;
36
+ }
37
+ /**
38
+ * Retrieves plugin options and the currently selected
39
+ * language IDs from anywhere in the Studio
40
+ */
41
+ declare function useLanguageFilterStudioContext(): LanguageFilterStudioContextValue;
42
+ declare const languageFilter: ReturnType<typeof definePlugin<LanguageFilterConfig>>;
43
+ export { type FilterFieldFunction, type Language, type LanguageFilterConfig, type LanguageFilterOptions, type LanguageFilterSchema, defaultFilterField, isLanguageFilterEnabled, languageFilter, useLanguageFilterStudioContext };
44
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","names":[],"sources":["../src/types.ts","../src/filterField.ts","../src/LanguageFilterStudioContext.tsx","../src/plugin.tsx"],"mappings":";UAEiB,qBAAA;EACf,cAAA;AAAA;AAAA,UAGe,oBAAA,SAA6B,gBAAA;EAC5C,OAAA,GAAU,qBAAA;AAAA;AAAA,KAGA,QAAA;EACV,EAAA,EAAI,IAAA,CAAK,4BAAA;EACT,KAAA;AAAA;AAAA,KAGU,gBAAA,IACV,MAAA,EAAQ,YAAA,EACR,aAAA,EAAe,MAAA,sBACZ,OAAA,CAAQ,QAAA;AAAA,KAED,mBAAA,IACV,aAAA,EAAe,gBAAA,EACf,KAAA,EAAO,WAAA,GAAc,aAAA,EACrB,mBAAA,YACA,WAAA,EAAa,MAAA;AAAA,UAGE,oBAAA;EACf,kBAAA,EAAoB,QAAA,KAAa,gBAAA;EACjC,gBAAA;EACA,aAAA;EACA,WAAA,GAAc,mBAAA;;;;;EAKd,UAAA;AAAA;AAAA,UAGe,6BAAA,SAAsC,oBAAA;EACrD,kBAAA,EAAoB,QAAA;AAAA;AAAA,cCpCT,kBAAA,EAAoB,mBAAA;AAAA,iBAMjB,uBAAA,CACd,UAAA,EAAY,UAAA,cACZ,OAAA,EAAS,oBAAA;AAAA,UCCM,oCAAA;EACf,OAAA,EAAS,QAAA,CAAS,6BAAA;AAAA;AAAA,UAGH,gCAAA,SAAyC,oCAAA;EACxD,mBAAA;EACA,sBAAA,GAAyB,GAAA;AAAA;;;;;iBAoFX,8BAAA,CAAA,GAAkC,gCAAA;AAAA,cCpDrC,cAAA,EAAgB,UAAA,QAAkB,YAAA,CAAa,oBAAA"}
package/dist/index.js ADDED
@@ -0,0 +1,358 @@
1
+ import { jsx, jsxs, Fragment } from "react/jsx-runtime";
2
+ import { c } from "react/compiler-runtime";
3
+ import { createContext, useState, useContext } from "react";
4
+ import { useObservable } from "react-rx";
5
+ import { of, defer, from, catchError, tap } from "rxjs";
6
+ import { useClient, TextWithTone, useFormValue, useSchema, definePlugin, isObjectSchemaType } from "sanity";
7
+ import { EyeClosedIcon, EyeOpenIcon, TranslateIcon, CheckmarkCircleIcon, CircleIcon } from "@sanity/icons";
8
+ import { useClickOutsideEvent, Card, Stack, Box, Popover, Button, Text, Flex, TextInput, Badge } from "@sanity/ui";
9
+ const defaultFilterField = (enclosingType, field, selectedLanguageIds) => !enclosingType.name.startsWith("locale") || selectedLanguageIds.includes(field.name);
10
+ function isLanguageFilterEnabled(schemaType, options) {
11
+ const schemaFilter = (
12
+ // oxlint-disable-next-line no-unsafe-type-assertion -- Checking if schemaType has options.languageFilter
13
+ isDocument(schemaType) && schemaType?.options?.languageFilter
14
+ ), defaultEnabled = !options.documentTypes;
15
+ return !!(defaultEnabled && schemaFilter !== !1 || !defaultEnabled && schemaFilter || schemaType && options.documentTypes?.includes(schemaType.name));
16
+ }
17
+ function isDocument(schemaType) {
18
+ return schemaType?.jsonType === "object" && getRootType(schemaType).name === "document";
19
+ }
20
+ function getRootType(schema) {
21
+ return schema.type ? getRootType(schema.type) : schema;
22
+ }
23
+ function getSelectableLanguages({
24
+ supportedLanguages,
25
+ defaultLanguages
26
+ }) {
27
+ return supportedLanguages.filter((lang) => !defaultLanguages?.includes(lang.id));
28
+ }
29
+ const storageKey = "@sanity/plugin/language-filter/selected-languages";
30
+ function getPersistedLanguageIds(options) {
31
+ const selectableLangs = getSelectableLanguages(options).map((l) => l.id);
32
+ let selected = selectableLangs;
33
+ try {
34
+ const persistedValue = window.localStorage.getItem(storageKey);
35
+ if (persistedValue) {
36
+ const parsed = JSON.parse(persistedValue);
37
+ Array.isArray(parsed) && parsed.every((item) => typeof item == "string") && (selected = parsed);
38
+ }
39
+ } catch {
40
+ }
41
+ selected = intersection(selected, selectableLangs);
42
+ const supportedLanguageIds = options.supportedLanguages.map((language) => language.id), defaultLanguageIds = intersection(options.defaultLanguages ?? [], supportedLanguageIds);
43
+ return unique$1([...defaultLanguageIds, ...selected]);
44
+ }
45
+ function setPersistedLanguageIds(languageIds) {
46
+ window.localStorage.setItem(storageKey, JSON.stringify(languageIds));
47
+ }
48
+ function intersection(array1, array2) {
49
+ return array1.filter((value) => array2.includes(value));
50
+ }
51
+ function unique$1(values) {
52
+ return Array.from(new Set(values));
53
+ }
54
+ const defaultContextValue = {
55
+ options: {
56
+ apiVersion: "2022-11-27",
57
+ supportedLanguages: [],
58
+ defaultLanguages: [],
59
+ documentTypes: [],
60
+ filterField: defaultFilterField
61
+ },
62
+ selectedLanguageIds: [],
63
+ setSelectedLanguageIds: () => console.error("LanguageFilterStudioContext not initialized")
64
+ }, LanguageFilterStudioContext = createContext(defaultContextValue), INITIAL_VALUE = [];
65
+ function LanguageFilterStudioProvider(props) {
66
+ const $ = c(18);
67
+ let t0;
68
+ $[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t0 = {
69
+ apiVersion: "2023-01-01"
70
+ }, $[0] = t0) : t0 = $[0];
71
+ const client = useClient(t0), supportedLanguages = props.options.supportedLanguages, defaultLanguages = props.options.defaultLanguages;
72
+ let t1;
73
+ $[1] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t1 = [], $[1] = t1) : t1 = $[1];
74
+ const [selectedLanguageIds, setSelectedLanguageIds] = useState(t1);
75
+ let t2;
76
+ $[2] !== client || $[3] !== defaultLanguages || $[4] !== supportedLanguages ? (t2 = () => (Array.isArray(supportedLanguages) ? of(supportedLanguages) : defer(() => from(supportedLanguages(client, {}))).pipe(catchError(_temp$2))).pipe(tap((languages) => {
77
+ const persistedLanguageIds = getPersistedLanguageIds({
78
+ supportedLanguages: languages,
79
+ defaultLanguages
80
+ });
81
+ setSelectedLanguageIds(persistedLanguageIds);
82
+ })), $[2] = client, $[3] = defaultLanguages, $[4] = supportedLanguages, $[5] = t2) : t2 = $[5];
83
+ const [languages$] = useState(t2), languages_0 = useObservable(languages$, INITIAL_VALUE);
84
+ let t3;
85
+ $[6] !== languages_0 || $[7] !== props.options ? (t3 = {
86
+ ...defaultContextValue.options,
87
+ ...props.options,
88
+ supportedLanguages: languages_0
89
+ }, $[6] = languages_0, $[7] = props.options, $[8] = t3) : t3 = $[8];
90
+ const options = t3;
91
+ let t4;
92
+ $[9] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t4 = (ids) => {
93
+ setSelectedLanguageIds(ids), setPersistedLanguageIds(ids);
94
+ }, $[9] = t4) : t4 = $[9];
95
+ const onSelectedLanguageIdsChange = t4;
96
+ let t5;
97
+ $[10] !== options || $[11] !== selectedLanguageIds ? (t5 = {
98
+ options,
99
+ selectedLanguageIds,
100
+ setSelectedLanguageIds: onSelectedLanguageIdsChange
101
+ }, $[10] = options, $[11] = selectedLanguageIds, $[12] = t5) : t5 = $[12];
102
+ const value = t5;
103
+ let t6;
104
+ $[13] !== props ? (t6 = props.renderDefault(props), $[13] = props, $[14] = t6) : t6 = $[14];
105
+ let t7;
106
+ return $[15] !== t6 || $[16] !== value ? (t7 = /* @__PURE__ */ jsx(LanguageFilterStudioContext.Provider, { value, children: t6 }), $[15] = t6, $[16] = value, $[17] = t7) : t7 = $[17], t7;
107
+ }
108
+ function _temp$2() {
109
+ return of([]);
110
+ }
111
+ function useLanguageFilterStudioContext() {
112
+ return useContext(LanguageFilterStudioContext);
113
+ }
114
+ const unique = (arr) => Array.from(new Set(arr));
115
+ function usePaneLanguages() {
116
+ const $ = c(25), {
117
+ selectedLanguageIds,
118
+ setSelectedLanguageIds,
119
+ options
120
+ } = useLanguageFilterStudioContext(), {
121
+ defaultLanguages: t0
122
+ } = options;
123
+ let t1;
124
+ $[0] !== t0 ? (t1 = t0 === void 0 ? [] : t0, $[0] = t0, $[1] = t1) : t1 = $[1];
125
+ const defaultLanguages = t1;
126
+ let t2;
127
+ $[2] !== options ? (t2 = getSelectableLanguages(options), $[2] = options, $[3] = t2) : t2 = $[3];
128
+ const selectableLanguages = t2;
129
+ let t3;
130
+ $[4] !== defaultLanguages || $[5] !== setSelectedLanguageIds ? (t3 = (ids) => {
131
+ setSelectedLanguageIds(unique([...defaultLanguages, ...ids]));
132
+ }, $[4] = defaultLanguages, $[5] = setSelectedLanguageIds, $[6] = t3) : t3 = $[6];
133
+ const updateSelectedIds = t3;
134
+ let t4;
135
+ $[7] !== selectableLanguages || $[8] !== updateSelectedIds ? (t4 = () => updateSelectedIds(selectableLanguages.map(_temp$1)), $[7] = selectableLanguages, $[8] = updateSelectedIds, $[9] = t4) : t4 = $[9];
136
+ const selectAll = t4;
137
+ let t5;
138
+ $[10] !== defaultLanguages || $[11] !== updateSelectedIds ? (t5 = () => {
139
+ updateSelectedIds(defaultLanguages);
140
+ }, $[10] = defaultLanguages, $[11] = updateSelectedIds, $[12] = t5) : t5 = $[12];
141
+ const selectNone = t5;
142
+ let t6;
143
+ $[13] !== selectedLanguageIds || $[14] !== updateSelectedIds ? (t6 = (languageId) => {
144
+ let lang = selectedLanguageIds;
145
+ lang.includes(languageId) ? lang = lang.filter((l_0) => l_0 !== languageId) : lang = unique([...lang, languageId]), updateSelectedIds(lang);
146
+ }, $[13] = selectedLanguageIds, $[14] = updateSelectedIds, $[15] = t6) : t6 = $[15];
147
+ const toggleLanguage = t6;
148
+ let t7;
149
+ $[16] !== defaultLanguages || $[17] !== selectedLanguageIds ? (t7 = unique([...defaultLanguages ?? [], ...selectedLanguageIds]), $[16] = defaultLanguages, $[17] = selectedLanguageIds, $[18] = t7) : t7 = $[18];
150
+ const activeLanguages = t7, t8 = selectedLanguageIds.length === selectableLanguages.length + defaultLanguages.length;
151
+ let t9;
152
+ return $[19] !== activeLanguages || $[20] !== selectAll || $[21] !== selectNone || $[22] !== t8 || $[23] !== toggleLanguage ? (t9 = {
153
+ activeLanguages,
154
+ allSelected: t8,
155
+ selectAll,
156
+ selectNone,
157
+ toggleLanguage
158
+ }, $[19] = activeLanguages, $[20] = selectAll, $[21] = selectNone, $[22] = t8, $[23] = toggleLanguage, $[24] = t9) : t9 = $[24], t9;
159
+ }
160
+ function _temp$1(l) {
161
+ return l.id;
162
+ }
163
+ function LanguageFilterMenuButton() {
164
+ const $ = c(54), {
165
+ options
166
+ } = useLanguageFilterStudioContext();
167
+ let t0;
168
+ $[0] !== options.defaultLanguages ? (t0 = (l) => options.defaultLanguages?.includes(l.id), $[0] = options.defaultLanguages, $[1] = t0) : t0 = $[1];
169
+ const defaultLanguages = options.supportedLanguages.filter(t0);
170
+ let t1;
171
+ $[2] !== options.defaultLanguages ? (t1 = (l_0) => !options.defaultLanguages?.includes(l_0.id), $[2] = options.defaultLanguages, $[3] = t1) : t1 = $[3];
172
+ const languageOptions = options.supportedLanguages.filter(t1), [open, setOpen] = useState(!1), {
173
+ activeLanguages,
174
+ allSelected,
175
+ selectAll,
176
+ selectNone,
177
+ toggleLanguage
178
+ } = usePaneLanguages(), [button, setButton] = useState(null), [popover, setPopover] = useState(null);
179
+ let t2;
180
+ $[4] !== selectAll || $[5] !== selectNone ? (t2 = (event) => {
181
+ event.currentTarget.value === "ALL" ? selectAll() : selectNone();
182
+ }, $[4] = selectAll, $[5] = selectNone, $[6] = t2) : t2 = $[6];
183
+ const handleToggleAll = t2;
184
+ let t3;
185
+ $[7] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t3 = () => setOpen(_temp), $[7] = t3) : t3 = $[7];
186
+ const handleClick = t3;
187
+ let t4;
188
+ $[8] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t4 = () => setOpen(!1), $[8] = t4) : t4 = $[8];
189
+ const handleClickOutside = t4;
190
+ let t5;
191
+ $[9] !== button || $[10] !== popover ? (t5 = () => [button, popover].filter(_temp2), $[9] = button, $[10] = popover, $[11] = t5) : t5 = $[11], useClickOutsideEvent(handleClickOutside, t5);
192
+ const langCount = options.supportedLanguages.length, [query, setQuery] = useState("");
193
+ let t6;
194
+ $[12] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t6 = (event_0) => {
195
+ event_0.currentTarget.value ? setQuery(event_0.currentTarget.value) : setQuery("");
196
+ }, $[12] = t6) : t6 = $[12];
197
+ const handleQuery = t6, showSearch = langCount > 4, T0 = Box, t7 = "auto";
198
+ let t8;
199
+ $[13] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t8 = {
200
+ maxHeight: "calc(100vh - 200px)"
201
+ }, $[13] = t8) : t8 = $[13];
202
+ const T1 = Stack, t9 = 1, t10 = 1, t11 = defaultLanguages.length > 0 && /* @__PURE__ */ jsxs(Fragment, { children: [
203
+ defaultLanguages.map(_temp3),
204
+ /* @__PURE__ */ jsx(Card, { borderTop: !0 })
205
+ ] }), t12 = allSelected ? "NONE" : "ALL", t13 = !!query;
206
+ let t14;
207
+ $[14] !== allSelected ? (t14 = /* @__PURE__ */ jsx(Text, { size: 2, children: allSelected ? /* @__PURE__ */ jsx(TextWithTone, { tone: "primary", children: /* @__PURE__ */ jsx(EyeClosedIcon, {}) }) : /* @__PURE__ */ jsx(EyeOpenIcon, {}) }), $[14] = allSelected, $[15] = t14) : t14 = $[15];
208
+ const t15 = allSelected ? "Hide all" : "Show all";
209
+ let t16;
210
+ $[16] !== t15 ? (t16 = /* @__PURE__ */ jsx(Box, { flex: 1, children: /* @__PURE__ */ jsx(Text, { children: t15 }) }), $[16] = t15, $[17] = t16) : t16 = $[17];
211
+ let t17;
212
+ $[18] !== t14 || $[19] !== t16 ? (t17 = /* @__PURE__ */ jsxs(Flex, { gap: 3, align: "center", children: [
213
+ t14,
214
+ t16
215
+ ] }), $[18] = t14, $[19] = t16, $[20] = t17) : t17 = $[20];
216
+ let t18;
217
+ $[21] !== handleToggleAll || $[22] !== t12 || $[23] !== t13 || $[24] !== t17 ? (t18 = /* @__PURE__ */ jsx(Button, { mode: "bleed", onClick: handleToggleAll, justify: "flex-start", value: t12, disabled: t13, children: t17 }), $[21] = handleToggleAll, $[22] = t12, $[23] = t13, $[24] = t17, $[25] = t18) : t18 = $[25];
218
+ let t19;
219
+ $[26] !== query || $[27] !== showSearch ? (t19 = showSearch ? /* @__PURE__ */ jsx(TextInput, { onChange: handleQuery, value: query, placeholder: "Filter languages" }) : /* @__PURE__ */ jsx(Card, { borderTop: !0 }), $[26] = query, $[27] = showSearch, $[28] = t19) : t19 = $[28];
220
+ let t20;
221
+ $[29] !== query ? (t20 = (language) => query ? language.title.toLowerCase().includes(query.toLowerCase()) : !0, $[29] = query, $[30] = t20) : t20 = $[30];
222
+ let t21;
223
+ $[31] !== activeLanguages || $[32] !== toggleLanguage ? (t21 = (lang) => /* @__PURE__ */ jsx(LanguageFilterOption, { id: lang.id, onToggle: toggleLanguage, selected: activeLanguages.includes(lang.id), title: lang.title }, lang.id), $[31] = activeLanguages, $[32] = toggleLanguage, $[33] = t21) : t21 = $[33];
224
+ const t22 = languageOptions.filter(t20).map(t21);
225
+ let t23;
226
+ $[34] !== T1 || $[35] !== t11 || $[36] !== t18 || $[37] !== t19 || $[38] !== t22 ? (t23 = /* @__PURE__ */ jsxs(T1, { padding: t9, space: t10, children: [
227
+ t11,
228
+ t18,
229
+ t19,
230
+ t22
231
+ ] }), $[34] = T1, $[35] = t11, $[36] = t18, $[37] = t19, $[38] = t22, $[39] = t23) : t23 = $[39];
232
+ let t24;
233
+ $[40] !== T0 || $[41] !== t23 || $[42] !== t8 ? (t24 = /* @__PURE__ */ jsx(T0, { overflow: t7, style: t8, children: t23 }), $[40] = T0, $[41] = t23, $[42] = t8, $[43] = t24) : t24 = $[43];
234
+ const content = t24, buttonText = activeLanguages.length === langCount ? "Showing all" : `Showing ${activeLanguages.length} / ${langCount}`;
235
+ let t25;
236
+ $[44] !== buttonText || $[45] !== handleClick || $[46] !== open || $[47] !== setButton ? (t25 = /* @__PURE__ */ jsx(Button, { text: buttonText, icon: TranslateIcon, mode: "bleed", onClick: handleClick, ref: setButton, selected: open }), $[44] = buttonText, $[45] = handleClick, $[46] = open, $[47] = setButton, $[48] = t25) : t25 = $[48];
237
+ let t26;
238
+ return $[49] !== content || $[50] !== open || $[51] !== setPopover || $[52] !== t25 ? (t26 = /* @__PURE__ */ jsx(Popover, { animate: !0, content, open, portal: !0, ref: setPopover, children: t25 }), $[49] = content, $[50] = open, $[51] = setPopover, $[52] = t25, $[53] = t26) : t26 = $[53], t26;
239
+ }
240
+ function _temp3(l_1) {
241
+ return /* @__PURE__ */ jsx(LanguageFilterOption, { id: l_1.id, title: l_1.title, selected: !0 }, l_1.id);
242
+ }
243
+ function _temp2(el) {
244
+ return el !== null;
245
+ }
246
+ function _temp(o) {
247
+ return !o;
248
+ }
249
+ function LanguageFilterOption(props) {
250
+ const $ = c(18), {
251
+ id,
252
+ onToggle,
253
+ selected,
254
+ title
255
+ } = props;
256
+ let t0;
257
+ $[0] !== id || $[1] !== onToggle ? (t0 = () => {
258
+ onToggle && onToggle(id);
259
+ }, $[0] = id, $[1] = onToggle, $[2] = t0) : t0 = $[2];
260
+ const handleChange = t0, disabled = !onToggle;
261
+ let t1;
262
+ $[3] !== disabled || $[4] !== selected ? (t1 = /* @__PURE__ */ jsx(Text, { size: 2, children: selected ? /* @__PURE__ */ jsx(TextWithTone, { tone: disabled ? "default" : "positive", children: /* @__PURE__ */ jsx(CheckmarkCircleIcon, {}) }) : /* @__PURE__ */ jsx(CircleIcon, {}) }), $[3] = disabled, $[4] = selected, $[5] = t1) : t1 = $[5];
263
+ let t2;
264
+ $[6] !== title ? (t2 = /* @__PURE__ */ jsx(Box, { flex: 1, children: /* @__PURE__ */ jsx(Text, { children: title }) }), $[6] = title, $[7] = t2) : t2 = $[7];
265
+ let t3;
266
+ $[8] !== id ? (t3 = /* @__PURE__ */ jsx(Badge, { children: id }), $[8] = id, $[9] = t3) : t3 = $[9];
267
+ let t4;
268
+ $[10] !== t1 || $[11] !== t2 || $[12] !== t3 ? (t4 = /* @__PURE__ */ jsxs(Flex, { gap: 3, align: "center", children: [
269
+ t1,
270
+ t2,
271
+ t3
272
+ ] }), $[10] = t1, $[11] = t2, $[12] = t3, $[13] = t4) : t4 = $[13];
273
+ let t5;
274
+ return $[14] !== disabled || $[15] !== handleChange || $[16] !== t4 ? (t5 = /* @__PURE__ */ jsx(Button, { mode: "bleed", onClick: handleChange, justify: "flex-start", disabled, children: t4 }), $[14] = disabled, $[15] = handleChange, $[16] = t4, $[17] = t5) : t5 = $[17], t5;
275
+ }
276
+ function FilteredObjectWrapper(props) {
277
+ const $ = c(8), {
278
+ options
279
+ } = useLanguageFilterStudioContext();
280
+ let t0;
281
+ $[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t0 = ["_type"], $[0] = t0) : t0 = $[0];
282
+ const documentType = useFormValue(t0), schema = useSchema();
283
+ let t1;
284
+ $[1] !== documentType || $[2] !== options || $[3] !== schema ? (t1 = isLanguageFilterEnabled(schema.get(documentType), options), $[1] = documentType, $[2] = options, $[3] = schema, $[4] = t1) : t1 = $[4];
285
+ const languageFilterEnabled = t1;
286
+ let t2;
287
+ return $[5] !== languageFilterEnabled || $[6] !== props ? (t2 = languageFilterEnabled ? /* @__PURE__ */ jsx(FilteredObjectInput, { ...props }) : props.renderDefault(props), $[5] = languageFilterEnabled, $[6] = props, $[7] = t2) : t2 = $[7], t2;
288
+ }
289
+ function FilteredObjectInput(props) {
290
+ const $ = c(16), {
291
+ members: membersProp,
292
+ schemaType,
293
+ renderDefault,
294
+ ...restProps
295
+ } = props, {
296
+ selectedLanguageIds,
297
+ options
298
+ } = useLanguageFilterStudioContext(), {
299
+ filterField
300
+ } = options, parentValue = props.value;
301
+ let t0;
302
+ if ($[0] !== filterField || $[1] !== membersProp || $[2] !== parentValue || $[3] !== schemaType || $[4] !== selectedLanguageIds) {
303
+ let t1;
304
+ $[6] !== filterField || $[7] !== parentValue || $[8] !== schemaType || $[9] !== selectedLanguageIds ? (t1 = (member) => member.kind === "field" && filterField(schemaType, member, selectedLanguageIds, parentValue) || member.kind === "fieldSet" || member.kind === "error", $[6] = filterField, $[7] = parentValue, $[8] = schemaType, $[9] = selectedLanguageIds, $[10] = t1) : t1 = $[10];
305
+ let t2;
306
+ $[11] !== filterField || $[12] !== parentValue || $[13] !== schemaType || $[14] !== selectedLanguageIds ? (t2 = (member_0) => member_0.kind === "fieldSet" ? Object.assign({}, member_0, {
307
+ fieldSet: Object.assign({}, member_0.fieldSet, {
308
+ members: member_0.fieldSet.members.filter((fieldsetMember) => fieldsetMember.kind === "field" && filterField(schemaType, fieldsetMember, selectedLanguageIds, parentValue))
309
+ })
310
+ }) : member_0, $[11] = filterField, $[12] = parentValue, $[13] = schemaType, $[14] = selectedLanguageIds, $[15] = t2) : t2 = $[15], t0 = membersProp.filter(t1).map(t2), $[0] = filterField, $[1] = membersProp, $[2] = parentValue, $[3] = schemaType, $[4] = selectedLanguageIds, $[5] = t0;
311
+ } else
312
+ t0 = $[5];
313
+ return renderDefault({
314
+ ...restProps,
315
+ members: t0,
316
+ schemaType,
317
+ renderDefault
318
+ });
319
+ }
320
+ const RenderLanguageFilter = () => {
321
+ const $ = c(1);
322
+ let t0;
323
+ return $[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel") ? (t0 = /* @__PURE__ */ jsx(LanguageFilterMenuButton, {}), $[0] = t0) : t0 = $[0], t0;
324
+ }, languageFilter = definePlugin((options) => {
325
+ const pluginOptions = {
326
+ ...defaultContextValue.options,
327
+ ...options
328
+ };
329
+ return {
330
+ name: "@sanity/language-filter",
331
+ studio: {
332
+ components: {
333
+ layout: (props) => LanguageFilterStudioProvider({
334
+ ...props,
335
+ options: pluginOptions
336
+ })
337
+ }
338
+ },
339
+ document: {
340
+ unstable_languageFilter: (prev, {
341
+ schemaType,
342
+ schema
343
+ }) => isLanguageFilterEnabled(schema.get(schemaType), options) ? [...prev, RenderLanguageFilter] : prev
344
+ },
345
+ form: {
346
+ components: {
347
+ input: (props) => props.id !== "root" && isObjectSchemaType(props.schemaType) ? FilteredObjectWrapper(props) : props.renderDefault(props)
348
+ }
349
+ }
350
+ };
351
+ });
352
+ export {
353
+ defaultFilterField,
354
+ isLanguageFilterEnabled,
355
+ languageFilter,
356
+ useLanguageFilterStudioContext
357
+ };
358
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../src/filterField.ts","../src/getSelectableLanguages.ts","../src/persistedLanguageIds.ts","../src/LanguageFilterStudioContext.tsx","../src/usePaneLanguages.ts","../src/LanguageFilterMenuButton.tsx","../src/LanguageFilterObjectInput.tsx","../src/plugin.tsx"],"sourcesContent":["import type {SchemaType} from 'sanity'\n\nimport type {FilterFieldFunction, LanguageFilterConfig, LanguageFilterSchema} from './types'\n\nexport const defaultFilterField: FilterFieldFunction = (\n enclosingType,\n field,\n selectedLanguageIds,\n) => !enclosingType.name.startsWith('locale') || selectedLanguageIds.includes(field.name)\n\nexport function isLanguageFilterEnabled(\n schemaType: SchemaType | undefined,\n options: LanguageFilterConfig,\n): boolean {\n const schemaFilter =\n // oxlint-disable-next-line no-unsafe-type-assertion -- Checking if schemaType has options.languageFilter\n isDocument(schemaType) && (schemaType as LanguageFilterSchema)?.options?.languageFilter\n const defaultEnabled = !options.documentTypes\n\n return !!(\n (defaultEnabled && schemaFilter !== false) ||\n (!defaultEnabled && schemaFilter) ||\n (schemaType && options.documentTypes?.includes(schemaType.name))\n )\n}\n\nfunction isDocument(schemaType?: SchemaType) {\n return schemaType?.jsonType === 'object' && getRootType(schemaType).name === 'document'\n}\n\nfunction getRootType(schema: SchemaType): SchemaType {\n if (schema.type) {\n return getRootType(schema.type)\n }\n return schema\n}\n","import type {Language} from './types'\n\nexport function getSelectableLanguages({\n supportedLanguages,\n defaultLanguages,\n}: {\n supportedLanguages: Language[]\n defaultLanguages?: string[]\n}): Language[] {\n return supportedLanguages.filter((lang) => !defaultLanguages?.includes(lang.id))\n}\n","import {getSelectableLanguages} from './getSelectableLanguages'\nimport type {Language} from './types'\n\nconst storageKey = '@sanity/plugin/language-filter/selected-languages'\n\nexport function getPersistedLanguageIds(options: {\n supportedLanguages: Language[]\n defaultLanguages?: string[]\n}): string[] {\n const selectableLangs = getSelectableLanguages(options).map((l) => l.id)\n let selected: string[] = selectableLangs\n try {\n const persistedValue = window.localStorage.getItem(storageKey)\n if (persistedValue) {\n const parsed = JSON.parse(persistedValue)\n if (Array.isArray(parsed) && parsed.every((item) => typeof item === 'string')) {\n selected = parsed\n }\n }\n } catch {}\n\n // constrain persisted/selected languages to the ones currently supported\n selected = intersection(selected, selectableLangs)\n\n const supportedLanguageIds = options.supportedLanguages.map((language) => language.id)\n const defaultLanguageIds = intersection(options.defaultLanguages ?? [], supportedLanguageIds)\n return unique([...defaultLanguageIds, ...selected])\n}\n\nexport function setPersistedLanguageIds(languageIds: string[]): void {\n window.localStorage.setItem(storageKey, JSON.stringify(languageIds))\n}\n\nfunction intersection(array1: string[], array2: string[]) {\n return array1.filter((value) => array2.includes(value))\n}\n\nfunction unique(values: string[]) {\n return Array.from(new Set(values))\n}\n","import {createContext, useCallback, useContext, useMemo, useState} from 'react'\nimport {useObservable} from 'react-rx'\nimport {catchError, defer, from, of, tap} from 'rxjs'\nimport {type LayoutProps, useClient} from 'sanity'\n\nimport {defaultFilterField} from './filterField'\nimport {getPersistedLanguageIds, setPersistedLanguageIds} from './persistedLanguageIds'\nimport type {LanguageFilterConfig, LanguageFilterConfigProcessed, Language} from './types'\n\nexport interface LanguageFilterStudioContextProps {\n options: Required<LanguageFilterConfig>\n}\n\nexport interface LanguageFilterStudioContextProcessed {\n options: Required<LanguageFilterConfigProcessed>\n}\n\nexport interface LanguageFilterStudioContextValue extends LanguageFilterStudioContextProcessed {\n selectedLanguageIds: string[]\n setSelectedLanguageIds: (ids: string[]) => void\n}\n\nexport const defaultContextValue: LanguageFilterStudioContextValue = {\n options: {\n apiVersion: '2022-11-27',\n supportedLanguages: [],\n defaultLanguages: [],\n documentTypes: [],\n filterField: defaultFilterField,\n },\n selectedLanguageIds: [],\n setSelectedLanguageIds: () => console.error('LanguageFilterStudioContext not initialized'),\n}\n\nconst LanguageFilterStudioContext =\n createContext<LanguageFilterStudioContextValue>(defaultContextValue)\n\nconst INITIAL_VALUE: Language[] = []\n\n/**\n * This is a separate Provider from the Context that wraps the document pane\n * but it used to listen to changes to the selected language IDs inside it\n * and provide them to a Studio-wide context\n */\nexport function LanguageFilterStudioProvider(\n props: LayoutProps & LanguageFilterStudioContextProps,\n): React.JSX.Element {\n const client = useClient({apiVersion: '2023-01-01'})\n const supportedLanguages = props.options.supportedLanguages\n const defaultLanguages = props.options.defaultLanguages\n const [selectedLanguageIds, setSelectedLanguageIds] = useState<string[]>([])\n const [languages$] = useState(() => {\n // We first resolve the languages from the callback or the array.\n const languagesObservable = Array.isArray(supportedLanguages)\n ? of(supportedLanguages)\n : defer(() => from(supportedLanguages(client, {}))).pipe(\n // If language resolution fails, keep the plugin operational with no selectable languages.\n catchError(() => of([])),\n )\n\n // After resolving the languages we can get the persisted languages by checking localStorage.\n return languagesObservable.pipe(\n tap((languages) => {\n const persistedLanguageIds = getPersistedLanguageIds({\n supportedLanguages: languages,\n defaultLanguages,\n })\n setSelectedLanguageIds(persistedLanguageIds)\n }),\n )\n })\n\n const languages = useObservable(languages$, INITIAL_VALUE)\n\n const options = useMemo<Required<LanguageFilterConfigProcessed>>(() => {\n return {\n ...defaultContextValue.options,\n ...props.options,\n supportedLanguages: languages,\n }\n }, [props.options, languages])\n\n const onSelectedLanguageIdsChange = useCallback((ids: string[]) => {\n setSelectedLanguageIds(ids)\n setPersistedLanguageIds(ids)\n }, [])\n\n const value = useMemo(\n () => ({options, selectedLanguageIds, setSelectedLanguageIds: onSelectedLanguageIdsChange}),\n [options, selectedLanguageIds, onSelectedLanguageIdsChange],\n )\n\n return (\n <LanguageFilterStudioContext.Provider value={value}>\n {props.renderDefault(props)}\n </LanguageFilterStudioContext.Provider>\n )\n}\n\n/**\n * Retrieves plugin options and the currently selected\n * language IDs from anywhere in the Studio\n */\nexport function useLanguageFilterStudioContext(): LanguageFilterStudioContextValue {\n return useContext(LanguageFilterStudioContext)\n}\n","import {useCallback, useMemo} from 'react'\n\nimport {getSelectableLanguages} from './getSelectableLanguages'\nimport {useLanguageFilterStudioContext} from './LanguageFilterStudioContext'\n\nconst unique = (arr: string[]) => Array.from(new Set(arr))\n\nexport function usePaneLanguages(): {\n activeLanguages: string[]\n allSelected: boolean\n selectAll: () => void\n selectNone: () => void\n toggleLanguage: (languageId: string) => void\n} {\n const {selectedLanguageIds, setSelectedLanguageIds, options} = useLanguageFilterStudioContext()\n const {defaultLanguages = []} = options\n\n const selectableLanguages = useMemo(() => getSelectableLanguages(options), [options])\n\n const updateSelectedIds = useCallback(\n (ids: string[]) => {\n setSelectedLanguageIds(unique([...defaultLanguages, ...ids]))\n },\n [defaultLanguages, setSelectedLanguageIds],\n )\n\n const selectAll = useCallback(\n () => updateSelectedIds(selectableLanguages.map((l) => l.id)),\n [updateSelectedIds, selectableLanguages],\n )\n\n const selectNone = useCallback(() => {\n updateSelectedIds(defaultLanguages)\n }, [defaultLanguages, updateSelectedIds])\n\n const toggleLanguage = useCallback(\n (languageId: string) => {\n let lang = selectedLanguageIds\n\n if (lang.includes(languageId)) {\n lang = lang.filter((l) => l !== languageId)\n } else {\n lang = unique([...lang, languageId])\n }\n\n updateSelectedIds(lang)\n },\n [updateSelectedIds, selectedLanguageIds],\n )\n\n const activeLanguages = useMemo(\n () => unique([...(defaultLanguages ?? []), ...selectedLanguageIds]),\n [defaultLanguages, selectedLanguageIds],\n )\n\n return {\n activeLanguages,\n allSelected:\n selectedLanguageIds.length === selectableLanguages.length + defaultLanguages.length,\n selectAll,\n selectNone,\n toggleLanguage,\n }\n}\n","import {\n CheckmarkCircleIcon,\n CircleIcon,\n EyeClosedIcon,\n EyeOpenIcon,\n TranslateIcon,\n} from '@sanity/icons'\nimport {\n Badge,\n Box,\n Button,\n Card,\n Flex,\n Popover,\n Stack,\n Text,\n TextInput,\n useClickOutsideEvent,\n} from '@sanity/ui'\nimport {type MouseEventHandler, useCallback, useState} from 'react'\nimport {TextWithTone} from 'sanity'\n\nimport {useLanguageFilterStudioContext} from './LanguageFilterStudioContext'\nimport {usePaneLanguages} from './usePaneLanguages'\n\nexport function LanguageFilterMenuButton(): React.JSX.Element {\n const {options} = useLanguageFilterStudioContext()\n\n const defaultLanguages = options.supportedLanguages.filter((l) =>\n options.defaultLanguages?.includes(l.id),\n )\n\n const languageOptions = options.supportedLanguages.filter(\n (l) => !options.defaultLanguages?.includes(l.id),\n )\n const [open, setOpen] = useState(false)\n const {activeLanguages, allSelected, selectAll, selectNone, toggleLanguage} = usePaneLanguages()\n const [button, setButton] = useState<HTMLElement | null>(null)\n const [popover, setPopover] = useState<HTMLElement | null>(null)\n\n const handleToggleAll: MouseEventHandler<HTMLButtonElement> = useCallback(\n (event) => {\n const checked = event.currentTarget.value === 'ALL'\n\n if (checked) {\n selectAll()\n } else {\n selectNone()\n }\n },\n [selectAll, selectNone],\n )\n\n const handleClick = useCallback(() => setOpen((o) => !o), [])\n\n const handleClickOutside = useCallback(() => setOpen(false), [])\n\n useClickOutsideEvent(\n handleClickOutside,\n useCallback(\n () => [button, popover].filter((el): el is HTMLElement => el !== null),\n [button, popover],\n ),\n )\n\n const langCount = options.supportedLanguages.length\n\n // Search filter query\n const [query, setQuery] = useState('')\n const handleQuery = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n if (event.currentTarget.value) {\n setQuery(event.currentTarget.value)\n } else {\n setQuery('')\n }\n }, [])\n\n const showSearch = langCount > 4\n\n const content = (\n <Box overflow=\"auto\" style={{maxHeight: 'calc(100vh - 200px)'}}>\n <Stack padding={1} space={1}>\n {defaultLanguages.length > 0 && (\n <>\n {defaultLanguages.map((l) => (\n <LanguageFilterOption key={l.id} id={l.id} title={l.title} selected />\n ))}\n <Card borderTop />\n </>\n )}\n\n <Button\n mode=\"bleed\"\n onClick={handleToggleAll}\n justify=\"flex-start\"\n value={allSelected ? 'NONE' : 'ALL'}\n disabled={!!query}\n >\n <Flex gap={3} align=\"center\">\n <Text size={2}>\n {allSelected ? (\n <TextWithTone tone=\"primary\">\n <EyeClosedIcon />\n </TextWithTone>\n ) : (\n <EyeOpenIcon />\n )}\n </Text>\n <Box flex={1}>\n <Text>{allSelected ? 'Hide all' : 'Show all'}</Text>\n </Box>\n </Flex>\n </Button>\n\n {showSearch ? (\n <TextInput onChange={handleQuery} value={query} placeholder=\"Filter languages\" />\n ) : (\n <Card borderTop />\n )}\n\n {languageOptions\n .filter((language) => {\n if (query) {\n return language.title.toLowerCase().includes(query.toLowerCase())\n }\n return true\n })\n .map((lang) => (\n <LanguageFilterOption\n id={lang.id}\n key={lang.id}\n onToggle={toggleLanguage}\n selected={activeLanguages.includes(lang.id)}\n title={lang.title}\n />\n ))}\n </Stack>\n </Box>\n )\n\n const buttonText =\n activeLanguages.length === langCount\n ? 'Showing all'\n : `Showing ${activeLanguages.length} / ${langCount}`\n return (\n <Popover animate content={content} open={open} portal ref={setPopover}>\n <Button\n text={buttonText}\n icon={TranslateIcon}\n mode=\"bleed\"\n onClick={handleClick}\n ref={setButton}\n selected={open}\n />\n </Popover>\n )\n}\n\nfunction LanguageFilterOption(props: {\n id: string\n selected: boolean\n title: string\n onToggle?: (id: string) => void\n}) {\n const {id, onToggle, selected, title} = props\n\n const handleChange = useCallback(() => {\n if (onToggle) {\n onToggle(id)\n }\n }, [id, onToggle])\n\n const disabled = !onToggle\n\n return (\n <Button mode=\"bleed\" onClick={handleChange} justify=\"flex-start\" disabled={disabled}>\n <Flex gap={3} align=\"center\">\n <Text size={2}>\n {selected ? (\n <TextWithTone tone={disabled ? 'default' : 'positive'}>\n <CheckmarkCircleIcon />\n </TextWithTone>\n ) : (\n <CircleIcon />\n )}\n </Text>\n <Box flex={1}>\n <Text>{title}</Text>\n </Box>\n <Badge>{id}</Badge>\n </Flex>\n </Button>\n )\n}\n","import {useMemo} from 'react'\nimport {type ObjectInputProps, type ObjectMember, useFormValue, useSchema} from 'sanity'\n\nimport {isLanguageFilterEnabled} from './filterField'\nimport {useLanguageFilterStudioContext} from './LanguageFilterStudioContext'\n\n// First check that this Object is in a schema type for which language-filter is enabled\nexport function FilteredObjectWrapper(props: ObjectInputProps) {\n const {options} = useLanguageFilterStudioContext()\n\n // oxlint-disable-next-line no-unsafe-type-assertion -- documentType is always a string for Sanity documents\n const documentType = useFormValue(['_type']) as string\n const schema = useSchema()\n const languageFilterEnabled = isLanguageFilterEnabled(schema.get(documentType), options)\n return languageFilterEnabled ? <FilteredObjectInput {...props} /> : props.renderDefault(props)\n}\n\n// Modify the object members based on selected languages in the filter\nfunction FilteredObjectInput(props: ObjectInputProps) {\n const {members: membersProp, schemaType, renderDefault, ...restProps} = props\n const {selectedLanguageIds, options} = useLanguageFilterStudioContext()\n const {filterField} = options\n const parentValue = props.value\n\n const members: ObjectMember[] = useMemo(() => {\n return membersProp\n .filter((member) => {\n return (\n (member.kind === 'field' &&\n filterField(schemaType, member, selectedLanguageIds, parentValue)) ||\n member.kind === 'fieldSet' ||\n member.kind === 'error'\n )\n })\n .map((member) => {\n if (member.kind === 'fieldSet') {\n return Object.assign({}, member, {\n fieldSet: Object.assign({}, member.fieldSet, {\n members: member.fieldSet.members.filter((fieldsetMember) => {\n return (\n fieldsetMember.kind === 'field' &&\n filterField(schemaType, fieldsetMember, selectedLanguageIds, parentValue)\n )\n }),\n }),\n })\n }\n return member\n })\n }, [schemaType, membersProp, filterField, selectedLanguageIds, parentValue])\n\n return renderDefault({...restProps, members, schemaType, renderDefault})\n}\n","import {\n definePlugin,\n type DocumentLanguageFilterComponent,\n isObjectSchemaType,\n type ObjectInputProps,\n} from 'sanity'\n\nimport {isLanguageFilterEnabled} from './filterField'\nimport {LanguageFilterMenuButton} from './LanguageFilterMenuButton'\nimport {FilteredObjectWrapper} from './LanguageFilterObjectInput'\nimport {defaultContextValue, LanguageFilterStudioProvider} from './LanguageFilterStudioContext'\nimport type {LanguageFilterConfig} from './types'\n\n/**\n * ## Usage in sanity.config.ts (or .js)\n *\n * ```\n * import {defineConfig} from 'sanity'\n * import {languageFilter} from '@sanity/language-filter'\n *\n * export const defineConfig({\n * /...\n * plugins: [\n * languageFilter({\n * supportedLanguages: [\n * {id: 'nb', title: 'Norwegian (Bokmål)'},\n * {id: 'nn', title: 'Norwegian (Nynorsk)'},\n * {id: 'en', title: 'English'},\n * {id: 'es', title: 'Spanish'},\n * {id: 'arb', title: 'Arabic'},\n * {id: 'pt', title: 'Portuguese'},\n * //...\n * ],\n * // Select Norwegian (Bokmål) by default\n * defaultLanguages: ['nb'],\n * // Only show language filter for document type `page` (schemaType.name)\n * // Can also enable via document-options: options.languageFilter: true\n * documentTypes: ['page'],\n * // default filter function shown\n * filterField: (enclosingType, field, selectedLanguageIds) =>\n * !enclosingType.name.startsWith('locale') || selectedLanguageIds.includes(field.name),\n * })\n * ]\n * })\n * ```\n */\n\nconst RenderLanguageFilter: DocumentLanguageFilterComponent = () => {\n return <LanguageFilterMenuButton />\n}\n\nexport const languageFilter: ReturnType<typeof definePlugin<LanguageFilterConfig>> =\n definePlugin<LanguageFilterConfig>((options) => {\n const pluginOptions = {\n ...defaultContextValue.options,\n ...options,\n }\n\n return {\n name: '@sanity/language-filter',\n studio: {\n components: {\n layout: (props) => LanguageFilterStudioProvider({...props, options: pluginOptions}),\n },\n },\n\n document: {\n unstable_languageFilter: (prev, {schemaType, schema}) => {\n if (isLanguageFilterEnabled(schema.get(schemaType), options)) {\n return [...prev, RenderLanguageFilter]\n }\n return prev\n },\n },\n\n form: {\n components: {\n input: (props) => {\n if (props.id !== 'root' && isObjectSchemaType(props.schemaType)) {\n // oxlint-disable-next-line no-unsafe-type-assertion -- isObjectSchemaType confirms the type\n return FilteredObjectWrapper(props as ObjectInputProps)\n }\n\n return props.renderDefault(props)\n },\n },\n },\n }\n })\n"],"names":["defaultFilterField","enclosingType","field","selectedLanguageIds","name","startsWith","includes","isLanguageFilterEnabled","schemaType","options","schemaFilter","isDocument","languageFilter","defaultEnabled","documentTypes","jsonType","getRootType","schema","type","getSelectableLanguages","supportedLanguages","defaultLanguages","filter","lang","id","storageKey","getPersistedLanguageIds","selectableLangs","map","l","selected","persistedValue","window","localStorage","getItem","parsed","JSON","parse","Array","isArray","every","item","intersection","supportedLanguageIds","language","defaultLanguageIds","unique","setPersistedLanguageIds","languageIds","setItem","stringify","array1","array2","value","values","from","Set","defaultContextValue","apiVersion","filterField","setSelectedLanguageIds","console","error","LanguageFilterStudioContext","createContext","INITIAL_VALUE","LanguageFilterStudioProvider","props","$","_c","t0","for","client","useClient","t1","Symbol","useState","t2","of","defer","pipe","catchError","_temp","tap","languages","persistedLanguageIds","languages$","languages_0","useObservable","t3","t4","ids","onSelectedLanguageIdsChange","t5","t6","renderDefault","t7","useLanguageFilterStudioContext","useContext","arr","usePaneLanguages","undefined","selectableLanguages","updateSelectedIds","selectAll","selectNone","languageId","l_0","toggleLanguage","activeLanguages","t8","length","t9","allSelected","LanguageFilterMenuButton","languageOptions","open","setOpen","button","setButton","popover","setPopover","event","currentTarget","handleToggleAll","handleClick","handleClickOutside","_temp2","useClickOutsideEvent","langCount","query","setQuery","event_0","handleQuery","showSearch","T0","Box","maxHeight","T1","Stack","t10","t11","_temp3","t12","t13","t14","t15","t16","t17","t18","t19","t20","title","toLowerCase","t21","t22","t23","t24","content","buttonText","t25","TranslateIcon","t26","l_1","el","o","LanguageFilterOption","onToggle","handleChange","disabled","FilteredObjectWrapper","documentType","useFormValue","useSchema","get","languageFilterEnabled","FilteredObjectInput","members","membersProp","restProps","parentValue","member","kind","member_0","Object","assign","fieldSet","fieldsetMember","RenderLanguageFilter","definePlugin","pluginOptions","studio","components","layout","document","unstable_languageFilter","prev","form","input","isObjectSchemaType"],"mappings":"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"}