1/*
2 * Copyright (c) 2023-2023 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 *     http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16const KeyCode = requireNapi('multimodalInput.keyCode').KeyCode;
17export var EditableLeftIconType;
18! function(e) {
19  e[e.Back = 0] = "Back";
20  e[e.Cancel = 1] = "Cancel"
21}(EditableLeftIconType || (EditableLeftIconType = {}));
22const PUBLIC_CANCEL = "";
23const PUBLIC_OK = "";
24const PUBLIC_BACK = "";
25export class EditableTitleBar extends ViewPU {
26  constructor(e, t, A, i = -1) {
27    super(e, A, i);
28    this.leftIconStyle = void 0;
29    this.title = void 0;
30    this.menuItems = void 0;
31    this.onSave = void 0;
32    this.onCancel = void 0;
33    this.__titleMaxWidth = new ObservedPropertySimplePU(0, this, "titleMaxWidth");
34    this.setInitiallyProvidedValue(t)
35  }
36  setInitiallyProvidedValue(e) {
37    void 0 !== e.leftIconStyle && (this.leftIconStyle = e.leftIconStyle);
38    void 0 !== e.title && (this.title = e.title);
39    void 0 !== e.menuItems && (this.menuItems = e.menuItems);
40    void 0 !== e.onSave && (this.onSave = e.onSave);
41    void 0 !== e.onCancel && (this.onCancel = e.onCancel);
42    void 0 !== e.titleMaxWidth && (this.titleMaxWidth = e.titleMaxWidth)
43  }
44  updateStateVars(e) {}
45  purgeVariableDependenciesOnElmtId(e) {
46    this.__titleMaxWidth.purgeDependencyOnElmtId(e)
47  }
48  aboutToBeDeleted() {
49    this.__titleMaxWidth.aboutToBeDeleted();
50    SubscriberManager.Get().delete(this.id__());
51    this.aboutToBeDeletedInternal()
52  }
53  get titleMaxWidth() {
54    return this.__titleMaxWidth.get()
55  }
56  set titleMaxWidth(e) {
57    this.__titleMaxWidth.set(e)
58  }
59  initialRender() {
60    this.observeComponentCreation(((e, t) => {
61      ViewStackProcessor.StartGetAccessRecordingFor(e);
62      Flex.create({
63        justifyContent: FlexAlign.SpaceBetween,
64        alignItems: ItemAlign.Stretch
65      });
66      Flex.width("100%");
67      Flex.height(EditableTitleBar.totalHeight);
68      Flex.backgroundColor({
69        id: -1,
70        type: 10001,
71        params: ["sys.color.ohos_id_color_background"],
72        bundleName: "",
73        moduleName: ""
74      });
75      Flex.onAreaChange(((e, t) => {
76        let A = Number(t.width);
77        A = A - EditableTitleBar.leftPadding - EditableTitleBar.rightPadding - EditableTitleBar.titlePadding;
78        A = A - ImageMenuItem.imageHotZoneWidth - ImageMenuItem.imageHotZoneWidth;
79        void 0 !== this.menuItems ? this.menuItems.length > EditableTitleBar.maxCountOfExtraItems ? this.titleMaxWidth = A - ImageMenuItem.imageHotZoneWidth * EditableTitleBar.maxCountOfExtraItems : this.titleMaxWidth = A - ImageMenuItem.imageHotZoneWidth * this.menuItems.length : this.titleMaxWidth = A
80      }));
81      t || Flex.pop();
82      ViewStackProcessor.StopGetAccessRecording()
83    }));
84    this.observeComponentCreation(((e, t) => {
85      ViewStackProcessor.StartGetAccessRecordingFor(e);
86      Row.create();
87      Row.margin({
88        left: {
89          id: -1,
90          type: 10002,
91          params: ["sys.float.ohos_id_default_padding_start"],
92          bundleName: "",
93          moduleName: ""
94        }
95      });
96      t || Row.pop();
97      ViewStackProcessor.StopGetAccessRecording()
98    }));
99    this.observeComponentCreation(((e, t) => {
100      ViewStackProcessor.StartGetAccessRecordingFor(e);
101      If.create();
102      this.leftIconStyle == EditableLeftIconType.Back ? this.ifElseBranchUpdateFunction(0, (() => {
103        this.observeComponentCreation(((e, t) => {
104          ViewStackProcessor.StartGetAccessRecordingFor(e);
105          Navigator.create();
106          t || Navigator.pop();
107          ViewStackProcessor.StopGetAccessRecording()
108        }));
109        this.observeComponentCreation(((e, t) => {
110          ViewStackProcessor.StartGetAccessRecordingFor(e);
111          t ? ViewPU.create(new ImageMenuItem(this, {
112            item: {
113              value: PUBLIC_BACK,
114              isEnabled: !0
115            }
116          }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
117          ViewStackProcessor.StopGetAccessRecording()
118        }));
119        Navigator.pop()
120      })) : this.ifElseBranchUpdateFunction(1, (() => {
121        this.observeComponentCreation(((e, t) => {
122          ViewStackProcessor.StartGetAccessRecordingFor(e);
123          t ? ViewPU.create(new ImageMenuItem(this, {
124            item: {
125              value: PUBLIC_CANCEL,
126              isEnabled: !0,
127              action: () => this.onCancel && this.onCancel()
128            }
129          }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
130          ViewStackProcessor.StopGetAccessRecording()
131        }))
132      }));
133      t || If.pop();
134      ViewStackProcessor.StopGetAccessRecording()
135    }));
136    If.pop();
137    this.observeComponentCreation(((e, t) => {
138      ViewStackProcessor.StartGetAccessRecordingFor(e);
139      Column.create();
140      Column.justifyContent(FlexAlign.Start);
141      Column.alignItems(HorizontalAlign.Start);
142      Column.constraintSize({
143        maxWidth: this.titleMaxWidth
144      });
145      t || Column.pop();
146      ViewStackProcessor.StopGetAccessRecording()
147    }));
148    this.observeComponentCreation(((e, t) => {
149      ViewStackProcessor.StartGetAccessRecordingFor(e);
150      Text.create(this.title);
151      Text.fontWeight(FontWeight.Medium);
152      Text.fontSize({
153        id: -1,
154        type: 10002,
155        params: ["sys.float.ohos_id_text_size_headline8"],
156        bundleName: "",
157        moduleName: ""
158      });
159      Text.fontColor({
160        id: -1,
161        type: 10001,
162        params: ["sys.color.ohos_id_color_titlebar_text"],
163        bundleName: "",
164        moduleName: ""
165      });
166      Text.maxLines(1);
167      Text.textOverflow({
168        overflow: TextOverflow.Ellipsis
169      });
170      Text.constraintSize({
171        maxWidth: this.titleMaxWidth
172      });
173      t || Text.pop();
174      ViewStackProcessor.StopGetAccessRecording()
175    }));
176    Text.pop();
177    Column.pop();
178    Row.pop();
179    this.observeComponentCreation(((e, t) => {
180      ViewStackProcessor.StartGetAccessRecordingFor(e);
181      t ? ViewPU.create(new EditableTitleBarMenuSection(this, {
182        menuItems: this.menuItems,
183        onSave: this.onSave
184      }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
185      ViewStackProcessor.StopGetAccessRecording()
186    }));
187    Flex.pop()
188  }
189  rerender() {
190    this.updateDirtyElements()
191  }
192}
193EditableTitleBar.maxCountOfExtraItems = 2;
194EditableTitleBar.totalHeight = 56;
195EditableTitleBar.leftPadding = 12;
196EditableTitleBar.rightPadding = 12;
197EditableTitleBar.titlePadding = 16;
198class EditableTitleBarMenuSection extends ViewPU {
199  constructor(e, t, A, i = -1) {
200    super(e, A, i);
201    this.menuItems = void 0;
202    this.onSave = void 0;
203    this.setInitiallyProvidedValue(t)
204  }
205  setInitiallyProvidedValue(e) {
206    void 0 !== e.menuItems && (this.menuItems = e.menuItems);
207    void 0 !== e.onSave && (this.onSave = e.onSave)
208  }
209  updateStateVars(e) {}
210  purgeVariableDependenciesOnElmtId(e) {}
211  aboutToBeDeleted() {
212    SubscriberManager.Get().delete(this.id__());
213    this.aboutToBeDeletedInternal()
214  }
215  initialRender() {
216    this.observeComponentCreation(((e, t) => {
217      ViewStackProcessor.StartGetAccessRecordingFor(e);
218      Column.create();
219      Column.margin({
220        left: {
221          id: -1,
222          type: 10002,
223          params: ["sys.float.ohos_id_elements_margin_vertical_l"],
224          bundleName: "",
225          moduleName: ""
226        },
227        right: {
228          id: -1,
229          type: 10002,
230          params: ["sys.float.ohos_id_default_padding_end"],
231          bundleName: "",
232          moduleName: ""
233        }
234      });
235      Column.justifyContent(FlexAlign.Center);
236      t || Column.pop();
237      ViewStackProcessor.StopGetAccessRecording()
238    }));
239    this.observeComponentCreation(((e, t) => {
240      ViewStackProcessor.StartGetAccessRecordingFor(e);
241      Row.create();
242      t || Row.pop();
243      ViewStackProcessor.StopGetAccessRecording()
244    }));
245    this.observeComponentCreation(((e, t) => {
246      ViewStackProcessor.StartGetAccessRecordingFor(e);
247      If.create();
248      void 0 !== this.menuItems && this.menuItems.length > 0 ? this.ifElseBranchUpdateFunction(0, (() => {
249        this.observeComponentCreation(((e, t) => {
250          ViewStackProcessor.StartGetAccessRecordingFor(e);
251          ForEach.create();
252          this.forEachUpdateFunction(e, this.menuItems.slice(0, EditableTitleBar.maxCountOfExtraItems), (e => {
253            const t = e;
254            this.observeComponentCreation(((e, A) => {
255              ViewStackProcessor.StartGetAccessRecordingFor(e);
256              A ? ViewPU.create(new ImageMenuItem(this, {
257                item: t
258              }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
259              ViewStackProcessor.StopGetAccessRecording()
260            }))
261          }));
262          t || ForEach.pop();
263          ViewStackProcessor.StopGetAccessRecording()
264        }));
265        ForEach.pop()
266      })) : If.branchId(1);
267      t || If.pop();
268      ViewStackProcessor.StopGetAccessRecording()
269    }));
270    If.pop();
271    this.observeComponentCreation(((e, t) => {
272      ViewStackProcessor.StartGetAccessRecordingFor(e);
273      t ? ViewPU.create(new ImageMenuItem(this, {
274        item: {
275          value: PUBLIC_OK,
276          isEnabled: !0,
277          action: () => this.onSave && this.onSave()
278        }
279      }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
280      ViewStackProcessor.StopGetAccessRecording()
281    }));
282    Row.pop();
283    Column.pop()
284  }
285  rerender() {
286    this.updateDirtyElements()
287  }
288}
289class ImageMenuItem extends ViewPU {
290  constructor(e, t, A, i = -1) {
291    super(e, A, i);
292    this.item = void 0;
293    this.__isOnFocus = new ObservedPropertySimplePU(!1, this, "isOnFocus");
294    this.__isOnHover = new ObservedPropertySimplePU(!1, this, "isOnHover");
295    this.__isOnClick = new ObservedPropertySimplePU(!1, this, "isOnClick");
296    this.setInitiallyProvidedValue(t)
297  }
298  setInitiallyProvidedValue(e) {
299    void 0 !== e.item && (this.item = e.item);
300    void 0 !== e.isOnFocus && (this.isOnFocus = e.isOnFocus);
301    void 0 !== e.isOnHover && (this.isOnHover = e.isOnHover);
302    void 0 !== e.isOnClick && (this.isOnClick = e.isOnClick)
303  }
304  updateStateVars(e) {}
305  purgeVariableDependenciesOnElmtId(e) {
306    this.__isOnFocus.purgeDependencyOnElmtId(e);
307    this.__isOnHover.purgeDependencyOnElmtId(e);
308    this.__isOnClick.purgeDependencyOnElmtId(e)
309  }
310  aboutToBeDeleted() {
311    this.__isOnFocus.aboutToBeDeleted();
312    this.__isOnHover.aboutToBeDeleted();
313    this.__isOnClick.aboutToBeDeleted();
314    SubscriberManager.Get().delete(this.id__());
315    this.aboutToBeDeletedInternal()
316  }
317  get isOnFocus() {
318    return this.__isOnFocus.get()
319  }
320  set isOnFocus(e) {
321    this.__isOnFocus.set(e)
322  }
323  get isOnHover() {
324    return this.__isOnHover.get()
325  }
326  set isOnHover(e) {
327    this.__isOnHover.set(e)
328  }
329  get isOnClick() {
330    return this.__isOnClick.get()
331  }
332  set isOnClick(e) {
333    this.__isOnClick.set(e)
334  }
335  getFgColor() {
336    return this.isOnClick ? {
337      id: -1,
338      type: 10001,
339      params: ["sys.color.ohos_id_color_titlebar_icon_pressed"],
340      bundleName: "",
341      moduleName: ""
342    } : {
343      id: -1,
344      type: 10001,
345      params: ["sys.color.ohos_id_color_titlebar_icon"],
346      bundleName: "",
347      moduleName: ""
348    }
349  }
350  getBgColor() {
351    return this.isOnClick ? {
352      id: -1,
353      type: 10001,
354      params: ["sys.color.ohos_id_color_click_effect"],
355      bundleName: "",
356      moduleName: ""
357    } : this.isOnHover ? {
358      id: -1,
359      type: 10001,
360      params: ["sys.color.ohos_id_color_hover"],
361      bundleName: "",
362      moduleName: ""
363    } : Color.Transparent
364  }
365  initialRender() {
366    this.observeComponentCreation(((e, t) => {
367      ViewStackProcessor.StartGetAccessRecordingFor(e);
368      Row.create();
369      Row.width(ImageMenuItem.imageHotZoneWidth);
370      Row.height(ImageMenuItem.imageHotZoneWidth);
371      Row.borderRadius(ImageMenuItem.buttonBorderRadius);
372      Row.foregroundColor(this.getFgColor());
373      Row.backgroundColor(this.getBgColor());
374      Row.justifyContent(FlexAlign.Center);
375      Row.opacity(this.item.isEnabled ? 1 : ImageMenuItem.disabledImageOpacity);
376      Row.border(this.isOnFocus ? {
377        width: ImageMenuItem.focusBorderWidth,
378        color: {
379          id: -1,
380          type: 10001,
381          params: ["sys.color.ohos_id_color_emphasize"],
382          bundleName: "",
383          moduleName: ""
384        },
385        style: BorderStyle.Solid
386      } : {
387        width: 0
388      });
389      Row.onFocus((() => {
390        this.item.isEnabled && (this.isOnFocus = !0)
391      }));
392      Row.onBlur((() => this.isOnFocus = !1));
393      Row.onHover((e => {
394        this.item.isEnabled && (this.isOnHover = e)
395      }));
396      Row.onKeyEvent((e => {
397        if (this.item.isEnabled && (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE)) {
398          e.type === KeyType.Down && (this.isOnClick = !0);
399          e.type === KeyType.Up && (this.isOnClick = !1)
400        }
401      }));
402      Row.onTouch((e => {
403        if (this.item.isEnabled) {
404          e.type === TouchType.Down && (this.isOnClick = !0);
405          e.type === TouchType.Up && (this.isOnClick = !1)
406        }
407      }));
408      Row.onClick((() => this.item.isEnabled && this.item.action && this.item.action()));
409      t || Row.pop();
410      ViewStackProcessor.StopGetAccessRecording()
411    }));
412    this.observeComponentCreation(((e, t) => {
413      ViewStackProcessor.StartGetAccessRecordingFor(e);
414      Image.create(this.item.value);
415      Image.width(ImageMenuItem.imageSize);
416      Image.height(ImageMenuItem.imageSize);
417      Image.focusable(this.item.isEnabled);
418      t || Image.pop();
419      ViewStackProcessor.StopGetAccessRecording()
420    }));
421    Row.pop()
422  }
423  rerender() {
424    this.updateDirtyElements()
425  }
426}
427ImageMenuItem.imageSize = 24;
428ImageMenuItem.imageHotZoneWidth = 48;
429ImageMenuItem.buttonBorderRadius = 8;
430ImageMenuItem.focusBorderWidth = 2;
431ImageMenuItem.disabledImageOpacity = .4;
432export default {
433  EditableLeftIconType: EditableLeftIconType,
434  EditableTitleBar: EditableTitleBar
435};