Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Oracle APEX [игнор отключен] [закрыт для гостей] / Доступ к атрибутам плагина из javascript / 25 сообщений из 42, страница 1 из 2
15.02.2015, 19:44
    #38880235
Diagnost89
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Здравствуйте.

Пишу простенький dynamic action плагин.
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
function render (
    p_dynamic_action in apex_plugin.t_dynamic_action,
    p_plugin         in apex_plugin.t_plugin )
    return apex_plugin.t_dynamic_action_render_result
is
render_result apex_plugin.t_dynamic_action_render_result default null;
begin
apex_javascript.add_library(
	p_name => 'validator',
    p_directory => p_plugin.file_prefix,
    p_version => null
);
render_result.attribute_01 := p_dynamic_action.attribute_01;
render_result.attribute_02 := p_dynamic_action.attribute_02;
render_result.javascript_function := 'init_validators';
return render_result;
end;



Первый атрибут - список итемов для проверки.
Второй атрибут - список кнопок, которые надо лочить, если хоть один из итемов пустой.

Файл validator.js:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
function reset() {
	var items = init_validators.prototype.action.attribute01.split(',');
	var buttons = init_validators.prototype.action.attribute02.split(',');
}

function init_validators() {
	var items = this.action.attribute01.split(',');
	var buttons = this.action.attribute02.split(',');
}



Функция init_validators определена как точка входа в pl/sql коде плагина и внутри нее доступ к атрибутам осуществляется через this.action.
А внутри функции reset получить доступ к этим атрибутам уже нельзя. пробовал решить это через глобальные переменные, но этот способ не подходит потому что если подключать плагин более одного раза на страницу то эти переменные затираются последующими вызовами. Какой подход поможет в данной ситуации?
...
Рейтинг: 0 / 0
16.02.2015, 10:57
    #38880484
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89,

Тут очень простой выход.
Внутри функции init_validators(), создай объект, из из любой другой обращайся к нему.

Код: javascript
1.
2.
3.
4.
var myObj = {
	items : this.action.attribute01.split(','),
	buttons : this.action.attribute02.split(',')
};



Обращение к объекту
Код: javascript
1.
myObj.items;



Ну это ближе к Яваскрипту уже.
...
Рейтинг: 0 / 0
16.02.2015, 11:13
    #38880502
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
blkangel,

Ах да, и функцию ресет внутри объекта надо разместить, тогда путаницы не будет.

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
var myObj = {
	items : this.action.attribute01.split(','),
	buttons : this.action.attribute02.split(','),
	reset : function () {
		var me=this;
		console.log(me.items);
		console.log(me.buttons);
	}
};
...
Рейтинг: 0 / 0
16.02.2015, 11:38
    #38880530
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
blkangel,

И еще, для того чтобы объекты не пересекались.
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
function render (
    p_dynamic_action in apex_plugin.t_dynamic_action,
    p_plugin         in apex_plugin.t_plugin )
    return apex_plugin.t_dynamic_action_render_result
is
render_result apex_plugin.t_dynamic_action_render_result default null;
begin
apex_javascript.add_library(
	p_name => 'validator',
    p_directory => p_plugin.file_prefix,
    p_version => null
);
render_result.attribute_01 := p_dynamic_action.attribute_01;
render_result.attribute_02 := p_dynamic_action.attribute_02;
render_result.javascript_function := 'init_validators("'||to_char(p_dynamic_action.id)||'")';
return render_result;
end;




Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
function init_validators(aId) {
	var myObj={};
	var myObj[aId] = {
		items : this.action.attribute01.split(','),
		buttons : this.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		}
	};
};
...
Рейтинг: 0 / 0
16.02.2015, 12:26
    #38880578
Diagnost89
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
blkangel,

при построении объекта происходит вот такая ошибка:
Uncaught TypeError: Cannot read property 'attribute01' of undefined

видимо потому что this уже не к контексту функции set_validators обращается, а к контексту объекта

да и получить доступ потом извне никак. смысл в том что есть функция set_validators. она соответствующим полям привязывала обработчики их изменения:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
function validator(item_id, items, inputs) {
    return function() {
        $('#' + item_id).on('focus click', function() {
            hide_tooltip(item_id);
        });
        $('#' + item_id).on('input blur', function () {
            if (item_is_empty(item_id)) {
                if (!production_mode)
                    console.log('item "' + item_id + '" is invalid. disabling all inputs');
                set_error_colors(item_id);
                show_tooltip(item_id, 'Обязательное поле');
                for (var i in inputs) {
                    disable_input(inputs[i]);
                }
            } else {
                hide_tooltip(item_id);
                if (!production_mode)
                    console.log('item "' + item_id + '" is valid. checking all items');
                set_valid_colors(item_id);
                var with_errors = false;
                for (var j in items) {
                    if (item_is_empty(items[j])) {
                        with_errors = true;
                        if (!production_mode)
                            console.log('item "' + items[j] + '" is invalid. disabling all inputs');
                        break;
                    }
                }
                if (!with_errors) {
                    if (!production_mode)
                        console.log('all items is valid. enabling all inputs');
                }
                for (var k in inputs) {
                    if (with_errors) {
                        disable_input(inputs[k]);
                    } else {
                        enable_input(inputs[k]);
                    }
                }
            }
        });
    };
}

function set_validators(dynamic_action_id) {
    var items = this.action.attribute01.split(',');
    var inputs = this.action.attribute02.split(',');

    for (var i in items) {
        var f = validator(items[i], items, inputs);
        f();
}



а еще должна быть отдельная функция reset_interface, которая бы убирала у полей сообщения об ошибках и сбрасывала цвет в обычный. у меня до этого приходилось на странице вызывать ее так: reset_interface( ['P50_X1', 'P50_X2'], ['P50_B1', 'P50_B2'] ) и это работало. но хотелось бы чтобы эта функция имела доступ к атрибутам плагина и вызов был reset_interface(). правда тут еще проблема определить, к какому плагину соответствует этот вызов
...
Рейтинг: 0 / 0
16.02.2015, 14:21
    #38880701
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89blkangel,

при построении объекта происходит вот такая ошибка:
Uncaught TypeError: Cannot read property 'attribute01' of undefined

видимо потому что this уже не к контексту функции set_validators обращается, а к контексту объекта

да и получить доступ потом извне никак. смысл в том что есть функция set_validators. она соответствующим полям привязывала обработчики их изменения:

Виноват, так конечно:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
function init_validators(aId) {
	var meFun=this;
	var myObj={};
	var myObj[aId] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		}
	};
};
...
Рейтинг: 0 / 0
16.02.2015, 14:22
    #38880702
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
blkangelDiagnost89blkangel,

при построении объекта происходит вот такая ошибка:
Uncaught TypeError: Cannot read property 'attribute01' of undefined

видимо потому что this уже не к контексту функции set_validators обращается, а к контексту объекта

да и получить доступ потом извне никак. смысл в том что есть функция set_validators. она соответствующим полям привязывала обработчики их изменения:

Виноват, так конечно:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
function init_validators(aId) {
	var meFun=this;
	var myObj={};
	var myObj[aId] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		}
	};
};


Еще чутка исправления.
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
function init_validators(aId) {
	var meFun=this;
	if (!myObj) {
		var myObj={};
	};
	var myObj[aId] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		}
	};
};
...
Рейтинг: 0 / 0
16.02.2015, 14:36
    #38880712
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89blkangel,
да и получить доступ потом извне никак. смысл в том что есть функция set_validators. она соответствующим полям привязывала обработчики их изменения:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
function validator(item_id, items, inputs) {
    return function() {
        $('#' + item_id).on('focus click', function() {
            hide_tooltip(item_id);
        });
        $('#' + item_id).on('input blur', function () {
            if (item_is_empty(item_id)) {
                if (!production_mode)
                    console.log('item "' + item_id + '" is invalid. disabling all inputs');
                set_error_colors(item_id);
                show_tooltip(item_id, 'Обязательное поле');
                for (var i in inputs) {
                    disable_input(inputs[i]);
                }
            } else {
                hide_tooltip(item_id);
                if (!production_mode)
                    console.log('item "' + item_id + '" is valid. checking all items');
                set_valid_colors(item_id);
                var with_errors = false;
                for (var j in items) {
                    if (item_is_empty(items[j])) {
                        with_errors = true;
                        if (!production_mode)
                            console.log('item "' + items[j] + '" is invalid. disabling all inputs');
                        break;
                    }
                }
                if (!with_errors) {
                    if (!production_mode)
                        console.log('all items is valid. enabling all inputs');
                }
                for (var k in inputs) {
                    if (with_errors) {
                        disable_input(inputs[k]);
                    } else {
                        enable_input(inputs[k]);
                    }
                }
            }
        });
    };
}

function set_validators(dynamic_action_id) {
    var items = this.action.attribute01.split(',');
    var inputs = this.action.attribute02.split(',');

    for (var i in items) {
        var f = validator(items[i], items, inputs);
        f();
}



а еще должна быть отдельная функция reset_interface, которая бы убирала у полей сообщения об ошибках и сбрасывала цвет в обычный. у меня до этого приходилось на странице вызывать ее так: reset_interface( ['P50_X1', 'P50_X2'], ['P50_B1', 'P50_B2'] ) и это работало. но хотелось бы чтобы эта функция имела доступ к атрибутам плагина и вызов был reset_interface(). правда тут еще проблема определить, к какому плагину соответствует этот вызов

А тут давай подробно разбирать...
1. Раз ты делаешь плагин, он должен быть независим, и не требовать дописок яваскрипта на страницах.
2. Предположим, что ты делаешь API для своего плагина, и тебе надо все таки из вне вызывать функцию. Загвоздка в том, что dynamic_action_id ты никогда не вычислишь из вне, но тут напрашивается вывод сам собой, ты должен третьим атрибутом передавать название объекта. И получится примерно так.
pl/sql упростится

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
function render (
    p_dynamic_action in apex_plugin.t_dynamic_action,
    p_plugin         in apex_plugin.t_plugin )
    return apex_plugin.t_dynamic_action_render_result
is
render_result apex_plugin.t_dynamic_action_render_result default null;
begin
apex_javascript.add_library(
	p_name => 'validator',
    p_directory => p_plugin.file_prefix,
    p_version => null
);
render_result.attribute_01 := p_dynamic_action.attribute_01;
render_result.attribute_02 := p_dynamic_action.attribute_02;
render_result.javascript_function := 'init_validators()';
return render_result;
end;



javascript :
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
function init_validators() {
	var meFun=this;
	if (!myObj) {
		var myObj={};
	};
	var myObj[meFun.action.attribute03] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		},
		setValidation : function () {
			var me=this;
			for (var i in me.items) {	
				var f = me.validator(me.items[i], me.items, me.inputs);
			}
		},
		validator : function(item_id, items, inputs) {
			....
		}
	};
};



Вызов функций внутри объекта, так.
Код: javascript
1.
myObj.attribute03.reset();
...
Рейтинг: 0 / 0
16.02.2015, 15:23
    #38880753
Diagnost89
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
В данный момент остановился на таком варианте:

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
120.
121.
122.
function disable_input(id) {
    $('#'+id).prop('disabled', 'disabled');
}

function enable_input(id) {
    $('#'+id).removeAttr('disabled');
}

function set_valid_colors(item_id) {
    $('label[for='+item_id+']>span,label[for='+item_id+']>a').css('color', '#444');
    $('#'+item_id).css('border', '1px solid rgb(170,170,170)');
}

function set_error_colors(item_id) {
    $('label[for='+item_id+']>span,label[for='+item_id+']>a').css('color', '#b94a48');
    $('#'+item_id).css('border', '1px solid #b94a48');
}

function item_is_empty(item_id) {
    return $('#'+item_id).val() == '';
}

function show_tooltip(item_id, message) {
    var td = $('#'+item_id).parent('td');
    $(td).css('position', 'relative');
    $('<div class="tooltip-container"><span class="tooltip-message">'+message+'</span></div>').appendTo(td);
}

function hide_tooltip(item_id) {
    var td = $('#'+item_id).parent('td');
    $(td).find('.tooltip-container').remove();
}

var production_mode = true;

function reset_interface(form_id) {
    var with_errors = false;
    var item_arr = $('#' + form_id + ' .not_empty_item');
    var input_arr = $('#' + form_id + ' .not_empty_button');
    for (var i in item_arr) {
        set_valid_colors(item_arr.get(i).id);
        hide_tooltip(item_arr.get(i).id);
        if (item_is_empty(item_arr.get(i).id)) {
            with_errors = true;
        }
    }
    for (var i in input_arr) {
        if (with_errors)
            disable_input(input_arr.get(i).id);
        else
            enable_input(input_arr.get(i).id);
    }
    if (!production_mode)
        console.log('interface reseted');
}

function validator(item_id, items, inputs) {
    return function() {
        $('#' + item_id).on('focus click', function() {
            hide_tooltip(item_id);
        });
        $('#' + item_id).on('input blur', function () {
            if (item_is_empty(item_id)) {
                if (!production_mode)
                    console.log('item "' + item_id + '" is invalid. disabling all inputs');
                set_error_colors(item_id);
                show_tooltip(item_id, 'Обязательное поле');
                for (var i in inputs) {
                    disable_input(inputs[i]);
                }
            } else {
                hide_tooltip(item_id);
                if (!production_mode)
                    console.log('item "' + item_id + '" is valid. checking all items');
                set_valid_colors(item_id);
                var with_errors = false;
                for (var j in items) {
                    if (item_is_empty(items[j])) {
                        with_errors = true;
                        if (!production_mode)
                            console.log('item "' + items[j] + '" is invalid. disabling all inputs');
                        break;
                    }
                }
                if (!with_errors) {
                    if (!production_mode)
                        console.log('all items is valid. enabling all inputs');
                }
                for (var k in inputs) {
                    if (with_errors) {
                        disable_input(inputs[k]);
                    } else {
                        enable_input(inputs[k]);
                    }
                }
            }
        });
    };
}

function class_adder(item_id, class_name) {
    return function() {
        $('#' + item_id).addClass(class_name);
    }
}

function set_validators() {

    var items = this.action.attribute01.split(',');
    var inputs = this.action.attribute02.split(',');

    for (var i in items) {
        var f = validator(items[i], items, inputs);
        f();
        var ca = class_adder(items[i], 'not_empty_item');
        ca();
    }
    for (var i in inputs) {
        var ca = class_adder(inputs[i], 'not_empty_button');
        ca();
    }
}



на странице несколько регионов. чтобы очистить элементы на определенном регионе, на странице дописал такую строчку:

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
$('#REGION_APP').dialog({
    autoOpen: false,
    resizable: false,
    modal: true,
    width: '800px',
    maxWidth: 800,
    open: function() {
        reset_interface($(this).get(0).id); // $(this).get(0).id - это как раз id родительского региона
    }
});
...
Рейтинг: 0 / 0
16.02.2015, 15:31
    #38880772
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89,

Ну я понял, что в итоге ты меня проигнорировал.
Ответь мне вот на такой вопрос. Вот эти функции, ты где цепляешь к странице?
Внутри плагина? Тогда, как же ты решил проблему многократного использования плагина?
На странице? Тогда это полуплагин...
...
Рейтинг: 0 / 0
16.02.2015, 15:33
    #38880775
Diagnost89
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
по поводу вашего кода: вы в pl/sql не добавили 3-й атрибут и не написали про него что он должен содержать. я не очень понял. и еще:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
function init_validators() {
	var meFun=this;
	if (!myObj) {
		var myObj={};
	};
	var myObj[meFun.action.attribute03] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		},
		setValidation : function () {
			var me=this;
			for (var i in me.items) {	
				var f = me.validator(me.items[i], me.items, me.inputs);
			}
		},
		validator : function(item_id, items, inputs) {
			....
		}
	};
};


допустим я создам локальную переменную myObj внутри init_validators. но достучаться до нее будет нельзя извне этой функции.

ситуация следующая: вот я создал на странице три региона. каждый из регионов изначально не отображается на странице, это делается через jquery ui dialog при нажатии на кнопку "добавить". в каждом регионе по два поля ввода и по одной кнопке. соответственно на
странице 3 динамик экшена, каждый при Page Load выполняет мой плагин, который привязывает обработчики событий к соответствующим элементам.

а теперь мне надо добавить следующую логику: при открытии каждого из этих регионов элементы интерфейса этого региона должны сбрасываться функцией reset_interface. сейчас проблема решена передачей в эту функцию id родительского региона. функция ищет в этом регионе элементы предопределенных классов ( у меня это not_empty_item и not_empty_button ) и работает с ними. по-другому вроде никак и не сделать
...
Рейтинг: 0 / 0
16.02.2015, 15:39
    #38880788
Diagnost89
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
ну сейчас это не совсем то, чего я добивался. но непонятно, как сделать так, чтобы работало
...
Рейтинг: 0 / 0
16.02.2015, 15:40
    #38880792
Diagnost89
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
вызов reset_interface происходит на странице...
...
Рейтинг: 0 / 0
16.02.2015, 15:44
    #38880797
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89,
Жестььььь........
Это называется, а не зайти ли мне с опы к данной проблеме.
Извините за мат, НАХЕРА ПЛАГИН? Чтобы бы посложнее все остальным было разобраться? Почему нельзя повесить ПРОСТО обработчик? Ну давайте tot дальше пойдем, сделаем плагин региона(рисовать элементы будет), на который навесим плагин DA (обработчики вешать).

Можно увидеть не решение задачи, а саму задачу?
...
Рейтинг: 0 / 0
16.02.2015, 15:58
    #38880813
Diagnost89
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
в виде плагина я это оформил потому что планирую это на всех страницах впилить. с валидацией то все как раз хорошо. одна проблема только с получением атрибутов из других функций. вы предложили локальную переменную создать, но если к ней доступа извне нет то зачем это? сейчас не самое красивое, но рабочее решение
...
Рейтинг: 0 / 0
16.02.2015, 16:44
    #38880900
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89,

Как любит тут один из наших постоянных посетителей форума выражаться, плагин нужен, если им можно и нужно управлять декларативно, если же для плагина нужно дописывать на каждой странице что то, то это хрень, а не плагин. Подход не правильный....

Создание индивидуального объекта, внутри плагина, решает проблему многоразового использования этого плагина. Почему вы не можете обратится к объекту из вне, я не понимаю...

А так же рассмотрите такой вариант, он мне кажется куда проще, чем плагин, тем более, что с яваскриптом на ты.
Объекты можно создавать динамически, например, вы определяете глобальную функцию, на весь апекс.
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
function myMultiObject (items,inputs)  {
	myMultiObject=this;
	myMultiObject.items=items;
	myMultiObject.items=inputs
	myMultiObject.reset=function() {
		var me=this;
		console.log(me.items);
		console.log(me.buttons);
	};
	myMultiObject.setValidation =function () {
		var me=this;
		for (var i in me.items) {	
			var f = me.validator(me.items[i], me.items, me.inputs);
		}
	};
	myMultiObject.validator : function(item_id, items, inputs) {
			....
	};
};
//И вызывать их в хеадере региона 
var newObj = new  myMultiObject("PXX_PPP;PXX_PPP3;PXX_PPP2;PXX_PPP1;","INPUT1;INPUT2;INPUT3;INPUT4;INPUT5;")
...
Рейтинг: 0 / 0
16.02.2015, 16:51
    #38880911
Petro123
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89,
вы так и не ответили - цель вашего плагина.
- есть штатная система валидации
- есть штатная Read only
- есть штатная для рендеринга Condition.
Чем они не устроили?
Возможно вы экономите на спичках, а 90 процентов времени будет уходить на логику страницы, а не на то что вы пишите.
imho
...
Рейтинг: 0 / 0
16.02.2015, 17:50
    #38881011
Diagnost89
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
цель - сделать так, чтобы унифицированно проверялись поля. и если они введены неправильно то выводились сообщения об ошибках и блокировались кнопки на форме (например блокировалась кнопка "сохранить"). это сейчас решено и управляется декларативно. тут все ок. сама проблема в том что нужна еще функция, которая сбрасывает состояние региона в начальное состояние. сейчас она решена как раз не совсем хорошо - вызовом функции в футере региона.

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
<script>
$('#REGION_APP').dialog({
    autoOpen: false,
    resizable: false,
    modal: true,
    width: '800px',
    maxWidth: 800,
    open: function() {
        reset_interface($(this).get(0).id);
    }
});
</script>



то есть если форму неправильно заполнили и потом закрыли то при открытии это уже не будет отображаться
...
Рейтинг: 0 / 0
16.02.2015, 17:58
    #38881023
Diagnost89
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
а с вашим примером который вы уже много раз предложили я так и не могу разобраться.

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
function say() {
	say = this;
	say.hello = function() {
		alert('hello, world!');
	};
}

say.hello(); // Uncaught TypeError: undefined is not a function
...
Рейтинг: 0 / 0
16.02.2015, 18:31
    #38881061
Petro123
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89цель - сделать так, чтобы унифицированно проверялись поля. и если они введены неправильно то выводились сообщения об ошибках и блокировались кнопки на форме (например блокировалась кнопка "сохранить").
- Validations смотрели? Хотя я предпочитаю проверки на сервере в триггере.
- DA - Event type - блокировка кнопок смотрели?
...
Рейтинг: 0 / 0
17.02.2015, 10:14
    #38881365
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89а с вашим примером который вы уже много раз предложили я так и не могу разобраться.

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
function say() {
	say = this;
	say.hello = function() {
		alert('hello, world!');
	};
};

say.hello(); // Uncaught TypeError: undefined is not a function


Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
function say() {
	say = this;
	say.hello = function() {
		alert('hello, world!');
	};
};
var mySay =new say();
mySay.hello();
...
Рейтинг: 0 / 0
17.02.2015, 11:22
    #38881480
blkangel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
Diagnost89то есть если форму неправильно заполнили и потом закрыли то при открытии это уже не будет отображаться
А вот тут не понял.
Можно чтобы сохранялось, можно чтобы очищалось. Есть такое понятие как ClearCache, Апекс давно уже написал функцию, которая чистит поля.
...
Рейтинг: 0 / 0
17.02.2015, 11:25
    #38881491
Petro123
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
blkangel,
+1
это веб. И тут трудно понять, что кому надо.
Некоторые ждут - "с чистого листа, т.к. не сохраняли".
...
Рейтинг: 0 / 0
17.02.2015, 11:28
    #38881493
SvDev
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
указанный выше способ скорее для библиотеки, а не для конструктора.

Не уверен что понимаю задачу, но вообще я знаю 3 способа взаимодействия с плагинами:

1. через массив, допустим

Код: plsql
1.
render_result.javascript_function := 'init_validators("'||to_char(p_dynamic_action.id)||'")';



можно определить глобальную функцию, которая по входному параметру p_dynamic_action.id будет обращаться к значениям соответствующего экземпляра плагина

на примере функции say:

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
function say() { 
  
  if (!gObjArr)  var gObjArr = []; 
  var gObj = {}; 
  
  gObj.ActionId = 10; 
  gObj.ItemList = 'PX_MYITEM'; 
  
  gObjArr.push(gObj);  
  
  window.hello = function(pActionID) { 
  
    alert( gObjArr.filter( function(pObj) { return pObj.ActionId = pActionID } )[0].ItemList );
  };
  
  window.GetObj = function(pActionID) { 
  
    return gObjArr.filter( function(pObj) { return pObj.ActionId = pActionID } )[0];
  };
}

say();
hello(10);
alert( GetObj(10).ItemList );



Соответственно, обработчик hello по переданному ActionID реализует некоторый стандартный метод,
обработчик GetObj по переданному ActionID возвращает object, в котором хранятся данные плагина.

Тут вместо say будет init_validators (вызывается автоматически), вместо gObj скажем this.action, который дополнить значением ActionId и т.д.
ActionId при вызове hello можно взять из apex_dictionary

метод filter не работает в ie8, чтобы работало можно выполнить где-нибудь при инициализации что-нибудь вроде

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
if (!Array.prototype.filter)
{
  Array.prototype.filter = function(fun /*, thisp */)
  {
    "use strict";

    if (this === void 0 || this === null)
      throw new TypeError();

    var t = Object(this);
    var len = t.length >>> 0;
    if (typeof fun !== "function")
      throw new TypeError();

    var res = [];
    var thisp = arguments[1];
    for (var i = 0; i < len; i++)
    {
      if (i in t)
      {
        var val = t[i]; // in case fun mutates this
        if (fun.call(thisp, val, i, t))
          res.push(val);
      }
    }

    return res;
  };
}




2. второй способ - вместо массива использовать события, которые рассылать элементам, над которыми плагин производит действия, внутрь можно передать необходимые данные

т.е., например, добавляем в плагин событие myEvent
плагин производит действие с элементом (допустим с Items-ом PX_MYITEM), после чего рассылает это событие:

Код: javascript
1.
2.
3.
4.
5.
6.
var gObj = {}; 
  
gObj.ActionId = 10; 
gObj.ItemList = 'PX_MYITEM'; 

$("#PX_MYITEM").trigger("myEvent", gObj);



тогда можно создать Dynamic Action:

Event: myEvent
Selection Type: Jquery Selector
jQuery Selector: #PX_MYITEM

Внутри Action можно будет обратиться к данным плагина:

alert(this.data.ItemList);

3. Третий способ - добавить атрибут, куда можно вписать обработчик яваскрипт при создании самого плагина, тогда обработчику можно будет предоставить необходимый интерфейс, через который можно обратиться к свойствам и методам, типа this.data и др.

Но третий я бы не рекоммендовал делать в большинстве случаев.
...
Рейтинг: 0 / 0
17.02.2015, 12:00
    #38881537
SvDev
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Доступ к атрибутам плагина из javascript
4. Можно еще создать глобальные методы с динамическими именами на основе p_dynamic_action.id, потом поизвращаться с функцией eval, или яваскрипт код генерировать динамически через pl/sql, но я не думаю, что это правильный подход, т.к. использование eval считается плохим тоном, точно так же как делать зависимым яваскрипт от pl/sql слишком сильно.

Впрочем он может иметь смысл с плагинами другого типа, когда плагин генерирует html на основе элементов с определенными именами, тогда плагин может догенерировать элементы с похожими именами, (например элемент имя item + приставка "_display" и т.д), но такой подход не подходит для данного вида плагина по архитектурным соображениям, имхо.
...
Рейтинг: 0 / 0
Форумы / Oracle APEX [игнор отключен] [закрыт для гостей] / Доступ к атрибутам плагина из javascript / 25 сообщений из 42, страница 1 из 2
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]