All Downloads are FREE. Search and download functionalities are using the official Maven repository.

portal.default.redbox.jaffa.widgets.anzsrc-Selection.js Maven / Gradle / Ivy

var AnzsrcSelectionWidgetBuilder = function($, jaffa) {
    var dropDownClass = jaffa.widgets.baseWidget.extend({
        field: null,
        labelField: null,
        oldField: null,
        oldLabelField: null,

        dropDownData: {},
        dropDownDataMapped: null,
        
        clearServerData: function(id) {
            var suffixes = ["skos:prefLabel", "rdf:resource", ".top.dropdown", ".middle.dropdown", ".bottom.dropdown"];
            for (var i = 0; i < 5; i++) {
                jaffa.serverData[id+suffixes[i]] = "";
            }
        },

        deleteWidget: function() {
            if (this.labelField != null) {
              jaffa.form.ignoreField(this.labelField);
            }
            jaffa.form.ignoreField(this.field+"skos:prefLabel");
            jaffa.form.ignoreField(this.field+"rdf:resource");
            jaffa.form.ignoreField(this.field+".top.dropdown");
            jaffa.form.ignoreField(this.field+".middle.dropdown");
            jaffa.form.ignoreField(this.field+".bottom.dropdown");
            this.clearServerData(this.field);
            this.getContainer().remove();
        },
        // Identity has been altered, adjust the DOM for all fields
        domUpdate: function(from, to, depth) {
            this._super(from, to, depth);
            // Store, we'll need them to notify Jaffa later
            this.oldField = this.field;
            // Replace the portion of the ID that changed
            this.field = this.oldField.domUpdate(from, to, depth);
            // Update DOM but constrain searches to container, since there may
            //  be very temporary duplicate IDs as sort orders swap
            var container = this.getContainer();
            container.find("span[id=\""+this.oldField+".displayLabel\"]").attr("id", this.field+".displayLabel");
            container.find("input[id=\""+this.oldField+"skos:prefLabel\"]").attr("id", this.field+"skos:prefLabel");
            container.find("input[id=\""+this.oldField+"rdf:resource\"]").attr("id", this.field+"rdf:resource");
            container.find("select[id=\""+this.oldField+".top.dropdown\"]").attr("id", this.field+".top.dropdown");
            container.find("span[id=\""+this.oldField+".top\"]").attr("id", this.field+".top");
            container.find("select[id=\""+this.oldField+".middle.dropdown\"]").attr("id", this.field+".middle.dropdown");
            container.find("span[id=\""+this.oldField+".middle\"]").attr("id", this.field+".middle");
            container.find("select[id=\""+this.oldField+".bottom.dropdown\"]").attr("id", this.field+".bottom.dropdown");
            container.find("span[id=\""+this.oldField+".bottom\"]").attr("id", this.field+".bottom");
            // Tell Jaffa to ignore the field's this widget used to manage
            jaffa.form.ignoreField(this.oldField);
            jaffa.form.ignoreField(this.oldField+"skos:prefLabel");
            jaffa.form.ignoreField(this.oldField+"rdf:resource");
            jaffa.form.ignoreField(this.oldField+".top.dropdown");
            jaffa.form.ignoreField(this.oldField+".middle.dropdown");
            jaffa.form.ignoreField(this.oldField+".bottom.dropdown");
    
    		var field = this.field;
    		var jsonDataUrl = this.getConfig("json-data-url");
    		$("[id='"+this.id()+"']").on("change","[id='"+this.field+".top.dropdown']",function(){
    												$("[id='"+field+".bottom.dropdown']").hide();
    												var comboValue = $(this).val();
    												if(comboValue != "") {
    													var labelValue = $(this).find("option:selected").text()
    													$("[id='"+field+"skos:prefLabel']").val(labelValue);
    													$("[id='"+field+".displayLabel']").text(labelValue);
    													$("[id='"+field+"rdf:resource']").val(comboValue);
    													
												   		var nextCombo= {};
    													nextCombo["field"] = field+".middle.dropdown";
    													nextCombo["json-data-url"] = jsonDataUrl;
       													nextCombo["data-top-level-id"] = comboValue;
        												nextCombo["data-id-key"] = 'rdf:about';       
            											nextCombo["data-label-key"] = 'skos:prefLabel';
        												nextCombo["data-list-key"] = 'results';
        												nextCombo["default-value"] = 'skos:narrower';           
    													nextCombo["class-list"] = 'widgetListBranding';
    													$("span[id='"+field+".middle']").jaffaDropDown(nextCombo);
    												}
    												if(comboValue == "") {
    													$("[id='"+field+".middle.dropdown']").hide();
    												}
												});
												
    		$("[id='"+this.id()+"']").on("change","[id='"+this.field+".middle.dropdown']",function(){
    												var comboValue = $(this).val();
    												if(comboValue != "") {
    													var labelValue = $(this).find("option:selected").text();
    													$("[id='"+field+"skos:prefLabel']").val(labelValue);
    													$("[id='"+field+".displayLabel']").text(labelValue);
    													$("[id='"+field+"rdf:resource']").val(comboValue);
													
												   		var nextCombo= {};
    													nextCombo["field"] = field+".bottom.dropdown";
    													nextCombo["json-data-url"] = jsonDataUrl;
       													nextCombo["data-top-level-id"] = comboValue;
        												nextCombo["data-id-key"] = 'rdf:about';       
            											nextCombo["data-label-key"] = 'skos:prefLabel';
        												nextCombo["data-list-key"] = 'results';
        												nextCombo["default-value"] = 'skos:narrower';           
    													nextCombo["class-list"] = 'widgetListBranding';
                                                        jaffa.serverData[field+".bottom.dropdown"] = "";
    													$("span[id='"+field+".bottom']").jaffaDropDown(nextCombo);
    												}
    												if(comboValue == "") {
    													//Set the top dropdown box's value and hide the bottom dropdown
    													comboValue = $("[id='"+field+".top.dropdown']").val();
    													var labelValue = $("[id='"+field+".top.dropdown']").find("option:selected").text();
    													$("[id='"+field+"skos:prefLabel']").val(labelValue);
    													$("[id='"+field+".displayLabel']").text(labelValue);
    													$("[id='"+field+"rdf:resource']").val(comboValue);
    													$("[id='"+field+".bottom.dropdown']").hide();
                                                        jaffa.serverData[field+".bottom.dropdown"] = "";
    												}
												});
												
			$("[id='"+this.id()+"']").on("change","[id='"+this.field+".bottom.dropdown']",function(){
    												var comboValue = $(this).val();
    												if(comboValue != "") {
    													var labelValue = $(this).find("option:selected").text()
    													$("[id='"+field+"skos:prefLabel']").val(labelValue);
    													$("[id='"+field+".displayLabel']").text(labelValue);
    													$("[id='"+field+"rdf:resource']").val(comboValue);
    												}
												});		
            
            // TODO: Testing
            // Do it all again for labels if they are stored
            if (this.labelField != null) {
                this.oldLabelField = this.labelField;
                this.labelField = this.oldLabelField.domUpdate(from, to, depth);
                container.find("input[id=\""+this.oldLabelField+"\"]").attr("id", this.labelField);
                jaffa.form.ignoreField(this.oldLabelField);
            }
        },
        // Notify Jaffa that field <=> widget relations need to be updated
        //  This is called separately from above to avoid duplicate IDs that
        //   may occur whilst DOM alterations are occuring
        jaffaUpdate: function() {
            // Only synch if an update has effected this widget
            if (this.oldField != null || this.oldLabelField != null) {
                this._super();
            }
            if (this.oldField != null) {
                jaffa.form.addField(this.field, this.id());
                jaffa.form.addField(this.field+"skos:prefLabel",this.id());
			    jaffa.form.addField(this.field+"rdf:resource",this.id());
                jaffa.form.addField(this.field+".top.dropdown",this.id());
                jaffa.form.addField(this.field+".middle.dropdown",this.id());
                jaffa.form.addField(this.field+".bottom.dropdown",this.id());
                this.oldField = null;
            }
            if (this.oldLabelField != null) {
                jaffa.form.addField(this.labelField, this.id());
                this.oldLabelField = null;
            }
            // TODO: Validation alterations
        },

        // Whereas init() is the constructor, this method is called after Jaffa
        // knows about us and needs us to build UI elements and modify the form.
        buildUi: function() {
            var ui = this.getContainer();
            ui.html("");
			var label = this.getConfig("label");
            if (label != null) {
                ui.append("");
            }
			
			this.field = this.getConfig("field");
            if (this.field == null) {
                // TODO: Testing
                jaffa.logError("No field name provided for widget '"+ this.field() +"'. This is mandatory!");
                return;
            }
            ui.append("Please select a code from the dropdown below");
            ui.append("");
            ui.append("");
           	ui.append("
"); var jsonDataUrl = this.getConfig("json-data-url"); var topCombo= {}; topCombo["field"] = this.field+".top.dropdown"; topCombo["json-data-url"] = jsonDataUrl; topCombo["data-top-level-id"] = 'top'; topCombo["data-id-key"] = 'rdf:about'; topCombo["data-label-key"] = 'skos:prefLabel'; topCombo["data-list-key"] = 'results'; topCombo["default-value"] = 'skos:narrower'; topCombo["class-list"] = 'widgetListBranding'; $("span[id='"+this.field+".top']").jaffaDropDown(topCombo); var field = this.field; $("[id='"+this.id()+"']").on("change","[id='"+this.field+".top.dropdown']",function(){ $("[id='"+field+".bottom.dropdown']").hide(); var comboValue = $(this).val(); if(comboValue != "") { var labelValue = $(this).find("option:selected").text() $("[id='"+field+"skos:prefLabel']").val(labelValue); $("[id='"+field+".displayLabel']").text(labelValue); $("[id='"+field+"rdf:resource']").val(comboValue); var nextCombo= {}; nextCombo["field"] = field+".middle.dropdown"; nextCombo["json-data-url"] = jsonDataUrl; nextCombo["data-top-level-id"] = comboValue; nextCombo["data-id-key"] = 'rdf:about'; nextCombo["data-label-key"] = 'skos:prefLabel'; nextCombo["data-list-key"] = 'results'; nextCombo["default-value"] = 'skos:narrower'; nextCombo["class-list"] = 'widgetListBranding'; $("span[id='"+field+".middle']").jaffaDropDown(nextCombo); } if(comboValue == "") { $("[id='"+field+".middle.dropdown']").hide(); } }); $("[id='"+this.id()+"']").on("change","[id='"+this.field+".middle.dropdown']",function(){ var comboValue = $(this).val(); if(comboValue != "") { var labelValue = $(this).find("option:selected").text(); $("[id='"+field+"skos:prefLabel']").val(labelValue); $("[id='"+field+".displayLabel']").text(labelValue); $("[id='"+field+"rdf:resource']").val(comboValue); var nextCombo= {}; nextCombo["field"] = field+".bottom.dropdown"; nextCombo["json-data-url"] = jsonDataUrl; nextCombo["data-top-level-id"] = comboValue; nextCombo["data-id-key"] = 'rdf:about'; nextCombo["data-label-key"] = 'skos:prefLabel'; nextCombo["data-list-key"] = 'results'; nextCombo["default-value"] = 'skos:narrower'; nextCombo["class-list"] = 'widgetListBranding'; $("span[id='"+field+".bottom']").jaffaDropDown(nextCombo); } if(comboValue == "") { //Set the top dropdown box's value and hide the bottom dropdown comboValue = $("[id='"+field+".top.dropdown']").val(); var labelValue = $("[id='"+field+".top.dropdown']").find("option:selected").text(); $("[id='"+field+"skos:prefLabel']").val(labelValue); $("[id='"+field+".displayLabel']").text(labelValue); $("[id='"+field+"rdf:resource']").val(comboValue); $("[id='"+field+".bottom.dropdown']").hide(); jaffa.serverData[field+".bottom.dropdown"] = ""; } }); $("[id='"+this.id()+"']").on("change","[id='"+this.field+".bottom.dropdown']",function(){ var comboValue = $(this).val(); if(comboValue != "") { var labelValue = $(this).find("option:selected").text() $("[id='"+field+"skos:prefLabel']").val(labelValue); $("[id='"+field+".displayLabel']").text(labelValue); $("[id='"+field+"rdf:resource']").val(comboValue); } }); jaffa.form.addField(this.field+"skos:prefLabel",this.id()); jaffa.form.addField(this.field+"rdf:resource",this.id()); // Add help content this._super(); // Activating a change trigger will synch // all fields and the managed data // Add some validation var mandatory = this.getConfig("mandatory"); var mandatoryOnSave = this.getConfig("mandatory-on-save"); if (mandatory === true || mandatoryOnSave === true) { // Error message creation var validationText = this.getConfig("validation-text") || "This field is mandatory"; var validationMessage = $("
"+validationText+"
"); ui.append(validationMessage); // Error message toggling validationMessage.hide(); function invalid(fieldId, testsFailed) { ui.addClass("error"); validationMessage.show(); } function valid(fieldId, testsPassed) { ui.removeClass("error"); validationMessage.hide(); } // Notify Jaffa about what we want if (mandatory === true) { jaffa.valid.setSubmitRules(this.field, ["required"], valid, invalid); } if (mandatoryOnSave === true) { jaffa.valid.setSaveRules(this.field, ["required"], valid, invalid); } } // Add our custom classes this.applyBranding(ui); }, // If any of the fields we told Jaffa we manage // are changed it will call this. change: function(fieldName, isValid) { // To avoid double handling, just pay attention to the actual value field if (fieldName == this.field) { // Update our label field if we have one if (this.labelField != null) { var label = jaffa.form.field(fieldName).find(":selected").text(); jaffa.form.value(this.labelField, label); } // Complex relations, we want to look like a jQuery automcomplete // to leverage the same methods on the base widget var lookupParser = this.getConfig("lookup-parser"); if (lookupParser != null) { // Because we have a static data source, we only need to map once if (this.dropDownDataMapped == null) { var thisWidget = this; function mapWrap(item) { return thisWidget.perItemMapping(item); } this.dropDownDataMapped = $.map(this.dropDownData, mapWrap); } // Find our currently selected item and 'select' it var len = this.dropDownDataMapped.length; for (var i = 0; i < len; i++) { var value = this.dropDownDataMapped[i].value; if (value == jaffa.form.value(fieldName)) { // A fake UI element the handler is expecting var ui = {item: this.dropDownDataMapped[i]}; this.onSelectItemHandling(null, ui); } } } } }, // Constructor... any user provided config and the // jQuery container this was called against. init: function(config, container) { this._super(config, container); } }); // ***************************************** // Let Jaffa know how things hang together. 'jaffaAnzsrcSelection' is how the // developer can create a widget, eg: $("#id").jaffaAnzsrcSelection(); // And the class links to the above variable that is a valid widget // implementation, extending the Jaffa bas widget. jaffa.widgets.registerWidget("jaffaAnzsrcSelection2", dropDownClass); } $.requestWidgetLoad(AnzsrcSelectionWidgetBuilder); var AnzsrcSelectionRepeatableWidgetBuilder = function($, jaffa) { var dropDownRepeatableClass = jaffa.widgets.listWidget.extend({ init: function(config, container) { this._super(config, container); // Make sure 'listWidget' knows how to create each element this.childCreator("jaffaAnzsrcSelection2"); } }); jaffa.widgets.registerWidget("jaffaAnzsrcSelectionRepeatable", dropDownRepeatableClass); } $.requestWidgetLoad(AnzsrcSelectionRepeatableWidgetBuilder);




© 2015 - 2025 Weber Informatics LLC | Privacy Policy