Merge branch 'develop/3.6' of github.com:thingsboard/thingsboard into develop/3.6
This commit is contained in:
		
						commit
						919779692f
					
				@ -3,7 +3,7 @@
 | 
			
		||||
    "alias": "alarm_widgets",
 | 
			
		||||
    "title": "Alarm widgets",
 | 
			
		||||
    "image": "",
 | 
			
		||||
    "description": "Visualization of alarms for devices, assets and other entities.",
 | 
			
		||||
    "description": "Visualization of alarms for devices, assets, and other entities.",
 | 
			
		||||
    "externalId": null,
 | 
			
		||||
    "name": "Alarm widgets"
 | 
			
		||||
  },
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							@ -3,7 +3,7 @@
 | 
			
		||||
    "alias": "count_widgets",
 | 
			
		||||
    "title": "Count widgets",
 | 
			
		||||
    "image": "",
 | 
			
		||||
    "description": "Cards to display the number of alarms or entities based on selected filter.",
 | 
			
		||||
    "description": "Cards to display the number of alarms or entities based on the selected filter.",
 | 
			
		||||
    "externalId": null,
 | 
			
		||||
    "name": "Count widgets"
 | 
			
		||||
  },
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							@ -3,7 +3,7 @@
 | 
			
		||||
    "alias": "edge_widgets",
 | 
			
		||||
    "title": "Edge widgets",
 | 
			
		||||
    "image": "",
 | 
			
		||||
    "description": "Widgets to manage ThingsBoard Edge.",
 | 
			
		||||
    "description": "Widgets to manage ThingsBoard Edge instances and navigate through their entities.",
 | 
			
		||||
    "externalId": null,
 | 
			
		||||
    "name": "Edge widgets"
 | 
			
		||||
  },
 | 
			
		||||
 | 
			
		||||
@ -3,7 +3,7 @@
 | 
			
		||||
    "alias": "entity_widgets",
 | 
			
		||||
    "title": "Entity widgets",
 | 
			
		||||
    "image": "",
 | 
			
		||||
    "description": "Contains entity hierarchy and entity tables.",
 | 
			
		||||
    "description": "Visualize entity properties and hierarchy using table and tree widgets.",
 | 
			
		||||
    "externalId": null,
 | 
			
		||||
    "name": "Entity widgets"
 | 
			
		||||
  },
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							@ -3,7 +3,7 @@
 | 
			
		||||
    "alias": "tables",
 | 
			
		||||
    "title": "Tables",
 | 
			
		||||
    "image": "",
 | 
			
		||||
    "description": "Contains entity, timeseries or alarm tables.",
 | 
			
		||||
    "description": "Contains tables to display alarms, entities, and their telemetry.",
 | 
			
		||||
    "externalId": null,
 | 
			
		||||
    "name": "Tables"
 | 
			
		||||
  },
 | 
			
		||||
 | 
			
		||||
@ -768,10 +768,10 @@ public class SqlDatabaseUpgradeService implements DatabaseEntitiesUpgradeService
 | 
			
		||||
                        } catch (Exception e) {
 | 
			
		||||
                        }
 | 
			
		||||
 | 
			
		||||
                        conn.createStatement().execute("UPDATE tb_schema_settings SET schema_version = 3005002;");
 | 
			
		||||
                        log.info("Schema updated to version 3.5.2.");
 | 
			
		||||
                        conn.createStatement().execute("UPDATE tb_schema_settings SET schema_version = 3006000;");
 | 
			
		||||
                        log.info("Schema updated to version 3.6.0.");
 | 
			
		||||
                    } else {
 | 
			
		||||
                        log.info("Skip schema re-update to version 3.5.2. Use env flag 'SKIP_SCHEMA_VERSION_CHECK' to force the re-update.");
 | 
			
		||||
                        log.info("Skip schema re-update to version 3.6.0. Use env flag 'SKIP_SCHEMA_VERSION_CHECK' to force the re-update.");
 | 
			
		||||
                    }
 | 
			
		||||
                } catch (Exception e) {
 | 
			
		||||
                    log.error("Failed updating schema!!!", e);
 | 
			
		||||
 | 
			
		||||
@ -157,4 +157,10 @@ public class Validator {
 | 
			
		||||
        return StringUtils.isEmpty(key) || RegexUtils.matches(key, PROPERTY_PATTERN);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static void checkNotNull(Object reference, String errorMessage) {
 | 
			
		||||
        if (reference == null) {
 | 
			
		||||
            throw new IncorrectParameterException(errorMessage);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -178,7 +178,10 @@ public class WidgetTypeServiceImpl implements WidgetTypeService {
 | 
			
		||||
        log.trace("Executing updateWidgetsBundleWidgetTypes, tenantId [{}], widgetsBundleId [{}], widgetTypeIds [{}]", tenantId, widgetsBundleId, widgetTypeIds);
 | 
			
		||||
        Validator.validateId(tenantId, INCORRECT_TENANT_ID + tenantId);
 | 
			
		||||
        Validator.validateId(widgetsBundleId, INCORRECT_WIDGETS_BUNDLE_ID + widgetsBundleId);
 | 
			
		||||
        Validator.checkNotNull(widgetTypeIds, "Incorrect widgetTypeIds " + widgetTypeIds);
 | 
			
		||||
        if (!widgetTypeIds.isEmpty()) {
 | 
			
		||||
            validateIds(widgetTypeIds, "Incorrect widgetTypeIds " + widgetTypeIds);
 | 
			
		||||
        }
 | 
			
		||||
        List<WidgetsBundleWidget> bundleWidgets = new ArrayList<>();
 | 
			
		||||
        for (int index = 0; index < widgetTypeIds.size(); index++) {
 | 
			
		||||
            bundleWidgets.add(new WidgetsBundleWidget(widgetsBundleId, widgetTypeIds.get(index), index));
 | 
			
		||||
 | 
			
		||||
@ -25,7 +25,7 @@ CREATE OR REPLACE PROCEDURE insert_tb_schema_settings()
 | 
			
		||||
$$
 | 
			
		||||
BEGIN
 | 
			
		||||
    IF (SELECT COUNT(*) FROM tb_schema_settings) = 0 THEN
 | 
			
		||||
        INSERT INTO tb_schema_settings (schema_version) VALUES (3005002);
 | 
			
		||||
        INSERT INTO tb_schema_settings (schema_version) VALUES (3006000);
 | 
			
		||||
    END IF;
 | 
			
		||||
END;
 | 
			
		||||
$$;
 | 
			
		||||
 | 
			
		||||
@ -218,4 +218,33 @@ public class WidgetTypeServiceTest extends AbstractServiceTest {
 | 
			
		||||
        widgetsBundleService.deleteWidgetsBundle(tenantId, savedWidgetsBundle.getId());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Test
 | 
			
		||||
    public void testDeleteAllTypesFromWidgetsBundle() {
 | 
			
		||||
        WidgetsBundle widgetsBundle = new WidgetsBundle();
 | 
			
		||||
        widgetsBundle.setTenantId(tenantId);
 | 
			
		||||
        widgetsBundle.setTitle("Widgets bundle");
 | 
			
		||||
        WidgetsBundle savedWidgetsBundle = widgetsBundleService.saveWidgetsBundle(widgetsBundle);
 | 
			
		||||
 | 
			
		||||
        List<WidgetType> widgetTypes = new ArrayList<>();
 | 
			
		||||
        for (int i = 0; i < 5; i++) {
 | 
			
		||||
            WidgetTypeDetails widgetType = new WidgetTypeDetails();
 | 
			
		||||
            widgetType.setTenantId(tenantId);
 | 
			
		||||
            widgetType.setName("Widget Type " + i);
 | 
			
		||||
            widgetType.setDescriptor(JacksonUtil.fromString("{ \"someKey\": \"someValue\" }", JsonNode.class));
 | 
			
		||||
            widgetTypes.add(new WidgetType(widgetTypeService.saveWidgetType(widgetType)));
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        List<WidgetTypeId> widgetTypeIds = widgetTypes.stream().map(WidgetType::getId).collect(Collectors.toList());
 | 
			
		||||
 | 
			
		||||
        widgetTypeService.updateWidgetsBundleWidgetTypes(tenantId, savedWidgetsBundle.getId(), widgetTypeIds);
 | 
			
		||||
 | 
			
		||||
        List<WidgetType> loadedWidgetTypes = widgetTypeService.findWidgetTypesByWidgetsBundleId(tenantId, savedWidgetsBundle.getId());
 | 
			
		||||
        Assert.assertEquals(widgetTypes.size(), loadedWidgetTypes.size());
 | 
			
		||||
 | 
			
		||||
        widgetTypeService.updateWidgetsBundleWidgetTypes(tenantId, savedWidgetsBundle.getId(), Collections.emptyList());
 | 
			
		||||
 | 
			
		||||
        loadedWidgetTypes = widgetTypeService.findWidgetTypesByWidgetsBundleId(tenantId, savedWidgetsBundle.getId());
 | 
			
		||||
        Assert.assertEquals(0, loadedWidgetTypes.size());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -398,7 +398,9 @@ export class ImportExportService {
 | 
			
		||||
                  const widgetTypesDetails = widgetsBundleItem.widgetTypes;
 | 
			
		||||
                  const saveWidgetTypesObservables: Array<Observable<WidgetTypeDetails>> = [];
 | 
			
		||||
                  for (const widgetTypeDetails of widgetTypesDetails) {
 | 
			
		||||
                    saveWidgetTypesObservables.push(this.widgetService.saveImportedWidgetTypeDetails(widgetTypeDetails));
 | 
			
		||||
                    saveWidgetTypesObservables.push(
 | 
			
		||||
                      this.widgetService.saveImportedWidgetTypeDetails(this.prepareWidgetType(widgetTypeDetails, savedWidgetsBundle))
 | 
			
		||||
                    );
 | 
			
		||||
                  }
 | 
			
		||||
                  widgetTypesObservable = forkJoin(saveWidgetTypesObservables);
 | 
			
		||||
                } else {
 | 
			
		||||
@ -432,6 +434,15 @@ export class ImportExportService {
 | 
			
		||||
    );
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  private prepareWidgetType(widgetType: WidgetTypeDetails & {alias?: string}, widgetsBundle: WidgetsBundle): WidgetTypeDetails {
 | 
			
		||||
    if (!widgetType.fqn) {
 | 
			
		||||
      widgetType.fqn = `${widgetsBundle.alias}.${widgetType.alias
 | 
			
		||||
                                                  ? widgetType.alias
 | 
			
		||||
                                                  : widgetType.name.toLowerCase().replace(/\W/g, '_')}`;
 | 
			
		||||
    }
 | 
			
		||||
    return widgetType;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  public bulkImportEntities(entitiesData: BulkImportRequest, entityType: EntityType, config?: RequestConfig): Observable<BulkImportResult> {
 | 
			
		||||
    switch (entityType) {
 | 
			
		||||
      case EntityType.DEVICE:
 | 
			
		||||
 | 
			
		||||
@ -75,6 +75,7 @@
 | 
			
		||||
            </mat-slide-toggle>
 | 
			
		||||
          </div>
 | 
			
		||||
          <tb-entity-autocomplete
 | 
			
		||||
            useFullEntityId
 | 
			
		||||
            formControlName="customerId"
 | 
			
		||||
            labelText="device.assign-to-customer"
 | 
			
		||||
            [entityType]="entityType.CUSTOMER">
 | 
			
		||||
 | 
			
		||||
@ -22,7 +22,7 @@ $previewSize: 78px !default;
 | 
			
		||||
 | 
			
		||||
  .tb-container {
 | 
			
		||||
    margin-top: 0;
 | 
			
		||||
    padding: 0;
 | 
			
		||||
    padding: 0 0 16px;
 | 
			
		||||
    label.tb-title {
 | 
			
		||||
      display: block;
 | 
			
		||||
      padding-bottom: 8px;
 | 
			
		||||
@ -121,6 +121,7 @@ $previewSize: 78px !default;
 | 
			
		||||
 | 
			
		||||
  .tb-hint{
 | 
			
		||||
    margin-top: 8px;
 | 
			
		||||
    padding-bottom: 0;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user