//  --------------------------------------------------------------------------------------
//  DESCRIPTION
//  Creates UP_98204204
//  ---------------------------------------------------------------------------------------
//
// eslint-disable-next-line no-unused-vars
//  --------------------------------------------------------------------------------------
//  Logger
let log = (logPrefix, logMessage) =&gt; {
    me.logger({
        logPrefix: logPrefix,
        logMessage: logMessage,
        logLevel: 'debugGreen'
    });
};

// --------------------------------------------------------------------------------------
const UP_DB = Things['AGCO.UP.Thing.DatabaseServices'];
const PROJECT = 'AGCO.Unicorn-Planning.Data';
const BASE_LOG_PREFIX = me.name + '.UpdateUPnodes()';
const UE_GENERIC_SERVICES = Things[&quot;AGCO.UE.Thing.GenericServices&quot;];
const EXCLUDE_FIELDS = ['tags', 'thingTemplate','description','name','AppName','PartView'];

log(BASE_LOG_PREFIX, 'Starting...');
(() =&gt; {
    'use strict';
    let count = 0;
    let now = new Date().getTime();
    let cachePartsToCreate = [];
    let partsCreatedSuccessfully = true;

    try {

        let dbParts= UP_DB.GetAllParts({}); //returns id and partnumber
        
        dbParts.rows.toArray().forEach((nextPart) =&gt; {
            now++;
            let unicornPartVals = {};
            let nextPartNumber = nextPart.partnumber;
            let nextPartID = nextPart.id;
            let newPartNumber = 'UP_' + now;
            let LOG_PREFIX = BASE_LOG_PREFIX + '.' + nextPartNumber + ': ';
            log(LOG_PREFIX, 'applying thing shape to part: ' + nextPartNumber);

            /* GET THE UNICORN DB VALUES AND ADD TO UP THING PROPERTIES */

            let unicornAttrsVals = UP_DB.SQLGetAttributeListWithValueByWTPartID({
                wtpart_id: nextPartID
            }); //output: AGCO.UP.editAttributeCollection


            if (unicornAttrsVals &amp;&amp; unicornAttrsVals.getRowCount()) {
                unicornAttrsVals.rows.toArray().forEach((nextVal) =&gt; {
                    let safeAttrName = ((nextVal.attribute_name).split(' ')).join('');
                    if (nextVal.attribute_type === &quot;Date&quot;) {
                        if (nextVal.attribute_value.indexOf('-') &lt; 0) {
                            let date = Things[&quot;AGCO.UP.Thing.GenericServices&quot;].ConvertTimeStampToDate({inputdate: nextVal.attribute_value});
                            unicornPartVals[safeAttrName] = date;
                        }
                    } else {
                        unicornPartVals[safeAttrName] = nextVal.attribute_value;
                    }
                });
            }
            log(LOG_PREFIX, ' found unicorn part vals ' + JSON.stringify(unicornPartVals));
            /* CREATE UP THING WITH BINDINGS TO WINDCHILL THING */

            // add thing shape to matching thing in classification tree
            try {
                let implementedPart = ThingTemplates[nextPartNumber].GetImplementingThingsWithData();
                let unicornParts = [];
                let windchillPart;
                let newUPThing;

                implementedPart.rows.toArray().forEach(nextThing =&gt; {
                    if ((nextThing.name).startsWith('UP_')) {
                        unicornParts.push(nextThing.name);
                    } else if ((nextThing.name).startsWith('WC_')) {
                        windchillPart = nextThing.name;
                    }
                });
                if (unicornParts.length) {
                    log(LOG_PREFIX, unicornParts.length +' things already exists');

                    unicornParts.sort();
                    let unicornPart = unicornParts.pop();
                    unicornParts.forEach(oldThing =&gt; {
                        Resources[&quot;EntityServices&quot;].DeleteThing({
                            name: oldThing /* THINGNAME */
                        });
                    });
                    newUPThing = Things[unicornPart];

                } else {
                    Resources.EntityServices.CreateThing({
                        name: newPartNumber,
                        thingTemplateName: nextPartNumber,
                        projectName: PROJECT
                    });

                    Things[newPartNumber].EnableThing();
                    Things[newPartNumber].RestartThing();

                    Resources.EntityServices.AddShapeToThing({
                        name: newPartNumber,
                        thingShapeName: 'AGCO.UP.ThingShape.PlanningPart.ManageableAttributes'
                    });

                    Resources.EntityServices.AddShapeToThing({
                        name: newPartNumber,
                        thingShapeName: 'AGCO.UP.ThingShape.PlanningPart.SystemAttributes'
                    });

                    Resources.EntityServices.AddShapeToThing({
                        name: newPartNumber,
                        thingShapeName: 'AGCO.UP.ThingShape.PlanningPart.WindchillAttributes'
                    });

                    log(LOG_PREFIX, 'added shape to thing, updating properties');

                    newUPThing = Things[newPartNumber];
                }

                newUPThing.AppName = 'UP';
                newUPThing.PartView = 'Design';

                if (windchillPart) {
                    let windchillPartProperties = Things[windchillPart].GetPropertyValues();
                    let windchillPartFields = windchillPartProperties.dataShape.fields;
                    let windchillPartAttrsArray = [];
                    windchillPartFields.forEach((nextField) =&gt; {
                        if (!EXCLUDE_FIELDS.includes(windchillPartFields[nextField][&quot;name&quot;])) {
                            windchillPartAttrsArray.push(windchillPartFields[nextField][&quot;name&quot;]);   
                        }
                    });

                    let newUPThingProperties = newUPThing.GetPropertyValues();
                    let newUPThingFields = newUPThingProperties.dataShape.fields;

                    newUPThingFields.forEach((nextAttribute) =&gt; {
                        try {
                            if (!EXCLUDE_FIELDS.includes(newUPThingFields[nextAttribute][&quot;name&quot;])) {
                                //if the newUPThing has an attribute that is found in the windchill part, add a local binding
                                if (windchillPartAttrsArray.includes(newUPThingFields[nextAttribute][&quot;name&quot;])) {
                                    //add windchill cache link
                                    newUPThing.SetLocalPropertyBinding({
                                        propertyName: newUPThingFields[nextAttribute][&quot;name&quot;],
                                        sourceThingName: windchillPart,
                                        sourcePropertyName: newUPThingFields[nextAttribute][&quot;name&quot;]
                                    });
                                    log(LOG_PREFIX + ' attempting to bind to ' + newUPThingFields[nextAttribute][&quot;name&quot;] + '..');
                                } else if (unicornPartVals.hasOwnProperty(newUPThingFields[nextAttribute][&quot;name&quot;])) {
                                    newUPThing[newUPThingFields[nextAttribute][&quot;name&quot;]] = unicornPartVals[newUPThingFields[nextAttribute][&quot;name&quot;]];
                                    log(LOG_PREFIX + ' attempting to add to ' + newUPThingFields[nextAttribute][&quot;name&quot;] + ' with ' + unicornPartVals[newUPThingFields[nextAttribute][&quot;name&quot;]] + '?.');
                                } else {
                                    //log(LOG_PREFIX + ' no match for ' + newUPThingFields[nextAttribute][&quot;name&quot;]);
                                }
                            }
                        } catch (er) {
                            log(LOG_PREFIX, 'error updating = ' + er + newUPThingFields[nextAttribute][&quot;name&quot;]);
                        }
                    });

                } else {
                    log(LOG_PREFIX, ' no wc_* windchill part found for ' + nextPartNumber);
                }

            } catch (err) {
                log(LOG_PREFIX, 'error creating UP thing, err = ' + err);
            }

        });

        result = true;
    } catch (error) {
        log(BASE_LOG_PREFIX, ': Error = ' + error.message);
    }

    log(BASE_LOG_PREFIX, ': Done...' + count);
})();
// --------------------------------------------------------------------------------------
// DESCRIPTION
// Creates UP_98204204
// ---------------------------------------------------------------------------------------
//
// eslint-disable-next-line no-unused-vars
// --------------------------------------------------------------------------------------
// Logger
let log = (logPrefix, logMessage) => {
me.logger({
logPrefix: logPrefix,
logMessage: logMessage,
logLevel: 'debugGreen'
});
};
// --------------------------------------------------------------------------------------
const UP_DB = Things['AGCO.UP.Thing.DatabaseServices'];
const PROJECT = 'AGCO.Unicorn-Planning.Data';
const BASE_LOG_PREFIX = me.name + '.UpdateUPnodes()';
const UE_GENERIC_SERVICES = Things["AGCO.UE.Thing.GenericServices"];
const EXCLUDE_FIELDS = ['tags', 'thingTemplate','description','name','AppName','PartView'];
log(BASE_LOG_PREFIX, 'Starting...');
(() => {
'use strict';
let count = 0;
let now = new Date().getTime();
let cachePartsToCreate = [];
let partsCreatedSuccessfully = true;
try {
let dbParts= UP_DB.GetAllParts({}); //returns id and partnumber
dbParts.rows.toArray().forEach((nextPart) => {
now++;
let unicornPartVals = {};
let nextPartNumber = nextPart.partnumber;
let nextPartID = nextPart.id;
let newPartNumber = 'UP_' + now;
let LOG_PREFIX = BASE_LOG_PREFIX + '.' + nextPartNumber + ': ';
log(LOG_PREFIX, 'applying thing shape to part: ' + nextPartNumber);
/* GET THE UNICORN DB VALUES AND ADD TO UP THING PROPERTIES */
let unicornAttrsVals = UP_DB.SQLGetAttributeListWithValueByWTPartID({
wtpart_id: nextPartID
}); //output: AGCO.UP.editAttributeCollection
if (unicornAttrsVals && unicornAttrsVals.getRowCount()) {
unicornAttrsVals.rows.toArray().forEach((nextVal) => {
let safeAttrName = ((nextVal.attribute_name).split(' ')).join('');
if (nextVal.attribute_type === "Date") {
if (nextVal.attribute_value.indexOf('-') < 0) {
let date = Things["AGCO.UP.Thing.GenericServices"].ConvertTimeStampToDate({inputdate: nextVal.attribute_value});
unicornPartVals[safeAttrName] = date;
}
} else {
unicornPartVals[safeAttrName] = nextVal.attribute_value;
}
});
}
log(LOG_PREFIX, ' found unicorn part vals ' + JSON.stringify(unicornPartVals));
/* CREATE UP THING WITH BINDINGS TO WINDCHILL THING */
// add thing shape to matching thing in classification tree
try {
let implementedPart = ThingTemplates[nextPartNumber].GetImplementingThingsWithData();
let unicornParts = [];
let windchillPart;
let newUPThing;
implementedPart.rows.toArray().forEach(nextThing => {
if ((nextThing.name).startsWith('UP_')) {
unicornParts.push(nextThing.name);
} else if ((nextThing.name).startsWith('WC_')) {
windchillPart = nextThing.name;
}
});
if (unicornParts.length) {
log(LOG_PREFIX, unicornParts.length +' things already exists');
unicornParts.sort();
let unicornPart = unicornParts.pop();
unicornParts.forEach(oldThing => {
Resources["EntityServices"].DeleteThing({
name: oldThing /* THINGNAME */
});
});
newUPThing = Things[unicornPart];
} else {
Resources.EntityServices.CreateThing({
name: newPartNumber,
thingTemplateName: nextPartNumber,
projectName: PROJECT
});
Things[newPartNumber].EnableThing();
Things[newPartNumber].RestartThing();
Resources.EntityServices.AddShapeToThing({
name: newPartNumber,
thingShapeName: 'AGCO.UP.ThingShape.PlanningPart.ManageableAttributes'
});
Resources.EntityServices.AddShapeToThing({
name: newPartNumber,
thingShapeName: 'AGCO.UP.ThingShape.PlanningPart.SystemAttributes'
});
Resources.EntityServices.AddShapeToThing({
name: newPartNumber,
thingShapeName: 'AGCO.UP.ThingShape.PlanningPart.WindchillAttributes'
});
log(LOG_PREFIX, 'added shape to thing, updating properties');
newUPThing = Things[newPartNumber];
}
newUPThing.AppName = 'UP';
newUPThing.PartView = 'Design';
if (windchillPart) {
let windchillPartProperties = Things[windchillPart].GetPropertyValues();
let windchillPartFields = windchillPartProperties.dataShape.fields;
let windchillPartAttrsArray = [];
windchillPartFields.forEach((nextField) => {
if (!EXCLUDE_FIELDS.includes(windchillPartFields[nextField]["name"])) {
windchillPartAttrsArray.push(windchillPartFields[nextField]["name"]);
}
});
let newUPThingProperties = newUPThing.GetPropertyValues();
let newUPThingFields = newUPThingProperties.dataShape.fields;
newUPThingFields.forEach((nextAttribute) => {
try {
if (!EXCLUDE_FIELDS.includes(newUPThingFields[nextAttribute]["name"])) {
//if the newUPThing has an attribute that is found in the windchill part, add a local binding
if (windchillPartAttrsArray.includes(newUPThingFields[nextAttribute]["name"])) {
//add windchill cache link
newUPThing.SetLocalPropertyBinding({
propertyName: newUPThingFields[nextAttribute]["name"],
sourceThingName: windchillPart,
sourcePropertyName: newUPThingFields[nextAttribute]["name"]
});
log(LOG_PREFIX + ' attempting to bind to ' + newUPThingFields[nextAttribute]["name"] + '..');
} else if (unicornPartVals.hasOwnProperty(newUPThingFields[nextAttribute]["name"])) {
newUPThing[newUPThingFields[nextAttribute]["name"]] = unicornPartVals[newUPThingFields[nextAttribute]["name"]];
log(LOG_PREFIX + ' attempting to add to ' + newUPThingFields[nextAttribute]["name"] + ' with ' + unicornPartVals[newUPThingFields[nextAttribute]["name"]] + '?.');
} else {
//log(LOG_PREFIX + ' no match for ' + newUPThingFields[nextAttribute]["name"]);
}
}
} catch (er) {
log(LOG_PREFIX, 'error updating = ' + er + newUPThingFields[nextAttribute]["name"]);
}
});
} else {
log(LOG_PREFIX, ' no wc_* windchill part found for ' + nextPartNumber);
}
} catch (err) {
log(LOG_PREFIX, 'error creating UP thing, err = ' + err);
}
});
result = true;
} catch (error) {
log(BASE_LOG_PREFIX, ': Error = ' + error.message);
}
log(BASE_LOG_PREFIX, ': Done...' + count);
})();