• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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.__backActive = new ObservedPropertySimplePU(!1, this, "backActive");
35    this.setInitiallyProvidedValue(t)
36  }
37  setInitiallyProvidedValue(e) {
38    void 0 !== e.leftIconStyle && (this.leftIconStyle = e.leftIconStyle);
39    void 0 !== e.title && (this.title = e.title);
40    void 0 !== e.menuItems && (this.menuItems = e.menuItems);
41    void 0 !== e.onSave && (this.onSave = e.onSave);
42    void 0 !== e.onCancel && (this.onCancel = e.onCancel);
43    void 0 !== e.titleMaxWidth && (this.titleMaxWidth = e.titleMaxWidth);
44    void 0 !== e.backActive && (this.backActive = e.backActive)
45  }
46  updateStateVars(e) {}
47  purgeVariableDependenciesOnElmtId(e) {
48    this.__titleMaxWidth.purgeDependencyOnElmtId(e);
49    this.__backActive.purgeDependencyOnElmtId(e)
50  }
51  aboutToBeDeleted() {
52    this.__titleMaxWidth.aboutToBeDeleted();
53    this.__backActive.aboutToBeDeleted();
54    SubscriberManager.Get().delete(this.id__());
55    this.aboutToBeDeletedInternal()
56  }
57  get titleMaxWidth() {
58    return this.__titleMaxWidth.get()
59  }
60  set titleMaxWidth(e) {
61    this.__titleMaxWidth.set(e)
62  }
63  get backActive() {
64    return this.__backActive.get()
65  }
66  set backActive(e) {
67    this.__backActive.set(e)
68  }
69  initialRender() {
70    this.observeComponentCreation(((e, t) => {
71      ViewStackProcessor.StartGetAccessRecordingFor(e);
72      Flex.create({
73        justifyContent: FlexAlign.SpaceBetween,
74        alignItems: ItemAlign.Stretch
75      });
76      Flex.width("100%");
77      Flex.height(EditableTitleBar.totalHeight);
78      Flex.backgroundColor({
79        id: -1,
80        type: 10001,
81        params: ["sys.color.ohos_id_color_background"],
82        bundleName: "",
83        moduleName: ""
84      });
85      Flex.onAreaChange(((e, t) => {
86        let A = Number(t.width);
87        A = A - EditableTitleBar.leftPadding - EditableTitleBar.rightPadding - EditableTitleBar.titlePadding;
88        A = A - ImageMenuItem.imageHotZoneWidth - ImageMenuItem.imageHotZoneWidth;
89        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
90      }));
91      t || Flex.pop();
92      ViewStackProcessor.StopGetAccessRecording()
93    }));
94    this.observeComponentCreation(((e, t) => {
95      ViewStackProcessor.StartGetAccessRecordingFor(e);
96      Row.create();
97      Row.margin({
98        left: {
99          id: -1,
100          type: 10002,
101          params: ["sys.float.ohos_id_default_padding_start"],
102          bundleName: "",
103          moduleName: ""
104        }
105      });
106      t || Row.pop();
107      ViewStackProcessor.StopGetAccessRecording()
108    }));
109    this.observeComponentCreation(((e, t) => {
110      ViewStackProcessor.StartGetAccessRecordingFor(e);
111      If.create();
112      this.leftIconStyle == EditableLeftIconType.Back ? this.ifElseBranchUpdateFunction(0, (() => {
113        this.observeComponentCreation(((e, t) => {
114          ViewStackProcessor.StartGetAccessRecordingFor(e);
115          Navigator.create();
116          Navigator.active(this.backActive);
117          t || Navigator.pop();
118          ViewStackProcessor.StopGetAccessRecording()
119        }));
120        Navigator.pop();
121        this.observeComponentCreation(((e, t) => {
122          ViewStackProcessor.StartGetAccessRecordingFor(e);
123          t ? ViewPU.create(new ImageMenuItem(this, {
124            item: {
125              value: PUBLIC_BACK,
126              isEnabled: !0,
127              action: () => this.backActive = !0
128            }
129          }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
130          ViewStackProcessor.StopGetAccessRecording()
131        }))
132      })) : this.ifElseBranchUpdateFunction(1, (() => {
133        this.observeComponentCreation(((e, t) => {
134          ViewStackProcessor.StartGetAccessRecordingFor(e);
135          t ? ViewPU.create(new ImageMenuItem(this, {
136            item: {
137              value: PUBLIC_CANCEL,
138              isEnabled: !0,
139              action: () => this.onCancel && this.onCancel()
140            }
141          }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
142          ViewStackProcessor.StopGetAccessRecording()
143        }))
144      }));
145      t || If.pop();
146      ViewStackProcessor.StopGetAccessRecording()
147    }));
148    If.pop();
149    this.observeComponentCreation(((e, t) => {
150      ViewStackProcessor.StartGetAccessRecordingFor(e);
151      Column.create();
152      Column.justifyContent(FlexAlign.Start);
153      Column.alignItems(HorizontalAlign.Start);
154      Column.constraintSize({
155        maxWidth: this.titleMaxWidth
156      });
157      t || Column.pop();
158      ViewStackProcessor.StopGetAccessRecording()
159    }));
160    this.observeComponentCreation(((e, t) => {
161      ViewStackProcessor.StartGetAccessRecordingFor(e);
162      Text.create(this.title);
163      Text.fontWeight(FontWeight.Medium);
164      Text.fontSize({
165        id: -1,
166        type: 10002,
167        params: ["sys.float.ohos_id_text_size_headline8"],
168        bundleName: "",
169        moduleName: ""
170      });
171      Text.fontColor({
172        id: -1,
173        type: 10001,
174        params: ["sys.color.ohos_id_color_titlebar_text"],
175        bundleName: "",
176        moduleName: ""
177      });
178      Text.maxLines(1);
179      Text.textOverflow({
180        overflow: TextOverflow.Ellipsis
181      });
182      Text.constraintSize({
183        maxWidth: this.titleMaxWidth
184      });
185      t || Text.pop();
186      ViewStackProcessor.StopGetAccessRecording()
187    }));
188    Text.pop();
189    Column.pop();
190    Row.pop();
191    this.observeComponentCreation(((e, t) => {
192      ViewStackProcessor.StartGetAccessRecordingFor(e);
193      t ? ViewPU.create(new EditableTitleBarMenuSection(this, {
194        menuItems: this.menuItems,
195        onSave: this.onSave
196      }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
197      ViewStackProcessor.StopGetAccessRecording()
198    }));
199    Flex.pop()
200  }
201  rerender() {
202    this.updateDirtyElements()
203  }
204}
205EditableTitleBar.maxCountOfExtraItems = 2;
206EditableTitleBar.totalHeight = 56;
207EditableTitleBar.leftPadding = 12;
208EditableTitleBar.rightPadding = 12;
209EditableTitleBar.titlePadding = 16;
210class EditableTitleBarMenuSection extends ViewPU {
211  constructor(e, t, A, i = -1) {
212    super(e, A, i);
213    this.menuItems = void 0;
214    this.onSave = void 0;
215    this.setInitiallyProvidedValue(t)
216  }
217  setInitiallyProvidedValue(e) {
218    void 0 !== e.menuItems && (this.menuItems = e.menuItems);
219    void 0 !== e.onSave && (this.onSave = e.onSave)
220  }
221  updateStateVars(e) {}
222  purgeVariableDependenciesOnElmtId(e) {}
223  aboutToBeDeleted() {
224    SubscriberManager.Get().delete(this.id__());
225    this.aboutToBeDeletedInternal()
226  }
227  initialRender() {
228    this.observeComponentCreation(((e, t) => {
229      ViewStackProcessor.StartGetAccessRecordingFor(e);
230      Column.create();
231      Column.margin({
232        left: {
233          id: -1,
234          type: 10002,
235          params: ["sys.float.ohos_id_elements_margin_vertical_l"],
236          bundleName: "",
237          moduleName: ""
238        },
239        right: {
240          id: -1,
241          type: 10002,
242          params: ["sys.float.ohos_id_default_padding_end"],
243          bundleName: "",
244          moduleName: ""
245        }
246      });
247      Column.justifyContent(FlexAlign.Center);
248      t || Column.pop();
249      ViewStackProcessor.StopGetAccessRecording()
250    }));
251    this.observeComponentCreation(((e, t) => {
252      ViewStackProcessor.StartGetAccessRecordingFor(e);
253      Row.create();
254      t || Row.pop();
255      ViewStackProcessor.StopGetAccessRecording()
256    }));
257    this.observeComponentCreation(((e, t) => {
258      ViewStackProcessor.StartGetAccessRecordingFor(e);
259      If.create();
260      void 0 !== this.menuItems && this.menuItems.length > 0 ? this.ifElseBranchUpdateFunction(0, (() => {
261        this.observeComponentCreation(((e, t) => {
262          ViewStackProcessor.StartGetAccessRecordingFor(e);
263          ForEach.create();
264          this.forEachUpdateFunction(e, this.menuItems.slice(0, EditableTitleBar.maxCountOfExtraItems), (e => {
265            const t = e;
266            this.observeComponentCreation(((e, A) => {
267              ViewStackProcessor.StartGetAccessRecordingFor(e);
268              A ? ViewPU.create(new ImageMenuItem(this, {
269                item: t
270              }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
271              ViewStackProcessor.StopGetAccessRecording()
272            }))
273          }));
274          t || ForEach.pop();
275          ViewStackProcessor.StopGetAccessRecording()
276        }));
277        ForEach.pop()
278      })) : If.branchId(1);
279      t || If.pop();
280      ViewStackProcessor.StopGetAccessRecording()
281    }));
282    If.pop();
283    this.observeComponentCreation(((e, t) => {
284      ViewStackProcessor.StartGetAccessRecordingFor(e);
285      t ? ViewPU.create(new ImageMenuItem(this, {
286        item: {
287          value: PUBLIC_OK,
288          isEnabled: !0,
289          action: () => this.onSave && this.onSave()
290        }
291      }, void 0, e)) : this.updateStateVarsOfChildByElmtId(e, {});
292      ViewStackProcessor.StopGetAccessRecording()
293    }));
294    Row.pop();
295    Column.pop()
296  }
297  rerender() {
298    this.updateDirtyElements()
299  }
300}
301class ImageMenuItem extends ViewPU {
302  constructor(e, t, A, i = -1) {
303    super(e, A, i);
304    this.item = void 0;
305    this.__isOnFocus = new ObservedPropertySimplePU(!1, this, "isOnFocus");
306    this.__isOnHover = new ObservedPropertySimplePU(!1, this, "isOnHover");
307    this.__isOnClick = new ObservedPropertySimplePU(!1, this, "isOnClick");
308    this.setInitiallyProvidedValue(t)
309  }
310  setInitiallyProvidedValue(e) {
311    void 0 !== e.item && (this.item = e.item);
312    void 0 !== e.isOnFocus && (this.isOnFocus = e.isOnFocus);
313    void 0 !== e.isOnHover && (this.isOnHover = e.isOnHover);
314    void 0 !== e.isOnClick && (this.isOnClick = e.isOnClick)
315  }
316  updateStateVars(e) {}
317  purgeVariableDependenciesOnElmtId(e) {
318    this.__isOnFocus.purgeDependencyOnElmtId(e);
319    this.__isOnHover.purgeDependencyOnElmtId(e);
320    this.__isOnClick.purgeDependencyOnElmtId(e)
321  }
322  aboutToBeDeleted() {
323    this.__isOnFocus.aboutToBeDeleted();
324    this.__isOnHover.aboutToBeDeleted();
325    this.__isOnClick.aboutToBeDeleted();
326    SubscriberManager.Get().delete(this.id__());
327    this.aboutToBeDeletedInternal()
328  }
329  get isOnFocus() {
330    return this.__isOnFocus.get()
331  }
332  set isOnFocus(e) {
333    this.__isOnFocus.set(e)
334  }
335  get isOnHover() {
336    return this.__isOnHover.get()
337  }
338  set isOnHover(e) {
339    this.__isOnHover.set(e)
340  }
341  get isOnClick() {
342    return this.__isOnClick.get()
343  }
344  set isOnClick(e) {
345    this.__isOnClick.set(e)
346  }
347  getFgColor() {
348    return this.isOnClick ? {
349      id: -1,
350      type: 10001,
351      params: ["sys.color.ohos_id_color_titlebar_icon_pressed"],
352      bundleName: "",
353      moduleName: ""
354    } : {
355      id: -1,
356      type: 10001,
357      params: ["sys.color.ohos_id_color_titlebar_icon"],
358      bundleName: "",
359      moduleName: ""
360    }
361  }
362  getBgColor() {
363    return this.isOnClick ? {
364      id: -1,
365      type: 10001,
366      params: ["sys.color.ohos_id_color_click_effect"],
367      bundleName: "",
368      moduleName: ""
369    } : this.isOnHover ? {
370      id: -1,
371      type: 10001,
372      params: ["sys.color.ohos_id_color_hover"],
373      bundleName: "",
374      moduleName: ""
375    } : Color.Transparent
376  }
377  initialRender() {
378    this.observeComponentCreation(((e, t) => {
379      ViewStackProcessor.StartGetAccessRecordingFor(e);
380      Row.create();
381      Row.width(ImageMenuItem.imageHotZoneWidth);
382      Row.height(ImageMenuItem.imageHotZoneWidth);
383      Row.borderRadius(ImageMenuItem.buttonBorderRadius);
384      Row.foregroundColor(this.getFgColor());
385      Row.backgroundColor(this.getBgColor());
386      Row.justifyContent(FlexAlign.Center);
387      Row.opacity(this.item.isEnabled ? 1 : ImageMenuItem.disabledImageOpacity);
388      ViewStackProcessor.visualState("focused");
389      Row.border({
390        radius: {
391          id: -1,
392          type: 10002,
393          params: ["sys.float.ohos_id_corner_radius_clicked"],
394          bundleName: "",
395          moduleName: ""
396        },
397        width: ImageMenuItem.focusBorderWidth,
398        color: {
399          id: -1,
400          type: 10001,
401          params: ["sys.color.ohos_id_color_focused_outline"],
402          bundleName: "",
403          moduleName: ""
404        },
405        style: BorderStyle.Solid
406      });
407      ViewStackProcessor.visualState("normal");
408      Row.border({
409        radius: {
410          id: -1,
411          type: 10002,
412          params: ["sys.float.ohos_id_corner_radius_clicked"],
413          bundleName: "",
414          moduleName: ""
415        },
416        width: 0
417      });
418      ViewStackProcessor.visualState();
419      Row.onFocus((() => {
420        this.item.isEnabled && (this.isOnFocus = !0)
421      }));
422      Row.onBlur((() => this.isOnFocus = !1));
423      Row.onHover((e => {
424        this.item.isEnabled && (this.isOnHover = e)
425      }));
426      Row.onKeyEvent((e => {
427        if (this.item.isEnabled && (e.keyCode === KeyCode.KEYCODE_ENTER || e.keyCode === KeyCode.KEYCODE_SPACE)) {
428          e.type === KeyType.Down && (this.isOnClick = !0);
429          e.type === KeyType.Up && (this.isOnClick = !1)
430        }
431      }));
432      Row.onTouch((e => {
433        if (this.item.isEnabled) {
434          e.type === TouchType.Down && (this.isOnClick = !0);
435          e.type === TouchType.Up && (this.isOnClick = !1)
436        }
437      }));
438      Row.onClick((() => this.item.isEnabled && this.item.action && this.item.action()));
439      t || Row.pop();
440      ViewStackProcessor.StopGetAccessRecording()
441    }));
442    this.observeComponentCreation(((e, t) => {
443      ViewStackProcessor.StartGetAccessRecordingFor(e);
444      Image.create(this.item.value);
445      Image.width(ImageMenuItem.imageSize);
446      Image.height(ImageMenuItem.imageSize);
447      Image.focusable(this.item.isEnabled);
448      t || Image.pop();
449      ViewStackProcessor.StopGetAccessRecording()
450    }));
451    Row.pop()
452  }
453  rerender() {
454    this.updateDirtyElements()
455  }
456}
457ImageMenuItem.imageSize = 24;
458ImageMenuItem.imageHotZoneWidth = 48;
459ImageMenuItem.buttonBorderRadius = 8;
460ImageMenuItem.focusBorderWidth = 2;
461ImageMenuItem.disabledImageOpacity = .4;
462export default {
463  EditableLeftIconType: EditableLeftIconType,
464  EditableTitleBar: EditableTitleBar
465};