admin
2020-06-10 a610f2ab6e543d2cb78c1ef212ac6a74ddc067d9
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
// Copyright © 2014 The CefSharp Authors. All rights reserved.
//
// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
 
using System.Collections.Generic;
using System.Runtime.Serialization;
using CefSharp.ModelBinding;
 
namespace CefSharp.Internals
{
    /// <summary>
    /// This maps the registered objects in the browser process
    /// to the reflection data necessary to update the objects,
    /// and mapping information to how the object/method/proprerty
    /// will be exposed to JavaScript.
    /// </summary>
    [DataContract]
    public class JavascriptObject //: DynamicObject maybe later
    {
        /// <summary>
        /// Identifies the <see cref="JavascriptObject" /> for BrowserProcess to RenderProcess communication
        /// </summary>
        [DataMember]
        public long Id { get; set; }
 
        [DataMember]
        public string Name { get; set; }
 
        [DataMember]
        public string JavascriptName { get; set; }
 
        /// <summary>
        /// Indicate if this object bound as async
        /// </summary>
        [DataMember]
        public bool IsAsync { get; set; }
 
        /// <summary>
        /// Indicate if JavascriptName is camel case or not
        /// </summary>
        public bool CamelCaseJavascriptNames { get; set; }
 
        /// <summary>
        /// Gets the methods of the <see cref="JavascriptObject" />.
        /// </summary>
        [DataMember]
        public List<JavascriptMethod> Methods { get; private set; }
 
        /// <summary>
        /// Gets the properties of the <see cref="JavascriptObject" />.
        /// </summary>
        [DataMember]
        public List<JavascriptProperty> Properties { get; private set; }
 
        /// <summary>
        /// A javascript object is created for every object, even those that are sub objects
        /// it's important we only transmit the Root Objects (top level/parent)
        /// </summary>
        public bool RootObject { get; set; }
 
        /// <summary>
        /// Gets or sets the value.
        /// </summary>
        public object Value { get; set; }
 
        public IBinder Binder { get; set; }
 
        public IMethodInterceptor MethodInterceptor { get; set; }
 
        public JavascriptObject()
        {
            Methods = new List<JavascriptMethod>();
            Properties = new List<JavascriptProperty>();
        }
 
        public override string ToString()
        {
            return Value != null ? Value.ToString() : base.ToString();
        }
    }
}