Skip to content

Commit

Permalink
Make Component::change impl mandatory (#1071)
Browse files Browse the repository at this point in the history
  • Loading branch information
jstarry authored Apr 4, 2020
1 parent 039c860 commit 8edf136
Show file tree
Hide file tree
Showing 38 changed files with 369 additions and 142 deletions.
4 changes: 4 additions & 0 deletions crates/macro/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,10 @@
//! # unimplemented!()
//! # }
//! #
//! # fn change(&mut self, props: Self::Properties) -> ShouldRender {
//! # unimplemented!()
//! # }
//! #
//! # fn view(&self) -> Html {
//! #
//! // ...
Expand Down
9 changes: 9 additions & 0 deletions crates/macro/tests/macro/html-component-fail.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,9 @@ impl Component for Child {
fn update(&mut self, _: Self::Message) -> ShouldRender {
unimplemented!()
}
fn change(&mut self, _: Self::Properties) -> ShouldRender {
unimplemented!()
}
fn view(&self) -> Html {
unimplemented!()
}
Expand All @@ -42,6 +45,9 @@ impl Component for ChildContainer {
fn update(&mut self, _: Self::Message) -> ShouldRender {
unimplemented!()
}
fn change(&mut self, _: Self::Properties) -> ShouldRender {
unimplemented!()
}
fn view(&self) -> Html {
unimplemented!()
}
Expand All @@ -61,6 +67,9 @@ impl Component for Generic<String> {
fn update(&mut self, _: Self::Message) -> ShouldRender {
unimplemented!()
}
fn change(&mut self, _: Self::Properties) -> ShouldRender {
unimplemented!()
}
fn view(&self) -> Html {
unimplemented!()
}
Expand Down
256 changes: 128 additions & 128 deletions crates/macro/tests/macro/html-component-fail.stderr

Large diffs are not rendered by default.

18 changes: 18 additions & 0 deletions crates/macro/tests/macro/html-component-pass.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,9 @@ impl Component for Generic<String> {
fn update(&mut self, _: Self::Message) -> ShouldRender {
unimplemented!()
}
fn change(&mut self, _: Self::Properties) -> ShouldRender {
unimplemented!()
}
fn view(&self) -> Html {
unimplemented!()
}
Expand All @@ -34,6 +37,9 @@ impl Component for Generic<Vec<String>> {
fn update(&mut self, _: Self::Message) -> ShouldRender {
unimplemented!()
}
fn change(&mut self, _: Self::Properties) -> ShouldRender {
unimplemented!()
}
fn view(&self) -> Html {
unimplemented!()
}
Expand All @@ -57,6 +63,9 @@ impl Component for Container {
fn update(&mut self, _: Self::Message) -> ShouldRender {
unimplemented!()
}
fn change(&mut self, _: Self::Properties) -> ShouldRender {
unimplemented!()
}
fn view(&self) -> Html {
unimplemented!()
}
Expand Down Expand Up @@ -113,6 +122,9 @@ impl Component for Child {
fn update(&mut self, _: Self::Message) -> ShouldRender {
unimplemented!()
}
fn change(&mut self, _: Self::Properties) -> ShouldRender {
unimplemented!()
}
fn view(&self) -> Html {
unimplemented!()
}
Expand All @@ -129,6 +141,9 @@ impl Component for AltChild {
fn update(&mut self, _: Self::Message) -> ShouldRender {
unimplemented!()
}
fn change(&mut self, _: Self::Properties) -> ShouldRender {
unimplemented!()
}
fn view(&self) -> Html {
unimplemented!()
}
Expand All @@ -152,6 +167,9 @@ impl Component for ChildContainer {
fn update(&mut self, _: Self::Message) -> ShouldRender {
unimplemented!()
}
fn change(&mut self, _: Self::Properties) -> ShouldRender {
unimplemented!()
}
fn view(&self) -> Html {
unimplemented!()
}
Expand Down
4 changes: 4 additions & 0 deletions examples/crm/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -146,6 +146,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
match self.scene {
Scene::ClientsList => html! {
Expand Down
4 changes: 4 additions & 0 deletions examples/custom_components/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,10 @@ impl Component for Model {
}
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
let counter = |x| {
html! {
Expand Down
4 changes: 4 additions & 0 deletions examples/dashboard/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -186,6 +186,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div>
Expand Down
4 changes: 4 additions & 0 deletions examples/fragments/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<>
Expand Down
4 changes: 4 additions & 0 deletions examples/game_of_life/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -209,6 +209,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div>
Expand Down
4 changes: 4 additions & 0 deletions examples/large_table/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<table>
Expand Down
4 changes: 4 additions & 0 deletions examples/showcase/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,10 @@ impl Component for Model {
}
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div id="fullscreen">
Expand Down
4 changes: 4 additions & 0 deletions examples/std_web/counter/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div>
Expand Down
4 changes: 4 additions & 0 deletions examples/std_web/inner_html/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
let js_svg = js! {
var div = document.createElement("div");
Expand Down
4 changes: 4 additions & 0 deletions examples/std_web/mount_point/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div>
Expand Down
5 changes: 5 additions & 0 deletions examples/std_web/node_refs/src/input.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,11 @@ impl Component for InputComponent {
false
}

fn change(&mut self, props: Self::Properties) -> ShouldRender {
self.props = props;
true
}

fn view(&self) -> Html {
html! {
<input
Expand Down
4 changes: 4 additions & 0 deletions examples/std_web/node_refs/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div class="main">
Expand Down
4 changes: 4 additions & 0 deletions examples/std_web/npm_and_rest/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
let view_exchange = |exchange| {
html! {
Expand Down
4 changes: 4 additions & 0 deletions examples/std_web/todomvc/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div class="todomvc-wrapper">
Expand Down
4 changes: 4 additions & 0 deletions examples/std_web/two_apps/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div>
Expand Down
4 changes: 4 additions & 0 deletions examples/textarea/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div>
Expand Down
4 changes: 4 additions & 0 deletions examples/timer/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
let view_message = |message| {
html! { <p>{ message }</p> }
Expand Down
4 changes: 4 additions & 0 deletions examples/web_sys/counter/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div>
Expand Down
4 changes: 4 additions & 0 deletions examples/web_sys/inner_html/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
let js_svg = {
let div = web_sys::window()
Expand Down
4 changes: 4 additions & 0 deletions examples/web_sys/mount_point/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div>
Expand Down
5 changes: 5 additions & 0 deletions examples/web_sys/node_refs/src/input.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,11 @@ impl Component for InputComponent {
false
}

fn change(&mut self, props: Self::Properties) -> ShouldRender {
self.props = props;
true
}

fn view(&self) -> Html {
html! {
<input
Expand Down
4 changes: 4 additions & 0 deletions examples/web_sys/node_refs/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div class="main">
Expand Down
4 changes: 4 additions & 0 deletions examples/web_sys/npm_and_rest/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
let view_exchange = |exchange| {
html! {
Expand Down
4 changes: 4 additions & 0 deletions examples/web_sys/todomvc/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div class="todomvc-wrapper">
Expand Down
4 changes: 4 additions & 0 deletions examples/web_sys/two_apps/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,10 @@ impl Component for Model {
true
}

fn change(&mut self, _: Self::Properties) -> ShouldRender {
false
}

fn view(&self) -> Html {
html! {
<div>
Expand Down
1 change: 1 addition & 0 deletions src/components/select.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
//!# type Message = ();type Properties = ();
//!# fn create(props: Self::Properties,link: ComponentLink<Self>) -> Self {unimplemented!()}
//!# fn update(&mut self,msg: Self::Message) -> bool {unimplemented!()}
//!# fn change(&mut self, _: Self::Properties) -> bool {unimplemented!()}
//!# fn view(&self) -> Html {unimplemented!()}}
//! impl ToString for Scene {
//! fn to_string(&self) -> String {
Expand Down
Loading

0 comments on commit 8edf136

Please sign in to comment.