mirror of
				https://github.com/beestat/app.git
				synced 2025-10-31 01:57:01 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			252 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			252 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * Home properties.
 | |
|  *
 | |
|  * @param {number} thermostat_id The thermostat_id this card is displaying
 | |
|  * data for.
 | |
|  */
 | |
| beestat.component.card.my_home = function(thermostat_id) {
 | |
|   var self = this;
 | |
| 
 | |
|   this.thermostat_id_ = thermostat_id;
 | |
| 
 | |
|   beestat.dispatcher.addEventListener('cache.thermostat', function() {
 | |
|     self.rerender();
 | |
|   });
 | |
| 
 | |
|   beestat.component.card.apply(this, arguments);
 | |
| };
 | |
| beestat.extend(beestat.component.card.my_home, beestat.component.card);
 | |
| 
 | |
| beestat.component.card.my_home.prototype.decorate_contents_ = function(parent) {
 | |
|   const system_container = document.createElement('div');
 | |
|   system_container.style.marginBottom = `${beestat.style.size.gutter}px`;
 | |
|   parent.appendChild(system_container);
 | |
|   this.decorate_system_type_($(system_container));
 | |
| 
 | |
|   const region_container = document.createElement('div');
 | |
|   region_container.style.marginBottom = `${beestat.style.size.gutter}px`;
 | |
|   parent.appendChild(region_container);
 | |
|   this.decorate_region_($(region_container));
 | |
| 
 | |
|   const property_container = document.createElement('div');
 | |
|   property_container.style.marginBottom = `${beestat.style.size.gutter}px`;
 | |
|   parent.appendChild(property_container);
 | |
|   this.decorate_property_($(property_container));
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Decorate the heating and cooling system types.
 | |
|  *
 | |
|  * @param {rocket.Elements} parent
 | |
|  */
 | |
| beestat.component.card.my_home.prototype.decorate_system_type_ = function(parent) {
 | |
|   var thermostat = beestat.cache.thermostat[this.thermostat_id_];
 | |
| 
 | |
|   (new beestat.component.title('System')).render(parent);
 | |
| 
 | |
|   const heat = beestat.thermostat.get_system_type(
 | |
|     thermostat.thermostat_id,
 | |
|     'heat'
 | |
|   );
 | |
|   const heat_stages = beestat.thermostat.get_stages(
 | |
|     thermostat.thermostat_id,
 | |
|     'heat'
 | |
|   );
 | |
|   const heat_stages_string = heat_stages > 1 ? ' (2 Stage)' : '';
 | |
|   const auxiliary_heat = beestat.thermostat.get_system_type(
 | |
|     thermostat.thermostat_id,
 | |
|     'auxiliary_heat'
 | |
|   );
 | |
|   const cool = beestat.thermostat.get_system_type(
 | |
|     thermostat.thermostat_id,
 | |
|     'cool'
 | |
|   );
 | |
|   const cool_stages = beestat.thermostat.get_stages(
 | |
|     thermostat.thermostat_id,
 | |
|     'cool'
 | |
|   );
 | |
|   const cool_stages_string = cool_stages > 1 ? ' (2 Stage)' : '';
 | |
| 
 | |
|   var tile_group = new beestat.component.tile_group();
 | |
|   tile_group.add_tile(new beestat.component.tile()
 | |
|     .set_type('pill')
 | |
|     .set_background_color(beestat.series.compressor_heat_1.color)
 | |
|     .set_text_color('#fff')
 | |
|     .set_icon('fire')
 | |
|     .set_text(heat.charAt(0).toUpperCase() + heat.slice(1) + heat_stages_string));
 | |
|   tile_group.add_tile(new beestat.component.tile()
 | |
|     .set_type('pill')
 | |
|     .set_background_color(beestat.series.auxiliary_heat_1.color)
 | |
|     .set_text_color('#fff')
 | |
|     .set_icon('fire')
 | |
|     .set_text(auxiliary_heat.charAt(0).toUpperCase() + auxiliary_heat.slice(1)));
 | |
|   tile_group.add_tile(new beestat.component.tile()
 | |
|     .set_type('pill')
 | |
|     .set_background_color(beestat.series.compressor_cool_1.color)
 | |
|     .set_text_color('#fff')
 | |
|     .set_icon('snowflake')
 | |
|     .set_text(cool.charAt(0).toUpperCase() + cool.slice(1) + cool_stages_string));
 | |
| 
 | |
|   tile_group.render(parent);
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Decorate the geographical region.
 | |
|  *
 | |
|  * @param {rocket.Elements} parent
 | |
|  */
 | |
| beestat.component.card.my_home.prototype.decorate_region_ = function(parent) {
 | |
|   var thermostat = beestat.cache.thermostat[this.thermostat_id_];
 | |
|   var address = beestat.cache.address[thermostat.address_id];
 | |
| 
 | |
|   (new beestat.component.title('Region')).render(parent);
 | |
| 
 | |
|   var region;
 | |
|   if (beestat.address.is_valid(address.address_id) === true) {
 | |
|     region =
 | |
|       address.normalized.components.state_abbreviation ||
 | |
|       address.normalized.components.locality ||
 | |
|       '';
 | |
| 
 | |
|     if (region !== '') {
 | |
|       region += ', ';
 | |
|     }
 | |
| 
 | |
|     region += address.normalized.components.country_iso_3;
 | |
|   } else {
 | |
|     region = null;
 | |
|   }
 | |
| 
 | |
|   var tile_group = new beestat.component.tile_group();
 | |
|   if (region !== null) {
 | |
|     var button = new beestat.component.tile()
 | |
|       .set_type('pill')
 | |
|       .set_background_color(beestat.style.color.green.base)
 | |
|       .set_text_color('#fff')
 | |
|       .set_icon('map_marker')
 | |
|       .set_text(region);
 | |
|     tile_group.add_tile(button);
 | |
|   } else {
 | |
|     tile_group.add_tile(new beestat.component.tile()
 | |
|       .set_type('pill')
 | |
|       .set_background_color(beestat.style.color.gray.dark)
 | |
|       .set_text_color('#fff')
 | |
|       .set_icon('border_none_variant')
 | |
|       .set_text('No Data'));
 | |
|   }
 | |
|   tile_group.render(parent);
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Decorate the property characteristics.
 | |
|  *
 | |
|  * @param {rocket.Elements} parent
 | |
|  */
 | |
| beestat.component.card.my_home.prototype.decorate_property_ = function(parent) {
 | |
|   var thermostat = beestat.cache.thermostat[this.thermostat_id_];
 | |
| 
 | |
|   (new beestat.component.title('Property')).render(parent);
 | |
| 
 | |
|   var tile_group = new beestat.component.tile_group();
 | |
|   let has_data = false;
 | |
| 
 | |
|   if (thermostat.property.structure_type !== null) {
 | |
|     has_data = true;
 | |
|     tile_group.add_tile(new beestat.component.tile()
 | |
|       .set_type('pill')
 | |
|       .set_background_color(beestat.style.color.purple.base)
 | |
|       .set_text_color('#fff')
 | |
|       .set_icon('home_floor_a')
 | |
|       .set_text(thermostat.property.structure_type.charAt(0).toUpperCase() +
 | |
|         thermostat.property.structure_type.slice(1)));
 | |
|   }
 | |
| 
 | |
|   if (
 | |
|     thermostat.property.stories !== null &&
 | |
|     (
 | |
|       thermostat.property.structure_type === 'detached' ||
 | |
|       thermostat.property.structure_type === 'townhouse' ||
 | |
|       thermostat.property.structure_type === 'semi-detached'
 | |
|     )
 | |
|   ) {
 | |
|     has_data = true;
 | |
|     tile_group.add_tile(new beestat.component.tile()
 | |
|       .set_type('pill')
 | |
|       .set_background_color(beestat.style.color.purple.base)
 | |
|       .set_text_color('#fff')
 | |
|       .set_icon('layers')
 | |
|       .set_text(thermostat.property.stories +
 | |
|         (thermostat.property.stories === 1 ? ' Story' : ' Stories')));
 | |
|   }
 | |
| 
 | |
|   if (thermostat.property.square_feet !== null) {
 | |
|     has_data = true;
 | |
|     tile_group.add_tile(new beestat.component.tile()
 | |
|       .set_type('pill')
 | |
|       .set_background_color(beestat.style.color.purple.base)
 | |
|       .set_text_color('#fff')
 | |
|       .set_icon('view_quilt')
 | |
|       .set_text(beestat.area({
 | |
|         'area': thermostat.property.square_feet,
 | |
|         'units': true,
 | |
|         'round': 0
 | |
|       }))
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   if (thermostat.property.age !== null) {
 | |
|     has_data = true;
 | |
|     tile_group.add_tile(new beestat.component.tile()
 | |
|       .set_type('pill')
 | |
|       .set_background_color(beestat.style.color.purple.base)
 | |
|       .set_text_color('#fff')
 | |
|       .set_icon('clock_outline')
 | |
|       .set_text(thermostat.property.age + ' Years'));
 | |
|   }
 | |
| 
 | |
|   if (has_data === false) {
 | |
|     tile_group.add_tile(new beestat.component.tile()
 | |
|       .set_type('pill')
 | |
|       .set_background_color(beestat.style.color.gray.dark)
 | |
|       .set_text_color('#fff')
 | |
|       .set_icon('border_none_variant')
 | |
|       .set_text('No Data'));
 | |
|   }
 | |
| 
 | |
|   tile_group.render(parent);
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Get the title of the card.
 | |
|  *
 | |
|  * @return {string} The title of the card.
 | |
|  */
 | |
| beestat.component.card.my_home.prototype.get_title_ = function() {
 | |
|   return 'My Home';
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Decorate the menu.
 | |
|  *
 | |
|  * @param {rocket.Elements} parent
 | |
|  */
 | |
| beestat.component.card.my_home.prototype.decorate_top_right_ = function(parent) {
 | |
|   var self = this;
 | |
| 
 | |
|   var menu = (new beestat.component.menu()).render(parent);
 | |
| 
 | |
|   menu.add_menu_item(new beestat.component.menu_item()
 | |
|     .set_text('Change System Type')
 | |
|     .set_icon('tune')
 | |
|     .set_callback(function() {
 | |
|       (new beestat.component.modal.change_system_type(self.thermostat_id_)).render();
 | |
|     }));
 | |
| 
 | |
|   menu.add_menu_item(new beestat.component.menu_item()
 | |
|     .set_text('Help')
 | |
|     .set_icon('help_circle')
 | |
|     .set_callback(function() {
 | |
|       window.open('https://doc.beestat.io/cc594772031e41a58ff38e04e66cf0ec');
 | |
|     }));
 | |
| };
 |