nnnjjj123
2020-11-17 1b2c1edb61190eeb19f465ff031eaa3b2a1b8dbc
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
///////////////////////////////////////////////////////////////////////////
// Copyright © 2018 NarutoGIS. All Rights Reserved.
///////////////////////////////////////////////////////////////////////////
 
define([
  'dojo/_base/declare',
  'dojo/_base/lang',
  'dojo/_base/html',
  'dijit/_WidgetBase',
  'dijit/_TemplatedMixin',
  'dojo/on',
  'dojo/mouse',
  'dojo/query'
],
function (declare, lang, html, _WidgetBase, _TemplatedMixin, on, mouse, query) {
  return declare([_WidgetBase, _TemplatedMixin], {
    templateString: '<div class="jimu-img-node"></div>',
    /**
    *options:
    *img: the img url,
    *label:
    *width/height/marginTop/marginLeft: can be px or %
    **/
    constructor: function(options, dom){
      /*jshint unused: false*/
    },
    postCreate: function () {
      this.box = html.create('div', {
        'class': 'node-box'
      }, this.domNode);
      html.create('img', {
        'src': this.img
      }, this.box);
      html.create('div', {
        'class': 'node-label',
        'innerHTML': this.label,
        title: this.label
      }, this.domNode);
 
      this.own(on(this.domNode, 'click', lang.hitch(this, this.onClick)));
    },
 
    onClick: function(){
      query('.jimu-img-node', this.getParent().domNode).removeClass('jimu-state-selected');
      query(this.domNode).addClass('jimu-state-selected');
    },
 
    highLight: function(){
      query('.jimu-img-node', this.getParent().domNode).removeClass('jimu-state-selected');
      query(this.domNode).addClass('jimu-state-selected');
    },
 
    startup: function(){
 
    }
 
  });
});