/* * Copyright (c) 2021 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "frameworks/bridge/declarative_frontend/jsview/js_toggle.h" #include #include #include "base/log/ace_scoring_log.h" #include "bridge/declarative_frontend/jsview/js_view_abstract.h" #include "bridge/declarative_frontend/jsview/models/toggle_model_impl.h" #include "core/common/container.h" #include "core/components/common/properties/color.h" #include "core/components_ng/pattern/button/toggle_button_model_ng.h" #include "core/components_ng/pattern/toggle/toggle_model_ng.h" namespace OHOS::Ace { std::unique_ptr ToggleModel::instance_ = nullptr; ToggleModel* ToggleModel::GetInstance() { if (!instance_) { #ifdef NG_BUILD instance_.reset(new NG::ToggleModelNG()); #else if (Container::IsCurrentUseNewPipeline()) { instance_.reset(new NG::ToggleModelNG()); } else { instance_.reset(new Framework::ToggleModelImpl()); } #endif } return instance_.get(); } } // namespace OHOS::Ace namespace OHOS::Ace::Framework { void JSToggle::JSBind(BindingTarget globalObj) { JSClass::Declare("Toggle"); JSClass::StaticMethod("create", &JSToggle::Create); JSClass::StaticMethod("onChange", &JSToggle::OnChange); JSClass::StaticMethod("selectedColor", &JSToggle::SelectedColor); JSClass::StaticMethod("width", &JSToggle::JsWidth); JSClass::StaticMethod("height", &JSToggle::JsHeight); JSClass::StaticMethod("size", &JSToggle::JsSize); JSClass::StaticMethod("padding", &JSToggle::JsPadding); JSClass::StaticMethod("switchPointColor", &JSToggle::SwitchPointColor); JSClass::StaticMethod("backgroundColor", &JSToggle::SetBackgroundColor); JSClass::StaticMethod("onTouch", &JSInteractableView::JsOnTouch); JSClass::StaticMethod("onClick", &JSInteractableView::JsOnClick); JSClass::StaticMethod("onHover", &JSInteractableView::JsOnHover); JSClass::StaticMethod("onKeyEvent", &JSInteractableView::JsOnKey); JSClass::StaticMethod("onDeleteEvent", &JSInteractableView::JsOnDelete); JSClass::StaticMethod("onAppear", &JSInteractableView::JsOnAppear); JSClass::StaticMethod("onDisAppear", &JSInteractableView::JsOnDisAppear); JSClass::Inherit(); JSClass::Bind(globalObj); } void JSToggle::Create(const JSCallbackInfo& info) { if (info.Length() < 1 || !info[0]->IsObject()) { LOGE("toggle create error, info is non-valid"); return; } auto paramObject = JSRef::Cast(info[0]); auto type = paramObject->GetProperty("type"); if (!type->IsNumber()) { LOGE("toggle create error, type is non-valid"); return; } auto tempIsOn = paramObject->GetProperty("isOn"); bool isOn = tempIsOn->IsBoolean() ? tempIsOn->ToBoolean() : false; auto toggleType = static_cast(type->ToNumber()); auto toggleTypeInt = static_cast(toggleType); ToggleModel::GetInstance()->Create(NG::ToggleType(toggleTypeInt), isOn); } void JSToggle::JsWidth(const JSCallbackInfo& info) { if (info.Length() < 1) { LOGE("The arg is wrong, it is supposed to have atleast 1 arguments"); return; } JsWidth(info[0]); } void JSToggle::JsWidth(const JSRef& jsValue) { Dimension value; if (!ParseJsDimensionVp(jsValue, value)) { return; } if (Container::IsCurrentUseNewPipeline()) { JSViewAbstract::JsWidth(jsValue); return; } ToggleModel::GetInstance()->SetWidth(value); } void JSToggle::JsHeight(const JSCallbackInfo& info) { if (info.Length() < 1) { LOGE("The arg is wrong, it is supposed to have atleast 1 arguments"); return; } JsHeight(info[0]); } void JSToggle::JsHeight(const JSRef& jsValue) { Dimension value; if (!ParseJsDimensionVp(jsValue, value)) { return; } if (Container::IsCurrentUseNewPipeline()) { JSViewAbstract::JsHeight(jsValue); return; } ToggleModel::GetInstance()->SetHeight(value); } void JSToggle::JsSize(const JSCallbackInfo& info) { if (info.Length() < 1) { LOGE("The arg is wrong, it is supposed to have atleast 1 arguments"); return; } if (!info[0]->IsObject()) { LOGE("arg is not Object or String."); return; } JSRef sizeObj = JSRef::Cast(info[0]); JsWidth(sizeObj->GetProperty("width")); JsHeight(sizeObj->GetProperty("height")); } void JSToggle::OnChange(const JSCallbackInfo& args) { auto jsFunc = AceType::MakeRefPtr(JSRef(), JSRef::Cast(args[0])); auto onChange = [execCtx = args.GetExecutionContext(), func = std::move(jsFunc)](bool isOn) { JAVASCRIPT_EXECUTION_SCOPE_WITH_CHECK(execCtx); ACE_SCORING_EVENT("Toggle.onChange"); auto newJSVal = JSRef::Make(ToJSValue(isOn)); func->ExecuteJS(1, &newJSVal); }; ToggleModel::GetInstance()->OnChange(std::move(onChange)); args.ReturnSelf(); } void JSToggle::SelectedColor(const JSCallbackInfo& info) { if (info.Length() < 1) { LOGE("The arg is wrong, it is supposed to have atleast 1 arguments"); return; } Color selectedColor; if (!ParseJsColor(info[0], selectedColor)) { return; } ToggleModel::GetInstance()->SetSelectedColor(selectedColor); } void JSToggle::SwitchPointColor(const JSCallbackInfo& info) { if (info.Length() < 1) { LOGE("The arg is wrong, it is supposed to have atleast 1 arguments"); return; } Color color; if (!ParseJsColor(info[0], color)) { return; } ToggleModel::GetInstance()->SetSwitchPointColor(color); } void JSToggle::JsPadding(const JSCallbackInfo& info) { if (info.Length() < 1) { LOGE("The arg is wrong, it is supposed to have atleast 1 arguments"); return; } if (!info[0]->IsString() && !info[0]->IsNumber() && !info[0]->IsObject()) { LOGE("arg is not a string, number or object."); return; } if (Container::IsCurrentUseNewPipeline() || ToggleModel::GetInstance()->IsToggle()) { JSViewAbstract::JsPadding(info); return; } if (info[0]->IsObject()) { auto argsPtrItem = JsonUtil::ParseJsonString(info[0]->ToString()); if (!argsPtrItem || argsPtrItem->IsNull()) { LOGE("Js Parse object failed. argsPtr is null. %s", info[0]->ToString().c_str()); return; } if (argsPtrItem->Contains("top") || argsPtrItem->Contains("bottom") || argsPtrItem->Contains("left") || argsPtrItem->Contains("right")) { Dimension topDimen = Dimension(0.0, DimensionUnit::VP); Dimension leftDimen = Dimension(0.0, DimensionUnit::VP); Dimension rightDimen = Dimension(0.0, DimensionUnit::VP); Dimension bottomDimen = Dimension(0.0, DimensionUnit::VP); ParseJsonDimensionVp(argsPtrItem->GetValue("top"), topDimen); ParseJsonDimensionVp(argsPtrItem->GetValue("left"), leftDimen); ParseJsonDimensionVp(argsPtrItem->GetValue("right"), rightDimen); ParseJsonDimensionVp(argsPtrItem->GetValue("bottom"), bottomDimen); if (leftDimen == 0.0_vp) { leftDimen = rightDimen; } if (topDimen == 0.0_vp) { topDimen = bottomDimen; } if (leftDimen == 0.0_vp) { leftDimen = topDimen; } NG::PaddingPropertyF padding; padding.left = leftDimen.ConvertToPx(); padding.right = rightDimen.ConvertToPx(); padding.top = topDimen.ConvertToPx(); padding.bottom = bottomDimen.ConvertToPx(); ToggleModel::GetInstance()->SetPadding(padding); return; } } Dimension length; if (!JSViewAbstract::ParseJsDimensionVp(info[0], length)) { return; } NG::PaddingPropertyF padding; padding.left = length.ConvertToPx(); padding.right = length.ConvertToPx(); padding.top = length.ConvertToPx(); padding.bottom = length.ConvertToPx(); ToggleModel::GetInstance()->SetPadding(padding); } void JSToggle::SetBackgroundColor(const JSCallbackInfo& info) { if (info.Length() < 1) { LOGE("The argv is wrong, it is supposed to have at least 1 argument"); return; } Color backgroundColor; if (!ParseJsColor(info[0], backgroundColor)) { return; } if (!Container::IsCurrentUseNewPipeline()) { JSViewAbstract::JsBackgroundColor(info); return; } ToggleModel::GetInstance()->SetBackgroundColor(backgroundColor); } } // namespace OHOS::Ace::Framework