• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2022 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 
16 #include "frameworks/bridge/declarative_frontend/jsview/js_grid_col.h"
17 
18 #include <cstdint>
19 
20 #include "base/log/ace_trace.h"
21 #include "bridge/declarative_frontend/jsview/js_view_common_def.h"
22 #include "bridge/declarative_frontend/jsview/models/grid_col_model_impl.h"
23 #include "core/components_ng/pattern/grid_col/grid_col_model_ng.h"
24 
25 namespace OHOS::Ace {
GetInstance()26 GridColModel* GridColModel::GetInstance()
27 {
28 #ifdef NG_BUILD
29     static NG::GridColModelNG instance;
30     return &instance;
31 #else
32     if (Container::IsCurrentUseNewPipeline()) {
33         static NG::GridColModelNG instance;
34         return &instance;
35     } else {
36         static Framework::GridColModelImpl instance;
37         return &instance;
38     }
39 #endif
40 }
41 } // namespace OHOS::Ace
42 namespace OHOS::Ace::Framework {
43 namespace {
44 constexpr size_t XS = 0;
45 constexpr size_t SM = 1;
46 constexpr size_t MD = 2;
47 constexpr size_t LG = 3;
48 constexpr size_t XL = 4;
49 constexpr size_t XXL = 5;
50 constexpr size_t MAX_NUMBER_BREAKPOINT = 6;
51 
InheritGridContainerSize(V2::GridContainerSize & gridContainerSize,std::optional<int32_t> (& containerSizeArray)[MAX_NUMBER_BREAKPOINT],int32_t defaultVal)52 void InheritGridContainerSize(V2::GridContainerSize& gridContainerSize,
53     std::optional<int32_t> (&containerSizeArray)[MAX_NUMBER_BREAKPOINT], int32_t defaultVal)
54 {
55     if (!containerSizeArray[0].has_value()) {
56         containerSizeArray[0] = defaultVal;
57     }
58     for (size_t i = 1; i < MAX_NUMBER_BREAKPOINT; i++) {
59         if (!containerSizeArray[i].has_value()) {
60             containerSizeArray[i] = containerSizeArray[i - 1].value();
61         }
62     }
63     gridContainerSize.xs = containerSizeArray[XS].value();
64     gridContainerSize.sm = containerSizeArray[SM].value();
65     gridContainerSize.md = containerSizeArray[MD].value();
66     gridContainerSize.lg = containerSizeArray[LG].value();
67     gridContainerSize.xl = containerSizeArray[XL].value();
68     gridContainerSize.xxl = containerSizeArray[XXL].value();
69 }
70 
ParserGridContainerSize(const JSRef<JSVal> & jsValue,int32_t defaultVal)71 V2::GridContainerSize ParserGridContainerSize(const JSRef<JSVal>& jsValue, int32_t defaultVal)
72 {
73     if (jsValue->IsNumber()) {
74         double columnNumber = 0.0;
75         JSViewAbstract::ParseJsDouble(jsValue, columnNumber);
76         auto gridContainerSize = columnNumber >= 0 ? V2::GridContainerSize(columnNumber)
77                                                    : V2::GridContainerSize(defaultVal);
78         return gridContainerSize;
79     } else if (jsValue->IsObject()) {
80         auto gridContainerSize = V2::GridContainerSize(defaultVal);
81         auto gridParam = JSRef<JSObject>::Cast(jsValue);
82         std::optional<int32_t> containerSizeArray[MAX_NUMBER_BREAKPOINT];
83         auto xs = gridParam->GetProperty("xs");
84         if (xs->IsNumber() && xs->ToNumber<int32_t>() >= 0) {
85             containerSizeArray[XS] = xs->ToNumber<int32_t>();
86         }
87         auto sm = gridParam->GetProperty("sm");
88         if (sm->IsNumber() && sm->ToNumber<int32_t>() >= 0) {
89             containerSizeArray[SM] = sm->ToNumber<int32_t>();
90         }
91         auto md = gridParam->GetProperty("md");
92         if (md->IsNumber() && md->ToNumber<int32_t>() >= 0) {
93             containerSizeArray[MD] = md->ToNumber<int32_t>();
94         }
95         auto lg = gridParam->GetProperty("lg");
96         if (lg->IsNumber() && lg->ToNumber<int32_t>() >= 0) {
97             containerSizeArray[LG] = lg->ToNumber<int32_t>();
98         }
99         auto xl = gridParam->GetProperty("xl");
100         if (xl->IsNumber() && xl->ToNumber<int32_t>() >= 0) {
101             containerSizeArray[XL] = xl->ToNumber<int32_t>();
102         }
103         auto xxl = gridParam->GetProperty("xxl");
104         if (xxl->IsNumber() && xxl->ToNumber<int32_t>() >= 0) {
105             containerSizeArray[XXL] = xxl->ToNumber<int32_t>();
106         }
107         InheritGridContainerSize(gridContainerSize, containerSizeArray, defaultVal);
108         return gridContainerSize;
109     } else {
110         return V2::GridContainerSize(defaultVal);
111     }
112 }
113 
114 } // namespace
115 
Create(const JSCallbackInfo & info)116 void JSGridCol::Create(const JSCallbackInfo& info)
117 {
118     if (info.Length() > 0 && info[0]->IsObject()) {
119         auto gridParam = JSRef<JSObject>::Cast(info[0]);
120         auto spanParam = gridParam->GetProperty("span");
121         auto offsetParam = gridParam->GetProperty("offset");
122         auto orderParam = gridParam->GetProperty("order");
123         auto span = ParserGridContainerSize(spanParam, 1);
124         auto offset = ParserGridContainerSize(offsetParam, 0);
125         auto order = ParserGridContainerSize(orderParam, 0);
126 
127         GridColModel::GetInstance()->Create(span, offset, order);
128     } else {
129         GridColModel::GetInstance()->Create();
130     }
131 }
132 
Span(const JSCallbackInfo & info)133 void JSGridCol::Span(const JSCallbackInfo& info)
134 {
135     if (info.Length() < 1) {
136         return;
137     }
138     auto span = ParserGridContainerSize(info[0], 1);
139     GridColModel::GetInstance()->SetSpan(span);
140 }
141 
Offset(const JSCallbackInfo & info)142 void JSGridCol::Offset(const JSCallbackInfo& info)
143 {
144     if (info.Length() < 1) {
145         return;
146     }
147 
148     if (info[0]->IsObject()) {
149         auto obj = JSRef<JSObject>::Cast(info[0]);
150         auto xVal = obj->GetProperty("x");
151         auto yVal = obj->GetProperty("y");
152         if (!xVal->IsUndefined() || !yVal->IsUndefined()) {
153             JSViewAbstract::JsOffset(info);
154             return;
155         }
156     }
157 
158     auto offset = ParserGridContainerSize(info[0], 0);
159     GridColModel::GetInstance()->SetOffset(offset);
160 }
161 
Order(const JSCallbackInfo & info)162 void JSGridCol::Order(const JSCallbackInfo& info)
163 {
164     if (info.Length() < 1) {
165         return;
166     }
167     auto order = ParserGridContainerSize(info[0], 0);
168     GridColModel::GetInstance()->SetOrder(order);
169 }
170 
JSBind(BindingTarget globalObj)171 void JSGridCol::JSBind(BindingTarget globalObj)
172 {
173     JSClass<JSGridCol>::Declare("GridCol");
174     JSClass<JSGridCol>::StaticMethod("create", &JSGridCol::Create, MethodOptions::NONE);
175     JSClass<JSGridCol>::StaticMethod("span", &JSGridCol::Span, MethodOptions::NONE);
176     JSClass<JSGridCol>::StaticMethod("offset", &JSGridCol::Offset, MethodOptions::NONE);
177     JSClass<JSGridCol>::StaticMethod("gridColOffset", &JSGridCol::Offset, MethodOptions::NONE);
178     JSClass<JSGridCol>::StaticMethod("order", &JSGridCol::Order, MethodOptions::NONE);
179     JSClass<JSGridCol>::StaticMethod("onDetach", &JSInteractableView::JsOnDetach);
180     JSClass<JSGridCol>::StaticMethod("onDisAppear", &JSInteractableView::JsOnDisAppear);
181     JSClass<JSGridCol>::StaticMethod("onAttach", &JSInteractableView::JsOnAttach);
182     JSClass<JSGridCol>::StaticMethod("onAppear", &JSInteractableView::JsOnAppear);
183     JSClass<JSGridCol>::StaticMethod("onTouch", &JSInteractableView::JsOnTouch);
184     JSClass<JSGridCol>::InheritAndBind<JSContainerBase>(globalObj);
185 }
186 
187 } // namespace OHOS::Ace::Framework
188