void Member_New(Member sender, umbraco.cms.businesslogic.NewEventArgs e) { //DocumentType documentType = DocumentType.GetByAlias("Gymnast"); //Document document = Document.MakeNew(sender.Text, documentType, new User("admin"), int.Parse(UmbracoCustom.GetParameterValue(Parameter.GymnastDocument))); //document.getProperty("member").Value = sender.Id; //document.Save(); //Log.Add(LogTypes.New, int.Parse(UmbracoCustom.GetParameterValue(Parameter.GymnastDocument)), string.Format("Create new user {0} in Member_New event", sender.Text)); }
public static void SetDefaultValuesOnNew(Document newDocument, umbraco.cms.businesslogic.NewEventArgs e) { log.Info("SetDefaultValuesOnNew Startet"); log.InfoFormat("Document id: {1} - Document Type Alias: {0}", newDocument.ContentType.Alias, newDocument.Id); // We wrap it in a try since this part should not break for the user in umbraco try { string path = newDocument.Path; if (string.IsNullOrEmpty(path)) { StopWithError("Path on new document not found!"); return; } string[] strings = StringUtil.Split(path, ",", true); string strHomeDocId = strings[1]; // Now we have the doc home id, lets see if the default value document based on document type alias exists string cacheKeyDefaultValueDocumentTypeAlias = string.Format("SetDefaultValuesOnNew#homeDoc:{0}#DefaultValueDocumentTypeAlias:{1}", strHomeDocId, newDocument.ContentType.Alias); int defaultValueDocId = -1; if (CacheUtil.Exist(cacheKeyDefaultValueDocumentTypeAlias)) { defaultValueDocId = CacheUtil.Get <int>(cacheKeyDefaultValueDocumentTypeAlias); } else { // Does not exist in the cache, lets try to look it up int defaultValuesFolderDocId = GetDefaultValuesFolderId(strHomeDocId); if (defaultValuesFolderDocId == -1) { StopWithError("Could not load default values folder id!"); return; } // For speed we use the published node factory Node node = UmbracoUtil.GetNode(defaultValuesFolderDocId); if (node == null) { StopWithError(string.Format("Could not load published node for default values folder id: {0}!", defaultValuesFolderDocId)); return; } Node defaultValueNode = node.GetDescendantViaDocumentTypePath(newDocument.ContentType.Alias); if (defaultValueNode != null) { defaultValueDocId = defaultValueNode.Id; CacheUtil.Insert(cacheKeyDefaultValueDocumentTypeAlias, defaultValueDocId, 10, false); } else { log.DebugFormat("No default node for document type alias: {0}", newDocument.ContentType.Alias); } } if (defaultValueDocId > -1) { Document defaultValueDocument = new Document(true, defaultValueDocId); log.DebugFormat("ContentType {0} match. Let's start copying", newDocument.ContentType.Alias); umbraco.cms.businesslogic.property.Properties newDocumentProperties = newDocument.GenericProperties; umbraco.cms.businesslogic.property.Properties defaultValueProperties = defaultValueDocument.GenericProperties; for (int i = 0; i < newDocumentProperties.Count; i++) { umbraco.cms.businesslogic.property.Property newDocumentProperty = newDocumentProperties[i]; umbraco.cms.businesslogic.property.Property defaultDocumentProperty = defaultValueProperties[i]; if (newDocumentProperty.Value != defaultDocumentProperty.Value) { log.DebugFormat("Set value on property alias {0}", newDocumentProperty.PropertyType.Alias); newDocumentProperty.Value = defaultDocumentProperty.Value; } } } log.Info("SetDefaultValuesOnNew Ended"); } catch (Exception ex) { log.Error("Could not complete SetDefaultValuesOnNew - stopped with exception", ex); } }